cojson 0.0.6 → 0.0.8

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.
Files changed (74) hide show
  1. package/.eslintrc.cjs +11 -8
  2. package/dist/coValue.d.ts +97 -0
  3. package/dist/coValue.js +341 -401
  4. package/dist/coValue.js.map +1 -0
  5. package/dist/coValue.test.d.ts +1 -0
  6. package/dist/coValue.test.js +69 -113
  7. package/dist/coValue.test.js.map +1 -0
  8. package/dist/contentType.d.ts +15 -0
  9. package/dist/contentType.js +5 -5
  10. package/dist/contentType.js.map +1 -0
  11. package/dist/contentType.test.d.ts +1 -0
  12. package/dist/contentType.test.js +138 -168
  13. package/dist/contentType.test.js.map +1 -0
  14. package/dist/contentTypes/coList.d.ts +11 -0
  15. package/dist/contentTypes/coList.js +14 -16
  16. package/dist/contentTypes/coList.js.map +1 -0
  17. package/dist/contentTypes/coMap.d.ts +56 -0
  18. package/dist/contentTypes/coMap.js +112 -112
  19. package/dist/contentTypes/coMap.js.map +1 -0
  20. package/dist/contentTypes/coStream.d.ts +11 -0
  21. package/dist/contentTypes/coStream.js +14 -16
  22. package/dist/contentTypes/coStream.js.map +1 -0
  23. package/dist/contentTypes/static.d.ts +11 -0
  24. package/dist/contentTypes/static.js +12 -14
  25. package/dist/contentTypes/static.js.map +1 -0
  26. package/dist/crypto.d.ts +97 -0
  27. package/dist/crypto.js +100 -151
  28. package/dist/crypto.js.map +1 -0
  29. package/dist/crypto.test.d.ts +1 -0
  30. package/dist/crypto.test.js +94 -134
  31. package/dist/crypto.test.js.map +1 -0
  32. package/dist/ids.d.ts +7 -0
  33. package/dist/ids.js +2 -1
  34. package/dist/ids.js.map +1 -0
  35. package/dist/index.d.ts +19 -0
  36. package/dist/index.js +10 -18
  37. package/dist/index.js.map +1 -0
  38. package/dist/jsonValue.d.ts +7 -0
  39. package/dist/jsonValue.js +2 -1
  40. package/dist/jsonValue.js.map +1 -0
  41. package/dist/node.d.ts +33 -0
  42. package/dist/node.js +102 -133
  43. package/dist/node.js.map +1 -0
  44. package/dist/permissions.d.ts +54 -0
  45. package/dist/permissions.js +202 -228
  46. package/dist/permissions.js.map +1 -0
  47. package/dist/permissions.test.d.ts +1 -0
  48. package/dist/permissions.test.js +724 -915
  49. package/dist/permissions.test.js.map +1 -0
  50. package/dist/sync.d.ts +80 -0
  51. package/dist/sync.js +247 -294
  52. package/dist/sync.js.map +1 -0
  53. package/dist/sync.test.d.ts +1 -0
  54. package/dist/sync.test.js +763 -798
  55. package/dist/sync.test.js.map +1 -0
  56. package/package.json +7 -4
  57. package/src/coValue.test.ts +3 -4
  58. package/src/coValue.ts +11 -17
  59. package/src/contentType.test.ts +3 -3
  60. package/src/contentType.ts +6 -6
  61. package/src/contentTypes/coList.ts +4 -4
  62. package/src/contentTypes/coMap.ts +6 -6
  63. package/src/contentTypes/coStream.ts +4 -4
  64. package/src/contentTypes/static.ts +5 -5
  65. package/src/crypto.test.ts +1 -1
  66. package/src/crypto.ts +2 -2
  67. package/src/index.ts +9 -7
  68. package/src/jsonValue.ts +1 -1
  69. package/src/node.ts +6 -7
  70. package/src/permissions.test.ts +5 -5
  71. package/src/permissions.ts +7 -7
  72. package/src/sync.test.ts +7 -7
  73. package/src/sync.ts +6 -6
  74. package/tsconfig.json +1 -7
