From 0e0f235d4d1b2e7d6a438483065a47ac1bce1602 Mon Sep 17 00:00:00 2001 From: Naomi Plasterer Date: Thu, 15 Feb 2024 15:48:08 -0800 Subject: [PATCH 1/2] register the codec on iOS --- ios/Wrappers/DecodedMessageWrapper.swift | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/ios/Wrappers/DecodedMessageWrapper.swift b/ios/Wrappers/DecodedMessageWrapper.swift index 72d6c2368..e5045d64a 100644 --- a/ios/Wrappers/DecodedMessageWrapper.swift +++ b/ios/Wrappers/DecodedMessageWrapper.swift @@ -41,8 +41,7 @@ struct ContentJson { ReplyCodec(), RemoteAttachmentCodec(), ReadReceiptCodec(), - // TODO: - // CompositeCodec(), + GroupMembershipChangedCodec(), ] static func initCodecs(client: Client) { From 259440a0606c2b8d278104055667fd4b817cd6b3 Mon Sep 17 00:00:00 2001 From: Naomi Plasterer Date: Thu, 15 Feb 2024 16:09:10 -0800 Subject: [PATCH 2/2] add the content type to the iOS side --- ios/Wrappers/DecodedMessageWrapper.swift | 16 ++++++++++++++++ src/lib/NativeCodecs/GroupChangeCodec.ts | 4 ++-- 2 files changed, 18 insertions(+), 2 deletions(-) diff --git a/ios/Wrappers/DecodedMessageWrapper.swift b/ios/Wrappers/DecodedMessageWrapper.swift index e5045d64a..e9b5ed39f 100644 --- a/ios/Wrappers/DecodedMessageWrapper.swift +++ b/ios/Wrappers/DecodedMessageWrapper.swift @@ -158,6 +158,22 @@ struct ContentJson { ]] case ContentTypeReadReceipt.id where content is XMTP.ReadReceipt: return ["readReceipt": ""] + case ContentTypeGroupMembershipChanged.id where content is XMTP.GroupMembershipChanges: + let groupChange = content as! XMTP.GroupMembershipChanges + return ["groupChange": [ + "membersAdded": groupChange.membersAdded.map { member in + [ + "address": member.accountAddress, + "initiatedByAddress": member.initiatedByAccountAddress + ] + }, + "membersRemoved": groupChange.membersRemoved.map { member in + [ + "address": member.accountAddress, + "initiatedByAddress": member.initiatedByAccountAddress + ] + }, + ]] default: if let encodedContent, let encodedContentJSON = try? encodedContent.jsonString() { return ["encoded": encodedContentJSON] diff --git a/src/lib/NativeCodecs/GroupChangeCodec.ts b/src/lib/NativeCodecs/GroupChangeCodec.ts index 96b153e4d..c5d5b446e 100644 --- a/src/lib/NativeCodecs/GroupChangeCodec.ts +++ b/src/lib/NativeCodecs/GroupChangeCodec.ts @@ -15,7 +15,7 @@ export class GroupChangeCodec versionMajor: 1, versionMinor: 0, } - + // Should never have to encode since only sent from Rust backend encode(): NativeMessageContent { return {} } @@ -25,6 +25,6 @@ export class GroupChangeCodec } fallback(): string | undefined { - return 'The members of this group have changed' + return undefined } }