diff --git a/bindings_ffi/Cargo.lock b/bindings_ffi/Cargo.lock index ce3dade1a..f835d820b 100644 --- a/bindings_ffi/Cargo.lock +++ b/bindings_ffi/Cargo.lock @@ -5383,7 +5383,6 @@ dependencies = [ "pbjson-types 0.5.1", "prost 0.12.3", "serde", - "serde_json", "tokio", "tonic", "tower", @@ -5474,9 +5473,7 @@ name = "xmtp_v2" version = "0.1.0" dependencies = [ "aes-gcm", - "chrono", "ecdsa 0.15.1", - "ethers-core", "generic-array", "getrandom", "hex", @@ -5484,11 +5481,8 @@ dependencies = [ "k256 0.12.0", "rand", "rand_chacha", - "rlp", - "serde", "sha2", "sha3", - "thiserror", ] [[package]] diff --git a/bindings_ffi/src/mls.rs b/bindings_ffi/src/mls.rs index b5944251c..221efcc8a 100644 --- a/bindings_ffi/src/mls.rs +++ b/bindings_ffi/src/mls.rs @@ -19,7 +19,8 @@ use xmtp_mls::{ client::Client as MlsClient, groups::MlsGroup, storage::{ - group_message::StoredGroupMessage, EncryptedMessageStore, EncryptionKey, StorageOption, + group_message::GroupMessageKind, group_message::StoredGroupMessage, EncryptedMessageStore, + EncryptionKey, StorageOption, }, types::Address, }; @@ -224,7 +225,10 @@ impl FfiConversations { Ok(out) } - pub fn process_streamed_welcome_message(&self, envelope_bytes: Vec) -> Result, GenericError> { + pub fn process_streamed_welcome_message( + &self, + envelope_bytes: Vec, + ) -> Result, GenericError> { let inner = self.inner_client.as_ref(); let group = inner.process_streamed_welcome_message(envelope_bytes)?; @@ -365,7 +369,13 @@ impl FfiGroup { ); let messages: Vec = group - .find_messages(None, opts.sent_before_ns, opts.sent_after_ns, None, opts.limit)? + .find_messages( + None, + opts.sent_before_ns, + opts.sent_after_ns, + None, + opts.limit, + )? .into_iter() .map(|msg| msg.into()) .collect(); @@ -373,7 +383,10 @@ impl FfiGroup { Ok(messages) } - pub async fn process_streamed_group_message(&self, envelope_bytes: Vec) -> Result { + pub async fn process_streamed_group_message( + &self, + envelope_bytes: Vec, + ) -> Result { let group = MlsGroup::new( self.inner_client.as_ref(), self.group_id.clone(), @@ -381,7 +394,7 @@ impl FfiGroup { ); let message = group.process_streamed_group_message(envelope_bytes).await?; let ffi_message = message.into(); - + Ok(ffi_message) } @@ -484,6 +497,21 @@ impl FfiGroup { } } +#[derive(uniffi::Enum)] +pub enum FfiGroupMessageKind { + Application, + MembershipChange, +} + +impl From for FfiGroupMessageKind { + fn from(kind: GroupMessageKind) -> Self { + match kind { + GroupMessageKind::Application => FfiGroupMessageKind::Application, + GroupMessageKind::MembershipChange => FfiGroupMessageKind::MembershipChange, + } + } +} + #[derive(uniffi::Record)] pub struct FfiMessage { pub id: Vec, @@ -491,6 +519,7 @@ pub struct FfiMessage { pub convo_id: Vec, pub addr_from: String, pub content: Vec, + pub kind: FfiGroupMessageKind, } impl From for FfiMessage { @@ -501,6 +530,7 @@ impl From for FfiMessage { convo_id: msg.group_id, addr_from: msg.sender_account_address, content: msg.decrypted_message_bytes, + kind: msg.kind.into(), } } }