@@ -1,244 +1,218 @@
1
- "use strict";
2
- import {
3
- createdNowUnique,
4
- newRandomKeySecret,
5
- seal,
6
- sealKeySecret
7
- } from "./crypto";
8
- import {
9
- agentIDfromSessionID
10
- } from "./coValue";
1
+ import { createdNowUnique, newRandomKeySecret, seal, sealKeySecret, } from './crypto.js';
2
+ import { agentIDfromSessionID, } from './coValue.js';
11
3
  export function determineValidTransactions(coValue) {
12
- if (coValue.header.ruleset.type === "team") {
13
- const allTrustingTransactionsSorted = Object.entries(
14
- coValue.sessions
15
- ).flatMap(([sessionID, sessionLog]) => {
16
- return sessionLog.transactions.map((tx, txIndex) => ({ sessionID, txIndex, tx })).filter(({ tx }) => {
17
- if (tx.privacy === "trusting") {
18
- return true;
19
- } else {
20
- console.warn("Unexpected private transaction in Team");
21
- return false;
4
+ if (coValue.header.ruleset.type === "team") {
5
+ const allTrustingTransactionsSorted = Object.entries(coValue.sessions).flatMap(([sessionID, sessionLog]) => {
6
+ return sessionLog.transactions
7
+ .map((tx, txIndex) => ({ sessionID, txIndex, tx }))
8
+ .filter(({ tx }) => {
9
+ if (tx.privacy === "trusting") {
10
+ return true;
11
+ }
12
+ else {
13
+ console.warn("Unexpected private transaction in Team");
14
+ return false;
15
+ }
16
+ });
17
+ });
18
+ allTrustingTransactionsSorted.sort((a, b) => {
19
+ return a.tx.madeAt - b.tx.madeAt;
20
+ });
21
+ const initialAdmin = coValue.header.ruleset.initialAdmin;
22
+ if (!initialAdmin) {
23
+ throw new Error("Team must have initialAdmin");
22
24
  }
23
- });
24
- });
25
- allTrustingTransactionsSorted.sort((a, b) => {
26
- return a.tx.madeAt - b.tx.madeAt;
27
- });
28
- const initialAdmin = coValue.header.ruleset.initialAdmin;
29
- if (!initialAdmin) {
30
- throw new Error("Team must have initialAdmin");
31
- }
32
- const memberState = {};
33
- const validTransactions = [];
34
- for (const {
35
- sessionID,
36
- txIndex,
37
- tx
38
- } of allTrustingTransactionsSorted) {
39
- const transactor = agentIDfromSessionID(sessionID);
40
- const change = tx.changes[0];
41
- if (tx.changes.length !== 1) {
42
- console.warn("Team transaction must have exactly one change");
43
- continue;
44
- }
45
- if (change.op !== "insert") {
46
- console.warn("Team transaction must set a role or readKey");
47
- continue;
48
- }
49
- if (change.key === "readKey") {
50
- if (memberState[transactor] !== "admin") {
51
- console.warn("Only admins can set readKeys");
52
- continue;
53
- }
54
- validTransactions.push({ txID: { sessionID, txIndex }, tx });
55
- continue;
56
- }
57
- const affectedMember = change.key;
58
- const assignedRole = change.value;
59
- if (change.value !== "admin" && change.value !== "writer" && change.value !== "reader" && change.value !== "revoked") {
60
- console.warn("Team transaction must set a valid role");
61
- continue;
62
- }
63
- const isFirstSelfAppointment = !memberState[transactor] && transactor === initialAdmin && change.op === "insert" && change.key === transactor && change.value === "admin";
64
- if (!isFirstSelfAppointment) {
65
- if (memberState[transactor] !== "admin") {
66
- console.warn(
67
- "Team transaction must be made by current admin"
68
- );
69
- continue;
25
+ const memberState = {};
26
+ const validTransactions = [];
27
+ for (const { sessionID, txIndex, tx, } of allTrustingTransactionsSorted) {
28
+ // console.log("before", { memberState, validTransactions });
29
+ const transactor = agentIDfromSessionID(sessionID);
30
+ const change = tx.changes[0];
31
+ if (tx.changes.length !== 1) {
32
+ console.warn("Team transaction must have exactly one change");
33
+ continue;
34
+ }
35
+ if (change.op !== "insert") {
36
+ console.warn("Team transaction must set a role or readKey");
37
+ continue;
38
+ }
39
+ if (change.key === "readKey") {
40
+ if (memberState[transactor] !== "admin") {
41
+ console.warn("Only admins can set readKeys");
42
+ continue;
43
+ }
44
+ // TODO: check validity of agents who the key is revealed to?
45
+ validTransactions.push({ txID: { sessionID, txIndex }, tx });
46
+ continue;
47
+ }
48
+ const affectedMember = change.key;
49
+ const assignedRole = change.value;
50
+ if (change.value !== "admin" &&
51
+ change.value !== "writer" &&
52
+ change.value !== "reader" &&
53
+ change.value !== "revoked") {
54
+ console.warn("Team transaction must set a valid role");
55
+ continue;
56
+ }
57
+ const isFirstSelfAppointment = !memberState[transactor] &&
58
+ transactor === initialAdmin &&
59
+ change.op === "insert" &&
60
+ change.key === transactor &&
61
+ change.value === "admin";
62
+ if (!isFirstSelfAppointment) {
63
+ if (memberState[transactor] !== "admin") {
64
+ console.warn("Team transaction must be made by current admin");
65
+ continue;
66
+ }
67
+ if (memberState[affectedMember] === "admin" &&
68
+ affectedMember !== transactor &&
69
+ assignedRole !== "admin") {
70
+ console.warn("Admins can only demote themselves.");
71
+ continue;
72
+ }
73
+ }
74
+ memberState[affectedMember] = change.value;
75
+ validTransactions.push({ txID: { sessionID, txIndex }, tx });
76
+ // console.log("after", { memberState, validTransactions });
70
77
  }
71
- if (memberState[affectedMember] === "admin" && affectedMember !== transactor && assignedRole !== "admin") {
72
- console.warn("Admins can only demote themselves.");
73
- continue;
78
+ return validTransactions;
79
+ }
80
+ else if (coValue.header.ruleset.type === "ownedByTeam") {
81
+ const teamContent = coValue.node.expectCoValueLoaded(coValue.header.ruleset.team, "Determining valid transaction in owned object but its team wasn't loaded").getCurrentContent();
82
+ if (teamContent.type !== "comap") {
83
+ throw new Error("Team must be a map");
74
84
  }
75
- }
76
- memberState[affectedMember] = change.value;
77
- validTransactions.push({ txID: { sessionID, txIndex }, tx });
85
+ return Object.entries(coValue.sessions).flatMap(([sessionID, sessionLog]) => {
86
+ const transactor = agentIDfromSessionID(sessionID);
87
+ return sessionLog.transactions
88
+ .filter((tx) => {
89
+ const transactorRoleAtTxTime = teamContent.getAtTime(transactor, tx.madeAt);
90
+ return (transactorRoleAtTxTime === "admin" ||
91
+ transactorRoleAtTxTime === "writer");
92
+ })
93
+ .map((tx, txIndex) => ({
94
+ txID: { sessionID: sessionID, txIndex },
95
+ tx,
96
+ }));
97
+ });
98
+ }
99
+ else if (coValue.header.ruleset.type === "unsafeAllowAll") {
100
+ return Object.entries(coValue.sessions).flatMap(([sessionID, sessionLog]) => {
101
+ return sessionLog.transactions.map((tx, txIndex) => ({
102
+ txID: { sessionID: sessionID, txIndex },
103
+ tx,
104
+ }));
105
+ });
78
106
  }
79
- return validTransactions;
80
- } else if (coValue.header.ruleset.type === "ownedByTeam") {
81
- const teamContent = coValue.node.expectCoValueLoaded(
82
- coValue.header.ruleset.team,
83
- "Determining valid transaction in owned object but its team wasn't loaded"
84
- ).getCurrentContent();
85
- if (teamContent.type !== "comap") {
86
- throw new Error("Team must be a map");
107
+ else if (coValue.header.ruleset.type === "agent") {
108
+ // TODO
109
+ return [];
110
+ }
111
+ else {
112
+ throw new Error("Unknown ruleset type " + coValue.header.ruleset.type);
87
113
  }
88
- return Object.entries(coValue.sessions).flatMap(
89
- ([sessionID, sessionLog]) => {
90
- const transactor = agentIDfromSessionID(sessionID);
91
- return sessionLog.transactions.filter((tx) => {
92
- const transactorRoleAtTxTime = teamContent.getAtTime(
93
- transactor,
94
- tx.madeAt
95
- );
96
- return transactorRoleAtTxTime === "admin" || transactorRoleAtTxTime === "writer";
97
- }).map((tx, txIndex) => ({
98
- txID: { sessionID, txIndex },
99
- tx
100
- }));
101
- }
102
- );
103
- } else if (coValue.header.ruleset.type === "unsafeAllowAll") {
104
- return Object.entries(coValue.sessions).flatMap(
105
- ([sessionID, sessionLog]) => {
106
- return sessionLog.transactions.map((tx, txIndex) => ({
107
- txID: { sessionID, txIndex },
108
- tx
109
- }));
110
- }
111
- );
112
- } else if (coValue.header.ruleset.type === "agent") {
113
- return [];
114
- } else {
115
- throw new Error("Unknown ruleset type " + coValue.header.ruleset.type);
116
- }
117
114
  }
118
115
  export function expectTeamContent(content) {
119
- if (content.type !== "comap") {
120
- throw new Error("Expected map");
121
- }
122
- return content;
116
+ if (content.type !== "comap") {
117
+ throw new Error("Expected map");
118
+ }
119
+ return content;
123
120
  }
124
121
  export class Team {
125
- teamMap;
126
- node;
127
- constructor(teamMap, node) {
128
- this.teamMap = teamMap;
129
- this.node = node;
130
- }
131
- get id() {
132
- return this.teamMap.id;
133
- }
134
- addMember(agentID, role) {
135
- this.teamMap = this.teamMap.edit((map) => {
136
- const agent = this.node.expectAgentLoaded(agentID, "Expected to know agent to add them to team");
137
- if (!agent) {
138
- throw new Error("Unknown agent " + agentID);
139
- }
140
- map.set(agentID, role, "trusting");
141
- if (map.get(agentID) !== role) {
142
- throw new Error("Failed to set role");
143
- }
144
- const currentReadKey = this.teamMap.coValue.getCurrentReadKey();
145
- if (!currentReadKey.secret) {
146
- throw new Error("Can't add member without read key secret");
147
- }
148
- const revelation = seal(
149
- currentReadKey.secret,
150
- this.teamMap.coValue.node.agentCredential.recipientSecret,
151
- /* @__PURE__ */ new Set([agent.recipientID]),
152
- {
153
- in: this.teamMap.coValue.id,
154
- tx: this.teamMap.coValue.nextTransactionID()
155
- }
156
- );
157
- map.set(
158
- "readKey",
159
- { keyID: currentReadKey.id, revelation },
160
- "trusting"
161
- );
162
- });
163
- }
164
- rotateReadKey() {
165
- const currentlyPermittedReaders = this.teamMap.keys().filter((key) => {
166
- if (key.startsWith("co_agent")) {
167
- const role = this.teamMap.get(key);
168
- return role === "admin" || role === "writer" || role === "reader";
169
- } else {
170
- return false;
171
- }
172
- });
173
- const maybeCurrentReadKey = this.teamMap.coValue.getCurrentReadKey();
174
- if (!maybeCurrentReadKey.secret) {
175
- throw new Error("Can't rotate read key secret we don't have access to");
122
+ constructor(teamMap, node) {
123
+ this.teamMap = teamMap;
124
+ this.node = node;
176
125
  }
177
- const currentReadKey = {
178
- id: maybeCurrentReadKey.id,
179
- secret: maybeCurrentReadKey.secret
180
- };
181
- const newReadKey = newRandomKeySecret();
182
- const newReadKeyRevelation = seal(
183
- newReadKey.secret,
184
- this.teamMap.coValue.node.agentCredential.recipientSecret,
185
- new Set(
186
- currentlyPermittedReaders.map(
187
- (reader) => {
126
+ get id() {
127
+ return this.teamMap.id;
128
+ }
129
+ addMember(agentID, role) {
130
+ this.teamMap = this.teamMap.edit((map) => {
131
+ const agent = this.node.expectAgentLoaded(agentID, "Expected to know agent to add them to team");
132
+ if (!agent) {
133
+ throw new Error("Unknown agent " + agentID);
134
+ }
135
+ map.set(agentID, role, "trusting");
136
+ if (map.get(agentID) !== role) {
137
+ throw new Error("Failed to set role");
138
+ }
139
+ const currentReadKey = this.teamMap.coValue.getCurrentReadKey();
140
+ if (!currentReadKey.secret) {
141
+ throw new Error("Can't add member without read key secret");
142
+ }
143
+ const revelation = seal(currentReadKey.secret, this.teamMap.coValue.node.agentCredential.recipientSecret, new Set([agent.recipientID]), {
144
+ in: this.teamMap.coValue.id,
145
+ tx: this.teamMap.coValue.nextTransactionID(),
146
+ });
147
+ map.set("readKey", { keyID: currentReadKey.id, revelation }, "trusting");
148
+ });
149
+ }
150
+ rotateReadKey() {
151
+ const currentlyPermittedReaders = this.teamMap.keys().filter((key) => {
152
+ if (key.startsWith("co_agent")) {
153
+ const role = this.teamMap.get(key);
154
+ return (role === "admin" || role === "writer" || role === "reader");
155
+ }
156
+ else {
157
+ return false;
158
+ }
159
+ });
160
+ const maybeCurrentReadKey = this.teamMap.coValue.getCurrentReadKey();
161
+ if (!maybeCurrentReadKey.secret) {
162
+ throw new Error("Can't rotate read key secret we don't have access to");
163
+ }
164
+ const currentReadKey = {
165
+ id: maybeCurrentReadKey.id,
166
+ secret: maybeCurrentReadKey.secret,
167
+ };
168
+ const newReadKey = newRandomKeySecret();
169
+ const newReadKeyRevelation = seal(newReadKey.secret, this.teamMap.coValue.node.agentCredential.recipientSecret, new Set(currentlyPermittedReaders.map((reader) => {
188
170
  const readerAgent = this.node.expectAgentLoaded(reader, "Expected to know currently permitted reader");
189
171
  if (!readerAgent) {
190
- throw new Error("Unknown agent " + reader);
172
+ throw new Error("Unknown agent " + reader);
191
173
  }
192
174
  return readerAgent.recipientID;
193
- }
194
- )
195
- ),
196
- {
197
- in: this.teamMap.coValue.id,
198
- tx: this.teamMap.coValue.nextTransactionID()
199
- }
200
- );
201
- this.teamMap = this.teamMap.edit((map) => {
202
- map.set(
203
- "readKey",
204
- {
205
- keyID: newReadKey.id,
206
- revelation: newReadKeyRevelation,
207
- previousKeys: {
208
- [currentReadKey.id]: sealKeySecret({
209
- sealing: newReadKey,
210
- toSeal: currentReadKey
211
- }).encrypted
212
- }
213
- },
214
- "trusting"
215
- );
216
- });
217
- }
218
- removeMember(agentID) {
219
- this.teamMap = this.teamMap.edit((map) => {
220
- map.set(agentID, "revoked", "trusting");
221
- });
222
- this.rotateReadKey();
223
- }
224
- createMap(meta) {
225
- return this.node.createCoValue({
226
- type: "comap",
227
- ruleset: {
228
- type: "ownedByTeam",
229
- team: this.teamMap.id
230
- },
231
- meta: meta || null,
232
- ...createdNowUnique(),
233
- publicNickname: "map"
234
- }).getCurrentContent();
235
- }
236
- testWithDifferentCredentials(credential, sessionId) {
237
- return new Team(
238
- expectTeamContent(
239
- this.teamMap.coValue.testWithDifferentCredentials(credential, sessionId).getCurrentContent()
240
- ),
241
- this.node
242
- );
243
- }
175
+ })), {
176
+ in: this.teamMap.coValue.id,
177
+ tx: this.teamMap.coValue.nextTransactionID(),
178
+ });
179
+ this.teamMap = this.teamMap.edit((map) => {
180
+ map.set("readKey", {
181
+ keyID: newReadKey.id,
182
+ revelation: newReadKeyRevelation,
183
+ previousKeys: {
184
+ [currentReadKey.id]: sealKeySecret({
185
+ sealing: newReadKey,
186
+ toSeal: currentReadKey,
187
+ }).encrypted,
188
+ },
189
+ }, "trusting");
190
+ });
191
+ }
192
+ removeMember(agentID) {
193
+ this.teamMap = this.teamMap.edit((map) => {
194
+ map.set(agentID, "revoked", "trusting");
195
+ });
196
+ this.rotateReadKey();
197
+ }
198
+ createMap(meta) {
199
+ return this.node
200
+ .createCoValue({
201
+ type: "comap",
202
+ ruleset: {
203
+ type: "ownedByTeam",
204
+ team: this.teamMap.id,
205
+ },
206
+ meta: meta || null,
207
+ ...createdNowUnique(),
208
+ publicNickname: "map",
209
+ })
210
+ .getCurrentContent();
211
+ }
212
+ testWithDifferentCredentials(credential, sessionId) {
213
+ return new Team(expectTeamContent(this.teamMap.coValue
214
+ .testWithDifferentCredentials(credential, sessionId)
215
+ .getCurrentContent()), this.node);
216
+ }
244
217
  }
218
+ //# sourceMappingURL=permissions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"permissions.js","sourceRoot":"","sources":["../src/permissions.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export {};