diff --git a/sdks/browser-sdk/package.json b/sdks/browser-sdk/package.json index ecf76edd5..9e923dc76 100644 --- a/sdks/browser-sdk/package.json +++ b/sdks/browser-sdk/package.json @@ -64,7 +64,7 @@ "@xmtp/content-type-primitives": "^2.0.0", "@xmtp/content-type-text": "^2.0.0", "@xmtp/proto": "^3.72.3", - "@xmtp/wasm-bindings": "^0.0.7", + "@xmtp/wasm-bindings": "^0.0.8", "uuid": "^11.0.3" }, "devDependencies": { diff --git a/sdks/browser-sdk/src/utils/conversions.ts b/sdks/browser-sdk/src/utils/conversions.ts index 1e9f32045..e0399777e 100644 --- a/sdks/browser-sdk/src/utils/conversions.ts +++ b/sdks/browser-sdk/src/utils/conversions.ts @@ -6,8 +6,10 @@ import { Consent, CreateGroupOptions, GroupMember, + GroupPermissionsOptions, ListConversationsOptions, ListMessagesOptions, + PermissionPolicySet, ContentTypeId as WasmContentTypeId, EncodedContent as WasmEncodedContent, type ConsentEntityType, @@ -16,7 +18,6 @@ import { type DeliveryStatus, type GroupMembershipState, type GroupMessageKind, - type GroupPermissionsOptions, type InboxState, type Installation, type Message, @@ -200,22 +201,62 @@ export const fromSafeListConversationsOptions = ( options.limit, ); +export type SafePermissionPolicySet = { + addAdminPolicy: PermissionPolicy; + addMemberPolicy: PermissionPolicy; + removeAdminPolicy: PermissionPolicy; + removeMemberPolicy: PermissionPolicy; + updateGroupDescriptionPolicy: PermissionPolicy; + updateGroupImageUrlSquarePolicy: PermissionPolicy; + updateGroupNamePolicy: PermissionPolicy; + updateGroupPinnedFrameUrlPolicy: PermissionPolicy; +}; + +export const toSafePermissionPolicySet = ( + policySet: PermissionPolicySet, +): SafePermissionPolicySet => ({ + addAdminPolicy: policySet.addAdminPolicy, + addMemberPolicy: policySet.addMemberPolicy, + removeAdminPolicy: policySet.removeAdminPolicy, + removeMemberPolicy: policySet.removeMemberPolicy, + updateGroupDescriptionPolicy: policySet.updateGroupDescriptionPolicy, + updateGroupImageUrlSquarePolicy: policySet.updateGroupImageUrlSquarePolicy, + updateGroupNamePolicy: policySet.updateGroupNamePolicy, + updateGroupPinnedFrameUrlPolicy: policySet.updateGroupPinnedFrameUrlPolicy, +}); + +export const fromSafePermissionPolicySet = ( + policySet: SafePermissionPolicySet, +): PermissionPolicySet => + new PermissionPolicySet( + policySet.addMemberPolicy, + policySet.removeMemberPolicy, + policySet.addAdminPolicy, + policySet.removeAdminPolicy, + policySet.updateGroupNamePolicy, + policySet.updateGroupDescriptionPolicy, + policySet.updateGroupImageUrlSquarePolicy, + policySet.updateGroupPinnedFrameUrlPolicy, + ); + export type SafeCreateGroupOptions = { - permissions?: GroupPermissionsOptions; - name?: string; - imageUrlSquare?: string; + customPermissionPolicySet?: SafePermissionPolicySet; description?: string; + imageUrlSquare?: string; + name?: string; + permissions?: GroupPermissionsOptions; pinnedFrameUrl?: string; }; export const toSafeCreateGroupOptions = ( options: CreateGroupOptions, ): SafeCreateGroupOptions => ({ - permissions: options.permissions, - name: options.groupName, - imageUrlSquare: options.groupImageUrlSquare, description: options.groupDescription, + imageUrlSquare: options.groupImageUrlSquare, + name: options.groupName, pinnedFrameUrl: options.groupPinnedFrameUrl, + permissions: options.permissions, + customPermissionPolicySet: options.customPermissionPolicySet, }); export const fromSafeCreateGroupOptions = ( @@ -227,6 +268,11 @@ export const fromSafeCreateGroupOptions = ( options.imageUrlSquare, options.description, options.pinnedFrameUrl, + // only include custom policy set if permissions are set to CustomPolicy + options.customPermissionPolicySet && + options.permissions === GroupPermissionsOptions.CustomPolicy + ? fromSafePermissionPolicySet(options.customPermissionPolicySet) + : undefined, ); export type SafeConversation = { diff --git a/sdks/browser-sdk/src/workers/client.ts b/sdks/browser-sdk/src/workers/client.ts index 61780b5ee..b6697ebf6 100644 --- a/sdks/browser-sdk/src/workers/client.ts +++ b/sdks/browser-sdk/src/workers/client.ts @@ -6,6 +6,7 @@ import type { } from "@/types"; import { fromEncodedContent, + fromSafeCreateGroupOptions, fromSafeEncodedContent, toSafeConversation, toSafeInboxState, @@ -290,6 +291,11 @@ self.onmessage = async (event: MessageEvent) => { break; } case "newGroup": { + // console.log( + // "newGroup", + // fromSafeCreateGroupOptions(data.options!), + // data.options, + // ); const conversation = await client.conversations.newGroup( data.accountAddresses, data.options, diff --git a/sdks/browser-sdk/test/Conversations.test.ts b/sdks/browser-sdk/test/Conversations.test.ts index fcc15f322..224ffc13d 100644 --- a/sdks/browser-sdk/test/Conversations.test.ts +++ b/sdks/browser-sdk/test/Conversations.test.ts @@ -255,4 +255,41 @@ describe.concurrent("Conversations", () => { expect(groupWithPinnedFrameUrl.description).toBe(""); expect(groupWithPinnedFrameUrl.pinnedFrameUrl).toBe("https://foo/bar"); }); + + it("should create a group with custom permissions", async () => { + const user1 = createUser(); + const user2 = createUser(); + const client1 = await createRegisteredClient(user1); + await createRegisteredClient(user2); + const group = await client1.conversations.newGroup( + [user2.account.address], + { + permissions: GroupPermissionsOptions.CustomPolicy, + customPermissionPolicySet: { + addAdminPolicy: 1, + addMemberPolicy: 0, + removeAdminPolicy: 1, + removeMemberPolicy: 1, + updateGroupNamePolicy: 1, + updateGroupDescriptionPolicy: 1, + updateGroupImageUrlSquarePolicy: 1, + updateGroupPinnedFrameUrlPolicy: 1, + }, + }, + ); + expect(group).toBeDefined(); + expect(group.permissions?.policyType).toBe( + GroupPermissionsOptions.CustomPolicy, + ); + expect(group.permissions?.policySet).toEqual({ + addAdminPolicy: 1, + addMemberPolicy: 0, + removeAdminPolicy: 1, + removeMemberPolicy: 1, + updateGroupNamePolicy: 1, + updateGroupDescriptionPolicy: 1, + updateGroupImageUrlSquarePolicy: 1, + updateGroupPinnedFrameUrlPolicy: 1, + }); + }); }); diff --git a/yarn.lock b/yarn.lock index 37f3dd5c2..7700db730 100644 --- a/yarn.lock +++ b/yarn.lock @@ -4809,7 +4809,7 @@ __metadata: "@xmtp/content-type-primitives": "npm:^2.0.0" "@xmtp/content-type-text": "npm:^2.0.0" "@xmtp/proto": "npm:^3.72.3" - "@xmtp/wasm-bindings": "npm:^0.0.7" + "@xmtp/wasm-bindings": "npm:^0.0.8" playwright: "npm:^1.49.0" rollup: "npm:^4.27.3" rollup-plugin-dts: "npm:^6.1.1" @@ -5236,10 +5236,10 @@ __metadata: languageName: node linkType: hard -"@xmtp/wasm-bindings@npm:^0.0.7": - version: 0.0.7 - resolution: "@xmtp/wasm-bindings@npm:0.0.7" - checksum: 10/4063d9cee51e4fd181d4d9f5840b861d8b99d6eb3d1bb6c3c09049105e126b958053c16ca29d729b62339d3d343b68e8955314d5a2c366b4d6e67d074228a94e +"@xmtp/wasm-bindings@npm:^0.0.8": + version: 0.0.8 + resolution: "@xmtp/wasm-bindings@npm:0.0.8" + checksum: 10/6020c15b56d3ac02fc76d86bb176c2504f1976aec7af2ae7f3aea7e159f2692db08c0d5501462f8ea4fb34530cacbd2568a3870d0a7b8189db33e7e7a49a9711 languageName: node linkType: hard