@geoprotocol/geo-sdk 0.19.2 → 0.20.0-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +98 -45
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/src/abis/dao-space-factory.d.ts +43 -6
- package/dist/src/abis/dao-space-factory.d.ts.map +1 -1
- package/dist/src/abis/dao-space-factory.js +38 -27
- package/dist/src/abis/dao-space-factory.js.map +1 -1
- package/dist/src/abis/dao-space-v2.test.d.ts +2 -0
- package/dist/src/abis/dao-space-v2.test.d.ts.map +1 -0
- package/dist/src/abis/dao-space-v2.test.js +67 -0
- package/dist/src/abis/dao-space-v2.test.js.map +1 -0
- package/dist/src/abis/dao-space.d.ts +98 -7
- package/dist/src/abis/dao-space.d.ts.map +1 -1
- package/dist/src/abis/dao-space.js +61 -99
- package/dist/src/abis/dao-space.js.map +1 -1
- package/dist/src/abis/index.d.ts +2 -2
- package/dist/src/abis/index.d.ts.map +1 -1
- package/dist/src/abis/index.js +2 -2
- package/dist/src/abis/index.js.map +1 -1
- package/dist/src/api-surface.e2e.test.d.ts +2 -0
- package/dist/src/api-surface.e2e.test.d.ts.map +1 -0
- package/dist/src/{e2e-api-surface.test.js → api-surface.e2e.test.js} +86 -100
- package/dist/src/api-surface.e2e.test.js.map +1 -0
- package/dist/src/client/dao-spaces.d.ts +65 -33
- package/dist/src/client/dao-spaces.d.ts.map +1 -1
- package/dist/src/client/dao-spaces.js +133 -42
- package/dist/src/client/dao-spaces.js.map +1 -1
- package/dist/src/client/dao-spaces.test.js +277 -79
- package/dist/src/client/dao-spaces.test.js.map +1 -1
- package/dist/src/client/personal-spaces.js +2 -2
- package/dist/src/client/personal-spaces.js.map +1 -1
- package/dist/src/client/spaces.test.js +9 -7
- package/dist/src/client/spaces.test.js.map +1 -1
- package/dist/src/client.d.ts +14 -14
- package/dist/src/client.d.ts.map +1 -1
- package/dist/src/client.js +48 -59
- package/dist/src/client.js.map +1 -1
- package/dist/src/client.test.js +8 -3
- package/dist/src/client.test.js.map +1 -1
- package/dist/src/contracts-v2/local-geobrowser.e2e.test.d.ts +2 -0
- package/dist/src/contracts-v2/local-geobrowser.e2e.test.d.ts.map +1 -0
- package/dist/src/contracts-v2/local-geobrowser.e2e.test.js +239 -0
- package/dist/src/contracts-v2/local-geobrowser.e2e.test.js.map +1 -0
- package/dist/src/dao-space/constants.d.ts +10 -0
- package/dist/src/dao-space/constants.d.ts.map +1 -1
- package/dist/src/dao-space/constants.js +10 -0
- package/dist/src/dao-space/constants.js.map +1 -1
- package/dist/src/dao-space/execute-proposal.d.ts +1 -1
- package/dist/src/dao-space/execute-proposal.js +2 -2
- package/dist/src/dao-space/execute-proposal.js.map +1 -1
- package/dist/src/dao-space/index.d.ts +2 -1
- package/dist/src/dao-space/index.d.ts.map +1 -1
- package/dist/src/dao-space/index.js +1 -0
- package/dist/src/dao-space/index.js.map +1 -1
- package/dist/src/dao-space/propose-add-editor.d.ts +1 -20
- package/dist/src/dao-space/propose-add-editor.d.ts.map +1 -1
- package/dist/src/dao-space/propose-add-editor.js +12 -87
- package/dist/src/dao-space/propose-add-editor.js.map +1 -1
- package/dist/src/dao-space/propose-add-editor.test.js +16 -4
- package/dist/src/dao-space/propose-add-editor.test.js.map +1 -1
- package/dist/src/dao-space/propose-add-member.d.ts +1 -20
- package/dist/src/dao-space/propose-add-member.d.ts.map +1 -1
- package/dist/src/dao-space/propose-add-member.js +12 -87
- package/dist/src/dao-space/propose-add-member.js.map +1 -1
- package/dist/src/dao-space/propose-add-member.test.js +13 -0
- package/dist/src/dao-space/propose-add-member.test.js.map +1 -1
- package/dist/src/dao-space/propose-edit.test.js +45 -0
- package/dist/src/dao-space/propose-edit.test.js.map +1 -1
- package/dist/src/dao-space/propose-remove-editor.d.ts +1 -22
- package/dist/src/dao-space/propose-remove-editor.d.ts.map +1 -1
- package/dist/src/dao-space/propose-remove-editor.js +12 -94
- package/dist/src/dao-space/propose-remove-editor.js.map +1 -1
- package/dist/src/dao-space/propose-remove-editor.test.js +22 -4
- package/dist/src/dao-space/propose-remove-editor.test.js.map +1 -1
- package/dist/src/dao-space/propose-remove-member.d.ts +1 -22
- package/dist/src/dao-space/propose-remove-member.d.ts.map +1 -1
- package/dist/src/dao-space/propose-remove-member.js +12 -94
- package/dist/src/dao-space/propose-remove-member.js.map +1 -1
- package/dist/src/dao-space/propose-remove-member.test.js +19 -0
- package/dist/src/dao-space/propose-remove-member.test.js.map +1 -1
- package/dist/src/dao-space/propose-update-voting-settings.d.ts +8 -0
- package/dist/src/dao-space/propose-update-voting-settings.d.ts.map +1 -0
- package/dist/src/dao-space/propose-update-voting-settings.js +19 -0
- package/dist/src/dao-space/propose-update-voting-settings.js.map +1 -0
- package/dist/src/dao-space/propose-update-voting-settings.test.d.ts +2 -0
- package/dist/src/dao-space/propose-update-voting-settings.test.d.ts.map +1 -0
- package/dist/src/dao-space/propose-update-voting-settings.test.js +118 -0
- package/dist/src/dao-space/propose-update-voting-settings.test.js.map +1 -0
- package/dist/src/dao-space/types.d.ts +72 -11
- package/dist/src/dao-space/types.d.ts.map +1 -1
- package/dist/src/dao-space/vote-proposal.d.ts +1 -1
- package/dist/src/dao-space/vote-proposal.js +2 -2
- package/dist/src/dao-space/vote-proposal.js.map +1 -1
- package/dist/src/dao-space/vote-proposal.test.js +54 -0
- package/dist/src/dao-space/vote-proposal.test.js.map +1 -1
- package/dist/src/e2e-test-environment.d.ts +26 -0
- package/dist/src/e2e-test-environment.d.ts.map +1 -0
- package/dist/src/e2e-test-environment.js +150 -0
- package/dist/src/e2e-test-environment.js.map +1 -0
- package/dist/src/encodings/get-create-dao-space-calldata.d.ts +31 -8
- package/dist/src/encodings/get-create-dao-space-calldata.d.ts.map +1 -1
- package/dist/src/encodings/get-create-dao-space-calldata.js +66 -17
- package/dist/src/encodings/get-create-dao-space-calldata.js.map +1 -1
- package/dist/src/encodings/get-create-dao-space-calldata.test.js +117 -34
- package/dist/src/encodings/get-create-dao-space-calldata.test.js.map +1 -1
- package/dist/src/full-flow-test.test.js +5 -2
- package/dist/src/full-flow-test.test.js.map +1 -1
- package/dist/src/legacy-api-surface.e2e.test.d.ts +2 -0
- package/dist/src/legacy-api-surface.e2e.test.d.ts.map +1 -0
- package/dist/src/{e2e-legacy-api-surface.test.js → legacy-api-surface.e2e.test.js} +90 -70
- package/dist/src/legacy-api-surface.e2e.test.js.map +1 -0
- package/dist/src/personal-space/constants.d.ts +1 -1
- package/dist/src/personal-space/constants.d.ts.map +1 -1
- package/dist/src/personal-space/constants.js +1 -1
- package/dist/src/personal-space/constants.js.map +1 -1
- package/dist/src/personal-space/create-space.d.ts +2 -2
- package/dist/src/personal-space/create-space.d.ts.map +1 -1
- package/dist/src/personal-space/create-space.js +4 -3
- package/dist/src/personal-space/create-space.js.map +1 -1
- package/dist/src/personal-space/types.d.ts +4 -1
- package/dist/src/personal-space/types.d.ts.map +1 -1
- package/package.json +3 -2
- package/dist/src/e2e-api-surface.test.d.ts +0 -2
- package/dist/src/e2e-api-surface.test.d.ts.map +0 -1
- package/dist/src/e2e-api-surface.test.js.map +0 -1
- package/dist/src/e2e-legacy-api-surface.test.d.ts +0 -2
- package/dist/src/e2e-legacy-api-surface.test.d.ts.map +0 -1
- package/dist/src/e2e-legacy-api-surface.test.js.map +0 -1
|
@@ -4,11 +4,13 @@ import { proposeAddMember } from './propose-add-member.js';
|
|
|
4
4
|
describe('proposeAddMember', () => {
|
|
5
5
|
const validAuthorSpaceId = '0x0eed5491b917cf58b33ac81255fe7ae9';
|
|
6
6
|
const validSpaceId = '0xabcdef12345678901234567890abcdef';
|
|
7
|
+
const validDaoSpaceAddress = '0x1234567890123456789012345678901234567890';
|
|
7
8
|
const validNewMemberSpaceId = '0x11111111111111111111111111111111';
|
|
8
9
|
it('should return correct structure', () => {
|
|
9
10
|
const result = proposeAddMember({
|
|
10
11
|
authorSpaceId: validAuthorSpaceId,
|
|
11
12
|
spaceId: validSpaceId,
|
|
13
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
12
14
|
newMemberSpaceId: validNewMemberSpaceId,
|
|
13
15
|
});
|
|
14
16
|
expect(result).toHaveProperty('to');
|
|
@@ -19,6 +21,7 @@ describe('proposeAddMember', () => {
|
|
|
19
21
|
const { to } = proposeAddMember({
|
|
20
22
|
authorSpaceId: validAuthorSpaceId,
|
|
21
23
|
spaceId: validSpaceId,
|
|
24
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
22
25
|
newMemberSpaceId: validNewMemberSpaceId,
|
|
23
26
|
});
|
|
24
27
|
expect(to).toBe(TESTNET.SPACE_REGISTRY_ADDRESS);
|
|
@@ -27,6 +30,7 @@ describe('proposeAddMember', () => {
|
|
|
27
30
|
const { calldata } = proposeAddMember({
|
|
28
31
|
authorSpaceId: validAuthorSpaceId,
|
|
29
32
|
spaceId: validSpaceId,
|
|
33
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
30
34
|
newMemberSpaceId: validNewMemberSpaceId,
|
|
31
35
|
});
|
|
32
36
|
expect(calldata).toBeTypeOf('string');
|
|
@@ -36,6 +40,7 @@ describe('proposeAddMember', () => {
|
|
|
36
40
|
const { proposalId } = proposeAddMember({
|
|
37
41
|
authorSpaceId: validAuthorSpaceId,
|
|
38
42
|
spaceId: validSpaceId,
|
|
43
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
39
44
|
newMemberSpaceId: validNewMemberSpaceId,
|
|
40
45
|
});
|
|
41
46
|
expect(proposalId).toMatch(/^0x[0-9a-fA-F]{32}$/);
|
|
@@ -45,6 +50,7 @@ describe('proposeAddMember', () => {
|
|
|
45
50
|
const { proposalId } = proposeAddMember({
|
|
46
51
|
authorSpaceId: validAuthorSpaceId,
|
|
47
52
|
spaceId: validSpaceId,
|
|
53
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
48
54
|
newMemberSpaceId: validNewMemberSpaceId,
|
|
49
55
|
proposalId: customProposalId,
|
|
50
56
|
});
|
|
@@ -54,6 +60,7 @@ describe('proposeAddMember', () => {
|
|
|
54
60
|
const result = proposeAddMember({
|
|
55
61
|
authorSpaceId: validAuthorSpaceId,
|
|
56
62
|
spaceId: validSpaceId,
|
|
63
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
57
64
|
newMemberSpaceId: validNewMemberSpaceId,
|
|
58
65
|
});
|
|
59
66
|
expect(result.calldata).toBeTruthy();
|
|
@@ -62,6 +69,7 @@ describe('proposeAddMember', () => {
|
|
|
62
69
|
const result = proposeAddMember({
|
|
63
70
|
authorSpaceId: validAuthorSpaceId,
|
|
64
71
|
spaceId: validSpaceId,
|
|
72
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
65
73
|
newMemberSpaceId: validNewMemberSpaceId,
|
|
66
74
|
votingMode: 'FAST',
|
|
67
75
|
});
|
|
@@ -71,11 +79,13 @@ describe('proposeAddMember', () => {
|
|
|
71
79
|
const result1 = proposeAddMember({
|
|
72
80
|
authorSpaceId: validAuthorSpaceId,
|
|
73
81
|
spaceId: validSpaceId,
|
|
82
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
74
83
|
newMemberSpaceId: validNewMemberSpaceId,
|
|
75
84
|
});
|
|
76
85
|
const result2 = proposeAddMember({
|
|
77
86
|
authorSpaceId: validAuthorSpaceId,
|
|
78
87
|
spaceId: validSpaceId,
|
|
88
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
79
89
|
newMemberSpaceId: validNewMemberSpaceId,
|
|
80
90
|
});
|
|
81
91
|
expect(result1.proposalId).not.toBe(result2.proposalId);
|
|
@@ -84,6 +94,7 @@ describe('proposeAddMember', () => {
|
|
|
84
94
|
expect(() => proposeAddMember({
|
|
85
95
|
authorSpaceId: '0xinvalid',
|
|
86
96
|
spaceId: validSpaceId,
|
|
97
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
87
98
|
newMemberSpaceId: validNewMemberSpaceId,
|
|
88
99
|
})).toThrow('authorSpaceId must be bytes16 hex');
|
|
89
100
|
});
|
|
@@ -91,6 +102,7 @@ describe('proposeAddMember', () => {
|
|
|
91
102
|
expect(() => proposeAddMember({
|
|
92
103
|
authorSpaceId: validAuthorSpaceId,
|
|
93
104
|
spaceId: '0xtooshort',
|
|
105
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
94
106
|
newMemberSpaceId: validNewMemberSpaceId,
|
|
95
107
|
})).toThrow('spaceId must be bytes16 hex');
|
|
96
108
|
});
|
|
@@ -98,6 +110,7 @@ describe('proposeAddMember', () => {
|
|
|
98
110
|
expect(() => proposeAddMember({
|
|
99
111
|
authorSpaceId: validAuthorSpaceId,
|
|
100
112
|
spaceId: validSpaceId,
|
|
113
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
101
114
|
newMemberSpaceId: '0xinvalid',
|
|
102
115
|
})).toThrow('newMemberSpaceId must be bytes16 hex');
|
|
103
116
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"propose-add-member.test.js","sourceRoot":"","sources":["../../../src/dao-space/propose-add-member.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAE9C,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAC7C,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAE3D,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;IAChC,MAAM,kBAAkB,GAAG,oCAA6C,CAAC;IACzE,MAAM,YAAY,GAAG,oCAA6C,CAAC;IACnE,MAAM,qBAAqB,GAAG,oCAA6C,CAAC;IAE5E,EAAE,CAAC,iCAAiC,EAAE,GAAG,EAAE;QACzC,MAAM,MAAM,GAAG,gBAAgB,CAAC;YAC9B,aAAa,EAAE,kBAAkB;YACjC,OAAO,EAAE,YAAY;YACrB,gBAAgB,EAAE,qBAAqB;SACxC,CAAC,CAAC;QAEH,MAAM,CAAC,MAAM,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QACpC,MAAM,CAAC,MAAM,CAAC,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;QAC1C,MAAM,CAAC,MAAM,CAAC,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC;IAC9C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6DAA6D,EAAE,GAAG,EAAE;QACrE,MAAM,EAAE,EAAE,EAAE,GAAG,gBAAgB,CAAC;YAC9B,aAAa,EAAE,kBAAkB;YACjC,OAAO,EAAE,YAAY;YACrB,gBAAgB,EAAE,qBAAqB;SACxC,CAAC,CAAC;QAEH,MAAM,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,sBAAsB,CAAC,CAAC;IAClD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE,GAAG,EAAE;QACtC,MAAM,EAAE,QAAQ,EAAE,GAAG,gBAAgB,CAAC;YACpC,aAAa,EAAE,kBAAkB;YACjC,OAAO,EAAE,YAAY;YACrB,gBAAgB,EAAE,qBAAqB;SACxC,CAAC,CAAC;QAEH,MAAM,CAAC,QAAQ,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;QACtC,MAAM,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC/C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8CAA8C,EAAE,GAAG,EAAE;QACtD,MAAM,EAAE,UAAU,EAAE,GAAG,gBAAgB,CAAC;YACtC,aAAa,EAAE,kBAAkB;YACjC,OAAO,EAAE,YAAY;YACrB,gBAAgB,EAAE,qBAAqB;SACxC,CAAC,CAAC;QAEH,MAAM,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,qBAAqB,CAAC,CAAC;IACpD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iCAAiC,EAAE,GAAG,EAAE;QACzC,MAAM,gBAAgB,GAAG,oCAA6C,CAAC;QAEvE,MAAM,EAAE,UAAU,EAAE,GAAG,gBAAgB,CAAC;YACtC,aAAa,EAAE,kBAAkB;YACjC,OAAO,EAAE,YAAY;YACrB,gBAAgB,EAAE,qBAAqB;YACvC,UAAU,EAAE,gBAAgB;SAC7B,CAAC,CAAC;QAEH,MAAM,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;IAC5C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+DAA+D,EAAE,GAAG,EAAE;QACvE,MAAM,MAAM,GAAG,gBAAgB,CAAC;YAC9B,aAAa,EAAE,kBAAkB;YACjC,OAAO,EAAE,YAAY;YACrB,gBAAgB,EAAE,qBAAqB;SACxC,CAAC,CAAC;QAEH,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,UAAU,EAAE,CAAC;IACvC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE,GAAG,EAAE;QACxC,MAAM,MAAM,GAAG,gBAAgB,CAAC;YAC9B,aAAa,EAAE,kBAAkB;YACjC,OAAO,EAAE,YAAY;YACrB,gBAAgB,EAAE,qBAAqB;YACvC,UAAU,EAAE,MAAM;SACnB,CAAC,CAAC;QAEH,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,UAAU,EAAE,CAAC;IACvC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uDAAuD,EAAE,GAAG,EAAE;QAC/D,MAAM,OAAO,GAAG,gBAAgB,CAAC;YAC/B,aAAa,EAAE,kBAAkB;YACjC,OAAO,EAAE,YAAY;YACrB,gBAAgB,EAAE,qBAAqB;SACxC,CAAC,CAAC;QAEH,MAAM,OAAO,GAAG,gBAAgB,CAAC;YAC/B,aAAa,EAAE,kBAAkB;YACjC,OAAO,EAAE,YAAY;YACrB,gBAAgB,EAAE,qBAAqB;SACxC,CAAC,CAAC;QAEH,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;IAC1D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yCAAyC,EAAE,GAAG,EAAE;QACjD,MAAM,CAAC,GAAG,EAAE,CACV,gBAAgB,CAAC;YACf,aAAa,EAAE,WAA4B;YAC3C,OAAO,EAAE,YAAY;YACrB,gBAAgB,EAAE,qBAAqB;SACxC,CAAC,CACH,CAAC,OAAO,CAAC,mCAAmC,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE,GAAG,EAAE;QACpD,MAAM,CAAC,GAAG,EAAE,CACV,gBAAgB,CAAC;YACf,aAAa,EAAE,kBAAkB;YACjC,OAAO,EAAE,YAA6B;YACtC,gBAAgB,EAAE,qBAAqB;SACxC,CAAC,CACH,CAAC,OAAO,CAAC,6BAA6B,CAAC,CAAC;IAC3C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE,GAAG,EAAE;QAC1D,MAAM,CAAC,GAAG,EAAE,CACV,gBAAgB,CAAC;YACf,aAAa,EAAE,kBAAkB;YACjC,OAAO,EAAE,YAAY;YACrB,gBAAgB,EAAE,WAA4B;SAC/C,CAAC,CACH,CAAC,OAAO,CAAC,sCAAsC,CAAC,CAAC;IACpD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
1
|
+
{"version":3,"file":"propose-add-member.test.js","sourceRoot":"","sources":["../../../src/dao-space/propose-add-member.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,6 +2,7 @@ import { afterEach, beforeEach, describe, expect, it, vi } from 'vitest';
|
|
|
2
2
|
import { TESTNET } from '../../contracts.js';
|
|
3
3
|
import { createEntity } from '../graph/create-entity.js';
|
|
4
4
|
import { generate } from '../id-utils.js';
|
|
5
|
+
import { defineGeoNetworkConfig } from '../networks.js';
|
|
5
6
|
import { proposeEdit } from './propose-edit.js';
|
|
6
7
|
describe('proposeEdit', () => {
|
|
7
8
|
const cid = 'ipfs://bafkreigwfjixq5cm3s4youhshorkpqh3ykpviyv76c2ei6gaalujtlqz5i';
|
|
@@ -10,6 +11,14 @@ describe('proposeEdit', () => {
|
|
|
10
11
|
const validDaoSpaceId = '0xabcdef12345678901234567890abcdef';
|
|
11
12
|
const validDaoSpaceAddress = '0x1234567890123456789012345678901234567890';
|
|
12
13
|
const validAuthor = generate();
|
|
14
|
+
const localNetwork = defineGeoNetworkConfig({
|
|
15
|
+
id: 'LOCAL',
|
|
16
|
+
name: 'Local Geo',
|
|
17
|
+
apiOrigin: 'http://localhost:3000',
|
|
18
|
+
contracts: {
|
|
19
|
+
SPACE_REGISTRY_ADDRESS: TESTNET.SPACE_REGISTRY_ADDRESS,
|
|
20
|
+
},
|
|
21
|
+
});
|
|
13
22
|
beforeEach(() => {
|
|
14
23
|
vi.stubGlobal('fetch', vi.fn().mockImplementation(() => Promise.resolve(new Response(JSON.stringify({ cid })))));
|
|
15
24
|
});
|
|
@@ -31,6 +40,7 @@ describe('proposeEdit', () => {
|
|
|
31
40
|
expect(result).toHaveProperty('to');
|
|
32
41
|
expect(result).toHaveProperty('calldata');
|
|
33
42
|
expect(result).toHaveProperty('proposalId');
|
|
43
|
+
expect(result).toHaveProperty('versionId', 1);
|
|
34
44
|
});
|
|
35
45
|
it('should return the correct contract address (Space Registry)', async () => {
|
|
36
46
|
const { ops } = createEntity({ name: 'Test Entity' });
|
|
@@ -108,6 +118,41 @@ describe('proposeEdit', () => {
|
|
|
108
118
|
});
|
|
109
119
|
expect(proposalId).toBe(customProposalId);
|
|
110
120
|
});
|
|
121
|
+
it('should return an explicit version for proposal updates', async () => {
|
|
122
|
+
const { ops } = createEntity({ name: 'Test Entity' });
|
|
123
|
+
const customProposalId = '0x11111111111111111111111111111111';
|
|
124
|
+
const result = await proposeEdit({
|
|
125
|
+
name: 'Test Edit',
|
|
126
|
+
ops,
|
|
127
|
+
author: validAuthor,
|
|
128
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
129
|
+
callerSpaceId: validCallerSpaceId,
|
|
130
|
+
daoSpaceId: validDaoSpaceId,
|
|
131
|
+
proposalId: customProposalId,
|
|
132
|
+
updateProposal: true,
|
|
133
|
+
versionId: 2,
|
|
134
|
+
network: localNetwork,
|
|
135
|
+
});
|
|
136
|
+
expect(result.proposalId).toBe(customProposalId);
|
|
137
|
+
expect(result.versionId).toBe(2);
|
|
138
|
+
});
|
|
139
|
+
it('should require versionId before upload for proposal updates without RPC config', async () => {
|
|
140
|
+
const { ops } = createEntity({ name: 'Test Entity' });
|
|
141
|
+
const customProposalId = '0x11111111111111111111111111111111';
|
|
142
|
+
const fetch = vi.mocked(globalThis.fetch);
|
|
143
|
+
await expect(proposeEdit({
|
|
144
|
+
name: 'Test Edit',
|
|
145
|
+
ops,
|
|
146
|
+
author: validAuthor,
|
|
147
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
148
|
+
callerSpaceId: validCallerSpaceId,
|
|
149
|
+
daoSpaceId: validDaoSpaceId,
|
|
150
|
+
proposalId: customProposalId,
|
|
151
|
+
updateProposal: true,
|
|
152
|
+
network: localNetwork,
|
|
153
|
+
})).rejects.toThrow('versionId is required when updateProposal is true and the network has no RPC URL');
|
|
154
|
+
expect(fetch).not.toHaveBeenCalled();
|
|
155
|
+
});
|
|
111
156
|
it('should default to FAST voting mode', async () => {
|
|
112
157
|
const { ops } = createEntity({ name: 'Test Entity' });
|
|
113
158
|
const result = await proposeEdit({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"propose-edit.test.js","sourceRoot":"","sources":["../../../src/dao-space/propose-edit.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAEzE,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD,QAAQ,CAAC,aAAa,EAAE,GAAG,EAAE;IAC3B,MAAM,GAAG,GAAG,oEAA6E,CAAC;IAC1F,oBAAoB;IACpB,MAAM,kBAAkB,GAAG,oCAA6C,CAAC;IACzE,MAAM,eAAe,GAAG,oCAA6C,CAAC;IACtE,MAAM,oBAAoB,GAAG,4CAAqD,CAAC;IACnF,MAAM,WAAW,GAAG,QAAQ,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"propose-edit.test.js","sourceRoot":"","sources":["../../../src/dao-space/propose-edit.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,28 +2,7 @@ import type { ProposeRemoveEditorParams, ProposeRemoveEditorResult } from './typ
|
|
|
2
2
|
/**
|
|
3
3
|
* Creates a proposal to remove an editor from a DAO space.
|
|
4
4
|
*
|
|
5
|
-
*
|
|
6
|
-
* 1. Validates the author, DAO space, and editor IDs
|
|
7
|
-
* 2. Encodes the `removeEditor()` call as the proposal action
|
|
8
|
-
* 3. Encodes the SpaceRegistry's `enter()` call with the `PROPOSAL_CREATED` action
|
|
9
|
-
*
|
|
10
|
-
* @param params - The parameters for proposing editor removal
|
|
11
|
-
* @returns Object containing `to` (Space Registry address), `calldata`, and `proposalId`
|
|
12
|
-
*
|
|
13
|
-
* @example
|
|
14
|
-
* ```ts
|
|
15
|
-
* import { daoSpace } from '@geoprotocol/geo-sdk';
|
|
16
|
-
*
|
|
17
|
-
* const { to, calldata, proposalId } = daoSpace.proposeRemoveEditor({
|
|
18
|
-
* authorSpaceId: '0xAuthorBytes16SpaceId...',
|
|
19
|
-
* spaceId: '0xDAOBytes16SpaceId...',
|
|
20
|
-
* editorToRemoveSpaceId: '0xEditorBytes16SpaceId...',
|
|
21
|
-
* network: 'TESTNET',
|
|
22
|
-
* });
|
|
23
|
-
*
|
|
24
|
-
* // Submit the transaction using viem or another client
|
|
25
|
-
* await walletClient.sendTransaction({ to, data: calldata });
|
|
26
|
-
* ```
|
|
5
|
+
* @deprecated Use `createGeoClient({ network }).daoSpaces.proposeRemoveEditor(...)`.
|
|
27
6
|
*/
|
|
28
7
|
export declare function proposeRemoveEditor(params: ProposeRemoveEditorParams): ProposeRemoveEditorResult;
|
|
29
8
|
//# sourceMappingURL=propose-remove-editor.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"propose-remove-editor.d.ts","sourceRoot":"","sources":["../../../src/dao-space/propose-remove-editor.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"propose-remove-editor.d.ts","sourceRoot":"","sources":["../../../src/dao-space/propose-remove-editor.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,yBAAyB,EAAE,yBAAyB,EAAE,MAAM,YAAY,CAAC;AAEvF;;;;GAIG;AACH,wBAAgB,mBAAmB,CAAC,MAAM,EAAE,yBAAyB,GAAG,yBAAyB,CAehG"}
|
|
@@ -1,104 +1,22 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import { bytes16ToBytes32LeftAligned, EMPTY_SIGNATURE, ensure0xPrefix, getContractAddressesBasedOnNetwork, isBytes16Hex, PROPOSAL_CREATED_ACTION, } from './constants.js';
|
|
1
|
+
import { createGeoClient } from '../client.js';
|
|
2
|
+
import { resolveGeoNetwork } from '../networks.js';
|
|
3
|
+
import { ensure0xPrefix, isBytes16Hex } from './constants.js';
|
|
5
4
|
/**
|
|
6
5
|
* Creates a proposal to remove an editor from a DAO space.
|
|
7
6
|
*
|
|
8
|
-
*
|
|
9
|
-
* 1. Validates the author, DAO space, and editor IDs
|
|
10
|
-
* 2. Encodes the `removeEditor()` call as the proposal action
|
|
11
|
-
* 3. Encodes the SpaceRegistry's `enter()` call with the `PROPOSAL_CREATED` action
|
|
12
|
-
*
|
|
13
|
-
* @param params - The parameters for proposing editor removal
|
|
14
|
-
* @returns Object containing `to` (Space Registry address), `calldata`, and `proposalId`
|
|
15
|
-
*
|
|
16
|
-
* @example
|
|
17
|
-
* ```ts
|
|
18
|
-
* import { daoSpace } from '@geoprotocol/geo-sdk';
|
|
19
|
-
*
|
|
20
|
-
* const { to, calldata, proposalId } = daoSpace.proposeRemoveEditor({
|
|
21
|
-
* authorSpaceId: '0xAuthorBytes16SpaceId...',
|
|
22
|
-
* spaceId: '0xDAOBytes16SpaceId...',
|
|
23
|
-
* editorToRemoveSpaceId: '0xEditorBytes16SpaceId...',
|
|
24
|
-
* network: 'TESTNET',
|
|
25
|
-
* });
|
|
26
|
-
*
|
|
27
|
-
* // Submit the transaction using viem or another client
|
|
28
|
-
* await walletClient.sendTransaction({ to, data: calldata });
|
|
29
|
-
* ```
|
|
7
|
+
* @deprecated Use `createGeoClient({ network }).daoSpaces.proposeRemoveEditor(...)`.
|
|
30
8
|
*/
|
|
31
9
|
export function proposeRemoveEditor(params) {
|
|
32
|
-
const {
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
const spaceId = ensure0xPrefix(rawSpaceId);
|
|
36
|
-
const editorToRemoveSpaceId = ensure0xPrefix(rawEditorToRemoveSpaceId);
|
|
37
|
-
// Validate inputs
|
|
38
|
-
if (!isBytes16Hex(authorSpaceId)) {
|
|
39
|
-
throw new Error(`authorSpaceId must be bytes16 hex (32 hex chars). Received: ${rawAuthorSpaceId}`);
|
|
40
|
-
}
|
|
41
|
-
if (!isBytes16Hex(spaceId)) {
|
|
42
|
-
throw new Error(`spaceId must be bytes16 hex (32 hex chars). Received: ${rawSpaceId}`);
|
|
10
|
+
const { network = 'TESTNET', ...args } = params;
|
|
11
|
+
if (!isBytes16Hex(ensure0xPrefix(args.authorSpaceId))) {
|
|
12
|
+
throw new Error(`authorSpaceId must be bytes16 hex (32 hex chars). Received: ${args.authorSpaceId}`);
|
|
43
13
|
}
|
|
44
|
-
if (!isBytes16Hex(
|
|
45
|
-
throw new Error(`
|
|
14
|
+
if (!isBytes16Hex(ensure0xPrefix(args.spaceId))) {
|
|
15
|
+
throw new Error(`spaceId must be bytes16 hex (32 hex chars). Received: ${args.spaceId}`);
|
|
46
16
|
}
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
? ensure0xPrefix(rawProposalId)
|
|
50
|
-
: `0x${uuidv4().replaceAll('-', '')}`;
|
|
51
|
-
if (!isBytes16Hex(proposalId)) {
|
|
52
|
-
throw new Error(`proposalId must be bytes16 hex (32 hex chars). Received: ${rawProposalId}`);
|
|
17
|
+
if (!isBytes16Hex(ensure0xPrefix(args.editorToRemoveSpaceId))) {
|
|
18
|
+
throw new Error(`editorToRemoveSpaceId must be bytes16 hex (32 hex chars). Received: ${args.editorToRemoveSpaceId}`);
|
|
53
19
|
}
|
|
54
|
-
|
|
55
|
-
const proposalActionCalldata = encodeFunctionData({
|
|
56
|
-
abi: DaoSpaceAbi,
|
|
57
|
-
functionName: 'removeEditor',
|
|
58
|
-
args: [editorToRemoveSpaceId],
|
|
59
|
-
});
|
|
60
|
-
const contracts = getContractAddressesBasedOnNetwork(network);
|
|
61
|
-
// Create the proposal action (calling removeEditor on the Space Registry)
|
|
62
|
-
const proposalActions = [
|
|
63
|
-
{
|
|
64
|
-
to: contracts.SPACE_REGISTRY_ADDRESS,
|
|
65
|
-
value: 0n,
|
|
66
|
-
data: proposalActionCalldata,
|
|
67
|
-
},
|
|
68
|
-
];
|
|
69
|
-
// Encode the proposal data: abi.encode(bytes16 proposalId, VotingMode votingMode, Action[] actions)
|
|
70
|
-
const data = encodeAbiParameters([
|
|
71
|
-
{ type: 'bytes16', name: 'proposalId' },
|
|
72
|
-
{ type: 'uint8', name: 'votingMode' },
|
|
73
|
-
{
|
|
74
|
-
type: 'tuple[]',
|
|
75
|
-
name: 'actions',
|
|
76
|
-
components: [
|
|
77
|
-
{ type: 'address', name: 'to' },
|
|
78
|
-
{ type: 'uint256', name: 'value' },
|
|
79
|
-
{ type: 'bytes', name: 'data' },
|
|
80
|
-
],
|
|
81
|
-
},
|
|
82
|
-
], [proposalId, votingMode === 'FAST' ? 1 : 0, proposalActions]);
|
|
83
|
-
// Convert proposalId to bytes32 for the topic (left-aligned)
|
|
84
|
-
const topic = bytes16ToBytes32LeftAligned(proposalId);
|
|
85
|
-
// Encode the SpaceRegistry.enter() call
|
|
86
|
-
const calldata = encodeFunctionData({
|
|
87
|
-
abi: SpaceRegistryAbi,
|
|
88
|
-
functionName: 'enter',
|
|
89
|
-
args: [
|
|
90
|
-
authorSpaceId, // fromSpaceId
|
|
91
|
-
spaceId, // toSpaceId
|
|
92
|
-
PROPOSAL_CREATED_ACTION, // action
|
|
93
|
-
topic, // topic (proposalId left-aligned to bytes32)
|
|
94
|
-
data, // data (encoded proposal)
|
|
95
|
-
EMPTY_SIGNATURE, // signature (unused when msg.sender == fromSpace)
|
|
96
|
-
],
|
|
97
|
-
});
|
|
98
|
-
return {
|
|
99
|
-
to: contracts.SPACE_REGISTRY_ADDRESS,
|
|
100
|
-
calldata,
|
|
101
|
-
proposalId,
|
|
102
|
-
};
|
|
20
|
+
return createGeoClient({ network: resolveGeoNetwork(network) }).daoSpaces.proposeRemoveEditor(args);
|
|
103
21
|
}
|
|
104
22
|
//# sourceMappingURL=propose-remove-editor.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"propose-remove-editor.js","sourceRoot":"","sources":["../../../src/dao-space/propose-remove-editor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"propose-remove-editor.js","sourceRoot":"","sources":["../../../src/dao-space/propose-remove-editor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAC/C,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAG9D;;;;GAIG;AACH,MAAM,UAAU,mBAAmB,CAAC,MAAiC;IACnE,MAAM,EAAE,OAAO,GAAG,SAAS,EAAE,GAAG,IAAI,EAAE,GAAG,MAAM,CAAC;IAChD,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,EAAE,CAAC;QACtD,MAAM,IAAI,KAAK,CAAC,+DAA+D,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC;IACvG,CAAC;IACD,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC;QAChD,MAAM,IAAI,KAAK,CAAC,yDAAyD,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;IAC3F,CAAC;IACD,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC,EAAE,CAAC;QAC9D,MAAM,IAAI,KAAK,CACb,uEAAuE,IAAI,CAAC,qBAAqB,EAAE,CACpG,CAAC;IACJ,CAAC;IAED,OAAO,eAAe,CAAC,EAAE,OAAO,EAAE,iBAAiB,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;AACtG,CAAC"}
|
|
@@ -6,11 +6,13 @@ describe('proposeRemoveEditor', () => {
|
|
|
6
6
|
// Valid test values
|
|
7
7
|
const validAuthorSpaceId = '0x0eed5491b917cf58b33ac81255fe7ae9';
|
|
8
8
|
const validSpaceId = '0xabcdef12345678901234567890abcdef';
|
|
9
|
+
const validDaoSpaceAddress = '0x1234567890123456789012345678901234567890';
|
|
9
10
|
const validEditorToRemove = '0x11111111111111111111111111111111';
|
|
10
11
|
it('should return correct structure', () => {
|
|
11
12
|
const result = proposeRemoveEditor({
|
|
12
13
|
authorSpaceId: validAuthorSpaceId,
|
|
13
14
|
spaceId: validSpaceId,
|
|
15
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
14
16
|
editorToRemoveSpaceId: validEditorToRemove,
|
|
15
17
|
});
|
|
16
18
|
expect(result).toHaveProperty('to');
|
|
@@ -21,6 +23,7 @@ describe('proposeRemoveEditor', () => {
|
|
|
21
23
|
const { to } = proposeRemoveEditor({
|
|
22
24
|
authorSpaceId: validAuthorSpaceId,
|
|
23
25
|
spaceId: validSpaceId,
|
|
26
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
24
27
|
editorToRemoveSpaceId: validEditorToRemove,
|
|
25
28
|
});
|
|
26
29
|
expect(to).toBe(TESTNET.SPACE_REGISTRY_ADDRESS);
|
|
@@ -29,6 +32,7 @@ describe('proposeRemoveEditor', () => {
|
|
|
29
32
|
const { calldata } = proposeRemoveEditor({
|
|
30
33
|
authorSpaceId: validAuthorSpaceId,
|
|
31
34
|
spaceId: validSpaceId,
|
|
35
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
32
36
|
editorToRemoveSpaceId: validEditorToRemove,
|
|
33
37
|
});
|
|
34
38
|
expect(calldata).toBeTypeOf('string');
|
|
@@ -38,6 +42,7 @@ describe('proposeRemoveEditor', () => {
|
|
|
38
42
|
const { proposalId } = proposeRemoveEditor({
|
|
39
43
|
authorSpaceId: validAuthorSpaceId,
|
|
40
44
|
spaceId: validSpaceId,
|
|
45
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
41
46
|
editorToRemoveSpaceId: validEditorToRemove,
|
|
42
47
|
});
|
|
43
48
|
expect(proposalId).toMatch(BYTES16_HEX_REGEX);
|
|
@@ -47,6 +52,7 @@ describe('proposeRemoveEditor', () => {
|
|
|
47
52
|
const { proposalId } = proposeRemoveEditor({
|
|
48
53
|
authorSpaceId: validAuthorSpaceId,
|
|
49
54
|
spaceId: validSpaceId,
|
|
55
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
50
56
|
editorToRemoveSpaceId: validEditorToRemove,
|
|
51
57
|
proposalId: customProposalId,
|
|
52
58
|
});
|
|
@@ -56,23 +62,25 @@ describe('proposeRemoveEditor', () => {
|
|
|
56
62
|
const result = proposeRemoveEditor({
|
|
57
63
|
authorSpaceId: validAuthorSpaceId,
|
|
58
64
|
spaceId: validSpaceId,
|
|
65
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
59
66
|
editorToRemoveSpaceId: validEditorToRemove,
|
|
60
67
|
});
|
|
61
68
|
expect(result.calldata).toBeTruthy();
|
|
62
69
|
});
|
|
63
|
-
it('should
|
|
64
|
-
|
|
70
|
+
it('should reject FAST voting mode', () => {
|
|
71
|
+
expect(() => proposeRemoveEditor({
|
|
65
72
|
authorSpaceId: validAuthorSpaceId,
|
|
66
73
|
spaceId: validSpaceId,
|
|
74
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
67
75
|
editorToRemoveSpaceId: validEditorToRemove,
|
|
68
76
|
votingMode: 'FAST',
|
|
69
|
-
});
|
|
70
|
-
expect(result.calldata).toBeTruthy();
|
|
77
|
+
})).toThrow('proposeRemoveEditor only supports SLOW voting mode');
|
|
71
78
|
});
|
|
72
79
|
it('should accept explicit SLOW voting mode', () => {
|
|
73
80
|
const params = {
|
|
74
81
|
authorSpaceId: validAuthorSpaceId,
|
|
75
82
|
spaceId: validSpaceId,
|
|
83
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
76
84
|
editorToRemoveSpaceId: validEditorToRemove,
|
|
77
85
|
};
|
|
78
86
|
const slowResult = proposeRemoveEditor({ ...params, votingMode: 'SLOW' });
|
|
@@ -84,12 +92,14 @@ describe('proposeRemoveEditor', () => {
|
|
|
84
92
|
const result1 = proposeRemoveEditor({
|
|
85
93
|
authorSpaceId: validAuthorSpaceId,
|
|
86
94
|
spaceId: validSpaceId,
|
|
95
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
87
96
|
editorToRemoveSpaceId: validEditorToRemove,
|
|
88
97
|
proposalId: sharedProposalId,
|
|
89
98
|
});
|
|
90
99
|
const result2 = proposeRemoveEditor({
|
|
91
100
|
authorSpaceId: validAuthorSpaceId,
|
|
92
101
|
spaceId: validSpaceId,
|
|
102
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
93
103
|
editorToRemoveSpaceId: otherEditor,
|
|
94
104
|
proposalId: sharedProposalId,
|
|
95
105
|
});
|
|
@@ -99,6 +109,7 @@ describe('proposeRemoveEditor', () => {
|
|
|
99
109
|
const result = proposeRemoveEditor({
|
|
100
110
|
authorSpaceId: '0eed5491b917cf58b33ac81255fe7ae9',
|
|
101
111
|
spaceId: 'abcdef12345678901234567890abcdef',
|
|
112
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
102
113
|
editorToRemoveSpaceId: '11111111111111111111111111111111',
|
|
103
114
|
});
|
|
104
115
|
expect(result.calldata).toBeTruthy();
|
|
@@ -108,12 +119,14 @@ describe('proposeRemoveEditor', () => {
|
|
|
108
119
|
const withPrefix = proposeRemoveEditor({
|
|
109
120
|
authorSpaceId: '0x0eed5491b917cf58b33ac81255fe7ae9',
|
|
110
121
|
spaceId: '0xabcdef12345678901234567890abcdef',
|
|
122
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
111
123
|
editorToRemoveSpaceId: '0x11111111111111111111111111111111',
|
|
112
124
|
proposalId,
|
|
113
125
|
});
|
|
114
126
|
const withoutPrefix = proposeRemoveEditor({
|
|
115
127
|
authorSpaceId: '0eed5491b917cf58b33ac81255fe7ae9',
|
|
116
128
|
spaceId: 'abcdef12345678901234567890abcdef',
|
|
129
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
117
130
|
editorToRemoveSpaceId: '11111111111111111111111111111111',
|
|
118
131
|
proposalId,
|
|
119
132
|
});
|
|
@@ -123,6 +136,7 @@ describe('proposeRemoveEditor', () => {
|
|
|
123
136
|
const params = {
|
|
124
137
|
authorSpaceId: validAuthorSpaceId,
|
|
125
138
|
spaceId: validSpaceId,
|
|
139
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
126
140
|
editorToRemoveSpaceId: validEditorToRemove,
|
|
127
141
|
};
|
|
128
142
|
const result1 = proposeRemoveEditor(params);
|
|
@@ -133,6 +147,7 @@ describe('proposeRemoveEditor', () => {
|
|
|
133
147
|
expect(() => proposeRemoveEditor({
|
|
134
148
|
authorSpaceId: 'invalid',
|
|
135
149
|
spaceId: validSpaceId,
|
|
150
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
136
151
|
editorToRemoveSpaceId: validEditorToRemove,
|
|
137
152
|
})).toThrow('authorSpaceId must be bytes16 hex');
|
|
138
153
|
});
|
|
@@ -140,6 +155,7 @@ describe('proposeRemoveEditor', () => {
|
|
|
140
155
|
expect(() => proposeRemoveEditor({
|
|
141
156
|
authorSpaceId: validAuthorSpaceId,
|
|
142
157
|
spaceId: 'tooshort',
|
|
158
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
143
159
|
editorToRemoveSpaceId: validEditorToRemove,
|
|
144
160
|
})).toThrow('spaceId must be bytes16 hex');
|
|
145
161
|
});
|
|
@@ -147,6 +163,7 @@ describe('proposeRemoveEditor', () => {
|
|
|
147
163
|
expect(() => proposeRemoveEditor({
|
|
148
164
|
authorSpaceId: validAuthorSpaceId,
|
|
149
165
|
spaceId: validSpaceId,
|
|
166
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
150
167
|
editorToRemoveSpaceId: 'badid',
|
|
151
168
|
})).toThrow('editorToRemoveSpaceId must be bytes16 hex');
|
|
152
169
|
});
|
|
@@ -154,6 +171,7 @@ describe('proposeRemoveEditor', () => {
|
|
|
154
171
|
expect(() => proposeRemoveEditor({
|
|
155
172
|
authorSpaceId: validAuthorSpaceId,
|
|
156
173
|
spaceId: validSpaceId,
|
|
174
|
+
daoSpaceAddress: validDaoSpaceAddress,
|
|
157
175
|
editorToRemoveSpaceId: validEditorToRemove,
|
|
158
176
|
proposalId: 'badproposalid',
|
|
159
177
|
})).toThrow('proposalId must be bytes16 hex');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"propose-remove-editor.test.js","sourceRoot":"","sources":["../../../src/dao-space/propose-remove-editor.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAE9C,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAC7C,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AAEjE,QAAQ,CAAC,qBAAqB,EAAE,GAAG,EAAE;IACnC,oBAAoB;IACpB,MAAM,kBAAkB,GAAG,oCAA6C,CAAC;IACzE,MAAM,YAAY,GAAG,oCAA6C,CAAC;
|
|
1
|
+
{"version":3,"file":"propose-remove-editor.test.js","sourceRoot":"","sources":["../../../src/dao-space/propose-remove-editor.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,28 +2,7 @@ import type { ProposeRemoveMemberParams, ProposeRemoveMemberResult } from './typ
|
|
|
2
2
|
/**
|
|
3
3
|
* Creates a proposal to remove a member from a DAO space.
|
|
4
4
|
*
|
|
5
|
-
*
|
|
6
|
-
* 1. Validates the author, DAO space, and member IDs
|
|
7
|
-
* 2. Encodes the `removeMember()` call as the proposal action
|
|
8
|
-
* 3. Encodes the SpaceRegistry's `enter()` call with the `PROPOSAL_CREATED` action
|
|
9
|
-
*
|
|
10
|
-
* @param params - The parameters for proposing member removal
|
|
11
|
-
* @returns Object containing `to` (Space Registry address), `calldata`, and `proposalId`
|
|
12
|
-
*
|
|
13
|
-
* @example
|
|
14
|
-
* ```ts
|
|
15
|
-
* import { daoSpace } from '@geoprotocol/geo-sdk';
|
|
16
|
-
*
|
|
17
|
-
* const { to, calldata, proposalId } = daoSpace.proposeRemoveMember({
|
|
18
|
-
* authorSpaceId: '0xAuthorBytes16SpaceId...',
|
|
19
|
-
* spaceId: '0xDAOBytes16SpaceId...',
|
|
20
|
-
* memberToRemoveSpaceId: '0xMemberBytes16SpaceId...',
|
|
21
|
-
* network: 'TESTNET',
|
|
22
|
-
* });
|
|
23
|
-
*
|
|
24
|
-
* // Submit the transaction using viem or another client
|
|
25
|
-
* await walletClient.sendTransaction({ to, data: calldata });
|
|
26
|
-
* ```
|
|
5
|
+
* @deprecated Use `createGeoClient({ network }).daoSpaces.proposeRemoveMember(...)`.
|
|
27
6
|
*/
|
|
28
7
|
export declare function proposeRemoveMember(params: ProposeRemoveMemberParams): ProposeRemoveMemberResult;
|
|
29
8
|
//# sourceMappingURL=propose-remove-member.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"propose-remove-member.d.ts","sourceRoot":"","sources":["../../../src/dao-space/propose-remove-member.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"propose-remove-member.d.ts","sourceRoot":"","sources":["../../../src/dao-space/propose-remove-member.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,yBAAyB,EAAE,yBAAyB,EAAE,MAAM,YAAY,CAAC;AAEvF;;;;GAIG;AACH,wBAAgB,mBAAmB,CAAC,MAAM,EAAE,yBAAyB,GAAG,yBAAyB,CAehG"}
|