cojson 0.7.0-alpha.5 → 0.7.0
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/.eslintrc.cjs +3 -2
- package/.prettierrc.js +9 -0
- package/.turbo/turbo-build.log +3 -30
- package/.turbo/turbo-lint.log +4 -0
- package/.turbo/turbo-test.log +1106 -0
- package/CHANGELOG.md +104 -0
- package/README.md +3 -1
- package/dist/base64url.test.js +25 -0
- package/dist/base64url.test.js.map +1 -0
- package/dist/coValueCore.js +60 -37
- package/dist/coValueCore.js.map +1 -1
- package/dist/coValues/account.js +16 -15
- package/dist/coValues/account.js.map +1 -1
- package/dist/coValues/coList.js +1 -1
- package/dist/coValues/coList.js.map +1 -1
- package/dist/coValues/coMap.js +17 -8
- package/dist/coValues/coMap.js.map +1 -1
- package/dist/coValues/group.js +13 -14
- package/dist/coValues/group.js.map +1 -1
- package/dist/coreToCoValue.js.map +1 -1
- package/dist/crypto/PureJSCrypto.js +89 -0
- package/dist/crypto/PureJSCrypto.js.map +1 -0
- package/dist/crypto/WasmCrypto.js +127 -0
- package/dist/crypto/WasmCrypto.js.map +1 -0
- package/dist/crypto/crypto.js +151 -0
- package/dist/crypto/crypto.js.map +1 -0
- package/dist/ids.js +4 -2
- package/dist/ids.js.map +1 -1
- package/dist/index.js +6 -8
- package/dist/index.js.map +1 -1
- package/dist/jsonStringify.js.map +1 -1
- package/dist/localNode.js +41 -38
- package/dist/localNode.js.map +1 -1
- package/dist/permissions.js +6 -6
- package/dist/permissions.js.map +1 -1
- package/dist/storage/FileSystem.js +61 -0
- package/dist/storage/FileSystem.js.map +1 -0
- package/dist/storage/chunksAndKnownStates.js +97 -0
- package/dist/storage/chunksAndKnownStates.js.map +1 -0
- package/dist/storage/index.js +265 -0
- package/dist/storage/index.js.map +1 -0
- package/dist/sync.js +29 -25
- package/dist/sync.js.map +1 -1
- package/dist/tests/account.test.js +58 -0
- package/dist/tests/account.test.js.map +1 -0
- package/dist/tests/coList.test.js +76 -0
- package/dist/tests/coList.test.js.map +1 -0
- package/dist/tests/coMap.test.js +136 -0
- package/dist/tests/coMap.test.js.map +1 -0
- package/dist/tests/coStream.test.js +172 -0
- package/dist/tests/coStream.test.js.map +1 -0
- package/dist/tests/coValueCore.test.js +114 -0
- package/dist/tests/coValueCore.test.js.map +1 -0
- package/dist/tests/crypto.test.js +118 -0
- package/dist/tests/crypto.test.js.map +1 -0
- package/dist/tests/cryptoImpl.test.js +113 -0
- package/dist/tests/cryptoImpl.test.js.map +1 -0
- package/dist/tests/group.test.js +34 -0
- package/dist/tests/group.test.js.map +1 -0
- package/dist/tests/permissions.test.js +1060 -0
- package/dist/tests/permissions.test.js.map +1 -0
- package/dist/tests/sync.test.js +816 -0
- package/dist/tests/sync.test.js.map +1 -0
- package/dist/tests/testUtils.js +12 -11
- package/dist/tests/testUtils.js.map +1 -1
- package/dist/typeUtils/accountOrAgentIDfromSessionID.js.map +1 -1
- package/dist/typeUtils/isAccountID.js.map +1 -1
- package/dist/typeUtils/isCoValue.js.map +1 -1
- package/package.json +14 -27
- package/src/base64url.test.ts +6 -5
- package/src/coValue.ts +1 -1
- package/src/coValueCore.ts +179 -126
- package/src/coValues/account.ts +30 -32
- package/src/coValues/coList.ts +11 -11
- package/src/coValues/coMap.ts +27 -17
- package/src/coValues/coStream.ts +17 -17
- package/src/coValues/group.ts +93 -109
- package/src/coreToCoValue.ts +5 -2
- package/src/crypto/PureJSCrypto.ts +200 -0
- package/src/crypto/WasmCrypto.ts +259 -0
- package/src/crypto/crypto.ts +336 -0
- package/src/ids.ts +8 -7
- package/src/index.ts +24 -24
- package/src/jsonStringify.ts +6 -4
- package/src/jsonValue.ts +2 -2
- package/src/localNode.ts +103 -109
- package/src/media.ts +3 -3
- package/src/permissions.ts +19 -21
- package/src/storage/FileSystem.ts +152 -0
- package/src/storage/chunksAndKnownStates.ts +139 -0
- package/src/storage/index.ts +479 -0
- package/src/streamUtils.ts +12 -12
- package/src/sync.ts +79 -63
- package/src/tests/account.test.ts +15 -15
- package/src/tests/coList.test.ts +94 -0
- package/src/tests/coMap.test.ts +162 -0
- package/src/tests/coStream.test.ts +246 -0
- package/src/tests/coValueCore.test.ts +36 -37
- package/src/tests/crypto.test.ts +66 -72
- package/src/tests/cryptoImpl.test.ts +183 -0
- package/src/tests/group.test.ts +16 -17
- package/src/tests/permissions.test.ts +269 -283
- package/src/tests/sync.test.ts +122 -123
- package/src/tests/testUtils.ts +24 -21
- package/src/typeUtils/accountOrAgentIDfromSessionID.ts +1 -2
- package/src/typeUtils/expectGroup.ts +1 -1
- package/src/typeUtils/isAccountID.ts +0 -1
- package/src/typeUtils/isCoValue.ts +1 -2
- package/tsconfig.json +0 -1
- package/dist/crypto.js +0 -254
- package/dist/crypto.js.map +0 -1
- package/src/crypto.ts +0 -484
- package/src/tests/coValue.test.ts +0 -497
package/dist/coValues/coMap.js
CHANGED
|
@@ -59,13 +59,22 @@ export class RawCoMapView {
|
|
|
59
59
|
*
|
|
60
60
|
* @category 1. Reading */
|
|
61
61
|
keys() {
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
62
|
+
return Object.keys(this.ops).filter((key) => {
|
|
63
|
+
const ops = this.ops[key];
|
|
64
|
+
if (!ops) {
|
|
65
|
+
return undefined;
|
|
66
|
+
}
|
|
67
|
+
const includeUntil = this.atTimeFilter;
|
|
68
|
+
const lastEntry = includeUntil
|
|
69
|
+
? ops.findLast((entry) => entry.madeAt <= includeUntil)
|
|
70
|
+
: ops[ops.length - 1];
|
|
71
|
+
if (lastEntry?.op === "del") {
|
|
72
|
+
return false;
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
return true;
|
|
76
|
+
}
|
|
77
|
+
});
|
|
69
78
|
}
|
|
70
79
|
/**
|
|
71
80
|
* Returns the current value for the given key.
|
|
@@ -73,7 +82,7 @@ export class RawCoMapView {
|
|
|
73
82
|
* @category 1. Reading
|
|
74
83
|
**/
|
|
75
84
|
get(key) {
|
|
76
|
-
const ops = this.
|
|
85
|
+
const ops = this.ops[key];
|
|
77
86
|
if (!ops) {
|
|
78
87
|
return undefined;
|
|
79
88
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"coMap.js","sourceRoot":"","sources":["../../src/coValues/coMap.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAC;AAEtD,OAAO,EAAE,6BAA6B,EAAE,MAAM,+CAA+C,CAAC;AAsB9F,MAAM,OAAO,YAAY;IAsBrB,gBAAgB;IAChB,YACI,IAAiB,EACjB,OAA6C;QAhBjD,wBAAwB;QACxB,SAAI,GAAG,OAAgB,CAAC;QAOxB,gBAAgB;QAChB,iBAAY,GAAY,SAAS,CAAC;QAS9B,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAgB,CAAC;QAChC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,GAAG,GAAG,EAAE,CAAC;QAEd,KAAK,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI,IAAI,CAAC,0BAA0B,CACnE,OAAO,CACV,EAAE;YACC,KAAK,MAAM,CAAC,SAAS,EAAE,aAAa,CAAC,IAAI,OAAO,CAAC,OAAO,EAAE,EAAE;gBACxD,MAAM,MAAM,GAAG,aAGd,CAAC;gBACF,IAAI,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;gBACnC,IAAI,CAAC,OAAO,EAAE;oBACV,OAAO,GAAG,EAAE,CAAC;oBACb,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC;iBAClC;gBACD,OAAO,CAAC,IAAI,CAAC;oBACT,IAAI;oBACJ,MAAM;oBACN,SAAS;oBACT,GAAI,MAGF;iBACL,CAAC,CAAC;aACN;SACJ;IACL,CAAC;IAED,wBAAwB;IACxB,IAAI,UAAU;QACV,OAAO,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAY,CAAC;IACzC,CAAC;IAED,wBAAwB;IACxB,IAAI,KAAK;QACL,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;IAChC,CAAC;IAED,+BAA+B;IAC/B,MAAM,CAAC,IAAY;QACf,MAAM,KAAK,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAS,CAAC;QAC1C,KAAK,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,CAAC;QACnB,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;QACvB,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;QACvB,KAAK,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC;QACrB,KAAK,CAAC,YAAY,GAAG,IAAI,CAAC;QAC1B,OAAO,KAAK,CAAC;IACjB,CAAC;IAED,gBAAgB;IAChB,eAAe,CACX,GAAM;QAEN,IAAI,IAAI,CAAC,YAAY,EAAE;YACnB,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,MAAM,CACxB,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,MAAM,IAAI,IAAI,CAAC,YAAa,CAC1C,CAAC;SACL;aAAM;YACH,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;SACxB;IACL,CAAC;IAED;;;8BAG0B;IAC1B,IAAI;QACA,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,
|
|
1
|
+
{"version":3,"file":"coMap.js","sourceRoot":"","sources":["../../src/coValues/coMap.ts"],"names":[],"mappings":"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"}
|
package/dist/coValues/group.js
CHANGED
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import { RawCoMap } from "./coMap.js";
|
|
2
|
-
import { createdNowUnique, newRandomKeySecret, seal, encryptKeySecret, getAgentSealerID, newRandomSecretSeed, agentSecretFromSecretSeed, getAgentID, } from "../crypto.js";
|
|
3
2
|
import { isAgentID } from "../ids.js";
|
|
4
3
|
import { base58 } from "@scure/base";
|
|
5
4
|
export const EVERYONE = "everyone";
|
|
@@ -79,10 +78,10 @@ export class RawGroup extends RawCoMap {
|
|
|
79
78
|
if (this.get(memberKey) !== role) {
|
|
80
79
|
throw new Error("Failed to set role");
|
|
81
80
|
}
|
|
82
|
-
this.set(`${currentReadKey.id}_for_${memberKey}`, seal({
|
|
81
|
+
this.set(`${currentReadKey.id}_for_${memberKey}`, this.core.crypto.seal({
|
|
83
82
|
message: currentReadKey.secret,
|
|
84
83
|
from: this.core.node.account.currentSealerSecret(),
|
|
85
|
-
to: getAgentSealerID(agent),
|
|
84
|
+
to: this.core.crypto.getAgentSealerID(agent),
|
|
86
85
|
nOnceMaterial: {
|
|
87
86
|
in: this.id,
|
|
88
87
|
tx: this.core.nextTransactionID(),
|
|
@@ -109,20 +108,20 @@ export class RawGroup extends RawCoMap {
|
|
|
109
108
|
id: maybeCurrentReadKey.id,
|
|
110
109
|
secret: maybeCurrentReadKey.secret,
|
|
111
110
|
};
|
|
112
|
-
const newReadKey = newRandomKeySecret();
|
|
111
|
+
const newReadKey = this.core.crypto.newRandomKeySecret();
|
|
113
112
|
for (const readerID of currentlyPermittedReaders) {
|
|
114
113
|
const reader = this.core.node.resolveAccountAgent(readerID, "Expected to know currently permitted reader");
|
|
115
|
-
this.set(`${newReadKey.id}_for_${readerID}`, seal({
|
|
114
|
+
this.set(`${newReadKey.id}_for_${readerID}`, this.core.crypto.seal({
|
|
116
115
|
message: newReadKey.secret,
|
|
117
116
|
from: this.core.node.account.currentSealerSecret(),
|
|
118
|
-
to: getAgentSealerID(reader),
|
|
117
|
+
to: this.core.crypto.getAgentSealerID(reader),
|
|
119
118
|
nOnceMaterial: {
|
|
120
119
|
in: this.id,
|
|
121
120
|
tx: this.core.nextTransactionID(),
|
|
122
121
|
},
|
|
123
122
|
}), "trusting");
|
|
124
123
|
}
|
|
125
|
-
this.set(`${currentReadKey.id}_for_${newReadKey.id}`, encryptKeySecret({
|
|
124
|
+
this.set(`${currentReadKey.id}_for_${newReadKey.id}`, this.core.crypto.encryptKeySecret({
|
|
126
125
|
encrypting: newReadKey,
|
|
127
126
|
toEncrypt: currentReadKey,
|
|
128
127
|
}).encrypted, "trusting");
|
|
@@ -152,9 +151,9 @@ export class RawGroup extends RawCoMap {
|
|
|
152
151
|
* @category 2. Role changing
|
|
153
152
|
*/
|
|
154
153
|
createInvite(role) {
|
|
155
|
-
const secretSeed = newRandomSecretSeed();
|
|
156
|
-
const inviteSecret = agentSecretFromSecretSeed(secretSeed);
|
|
157
|
-
const inviteID = getAgentID(inviteSecret);
|
|
154
|
+
const secretSeed = this.core.crypto.newRandomSecretSeed();
|
|
155
|
+
const inviteSecret = this.core.crypto.agentSecretFromSecretSeed(secretSeed);
|
|
156
|
+
const inviteID = this.core.crypto.getAgentID(inviteSecret);
|
|
158
157
|
this.addMemberInternal(inviteID, `${role}Invite`);
|
|
159
158
|
return inviteSecretFromSecretSeed(secretSeed);
|
|
160
159
|
}
|
|
@@ -173,7 +172,7 @@ export class RawGroup extends RawCoMap {
|
|
|
173
172
|
group: this.id,
|
|
174
173
|
},
|
|
175
174
|
meta: meta || null,
|
|
176
|
-
...createdNowUnique(),
|
|
175
|
+
...this.core.crypto.createdNowUnique(),
|
|
177
176
|
})
|
|
178
177
|
.getCurrentContent();
|
|
179
178
|
if (init) {
|
|
@@ -198,7 +197,7 @@ export class RawGroup extends RawCoMap {
|
|
|
198
197
|
group: this.id,
|
|
199
198
|
},
|
|
200
199
|
meta: meta || null,
|
|
201
|
-
...createdNowUnique(),
|
|
200
|
+
...this.core.crypto.createdNowUnique(),
|
|
202
201
|
})
|
|
203
202
|
.getCurrentContent();
|
|
204
203
|
if (init) {
|
|
@@ -218,7 +217,7 @@ export class RawGroup extends RawCoMap {
|
|
|
218
217
|
group: this.id,
|
|
219
218
|
},
|
|
220
219
|
meta: meta || null,
|
|
221
|
-
...createdNowUnique(),
|
|
220
|
+
...this.core.crypto.createdNowUnique(),
|
|
222
221
|
})
|
|
223
222
|
.getCurrentContent();
|
|
224
223
|
}
|
|
@@ -232,7 +231,7 @@ export class RawGroup extends RawCoMap {
|
|
|
232
231
|
group: this.id,
|
|
233
232
|
},
|
|
234
233
|
meta: meta,
|
|
235
|
-
...createdNowUnique(),
|
|
234
|
+
...this.core.crypto.createdNowUnique(),
|
|
236
235
|
})
|
|
237
236
|
.getCurrentContent();
|
|
238
237
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"group.js","sourceRoot":"","sources":["../../src/coValues/group.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;
|
|
1
|
+
{"version":3,"file":"group.js","sourceRoot":"","sources":["../../src/coValues/group.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"coreToCoValue.js","sourceRoot":"","sources":["../src/coreToCoValue.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,oBAAoB,EAAE,MAAM,uBAAuB,CAAC;AACzE,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAC/C,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AACrD,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAE3D,MAAM,UAAU,aAAa,CACzB,IAAiB,EACjB,OAA6C;IAE7C,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,OAAO,EAAE;QAC9B,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,KAAK,OAAO,EAAE;YACtC,IACI,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,KAAK,SAAS;gBACpC,CAAC,OAAO,EAAE,yBAAyB,EACrC;gBACE,IAAI,IAAI,CAAC,EAAE,KAAK,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,EAAE;oBAClC,OAAO,IAAI,oBAAoB,
|
|
1
|
+
{"version":3,"file":"coreToCoValue.js","sourceRoot":"","sources":["../src/coreToCoValue.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,oBAAoB,EAAE,MAAM,uBAAuB,CAAC;AACzE,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAC/C,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AACrD,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAE3D,MAAM,UAAU,aAAa,CACzB,IAAiB,EACjB,OAA6C;IAE7C,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,OAAO,EAAE;QAC9B,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,KAAK,OAAO,EAAE;YACtC,IACI,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,KAAK,SAAS;gBACpC,CAAC,OAAO,EAAE,yBAAyB,EACrC;gBACE,IAAI,IAAI,CAAC,EAAE,KAAK,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,EAAE;oBAClC,OAAO,IAAI,oBAAoB,CAC3B,IAAI,EACJ,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,CAChC,CAAC;iBACL;qBAAM;oBACH,OAAO,IAAI,UAAU,CAAC,IAAI,CAAC,CAAC;iBAC/B;aACJ;iBAAM;gBACH,OAAO,IAAI,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;aACtC;SACJ;aAAM;YACH,OAAO,IAAI,QAAQ,CAAC,IAAI,CAAC,CAAC;SAC7B;KACJ;SAAM,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,QAAQ,EAAE;QACtC,OAAO,IAAI,SAAS,CAAC,IAAI,CAAC,CAAC;KAC9B;SAAM,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,UAAU,EAAE;QACxC,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,KAAK,QAAQ,EAAE;YACxD,OAAO,IAAI,iBAAiB,CAAC,IAAI,CAAC,CAAC;SACtC;aAAM;YACH,OAAO,IAAI,WAAW,CAAC,IAAI,CAAC,CAAC;SAChC;KACJ;SAAM;QACH,MAAM,IAAI,KAAK,CAAC,wBAAwB,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC;KAC/D;AACL,CAAC"}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import { ed25519, x25519 } from "@noble/curves/ed25519";
|
|
2
|
+
import { xsalsa20_poly1305, xsalsa20 } from "@noble/ciphers/salsa";
|
|
3
|
+
import { base58 } from "@scure/base";
|
|
4
|
+
import { randomBytes } from "@noble/ciphers/webcrypto/utils";
|
|
5
|
+
import { base64URLtoBytes, bytesToBase64url } from "../base64url.js";
|
|
6
|
+
import { stableStringify } from "../jsonStringify.js";
|
|
7
|
+
import { blake3 } from "@noble/hashes/blake3";
|
|
8
|
+
import { CryptoProvider, textEncoder, textDecoder, } from "./crypto.js";
|
|
9
|
+
export class PureJSCrypto extends CryptoProvider {
|
|
10
|
+
static async create() {
|
|
11
|
+
return new PureJSCrypto();
|
|
12
|
+
}
|
|
13
|
+
randomBytes(length) {
|
|
14
|
+
return randomBytes(length);
|
|
15
|
+
}
|
|
16
|
+
emptyBlake3State() {
|
|
17
|
+
return blake3.create({});
|
|
18
|
+
}
|
|
19
|
+
blake3HashOnce(data) {
|
|
20
|
+
return blake3(data);
|
|
21
|
+
}
|
|
22
|
+
blake3HashOnceWithContext(data, { context }) {
|
|
23
|
+
return blake3.create({}).update(context).update(data).digest();
|
|
24
|
+
}
|
|
25
|
+
blake3IncrementalUpdate(state, data) {
|
|
26
|
+
return state.update(data);
|
|
27
|
+
}
|
|
28
|
+
blake3DigestForState(state) {
|
|
29
|
+
return state.clone().digest();
|
|
30
|
+
}
|
|
31
|
+
newEd25519SigningKey() {
|
|
32
|
+
return ed25519.utils.randomPrivateKey();
|
|
33
|
+
}
|
|
34
|
+
getSignerID(secret) {
|
|
35
|
+
return `signer_z${base58.encode(ed25519.getPublicKey(base58.decode(secret.substring("signerSecret_z".length))))}`;
|
|
36
|
+
}
|
|
37
|
+
sign(secret, message) {
|
|
38
|
+
const signature = ed25519.sign(textEncoder.encode(stableStringify(message)), base58.decode(secret.substring("signerSecret_z".length)));
|
|
39
|
+
return `signature_z${base58.encode(signature)}`;
|
|
40
|
+
}
|
|
41
|
+
verify(signature, message, id) {
|
|
42
|
+
return ed25519.verify(base58.decode(signature.substring("signature_z".length)), textEncoder.encode(stableStringify(message)), base58.decode(id.substring("signer_z".length)));
|
|
43
|
+
}
|
|
44
|
+
newX25519StaticSecret() {
|
|
45
|
+
return x25519.utils.randomPrivateKey();
|
|
46
|
+
}
|
|
47
|
+
getSealerID(secret) {
|
|
48
|
+
return `sealer_z${base58.encode(x25519.getPublicKey(base58.decode(secret.substring("sealerSecret_z".length))))}`;
|
|
49
|
+
}
|
|
50
|
+
encrypt(value, keySecret, nOnceMaterial) {
|
|
51
|
+
const keySecretBytes = base58.decode(keySecret.substring("keySecret_z".length));
|
|
52
|
+
const nOnce = this.blake3HashOnce(textEncoder.encode(stableStringify(nOnceMaterial))).slice(0, 24);
|
|
53
|
+
const plaintext = textEncoder.encode(stableStringify(value));
|
|
54
|
+
const ciphertext = xsalsa20(keySecretBytes, nOnce, plaintext);
|
|
55
|
+
return `encrypted_U${bytesToBase64url(ciphertext)}`;
|
|
56
|
+
}
|
|
57
|
+
decryptRaw(encrypted, keySecret, nOnceMaterial) {
|
|
58
|
+
const keySecretBytes = base58.decode(keySecret.substring("keySecret_z".length));
|
|
59
|
+
const nOnce = this.blake3HashOnce(textEncoder.encode(stableStringify(nOnceMaterial))).slice(0, 24);
|
|
60
|
+
const ciphertext = base64URLtoBytes(encrypted.substring("encrypted_U".length));
|
|
61
|
+
const plaintext = xsalsa20(keySecretBytes, nOnce, ciphertext);
|
|
62
|
+
return textDecoder.decode(plaintext);
|
|
63
|
+
}
|
|
64
|
+
seal({ message, from, to, nOnceMaterial, }) {
|
|
65
|
+
const nOnce = this.blake3HashOnce(textEncoder.encode(stableStringify(nOnceMaterial))).slice(0, 24);
|
|
66
|
+
const sealerPub = base58.decode(to.substring("sealer_z".length));
|
|
67
|
+
const senderPriv = base58.decode(from.substring("sealerSecret_z".length));
|
|
68
|
+
const plaintext = textEncoder.encode(stableStringify(message));
|
|
69
|
+
const sharedSecret = x25519.getSharedSecret(senderPriv, sealerPub);
|
|
70
|
+
const sealedBytes = xsalsa20_poly1305(sharedSecret, nOnce).encrypt(plaintext);
|
|
71
|
+
return `sealed_U${bytesToBase64url(sealedBytes)}`;
|
|
72
|
+
}
|
|
73
|
+
unseal(sealed, sealer, from, nOnceMaterial) {
|
|
74
|
+
const nOnce = this.blake3HashOnce(textEncoder.encode(stableStringify(nOnceMaterial))).slice(0, 24);
|
|
75
|
+
const sealerPriv = base58.decode(sealer.substring("sealerSecret_z".length));
|
|
76
|
+
const senderPub = base58.decode(from.substring("sealer_z".length));
|
|
77
|
+
const sealedBytes = base64URLtoBytes(sealed.substring("sealed_U".length));
|
|
78
|
+
const sharedSecret = x25519.getSharedSecret(sealerPriv, senderPub);
|
|
79
|
+
const plaintext = xsalsa20_poly1305(sharedSecret, nOnce).decrypt(sealedBytes);
|
|
80
|
+
try {
|
|
81
|
+
return JSON.parse(textDecoder.decode(plaintext));
|
|
82
|
+
}
|
|
83
|
+
catch (e) {
|
|
84
|
+
console.error("Failed to decrypt/parse sealed message", e);
|
|
85
|
+
return undefined;
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
//# sourceMappingURL=PureJSCrypto.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PureJSCrypto.js","sourceRoot":"","sources":["../../src/crypto/PureJSCrypto.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import { initBundledOnce, Ed25519SigningKey, Ed25519VerifyingKey, X25519StaticSecret, Memory, Ed25519Signature, X25519PublicKey, } from "@hazae41/berith";
|
|
2
|
+
import { xsalsa20_poly1305, xsalsa20 } from "@noble/ciphers/salsa";
|
|
3
|
+
import { base58 } from "@scure/base";
|
|
4
|
+
import { randomBytes } from "@noble/ciphers/webcrypto/utils";
|
|
5
|
+
import { base64URLtoBytes, bytesToBase64url } from "../base64url.js";
|
|
6
|
+
import { createBLAKE3 } from "hash-wasm";
|
|
7
|
+
import { stableStringify } from "../jsonStringify.js";
|
|
8
|
+
import { CryptoProvider, textEncoder, textDecoder, } from "./crypto.js";
|
|
9
|
+
export class WasmCrypto extends CryptoProvider {
|
|
10
|
+
constructor(blake3Instance) {
|
|
11
|
+
super();
|
|
12
|
+
this.blake3Instance = blake3Instance;
|
|
13
|
+
}
|
|
14
|
+
static async create() {
|
|
15
|
+
return Promise.all([
|
|
16
|
+
createBLAKE3(),
|
|
17
|
+
initBundledOnce(),
|
|
18
|
+
new Promise((resolve) => {
|
|
19
|
+
if ("crypto" in globalThis) {
|
|
20
|
+
resolve();
|
|
21
|
+
}
|
|
22
|
+
else {
|
|
23
|
+
return import("node:crypto").then(({ webcrypto }) => {
|
|
24
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
25
|
+
globalThis.crypto = webcrypto;
|
|
26
|
+
resolve();
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
}),
|
|
30
|
+
]).then(([blake3instance]) => new WasmCrypto(blake3instance));
|
|
31
|
+
}
|
|
32
|
+
randomBytes(length) {
|
|
33
|
+
return randomBytes(length);
|
|
34
|
+
}
|
|
35
|
+
emptyBlake3State() {
|
|
36
|
+
return this.blake3Instance.init().save();
|
|
37
|
+
}
|
|
38
|
+
blake3HashOnce(data) {
|
|
39
|
+
return this.blake3Instance.init().update(data).digest("binary");
|
|
40
|
+
}
|
|
41
|
+
blake3HashOnceWithContext(data, { context }) {
|
|
42
|
+
return this.blake3Instance
|
|
43
|
+
.init()
|
|
44
|
+
.update(context)
|
|
45
|
+
.update(data)
|
|
46
|
+
.digest("binary");
|
|
47
|
+
}
|
|
48
|
+
blake3IncrementalUpdate(state, data) {
|
|
49
|
+
return this.blake3Instance.load(state).update(data).save();
|
|
50
|
+
}
|
|
51
|
+
blake3DigestForState(state) {
|
|
52
|
+
return this.blake3Instance.load(state).digest("binary");
|
|
53
|
+
}
|
|
54
|
+
newEd25519SigningKey() {
|
|
55
|
+
return new Ed25519SigningKey().to_bytes().copyAndDispose();
|
|
56
|
+
}
|
|
57
|
+
getSignerID(secret) {
|
|
58
|
+
return `signer_z${base58.encode(Ed25519SigningKey.from_bytes(new Memory(base58.decode(secret.substring("signerSecret_z".length))))
|
|
59
|
+
.public()
|
|
60
|
+
.to_bytes()
|
|
61
|
+
.copyAndDispose())}`;
|
|
62
|
+
}
|
|
63
|
+
sign(secret, message) {
|
|
64
|
+
const signature = Ed25519SigningKey.from_bytes(new Memory(base58.decode(secret.substring("signerSecret_z".length))))
|
|
65
|
+
.sign(new Memory(textEncoder.encode(stableStringify(message))))
|
|
66
|
+
.to_bytes()
|
|
67
|
+
.copyAndDispose();
|
|
68
|
+
return `signature_z${base58.encode(signature)}`;
|
|
69
|
+
}
|
|
70
|
+
verify(signature, message, id) {
|
|
71
|
+
return new Ed25519VerifyingKey(new Memory(base58.decode(id.substring("signer_z".length)))).verify(new Memory(textEncoder.encode(stableStringify(message))), new Ed25519Signature(new Memory(base58.decode(signature.substring("signature_z".length)))));
|
|
72
|
+
}
|
|
73
|
+
newX25519StaticSecret() {
|
|
74
|
+
return new X25519StaticSecret().to_bytes().copyAndDispose();
|
|
75
|
+
}
|
|
76
|
+
getSealerID(secret) {
|
|
77
|
+
return `sealer_z${base58.encode(X25519StaticSecret.from_bytes(new Memory(base58.decode(secret.substring("sealerSecret_z".length))))
|
|
78
|
+
.to_public()
|
|
79
|
+
.to_bytes()
|
|
80
|
+
.copyAndDispose())}`;
|
|
81
|
+
}
|
|
82
|
+
encrypt(value, keySecret, nOnceMaterial) {
|
|
83
|
+
const keySecretBytes = base58.decode(keySecret.substring("keySecret_z".length));
|
|
84
|
+
const nOnce = this.blake3HashOnce(textEncoder.encode(stableStringify(nOnceMaterial))).slice(0, 24);
|
|
85
|
+
const plaintext = textEncoder.encode(stableStringify(value));
|
|
86
|
+
const ciphertext = xsalsa20(keySecretBytes, nOnce, plaintext);
|
|
87
|
+
return `encrypted_U${bytesToBase64url(ciphertext)}`;
|
|
88
|
+
}
|
|
89
|
+
decryptRaw(encrypted, keySecret, nOnceMaterial) {
|
|
90
|
+
const keySecretBytes = base58.decode(keySecret.substring("keySecret_z".length));
|
|
91
|
+
const nOnce = this.blake3HashOnce(textEncoder.encode(stableStringify(nOnceMaterial))).slice(0, 24);
|
|
92
|
+
const ciphertext = base64URLtoBytes(encrypted.substring("encrypted_U".length));
|
|
93
|
+
const plaintext = xsalsa20(keySecretBytes, nOnce, ciphertext);
|
|
94
|
+
return textDecoder.decode(plaintext);
|
|
95
|
+
}
|
|
96
|
+
seal({ message, from, to, nOnceMaterial, }) {
|
|
97
|
+
const nOnce = this.blake3HashOnce(textEncoder.encode(stableStringify(nOnceMaterial))).slice(0, 24);
|
|
98
|
+
const sealerPub = base58.decode(to.substring("sealer_z".length));
|
|
99
|
+
const senderPriv = base58.decode(from.substring("sealerSecret_z".length));
|
|
100
|
+
const plaintext = textEncoder.encode(stableStringify(message));
|
|
101
|
+
const sharedSecret = X25519StaticSecret.from_bytes(new Memory(senderPriv))
|
|
102
|
+
.diffie_hellman(X25519PublicKey.from_bytes(new Memory(sealerPub)))
|
|
103
|
+
.to_bytes()
|
|
104
|
+
.copyAndDispose();
|
|
105
|
+
const sealedBytes = xsalsa20_poly1305(sharedSecret, nOnce).encrypt(plaintext);
|
|
106
|
+
return `sealed_U${bytesToBase64url(sealedBytes)}`;
|
|
107
|
+
}
|
|
108
|
+
unseal(sealed, sealer, from, nOnceMaterial) {
|
|
109
|
+
const nOnce = this.blake3HashOnce(textEncoder.encode(stableStringify(nOnceMaterial))).slice(0, 24);
|
|
110
|
+
const sealerPriv = base58.decode(sealer.substring("sealerSecret_z".length));
|
|
111
|
+
const senderPub = base58.decode(from.substring("sealer_z".length));
|
|
112
|
+
const sealedBytes = base64URLtoBytes(sealed.substring("sealed_U".length));
|
|
113
|
+
const sharedSecret = X25519StaticSecret.from_bytes(new Memory(sealerPriv))
|
|
114
|
+
.diffie_hellman(X25519PublicKey.from_bytes(new Memory(senderPub)))
|
|
115
|
+
.to_bytes()
|
|
116
|
+
.copyAndDispose();
|
|
117
|
+
const plaintext = xsalsa20_poly1305(sharedSecret, nOnce).decrypt(sealedBytes);
|
|
118
|
+
try {
|
|
119
|
+
return JSON.parse(textDecoder.decode(plaintext));
|
|
120
|
+
}
|
|
121
|
+
catch (e) {
|
|
122
|
+
console.error("Failed to decrypt/parse sealed message", e);
|
|
123
|
+
return undefined;
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
//# sourceMappingURL=WasmCrypto.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"WasmCrypto.js","sourceRoot":"","sources":["../../src/crypto/WasmCrypto.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
import { base58 } from "@scure/base";
|
|
2
|
+
import { parseJSON, stableStringify } from "../jsonStringify.js";
|
|
3
|
+
export const textEncoder = new TextEncoder();
|
|
4
|
+
export const textDecoder = new TextDecoder();
|
|
5
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
6
|
+
export class CryptoProvider {
|
|
7
|
+
newRandomSigner() {
|
|
8
|
+
return `signerSecret_z${base58.encode(this.newEd25519SigningKey())}`;
|
|
9
|
+
}
|
|
10
|
+
signerSecretToBytes(secret) {
|
|
11
|
+
return base58.decode(secret.substring("signerSecret_z".length));
|
|
12
|
+
}
|
|
13
|
+
signerSecretFromBytes(bytes) {
|
|
14
|
+
return `signerSecret_z${base58.encode(bytes)}`;
|
|
15
|
+
}
|
|
16
|
+
newRandomSealer() {
|
|
17
|
+
return `sealerSecret_z${base58.encode(this.newX25519StaticSecret())}`;
|
|
18
|
+
}
|
|
19
|
+
sealerSecretToBytes(secret) {
|
|
20
|
+
return base58.decode(secret.substring("sealerSecret_z".length));
|
|
21
|
+
}
|
|
22
|
+
sealerSecretFromBytes(bytes) {
|
|
23
|
+
return `sealerSecret_z${base58.encode(bytes)}`;
|
|
24
|
+
}
|
|
25
|
+
newRandomAgentSecret() {
|
|
26
|
+
return `${this.newRandomSealer()}/${this.newRandomSigner()}`;
|
|
27
|
+
}
|
|
28
|
+
agentSecretToBytes(secret) {
|
|
29
|
+
const [sealerSecret, signerSecret] = secret.split("/");
|
|
30
|
+
return new Uint8Array([
|
|
31
|
+
...this.sealerSecretToBytes(sealerSecret),
|
|
32
|
+
...this.signerSecretToBytes(signerSecret),
|
|
33
|
+
]);
|
|
34
|
+
}
|
|
35
|
+
agentSecretFromBytes(bytes) {
|
|
36
|
+
const sealerSecret = this.sealerSecretFromBytes(bytes.slice(0, 32));
|
|
37
|
+
const signerSecret = this.signerSecretFromBytes(bytes.slice(32));
|
|
38
|
+
return `${sealerSecret}/${signerSecret}`;
|
|
39
|
+
}
|
|
40
|
+
getAgentID(secret) {
|
|
41
|
+
const [sealerSecret, signerSecret] = secret.split("/");
|
|
42
|
+
return `${this.getSealerID(sealerSecret)}/${this.getSignerID(signerSecret)}`;
|
|
43
|
+
}
|
|
44
|
+
getAgentSignerID(agentId) {
|
|
45
|
+
return agentId.split("/")[1];
|
|
46
|
+
}
|
|
47
|
+
getAgentSignerSecret(agentSecret) {
|
|
48
|
+
return agentSecret.split("/")[1];
|
|
49
|
+
}
|
|
50
|
+
getAgentSealerID(agentId) {
|
|
51
|
+
return agentId.split("/")[0];
|
|
52
|
+
}
|
|
53
|
+
getAgentSealerSecret(agentSecret) {
|
|
54
|
+
return agentSecret.split("/")[0];
|
|
55
|
+
}
|
|
56
|
+
secureHash(value) {
|
|
57
|
+
return `hash_z${base58.encode(this.blake3HashOnce(textEncoder.encode(stableStringify(value))))}`;
|
|
58
|
+
}
|
|
59
|
+
shortHash(value) {
|
|
60
|
+
return `shortHash_z${base58.encode(this.blake3HashOnce(textEncoder.encode(stableStringify(value))).slice(0, shortHashLength))}`;
|
|
61
|
+
}
|
|
62
|
+
encryptForTransaction(value, keySecret, nOnceMaterial) {
|
|
63
|
+
return this.encrypt(value, keySecret, nOnceMaterial);
|
|
64
|
+
}
|
|
65
|
+
decrypt(encrypted, keySecret, nOnceMaterial) {
|
|
66
|
+
try {
|
|
67
|
+
return parseJSON(this.decryptRaw(encrypted, keySecret, nOnceMaterial));
|
|
68
|
+
}
|
|
69
|
+
catch (e) {
|
|
70
|
+
console.error("Decryption error", e);
|
|
71
|
+
return undefined;
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
newRandomKeySecret() {
|
|
75
|
+
return {
|
|
76
|
+
secret: `keySecret_z${base58.encode(this.randomBytes(32))}`,
|
|
77
|
+
id: `key_z${base58.encode(this.randomBytes(12))}`,
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
decryptRawForTransaction(encrypted, keySecret, nOnceMaterial) {
|
|
81
|
+
return this.decryptRaw(encrypted, keySecret, nOnceMaterial);
|
|
82
|
+
}
|
|
83
|
+
decryptForTransaction(encrypted, keySecret, nOnceMaterial) {
|
|
84
|
+
return this.decrypt(encrypted, keySecret, nOnceMaterial);
|
|
85
|
+
}
|
|
86
|
+
encryptKeySecret(keys) {
|
|
87
|
+
const nOnceMaterial = {
|
|
88
|
+
encryptedID: keys.toEncrypt.id,
|
|
89
|
+
encryptingID: keys.encrypting.id,
|
|
90
|
+
};
|
|
91
|
+
return {
|
|
92
|
+
encryptedID: keys.toEncrypt.id,
|
|
93
|
+
encryptingID: keys.encrypting.id,
|
|
94
|
+
encrypted: this.encrypt(keys.toEncrypt.secret, keys.encrypting.secret, nOnceMaterial),
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
decryptKeySecret(encryptedInfo, sealingSecret) {
|
|
98
|
+
const nOnceMaterial = {
|
|
99
|
+
encryptedID: encryptedInfo.encryptedID,
|
|
100
|
+
encryptingID: encryptedInfo.encryptingID,
|
|
101
|
+
};
|
|
102
|
+
return this.decrypt(encryptedInfo.encrypted, sealingSecret, nOnceMaterial);
|
|
103
|
+
}
|
|
104
|
+
uniquenessForHeader() {
|
|
105
|
+
return `z${base58.encode(this.randomBytes(12))}`;
|
|
106
|
+
}
|
|
107
|
+
createdNowUnique() {
|
|
108
|
+
const createdAt = new Date().toISOString();
|
|
109
|
+
return {
|
|
110
|
+
createdAt,
|
|
111
|
+
uniqueness: this.uniquenessForHeader(),
|
|
112
|
+
};
|
|
113
|
+
}
|
|
114
|
+
newRandomSecretSeed() {
|
|
115
|
+
return this.randomBytes(secretSeedLength);
|
|
116
|
+
}
|
|
117
|
+
agentSecretFromSecretSeed(secretSeed) {
|
|
118
|
+
if (secretSeed.length !== secretSeedLength) {
|
|
119
|
+
throw new Error(`Secret seed needs to be ${secretSeedLength} bytes long`);
|
|
120
|
+
}
|
|
121
|
+
return `sealerSecret_z${base58.encode(this.blake3HashOnceWithContext(secretSeed, {
|
|
122
|
+
context: textEncoder.encode("seal"),
|
|
123
|
+
}))}/signerSecret_z${base58.encode(this.blake3HashOnceWithContext(secretSeed, {
|
|
124
|
+
context: textEncoder.encode("sign"),
|
|
125
|
+
}))}`;
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
export class StreamingHash {
|
|
129
|
+
constructor(crypto, fromClone) {
|
|
130
|
+
this.state = fromClone || crypto.emptyBlake3State();
|
|
131
|
+
this.crypto = crypto;
|
|
132
|
+
}
|
|
133
|
+
update(value) {
|
|
134
|
+
const encoded = textEncoder.encode(stableStringify(value));
|
|
135
|
+
// const before = performance.now();
|
|
136
|
+
this.state = this.crypto.blake3IncrementalUpdate(this.state, encoded);
|
|
137
|
+
// const after = performance.now();
|
|
138
|
+
// console.log(`Hashing throughput in MB/s`, 1000 * (encoded.length / (after - before)) / (1024 * 1024));
|
|
139
|
+
return encoded;
|
|
140
|
+
}
|
|
141
|
+
digest() {
|
|
142
|
+
const hash = this.crypto.blake3DigestForState(this.state);
|
|
143
|
+
return `hash_z${base58.encode(hash)}`;
|
|
144
|
+
}
|
|
145
|
+
clone() {
|
|
146
|
+
return new StreamingHash(this.crypto, new Uint8Array(this.state));
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
export const shortHashLength = 19;
|
|
150
|
+
export const secretSeedLength = 32;
|
|
151
|
+
//# sourceMappingURL=crypto.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"crypto.js","sourceRoot":"","sources":["../../src/crypto/crypto.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAErC,OAAO,EAAe,SAAS,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAY9E,MAAM,CAAC,MAAM,WAAW,GAAG,IAAI,WAAW,EAAE,CAAC;AAC7C,MAAM,CAAC,MAAM,WAAW,GAAG,IAAI,WAAW,EAAE,CAAC;AAE7C,8DAA8D;AAC9D,MAAM,OAAgB,cAAc;IAKhC,eAAe;QACX,OAAO,iBAAiB,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,oBAAoB,EAAE,CAAC,EAAE,CAAC;IACzE,CAAC;IAED,mBAAmB,CAAC,MAAoB;QACpC,OAAO,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAC;IACpE,CAAC;IAED,qBAAqB,CAAC,KAAiB;QACnC,OAAO,iBAAiB,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC;IACnD,CAAC;IAcD,eAAe;QACX,OAAO,iBAAiB,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,qBAAqB,EAAE,CAAC,EAAE,CAAC;IAC1E,CAAC;IAED,mBAAmB,CAAC,MAAoB;QACpC,OAAO,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAC;IACpE,CAAC;IAED,qBAAqB,CAAC,KAAiB;QACnC,OAAO,iBAAiB,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC;IACnD,CAAC;IAID,oBAAoB;QAChB,OAAO,GAAG,IAAI,CAAC,eAAe,EAAE,IAAI,IAAI,CAAC,eAAe,EAAE,EAAE,CAAC;IACjE,CAAC;IAED,kBAAkB,CAAC,MAAmB;QAClC,MAAM,CAAC,YAAY,EAAE,YAAY,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QACvD,OAAO,IAAI,UAAU,CAAC;YAClB,GAAG,IAAI,CAAC,mBAAmB,CAAC,YAA4B,CAAC;YACzD,GAAG,IAAI,CAAC,mBAAmB,CAAC,YAA4B,CAAC;SAC5D,CAAC,CAAC;IACP,CAAC;IAED,oBAAoB,CAAC,KAAiB;QAClC,MAAM,YAAY,GAAG,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;QACpE,MAAM,YAAY,GAAG,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;QACjE,OAAO,GAAG,YAAY,IAAI,YAAY,EAAE,CAAC;IAC7C,CAAC;IAED,UAAU,CAAC,MAAmB;QAC1B,MAAM,CAAC,YAAY,EAAE,YAAY,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QACvD,OAAO,GAAG,IAAI,CAAC,WAAW,CACtB,YAA4B,CAC/B,IAAI,IAAI,CAAC,WAAW,CAAC,YAA4B,CAAC,EAAE,CAAC;IAC1D,CAAC;IAED,gBAAgB,CAAC,OAAgB;QAC7B,OAAO,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAa,CAAC;IAC7C,CAAC;IAED,oBAAoB,CAAC,WAAwB;QACzC,OAAO,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAiB,CAAC;IACrD,CAAC;IAED,gBAAgB,CAAC,OAAgB;QAC7B,OAAO,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAa,CAAC;IAC7C,CAAC;IAED,oBAAoB,CAAC,WAAwB;QACzC,OAAO,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAiB,CAAC;IACrD,CAAC;IAcD,UAAU,CAAC,KAAgB;QACvB,OAAO,SAAS,MAAM,CAAC,MAAM,CACzB,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,MAAM,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,CAAC,CAClE,EAAE,CAAC;IACR,CAAC;IAED,SAAS,CAAC,KAAgB;QACtB,OAAO,cAAc,MAAM,CAAC,MAAM,CAC9B,IAAI,CAAC,cAAc,CACf,WAAW,CAAC,MAAM,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,CAC7C,CAAC,KAAK,CAAC,CAAC,EAAE,eAAe,CAAC,CAC9B,EAAE,CAAC;IACR,CAAC;IAQD,qBAAqB,CACjB,KAAQ,EACR,SAAoB,EACpB,aAAiD;QAEjD,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,SAAS,EAAE,aAAa,CAAC,CAAC;IACzD,CAAC;IAQD,OAAO,CACH,SAA0B,EAC1B,SAAoB,EACpB,aAAgB;QAEhB,IAAI;YACA,OAAO,SAAS,CACZ,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,SAAS,EAAE,aAAa,CAAC,CACvD,CAAC;SACL;QAAC,OAAO,CAAC,EAAE;YACR,OAAO,CAAC,KAAK,CAAC,kBAAkB,EAAE,CAAC,CAAC,CAAC;YACrC,OAAO,SAAS,CAAC;SACpB;IACL,CAAC;IAED,kBAAkB;QACd,OAAO;YACH,MAAM,EAAE,cAAc,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,EAAE;YAC3D,EAAE,EAAE,QAAQ,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,EAAE;SACpD,CAAC;IACN,CAAC;IAED,wBAAwB,CACpB,SAA2D,EAC3D,SAAoB,EACpB,aAAiD;QAEjD,OAAO,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,SAAS,EAAE,aAAa,CAAC,CAAC;IAChE,CAAC;IAED,qBAAqB,CACjB,SAA2D,EAC3D,SAAoB,EACpB,aAAiD;QAEjD,OAAO,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,SAAS,EAAE,aAAa,CAAC,CAAC;IAC7D,CAAC;IAED,gBAAgB,CAAC,IAGhB;QAQG,MAAM,aAAa,GAAG;YAClB,WAAW,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE;YAC9B,YAAY,EAAE,IAAI,CAAC,UAAU,CAAC,EAAE;SACnC,CAAC;QAEF,OAAO;YACH,WAAW,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE;YAC9B,YAAY,EAAE,IAAI,CAAC,UAAU,CAAC,EAAE;YAChC,SAAS,EAAE,IAAI,CAAC,OAAO,CACnB,IAAI,CAAC,SAAS,CAAC,MAAM,EACrB,IAAI,CAAC,UAAU,CAAC,MAAM,EACtB,aAAa,CAChB;SACJ,CAAC;IACN,CAAC;IAED,gBAAgB,CACZ,aAOC,EACD,aAAwB;QAExB,MAAM,aAAa,GAAG;YAClB,WAAW,EAAE,aAAa,CAAC,WAAW;YACtC,YAAY,EAAE,aAAa,CAAC,YAAY;SAC3C,CAAC;QAEF,OAAO,IAAI,CAAC,OAAO,CACf,aAAa,CAAC,SAAS,EACvB,aAAa,EACb,aAAa,CAChB,CAAC;IACN,CAAC;IAqBD,mBAAmB;QACf,OAAO,IAAI,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC;IACrD,CAAC;IAED,gBAAgB;QAIZ,MAAM,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAkB,CAAC;QAC3D,OAAO;YACH,SAAS;YACT,UAAU,EAAE,IAAI,CAAC,mBAAmB,EAAE;SACzC,CAAC;IACN,CAAC;IAED,mBAAmB;QACf,OAAO,IAAI,CAAC,WAAW,CAAC,gBAAgB,CAAC,CAAC;IAC9C,CAAC;IAED,yBAAyB,CAAC,UAAsB;QAC5C,IAAI,UAAU,CAAC,MAAM,KAAK,gBAAgB,EAAE;YACxC,MAAM,IAAI,KAAK,CACX,2BAA2B,gBAAgB,aAAa,CAC3D,CAAC;SACL;QAED,OAAO,iBAAiB,MAAM,CAAC,MAAM,CACjC,IAAI,CAAC,yBAAyB,CAAC,UAAU,EAAE;YACvC,OAAO,EAAE,WAAW,CAAC,MAAM,CAAC,MAAM,CAAC;SACtC,CAAC,CACL,kBAAkB,MAAM,CAAC,MAAM,CAC5B,IAAI,CAAC,yBAAyB,CAAC,UAAU,EAAE;YACvC,OAAO,EAAE,WAAW,CAAC,MAAM,CAAC,MAAM,CAAC;SACtC,CAAC,CACL,EAAE,CAAC;IACR,CAAC;CACJ;AAID,MAAM,OAAO,aAAa;IAItB,YAAY,MAAsB,EAAE,SAAsB;QACtD,IAAI,CAAC,KAAK,GAAG,SAAS,IAAI,MAAM,CAAC,gBAAgB,EAAE,CAAC;QACpD,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACzB,CAAC;IAED,MAAM,CAAC,KAAgB;QACnB,MAAM,OAAO,GAAG,WAAW,CAAC,MAAM,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,CAAC;QAC3D,oCAAoC;QACpC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,uBAAuB,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;QACtE,mCAAmC;QACnC,yGAAyG;QACzG,OAAO,OAAO,CAAC;IACnB,CAAC;IAED,MAAM;QACF,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1D,OAAO,SAAS,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC;IAC1C,CAAC;IAED,KAAK;QACD,OAAO,IAAI,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;IACtE,CAAC;CACJ;AAGD,MAAM,CAAC,MAAM,eAAe,GAAG,EAAE,CAAC;AAUlC,MAAM,CAAC,MAAM,gBAAgB,GAAG,EAAE,CAAC"}
|
package/dist/ids.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { base58 } from "@scure/base";
|
|
2
|
-
import { shortHashLength } from
|
|
2
|
+
import { shortHashLength } from "./crypto/crypto.js";
|
|
3
3
|
export function isRawCoID(id) {
|
|
4
4
|
return typeof id === "string" && id.startsWith("co_z");
|
|
5
5
|
}
|
|
@@ -10,6 +10,8 @@ export function rawCoIDfromBytes(bytes) {
|
|
|
10
10
|
return `co_z${base58.encode(bytes.slice(0, shortHashLength))}`;
|
|
11
11
|
}
|
|
12
12
|
export function isAgentID(id) {
|
|
13
|
-
return typeof id === "string" &&
|
|
13
|
+
return (typeof id === "string" &&
|
|
14
|
+
id.startsWith("sealer_") &&
|
|
15
|
+
id.includes("/signer_"));
|
|
14
16
|
}
|
|
15
17
|
//# sourceMappingURL=ids.js.map
|
package/dist/ids.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ids.js","sourceRoot":"","sources":["../src/ids.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,eAAe,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"ids.js","sourceRoot":"","sources":["../src/ids.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAIrD,MAAM,UAAU,SAAS,CAAC,EAAW;IACjC,OAAO,OAAO,EAAE,KAAK,QAAQ,IAAI,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;AAC3D,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,EAAW;IACtC,OAAO,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;AACtD,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,KAAiB;IAC9C,OAAO,OAAO,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,eAAe,CAAC,CAAC,EAAa,CAAC;AAC9E,CAAC;AAMD,MAAM,UAAU,SAAS,CAAC,EAAU;IAChC,OAAO,CACH,OAAO,EAAE,KAAK,QAAQ;QACtB,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC;QACxB,EAAE,CAAC,QAAQ,CAAC,UAAU,CAAC,CAC1B,CAAC;AACN,CAAC"}
|