cojson 0.10.0 → 0.10.2

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 (212) hide show
  1. package/.turbo/turbo-build.log +2 -10
  2. package/CHANGELOG.md +13 -0
  3. package/dist/CoValuesStore.js.map +1 -0
  4. package/dist/PeerKnownStates.js.map +1 -0
  5. package/dist/PeerState.js.map +1 -0
  6. package/dist/PriorityBasedMessageQueue.js.map +1 -0
  7. package/dist/SyncStateManager.js.map +1 -0
  8. package/dist/base64url.js.map +1 -0
  9. package/dist/base64url.test.js.map +1 -0
  10. package/dist/coValue.js.map +1 -0
  11. package/dist/coValueCore.js.map +1 -0
  12. package/dist/{native/coValueState.js → coValueState.js} +1 -0
  13. package/dist/coValueState.js.map +1 -0
  14. package/dist/coValues/account.js.map +1 -0
  15. package/dist/coValues/coList.js.map +1 -0
  16. package/dist/coValues/coMap.js.map +1 -0
  17. package/dist/coValues/coPlainText.js.map +1 -0
  18. package/dist/coValues/coStream.js.map +1 -0
  19. package/dist/coValues/group.js.map +1 -0
  20. package/dist/coreToCoValue.js.map +1 -0
  21. package/dist/crypto/PureJSCrypto.js.map +1 -0
  22. package/dist/crypto/WasmCrypto.js.map +1 -0
  23. package/dist/crypto/crypto.js.map +1 -0
  24. package/dist/exports.js.map +1 -0
  25. package/dist/ids.js.map +1 -0
  26. package/dist/index.js +2 -0
  27. package/dist/index.js.map +1 -0
  28. package/dist/jsonStringify.js.map +1 -0
  29. package/dist/{native/jsonValue.js.map → jsonValue.js.map} +1 -1
  30. package/dist/localNode.js.map +1 -0
  31. package/dist/logger.js.map +1 -0
  32. package/dist/media.js.map +1 -0
  33. package/dist/permissions.js.map +1 -0
  34. package/dist/priority.js.map +1 -0
  35. package/dist/storage/FileSystem.js.map +1 -0
  36. package/dist/storage/chunksAndKnownStates.js.map +1 -0
  37. package/dist/storage/index.js.map +1 -0
  38. package/dist/streamUtils.js.map +1 -0
  39. package/dist/{web/sync.js → sync.js} +5 -1
  40. package/dist/sync.js.map +1 -0
  41. package/dist/typeUtils/accountOrAgentIDfromSessionID.js.map +1 -0
  42. package/dist/typeUtils/expectGroup.js.map +1 -0
  43. package/dist/typeUtils/isAccountID.js.map +1 -0
  44. package/dist/typeUtils/isCoValue.js.map +1 -0
  45. package/package.json +19 -21
  46. package/src/coValueState.ts +1 -0
  47. package/src/exports.ts +1 -0
  48. package/src/index.ts +1 -0
  49. package/src/sync.ts +5 -1
  50. package/tsconfig.json +3 -1
  51. package/dist/native/CoValuesStore.js.map +0 -1
  52. package/dist/native/PeerKnownStates.js.map +0 -1
  53. package/dist/native/PeerState.js.map +0 -1
  54. package/dist/native/PriorityBasedMessageQueue.js.map +0 -1
  55. package/dist/native/SyncStateManager.js.map +0 -1
  56. package/dist/native/base64url.js.map +0 -1
  57. package/dist/native/base64url.test.js.map +0 -1
  58. package/dist/native/coValue.js.map +0 -1
  59. package/dist/native/coValueCore.js.map +0 -1
  60. package/dist/native/coValueState.js.map +0 -1
  61. package/dist/native/coValues/account.js.map +0 -1
  62. package/dist/native/coValues/coList.js.map +0 -1
  63. package/dist/native/coValues/coMap.js.map +0 -1
  64. package/dist/native/coValues/coPlainText.js.map +0 -1
  65. package/dist/native/coValues/coStream.js.map +0 -1
  66. package/dist/native/coValues/group.js.map +0 -1
  67. package/dist/native/coreToCoValue.js.map +0 -1
  68. package/dist/native/crypto/PureJSCrypto.js.map +0 -1
  69. package/dist/native/crypto/WasmCrypto.js.map +0 -1
  70. package/dist/native/crypto/crypto.js.map +0 -1
  71. package/dist/native/crypto/export.js +0 -3
  72. package/dist/native/crypto/export.js.map +0 -1
  73. package/dist/native/exports.js.map +0 -1
  74. package/dist/native/ids.js.map +0 -1
  75. package/dist/native/index.native.js +0 -3
  76. package/dist/native/index.native.js.map +0 -1
  77. package/dist/native/jsonStringify.js.map +0 -1
  78. package/dist/native/localNode.js.map +0 -1
  79. package/dist/native/logger.js.map +0 -1
  80. package/dist/native/media.js.map +0 -1
  81. package/dist/native/permissions.js.map +0 -1
  82. package/dist/native/priority.js.map +0 -1
  83. package/dist/native/storage/FileSystem.js.map +0 -1
  84. package/dist/native/storage/chunksAndKnownStates.js.map +0 -1
  85. package/dist/native/storage/index.js.map +0 -1
  86. package/dist/native/streamUtils.js.map +0 -1
  87. package/dist/native/sync.js +0 -555
  88. package/dist/native/sync.js.map +0 -1
  89. package/dist/native/typeUtils/accountOrAgentIDfromSessionID.js.map +0 -1
  90. package/dist/native/typeUtils/expectGroup.js.map +0 -1
  91. package/dist/native/typeUtils/isAccountID.js.map +0 -1
  92. package/dist/native/typeUtils/isCoValue.js.map +0 -1
  93. package/dist/web/CoValuesStore.js +0 -31
  94. package/dist/web/CoValuesStore.js.map +0 -1
  95. package/dist/web/PeerKnownStates.js +0 -68
  96. package/dist/web/PeerKnownStates.js.map +0 -1
  97. package/dist/web/PeerState.js +0 -103
  98. package/dist/web/PeerState.js.map +0 -1
  99. package/dist/web/PriorityBasedMessageQueue.js +0 -98
  100. package/dist/web/PriorityBasedMessageQueue.js.map +0 -1
  101. package/dist/web/SyncStateManager.js +0 -94
  102. package/dist/web/SyncStateManager.js.map +0 -1
  103. package/dist/web/base64url.js +0 -53
  104. package/dist/web/base64url.js.map +0 -1
  105. package/dist/web/base64url.test.js +0 -25
  106. package/dist/web/base64url.test.js.map +0 -1
  107. package/dist/web/coValue.js +0 -52
  108. package/dist/web/coValue.js.map +0 -1
  109. package/dist/web/coValueCore.js +0 -597
  110. package/dist/web/coValueCore.js.map +0 -1
  111. package/dist/web/coValueState.js +0 -267
  112. package/dist/web/coValueState.js.map +0 -1
  113. package/dist/web/coValues/account.js +0 -100
  114. package/dist/web/coValues/account.js.map +0 -1
  115. package/dist/web/coValues/coList.js +0 -381
  116. package/dist/web/coValues/coList.js.map +0 -1
  117. package/dist/web/coValues/coMap.js +0 -273
  118. package/dist/web/coValues/coMap.js.map +0 -1
  119. package/dist/web/coValues/coPlainText.js +0 -86
  120. package/dist/web/coValues/coPlainText.js.map +0 -1
  121. package/dist/web/coValues/coStream.js +0 -224
  122. package/dist/web/coValues/coStream.js.map +0 -1
  123. package/dist/web/coValues/group.js +0 -522
  124. package/dist/web/coValues/group.js.map +0 -1
  125. package/dist/web/coreToCoValue.js +0 -46
  126. package/dist/web/coreToCoValue.js.map +0 -1
  127. package/dist/web/crypto/PureJSCrypto.js +0 -94
  128. package/dist/web/crypto/PureJSCrypto.js.map +0 -1
  129. package/dist/web/crypto/WasmCrypto.js +0 -115
  130. package/dist/web/crypto/WasmCrypto.js.map +0 -1
  131. package/dist/web/crypto/crypto.js +0 -152
  132. package/dist/web/crypto/crypto.js.map +0 -1
  133. package/dist/web/crypto/export.js +0 -3
  134. package/dist/web/crypto/export.js.map +0 -1
  135. package/dist/web/exports.js +0 -48
  136. package/dist/web/exports.js.map +0 -1
  137. package/dist/web/ids.js +0 -50
  138. package/dist/web/ids.js.map +0 -1
  139. package/dist/web/index.web.js +0 -3
  140. package/dist/web/index.web.js.map +0 -1
  141. package/dist/web/jsonStringify.js +0 -57
  142. package/dist/web/jsonStringify.js.map +0 -1
  143. package/dist/web/jsonValue.js +0 -2
  144. package/dist/web/jsonValue.js.map +0 -1
  145. package/dist/web/localNode.js +0 -412
  146. package/dist/web/localNode.js.map +0 -1
  147. package/dist/web/logger.js +0 -58
  148. package/dist/web/logger.js.map +0 -1
  149. package/dist/web/media.js +0 -2
  150. package/dist/web/media.js.map +0 -1
  151. package/dist/web/permissions.js +0 -341
  152. package/dist/web/permissions.js.map +0 -1
  153. package/dist/web/priority.js +0 -31
  154. package/dist/web/priority.js.map +0 -1
  155. package/dist/web/storage/FileSystem.js +0 -48
  156. package/dist/web/storage/FileSystem.js.map +0 -1
  157. package/dist/web/storage/chunksAndKnownStates.js +0 -98
  158. package/dist/web/storage/chunksAndKnownStates.js.map +0 -1
  159. package/dist/web/storage/index.js +0 -336
  160. package/dist/web/storage/index.js.map +0 -1
  161. package/dist/web/streamUtils.js +0 -41
  162. package/dist/web/streamUtils.js.map +0 -1
  163. package/dist/web/sync.js.map +0 -1
  164. package/dist/web/typeUtils/accountOrAgentIDfromSessionID.js +0 -5
  165. package/dist/web/typeUtils/accountOrAgentIDfromSessionID.js.map +0 -1
  166. package/dist/web/typeUtils/expectGroup.js +0 -13
  167. package/dist/web/typeUtils/expectGroup.js.map +0 -1
  168. package/dist/web/typeUtils/isAccountID.js +0 -4
  169. package/dist/web/typeUtils/isAccountID.js.map +0 -1
  170. package/dist/web/typeUtils/isCoValue.js +0 -11
  171. package/dist/web/typeUtils/isCoValue.js.map +0 -1
  172. package/src/crypto/export.ts +0 -2
  173. package/src/index.native.ts +0 -2
  174. package/src/index.web.ts +0 -2
  175. package/tsconfig.native.json +0 -10
  176. package/tsconfig.web.json +0 -5
  177. /package/dist/{native/CoValuesStore.js → CoValuesStore.js} +0 -0
  178. /package/dist/{native/PeerKnownStates.js → PeerKnownStates.js} +0 -0
  179. /package/dist/{native/PeerState.js → PeerState.js} +0 -0
  180. /package/dist/{native/PriorityBasedMessageQueue.js → PriorityBasedMessageQueue.js} +0 -0
  181. /package/dist/{native/SyncStateManager.js → SyncStateManager.js} +0 -0
  182. /package/dist/{native/base64url.js → base64url.js} +0 -0
  183. /package/dist/{native/base64url.test.js → base64url.test.js} +0 -0
  184. /package/dist/{native/coValue.js → coValue.js} +0 -0
  185. /package/dist/{native/coValueCore.js → coValueCore.js} +0 -0
  186. /package/dist/{native/coValues → coValues}/account.js +0 -0
  187. /package/dist/{native/coValues → coValues}/coList.js +0 -0
  188. /package/dist/{native/coValues → coValues}/coMap.js +0 -0
  189. /package/dist/{native/coValues → coValues}/coPlainText.js +0 -0
  190. /package/dist/{native/coValues → coValues}/coStream.js +0 -0
  191. /package/dist/{native/coValues → coValues}/group.js +0 -0
  192. /package/dist/{native/coreToCoValue.js → coreToCoValue.js} +0 -0
  193. /package/dist/{native/crypto → crypto}/PureJSCrypto.js +0 -0
  194. /package/dist/{native/crypto → crypto}/WasmCrypto.js +0 -0
  195. /package/dist/{native/crypto → crypto}/crypto.js +0 -0
  196. /package/dist/{native/exports.js → exports.js} +0 -0
  197. /package/dist/{native/ids.js → ids.js} +0 -0
  198. /package/dist/{native/jsonStringify.js → jsonStringify.js} +0 -0
  199. /package/dist/{native/jsonValue.js → jsonValue.js} +0 -0
  200. /package/dist/{native/localNode.js → localNode.js} +0 -0
  201. /package/dist/{native/logger.js → logger.js} +0 -0
  202. /package/dist/{native/media.js → media.js} +0 -0
  203. /package/dist/{native/permissions.js → permissions.js} +0 -0
  204. /package/dist/{native/priority.js → priority.js} +0 -0
  205. /package/dist/{native/storage → storage}/FileSystem.js +0 -0
  206. /package/dist/{native/storage → storage}/chunksAndKnownStates.js +0 -0
  207. /package/dist/{native/storage → storage}/index.js +0 -0
  208. /package/dist/{native/streamUtils.js → streamUtils.js} +0 -0
  209. /package/dist/{native/typeUtils → typeUtils}/accountOrAgentIDfromSessionID.js +0 -0
  210. /package/dist/{native/typeUtils → typeUtils}/expectGroup.js +0 -0
  211. /package/dist/{native/typeUtils → typeUtils}/isAccountID.js +0 -0
  212. /package/dist/{native/typeUtils → typeUtils}/isCoValue.js +0 -0
@@ -1,94 +0,0 @@
1
- import { xsalsa20, xsalsa20_poly1305 } from "@noble/ciphers/salsa";
2
- import { randomBytes } from "@noble/ciphers/webcrypto/utils";
3
- import { ed25519, x25519 } from "@noble/curves/ed25519";
4
- import { blake3 } from "@noble/hashes/blake3";
5
- import { base58 } from "@scure/base";
6
- import { base64URLtoBytes, bytesToBase64url } from "../base64url.js";
7
- import { stableStringify } from "../jsonStringify.js";
8
- import { logger } from "../logger.js";
9
- import { CryptoProvider, textDecoder, textEncoder, } from "./crypto.js";
10
- export class PureJSCrypto extends CryptoProvider {
11
- static async create() {
12
- return new PureJSCrypto();
13
- }
14
- randomBytes(length) {
15
- return randomBytes(length);
16
- }
17
- emptyBlake3State() {
18
- return blake3.create({});
19
- }
20
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
21
- cloneBlake3State(state) {
22
- return state.clone();
23
- }
24
- blake3HashOnce(data) {
25
- return blake3(data);
26
- }
27
- blake3HashOnceWithContext(data, { context }) {
28
- return blake3.create({}).update(context).update(data).digest();
29
- }
30
- blake3IncrementalUpdate(state, data) {
31
- return state.update(data);
32
- }
33
- blake3DigestForState(state) {
34
- return state.clone().digest();
35
- }
36
- newEd25519SigningKey() {
37
- return ed25519.utils.randomPrivateKey();
38
- }
39
- getSignerID(secret) {
40
- return `signer_z${base58.encode(ed25519.getPublicKey(base58.decode(secret.substring("signerSecret_z".length))))}`;
41
- }
42
- sign(secret, message) {
43
- const signature = ed25519.sign(textEncoder.encode(stableStringify(message)), base58.decode(secret.substring("signerSecret_z".length)));
44
- return `signature_z${base58.encode(signature)}`;
45
- }
46
- verify(signature, message, id) {
47
- return ed25519.verify(base58.decode(signature.substring("signature_z".length)), textEncoder.encode(stableStringify(message)), base58.decode(id.substring("signer_z".length)));
48
- }
49
- newX25519StaticSecret() {
50
- return x25519.utils.randomPrivateKey();
51
- }
52
- getSealerID(secret) {
53
- return `sealer_z${base58.encode(x25519.getPublicKey(base58.decode(secret.substring("sealerSecret_z".length))))}`;
54
- }
55
- encrypt(value, keySecret, nOnceMaterial) {
56
- const keySecretBytes = base58.decode(keySecret.substring("keySecret_z".length));
57
- const nOnce = this.blake3HashOnce(textEncoder.encode(stableStringify(nOnceMaterial))).slice(0, 24);
58
- const plaintext = textEncoder.encode(stableStringify(value));
59
- const ciphertext = xsalsa20(keySecretBytes, nOnce, plaintext);
60
- return `encrypted_U${bytesToBase64url(ciphertext)}`;
61
- }
62
- decryptRaw(encrypted, keySecret, nOnceMaterial) {
63
- const keySecretBytes = base58.decode(keySecret.substring("keySecret_z".length));
64
- const nOnce = this.blake3HashOnce(textEncoder.encode(stableStringify(nOnceMaterial))).slice(0, 24);
65
- const ciphertext = base64URLtoBytes(encrypted.substring("encrypted_U".length));
66
- const plaintext = xsalsa20(keySecretBytes, nOnce, ciphertext);
67
- return textDecoder.decode(plaintext);
68
- }
69
- seal({ message, from, to, nOnceMaterial, }) {
70
- const nOnce = this.blake3HashOnce(textEncoder.encode(stableStringify(nOnceMaterial))).slice(0, 24);
71
- const sealerPub = base58.decode(to.substring("sealer_z".length));
72
- const senderPriv = base58.decode(from.substring("sealerSecret_z".length));
73
- const plaintext = textEncoder.encode(stableStringify(message));
74
- const sharedSecret = x25519.getSharedSecret(senderPriv, sealerPub);
75
- const sealedBytes = xsalsa20_poly1305(sharedSecret, nOnce).encrypt(plaintext);
76
- return `sealed_U${bytesToBase64url(sealedBytes)}`;
77
- }
78
- unseal(sealed, sealer, from, nOnceMaterial) {
79
- const nOnce = this.blake3HashOnce(textEncoder.encode(stableStringify(nOnceMaterial))).slice(0, 24);
80
- const sealerPriv = base58.decode(sealer.substring("sealerSecret_z".length));
81
- const senderPub = base58.decode(from.substring("sealer_z".length));
82
- const sealedBytes = base64URLtoBytes(sealed.substring("sealed_U".length));
83
- const sharedSecret = x25519.getSharedSecret(sealerPriv, senderPub);
84
- const plaintext = xsalsa20_poly1305(sharedSecret, nOnce).decrypt(sealedBytes);
85
- try {
86
- return JSON.parse(textDecoder.decode(plaintext));
87
- }
88
- catch (e) {
89
- logger.error("Failed to decrypt/parse sealed message: " + e?.message);
90
- return undefined;
91
- }
92
- }
93
- }
94
- //# sourceMappingURL=PureJSCrypto.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"PureJSCrypto.js","sourceRoot":"","sources":["../../../src/crypto/PureJSCrypto.ts"],"names":[],"mappings":"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"}
@@ -1,115 +0,0 @@
1
- import { Ed25519Signature, Ed25519SigningKey, Ed25519VerifyingKey, Memory, X25519PublicKey, X25519StaticSecret, initBundledOnce, } from "@hazae41/berith";
2
- import { xsalsa20, xsalsa20_poly1305 } from "@noble/ciphers/salsa";
3
- import { randomBytes } from "@noble/ciphers/webcrypto/utils";
4
- import { base58 } from "@scure/base";
5
- import { createBLAKE3 } from "hash-wasm";
6
- import { base64URLtoBytes, bytesToBase64url } from "../base64url.js";
7
- import { stableStringify } from "../jsonStringify.js";
8
- import { logger } from "../logger.js";
9
- import { CryptoProvider, textDecoder, textEncoder, } from "./crypto.js";
10
- export class WasmCrypto extends CryptoProvider {
11
- constructor(blake3Instance) {
12
- super();
13
- this.blake3Instance = blake3Instance;
14
- }
15
- static async create() {
16
- return Promise.all([createBLAKE3(), initBundledOnce()]).then(([blake3instance]) => new WasmCrypto(blake3instance));
17
- }
18
- randomBytes(length) {
19
- return randomBytes(length);
20
- }
21
- emptyBlake3State() {
22
- return this.blake3Instance.init().save();
23
- }
24
- cloneBlake3State(state) {
25
- return this.blake3Instance.load(state).save();
26
- }
27
- blake3HashOnce(data) {
28
- return this.blake3Instance.init().update(data).digest("binary");
29
- }
30
- blake3HashOnceWithContext(data, { context }) {
31
- return this.blake3Instance
32
- .init()
33
- .update(context)
34
- .update(data)
35
- .digest("binary");
36
- }
37
- blake3IncrementalUpdate(state, data) {
38
- return this.blake3Instance.load(state).update(data).save();
39
- }
40
- blake3DigestForState(state) {
41
- return this.blake3Instance.load(state).digest("binary");
42
- }
43
- newEd25519SigningKey() {
44
- return new Ed25519SigningKey().to_bytes().copyAndDispose();
45
- }
46
- getSignerID(secret) {
47
- return `signer_z${base58.encode(Ed25519SigningKey.from_bytes(new Memory(base58.decode(secret.substring("signerSecret_z".length))))
48
- .public()
49
- .to_bytes()
50
- .copyAndDispose())}`;
51
- }
52
- sign(secret, message) {
53
- const signature = Ed25519SigningKey.from_bytes(new Memory(base58.decode(secret.substring("signerSecret_z".length))))
54
- .sign(new Memory(textEncoder.encode(stableStringify(message))))
55
- .to_bytes()
56
- .copyAndDispose();
57
- return `signature_z${base58.encode(signature)}`;
58
- }
59
- verify(signature, message, id) {
60
- 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)))));
61
- }
62
- newX25519StaticSecret() {
63
- return new X25519StaticSecret().to_bytes().copyAndDispose();
64
- }
65
- getSealerID(secret) {
66
- return `sealer_z${base58.encode(X25519StaticSecret.from_bytes(new Memory(base58.decode(secret.substring("sealerSecret_z".length))))
67
- .to_public()
68
- .to_bytes()
69
- .copyAndDispose())}`;
70
- }
71
- encrypt(value, keySecret, nOnceMaterial) {
72
- const keySecretBytes = base58.decode(keySecret.substring("keySecret_z".length));
73
- const nOnce = this.blake3HashOnce(textEncoder.encode(stableStringify(nOnceMaterial))).slice(0, 24);
74
- const plaintext = textEncoder.encode(stableStringify(value));
75
- const ciphertext = xsalsa20(keySecretBytes, nOnce, plaintext);
76
- return `encrypted_U${bytesToBase64url(ciphertext)}`;
77
- }
78
- decryptRaw(encrypted, keySecret, nOnceMaterial) {
79
- const keySecretBytes = base58.decode(keySecret.substring("keySecret_z".length));
80
- const nOnce = this.blake3HashOnce(textEncoder.encode(stableStringify(nOnceMaterial))).slice(0, 24);
81
- const ciphertext = base64URLtoBytes(encrypted.substring("encrypted_U".length));
82
- const plaintext = xsalsa20(keySecretBytes, nOnce, ciphertext);
83
- return textDecoder.decode(plaintext);
84
- }
85
- seal({ message, from, to, nOnceMaterial, }) {
86
- const nOnce = this.blake3HashOnce(textEncoder.encode(stableStringify(nOnceMaterial))).slice(0, 24);
87
- const sealerPub = base58.decode(to.substring("sealer_z".length));
88
- const senderPriv = base58.decode(from.substring("sealerSecret_z".length));
89
- const plaintext = textEncoder.encode(stableStringify(message));
90
- const sharedSecret = X25519StaticSecret.from_bytes(new Memory(senderPriv))
91
- .diffie_hellman(X25519PublicKey.from_bytes(new Memory(sealerPub)))
92
- .to_bytes()
93
- .copyAndDispose();
94
- const sealedBytes = xsalsa20_poly1305(sharedSecret, nOnce).encrypt(plaintext);
95
- return `sealed_U${bytesToBase64url(sealedBytes)}`;
96
- }
97
- unseal(sealed, sealer, from, nOnceMaterial) {
98
- const nOnce = this.blake3HashOnce(textEncoder.encode(stableStringify(nOnceMaterial))).slice(0, 24);
99
- const sealerPriv = base58.decode(sealer.substring("sealerSecret_z".length));
100
- const senderPub = base58.decode(from.substring("sealer_z".length));
101
- const sealedBytes = base64URLtoBytes(sealed.substring("sealed_U".length));
102
- const sharedSecret = X25519StaticSecret.from_bytes(new Memory(sealerPriv))
103
- .diffie_hellman(X25519PublicKey.from_bytes(new Memory(senderPub)))
104
- .to_bytes()
105
- .copyAndDispose();
106
- const plaintext = xsalsa20_poly1305(sharedSecret, nOnce).decrypt(sealedBytes);
107
- try {
108
- return JSON.parse(textDecoder.decode(plaintext));
109
- }
110
- catch (e) {
111
- logger.error("Failed to decrypt/parse sealed message: " + e?.message);
112
- }
113
- }
114
- }
115
- //# sourceMappingURL=WasmCrypto.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"WasmCrypto.js","sourceRoot":"","sources":["../../../src/crypto/WasmCrypto.ts"],"names":[],"mappings":"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"}
@@ -1,152 +0,0 @@
1
- import { base58 } from "@scure/base";
2
- import { parseJSON, stableStringify } from "../jsonStringify.js";
3
- import { logger } from "../logger.js";
4
- export const textEncoder = new TextEncoder();
5
- export const textDecoder = new TextDecoder();
6
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
7
- export class CryptoProvider {
8
- newRandomSigner() {
9
- return `signerSecret_z${base58.encode(this.newEd25519SigningKey())}`;
10
- }
11
- signerSecretToBytes(secret) {
12
- return base58.decode(secret.substring("signerSecret_z".length));
13
- }
14
- signerSecretFromBytes(bytes) {
15
- return `signerSecret_z${base58.encode(bytes)}`;
16
- }
17
- newRandomSealer() {
18
- return `sealerSecret_z${base58.encode(this.newX25519StaticSecret())}`;
19
- }
20
- sealerSecretToBytes(secret) {
21
- return base58.decode(secret.substring("sealerSecret_z".length));
22
- }
23
- sealerSecretFromBytes(bytes) {
24
- return `sealerSecret_z${base58.encode(bytes)}`;
25
- }
26
- newRandomAgentSecret() {
27
- return `${this.newRandomSealer()}/${this.newRandomSigner()}`;
28
- }
29
- agentSecretToBytes(secret) {
30
- const [sealerSecret, signerSecret] = secret.split("/");
31
- return new Uint8Array([
32
- ...this.sealerSecretToBytes(sealerSecret),
33
- ...this.signerSecretToBytes(signerSecret),
34
- ]);
35
- }
36
- agentSecretFromBytes(bytes) {
37
- const sealerSecret = this.sealerSecretFromBytes(bytes.slice(0, 32));
38
- const signerSecret = this.signerSecretFromBytes(bytes.slice(32));
39
- return `${sealerSecret}/${signerSecret}`;
40
- }
41
- getAgentID(secret) {
42
- const [sealerSecret, signerSecret] = secret.split("/");
43
- return `${this.getSealerID(sealerSecret)}/${this.getSignerID(signerSecret)}`;
44
- }
45
- getAgentSignerID(agentId) {
46
- return agentId.split("/")[1];
47
- }
48
- getAgentSignerSecret(agentSecret) {
49
- return agentSecret.split("/")[1];
50
- }
51
- getAgentSealerID(agentId) {
52
- return agentId.split("/")[0];
53
- }
54
- getAgentSealerSecret(agentSecret) {
55
- return agentSecret.split("/")[0];
56
- }
57
- secureHash(value) {
58
- return `hash_z${base58.encode(this.blake3HashOnce(textEncoder.encode(stableStringify(value))))}`;
59
- }
60
- shortHash(value) {
61
- return `shortHash_z${base58.encode(this.blake3HashOnce(textEncoder.encode(stableStringify(value))).slice(0, shortHashLength))}`;
62
- }
63
- encryptForTransaction(value, keySecret, nOnceMaterial) {
64
- return this.encrypt(value, keySecret, nOnceMaterial);
65
- }
66
- decrypt(encrypted, keySecret, nOnceMaterial) {
67
- try {
68
- return parseJSON(this.decryptRaw(encrypted, keySecret, nOnceMaterial));
69
- }
70
- catch (e) {
71
- logger.error("Decryption error: " + e?.message);
72
- return undefined;
73
- }
74
- }
75
- newRandomKeySecret() {
76
- return {
77
- secret: `keySecret_z${base58.encode(this.randomBytes(32))}`,
78
- id: `key_z${base58.encode(this.randomBytes(12))}`,
79
- };
80
- }
81
- decryptRawForTransaction(encrypted, keySecret, nOnceMaterial) {
82
- return this.decryptRaw(encrypted, keySecret, nOnceMaterial);
83
- }
84
- decryptForTransaction(encrypted, keySecret, nOnceMaterial) {
85
- return this.decrypt(encrypted, keySecret, nOnceMaterial);
86
- }
87
- encryptKeySecret(keys) {
88
- const nOnceMaterial = {
89
- encryptedID: keys.toEncrypt.id,
90
- encryptingID: keys.encrypting.id,
91
- };
92
- return {
93
- encryptedID: keys.toEncrypt.id,
94
- encryptingID: keys.encrypting.id,
95
- encrypted: this.encrypt(keys.toEncrypt.secret, keys.encrypting.secret, nOnceMaterial),
96
- };
97
- }
98
- decryptKeySecret(encryptedInfo, sealingSecret) {
99
- const nOnceMaterial = {
100
- encryptedID: encryptedInfo.encryptedID,
101
- encryptingID: encryptedInfo.encryptingID,
102
- };
103
- return this.decrypt(encryptedInfo.encrypted, sealingSecret, nOnceMaterial);
104
- }
105
- uniquenessForHeader() {
106
- return `z${base58.encode(this.randomBytes(12))}`;
107
- }
108
- createdNowUnique() {
109
- const createdAt = new Date().toISOString();
110
- return {
111
- createdAt,
112
- uniqueness: this.uniquenessForHeader(),
113
- };
114
- }
115
- newRandomSecretSeed() {
116
- return this.randomBytes(secretSeedLength);
117
- }
118
- agentSecretFromSecretSeed(secretSeed) {
119
- if (secretSeed.length !== secretSeedLength) {
120
- throw new Error(`Secret seed needs to be ${secretSeedLength} bytes long`);
121
- }
122
- return `sealerSecret_z${base58.encode(this.blake3HashOnceWithContext(secretSeed, {
123
- context: textEncoder.encode("seal"),
124
- }))}/signerSecret_z${base58.encode(this.blake3HashOnceWithContext(secretSeed, {
125
- context: textEncoder.encode("sign"),
126
- }))}`;
127
- }
128
- newRandomSessionID(accountID) {
129
- return `${accountID}_session_z${base58.encode(this.randomBytes(8))}`;
130
- }
131
- }
132
- export class StreamingHash {
133
- constructor(crypto, fromClone) {
134
- this.state = fromClone || crypto.emptyBlake3State();
135
- this.crypto = crypto;
136
- }
137
- update(value) {
138
- const encoded = textEncoder.encode(stableStringify(value));
139
- this.state = this.crypto.blake3IncrementalUpdate(this.state, encoded);
140
- return encoded;
141
- }
142
- digest() {
143
- const hash = this.crypto.blake3DigestForState(this.state);
144
- return `hash_z${base58.encode(hash)}`;
145
- }
146
- clone() {
147
- return new StreamingHash(this.crypto, this.crypto.cloneBlake3State(this.state));
148
- }
149
- }
150
- export const shortHashLength = 19;
151
- export const secretSeedLength = 32;
152
- //# sourceMappingURL=crypto.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"crypto.js","sourceRoot":"","sources":["../../../src/crypto/crypto.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAIrC,OAAO,EAAe,SAAS,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAE9E,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AAYtC,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;IAKlC,eAAe;QACb,OAAO,iBAAiB,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,oBAAoB,EAAE,CAAC,EAAE,CAAC;IACvE,CAAC;IAED,mBAAmB,CAAC,MAAoB;QACtC,OAAO,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAC;IAClE,CAAC;IAED,qBAAqB,CAAC,KAAiB;QACrC,OAAO,iBAAiB,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC;IACjD,CAAC;IAcD,eAAe;QACb,OAAO,iBAAiB,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,qBAAqB,EAAE,CAAC,EAAE,CAAC;IACxE,CAAC;IAED,mBAAmB,CAAC,MAAoB;QACtC,OAAO,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAC;IAClE,CAAC;IAED,qBAAqB,CAAC,KAAiB;QACrC,OAAO,iBAAiB,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC;IACjD,CAAC;IAID,oBAAoB;QAClB,OAAO,GAAG,IAAI,CAAC,eAAe,EAAE,IAAI,IAAI,CAAC,eAAe,EAAE,EAAE,CAAC;IAC/D,CAAC;IAED,kBAAkB,CAAC,MAAmB;QACpC,MAAM,CAAC,YAAY,EAAE,YAAY,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QACvD,OAAO,IAAI,UAAU,CAAC;YACpB,GAAG,IAAI,CAAC,mBAAmB,CAAC,YAA4B,CAAC;YACzD,GAAG,IAAI,CAAC,mBAAmB,CAAC,YAA4B,CAAC;SAC1D,CAAC,CAAC;IACL,CAAC;IAED,oBAAoB,CAAC,KAAiB;QACpC,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;IAC3C,CAAC;IAED,UAAU,CAAC,MAAmB;QAC5B,MAAM,CAAC,YAAY,EAAE,YAAY,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QACvD,OAAO,GAAG,IAAI,CAAC,WAAW,CACxB,YAA4B,CAC7B,IAAI,IAAI,CAAC,WAAW,CAAC,YAA4B,CAAC,EAAE,CAAC;IACxD,CAAC;IAED,gBAAgB,CAAC,OAAgB;QAC/B,OAAO,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAa,CAAC;IAC3C,CAAC;IAED,oBAAoB,CAAC,WAAwB;QAC3C,OAAO,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAiB,CAAC;IACnD,CAAC;IAED,gBAAgB,CAAC,OAAgB;QAC/B,OAAO,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAa,CAAC;IAC3C,CAAC;IAED,oBAAoB,CAAC,WAAwB;QAC3C,OAAO,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAiB,CAAC;IACnD,CAAC;IAeD,UAAU,CAAC,KAAgB;QACzB,OAAO,SAAS,MAAM,CAAC,MAAM,CAC3B,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,MAAM,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,CAAC,CAChE,EAAE,CAAC;IACN,CAAC;IAED,SAAS,CAAC,KAAgB;QACxB,OAAO,cAAc,MAAM,CAAC,MAAM,CAChC,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,MAAM,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CACnE,CAAC,EACD,eAAe,CAChB,CACF,EAAE,CAAC;IACN,CAAC;IAQD,qBAAqB,CACnB,KAAQ,EACR,SAAoB,EACpB,aAAiD;QAEjD,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,SAAS,EAAE,aAAa,CAAC,CAAC;IACvD,CAAC;IAQD,OAAO,CACL,SAA0B,EAC1B,SAAoB,EACpB,aAAgB;QAEhB,IAAI,CAAC;YACH,OAAO,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,SAAS,EAAE,aAAa,CAAC,CAAC,CAAC;QACzE,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,MAAM,CAAC,KAAK,CAAC,oBAAoB,GAAI,CAAW,EAAE,OAAO,CAAC,CAAC;YAC3D,OAAO,SAAS,CAAC;QACnB,CAAC;IACH,CAAC;IAED,kBAAkB;QAChB,OAAO;YACL,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;SAClD,CAAC;IACJ,CAAC;IAED,wBAAwB,CACtB,SAA2D,EAC3D,SAAoB,EACpB,aAAiD;QAEjD,OAAO,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,SAAS,EAAE,aAAa,CAAC,CAAC;IAC9D,CAAC;IAED,qBAAqB,CACnB,SAA2D,EAC3D,SAAoB,EACpB,aAAiD;QAEjD,OAAO,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,SAAS,EAAE,aAAa,CAAC,CAAC;IAC3D,CAAC;IAED,gBAAgB,CAAC,IAGhB;QAQC,MAAM,aAAa,GAAG;YACpB,WAAW,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE;YAC9B,YAAY,EAAE,IAAI,CAAC,UAAU,CAAC,EAAE;SACjC,CAAC;QAEF,OAAO;YACL,WAAW,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE;YAC9B,YAAY,EAAE,IAAI,CAAC,UAAU,CAAC,EAAE;YAChC,SAAS,EAAE,IAAI,CAAC,OAAO,CACrB,IAAI,CAAC,SAAS,CAAC,MAAM,EACrB,IAAI,CAAC,UAAU,CAAC,MAAM,EACtB,aAAa,CACd;SACF,CAAC;IACJ,CAAC;IAED,gBAAgB,CACd,aAOC,EACD,aAAwB;QAExB,MAAM,aAAa,GAAG;YACpB,WAAW,EAAE,aAAa,CAAC,WAAW;YACtC,YAAY,EAAE,aAAa,CAAC,YAAY;SACzC,CAAC;QAEF,OAAO,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,SAAS,EAAE,aAAa,EAAE,aAAa,CAAC,CAAC;IAC7E,CAAC;IAqBD,mBAAmB;QACjB,OAAO,IAAI,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC;IACnD,CAAC;IAED,gBAAgB;QAId,MAAM,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAkB,CAAC;QAC3D,OAAO;YACL,SAAS;YACT,UAAU,EAAE,IAAI,CAAC,mBAAmB,EAAE;SACvC,CAAC;IACJ,CAAC;IAED,mBAAmB;QACjB,OAAO,IAAI,CAAC,WAAW,CAAC,gBAAgB,CAAC,CAAC;IAC5C,CAAC;IAED,yBAAyB,CAAC,UAAsB;QAC9C,IAAI,UAAU,CAAC,MAAM,KAAK,gBAAgB,EAAE,CAAC;YAC3C,MAAM,IAAI,KAAK,CAAC,2BAA2B,gBAAgB,aAAa,CAAC,CAAC;QAC5E,CAAC;QAED,OAAO,iBAAiB,MAAM,CAAC,MAAM,CACnC,IAAI,CAAC,yBAAyB,CAAC,UAAU,EAAE;YACzC,OAAO,EAAE,WAAW,CAAC,MAAM,CAAC,MAAM,CAAC;SACpC,CAAC,CACH,kBAAkB,MAAM,CAAC,MAAM,CAC9B,IAAI,CAAC,yBAAyB,CAAC,UAAU,EAAE;YACzC,OAAO,EAAE,WAAW,CAAC,MAAM,CAAC,MAAM,CAAC;SACpC,CAAC,CACH,EAAE,CAAC;IACN,CAAC;IAED,kBAAkB,CAAC,SAAiC;QAClD,OAAO,GAAG,SAAS,aAAa,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IACvE,CAAC;CACF;AAID,MAAM,OAAO,aAAa;IAIxB,YAAY,MAAsB,EAAE,SAAsB;QACxD,IAAI,CAAC,KAAK,GAAG,SAAS,IAAI,MAAM,CAAC,gBAAgB,EAAE,CAAC;QACpD,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;IAED,MAAM,CAAC,KAAgB;QACrB,MAAM,OAAO,GAAG,WAAW,CAAC,MAAM,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,CAAC;QAC3D,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,uBAAuB,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;QACtE,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,MAAM;QACJ,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;IACxC,CAAC;IAED,KAAK;QACH,OAAO,IAAI,aAAa,CACtB,IAAI,CAAC,MAAM,EACX,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CACzC,CAAC;IACJ,CAAC;CACF;AAGD,MAAM,CAAC,MAAM,eAAe,GAAG,EAAE,CAAC;AAUlC,MAAM,CAAC,MAAM,gBAAgB,GAAG,EAAE,CAAC"}
@@ -1,3 +0,0 @@
1
- export * from "./PureJSCrypto.js";
2
- export * from "./WasmCrypto.js";
3
- //# sourceMappingURL=export.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"export.js","sourceRoot":"","sources":["../../../src/crypto/export.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,iBAAiB,CAAC"}
@@ -1,48 +0,0 @@
1
- import { base64URLtoBytes, bytesToBase64url } from "./base64url.js";
2
- import { CoValueCore, MAX_RECOMMENDED_TX_SIZE, idforHeader, } from "./coValueCore.js";
3
- import { ControlledAgent, RawAccount, RawControlledAccount, RawProfile, accountHeaderForInitialAgentSecret, } from "./coValues/account.js";
4
- import { RawCoList } from "./coValues/coList.js";
5
- import { RawCoMap } from "./coValues/coMap.js";
6
- import { RawCoPlainText, stringifyOpID } from "./coValues/coPlainText.js";
7
- import { RawBinaryCoStream, RawCoStream, } from "./coValues/coStream.js";
8
- import { EVERYONE, RawGroup } from "./coValues/group.js";
9
- import { CryptoProvider, StreamingHash, secretSeedLength, shortHashLength, } from "./crypto/crypto.js";
10
- import { getGroupDependentKey, getGroupDependentKeyList, isRawCoID, rawCoIDfromBytes, rawCoIDtoBytes, } from "./ids.js";
11
- import { parseJSON, stableStringify } from "./jsonStringify.js";
12
- import { LocalNode } from "./localNode.js";
13
- import { Channel, connectedPeers } from "./streamUtils.js";
14
- import { accountOrAgentIDfromSessionID } from "./typeUtils/accountOrAgentIDfromSessionID.js";
15
- import { expectGroup } from "./typeUtils/expectGroup.js";
16
- import { isAccountID } from "./typeUtils/isAccountID.js";
17
- import { disablePermissionErrors } from "./permissions.js";
18
- import { emptyKnownState, } from "./sync.js";
19
- import { CO_VALUE_LOADING_CONFIG } from "./coValueState.js";
20
- import { logger } from "./logger.js";
21
- import { getPriorityFromHeader } from "./priority.js";
22
- import { LSMStorage } from "./storage/index.js";
23
- /** @hidden */
24
- export const cojsonInternals = {
25
- connectedPeers,
26
- rawCoIDtoBytes,
27
- rawCoIDfromBytes,
28
- secretSeedLength,
29
- shortHashLength,
30
- expectGroup,
31
- base64URLtoBytes,
32
- bytesToBase64url,
33
- parseJSON,
34
- stableStringify,
35
- accountOrAgentIDfromSessionID,
36
- isAccountID,
37
- accountHeaderForInitialAgentSecret,
38
- idforHeader,
39
- StreamingHash,
40
- Channel,
41
- getPriorityFromHeader,
42
- getGroupDependentKeyList,
43
- getGroupDependentKey,
44
- disablePermissionErrors,
45
- CO_VALUE_LOADING_CONFIG,
46
- };
47
- export { LocalNode, RawGroup, EVERYONE, RawCoMap, RawCoList, RawCoStream, RawBinaryCoStream, RawAccount, RawProfile as Profile, CoValueCore, ControlledAgent, RawControlledAccount, MAX_RECOMMENDED_TX_SIZE, CryptoProvider, isRawCoID, LSMStorage, emptyKnownState, RawCoPlainText, stringifyOpID, logger, base64URLtoBytes, bytesToBase64url, };
48
- //# sourceMappingURL=exports.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"exports.js","sourceRoot":"","sources":["../../src/exports.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAEpE,OAAO,EACL,WAAW,EAEX,uBAAuB,EACvB,WAAW,GACZ,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EACL,eAAe,EACf,UAAU,EACV,oBAAoB,EACpB,UAAU,EACV,kCAAkC,GACnC,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EAAQ,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAC/C,OAAO,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC1E,OAAO,EAIL,iBAAiB,EACjB,WAAW,GACZ,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAEzD,OAAO,EACL,cAAc,EACd,aAAa,EACb,gBAAgB,EAChB,eAAe,GAChB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EACL,oBAAoB,EACpB,wBAAwB,EACxB,SAAS,EACT,gBAAgB,EAChB,cAAc,GACf,MAAM,UAAU,CAAC;AAClB,OAAO,EAAe,SAAS,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAC7E,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C,OAAO,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAC3D,OAAO,EAAE,6BAA6B,EAAE,MAAM,8CAA8C,CAAC;AAC7F,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AACzD,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AAiBzD,OAAO,EAAE,uBAAuB,EAAE,MAAM,kBAAkB,CAAC;AAO3D,OAAO,EAGL,eAAe,GAChB,MAAM,WAAW,CAAC;AAInB,OAAO,EAAE,uBAAuB,EAAE,MAAM,mBAAmB,CAAC;AAC5D,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,qBAAqB,EAAE,MAAM,eAAe,CAAC;AAEtD,OAAO,EAAiB,UAAU,EAAe,MAAM,oBAAoB,CAAC;AAE5E,cAAc;AACd,MAAM,CAAC,MAAM,eAAe,GAAG;IAC7B,cAAc;IACd,cAAc;IACd,gBAAgB;IAChB,gBAAgB;IAChB,eAAe;IACf,WAAW;IACX,gBAAgB;IAChB,gBAAgB;IAChB,SAAS;IACT,eAAe;IACf,6BAA6B;IAC7B,WAAW;IACX,kCAAkC;IAClC,WAAW;IACX,aAAa;IACb,OAAO;IACP,qBAAqB;IACrB,wBAAwB;IACxB,oBAAoB;IACpB,uBAAuB;IACvB,uBAAuB;CACxB,CAAC;AAEF,OAAO,EACL,SAAS,EACT,QAAQ,EAER,QAAQ,EAER,QAAQ,EACR,SAAS,EACT,WAAW,EACX,iBAAiB,EAKjB,UAAU,EAIV,UAAU,IAAI,OAAO,EAGrB,WAAW,EACX,eAAe,EACf,oBAAoB,EACpB,uBAAuB,EASvB,cAAc,EAEd,SAAS,EACT,UAAU,EACV,eAAe,EACf,cAAc,EACd,aAAa,EACb,MAAM,EACN,gBAAgB,EAChB,gBAAgB,GACjB,CAAC"}
package/dist/web/ids.js DELETED
@@ -1,50 +0,0 @@
1
- import { base58 } from "@scure/base";
2
- import { shortHashLength } from "./crypto/crypto.js";
3
- export function isRawCoID(id) {
4
- return typeof id === "string" && id.startsWith("co_z");
5
- }
6
- export function rawCoIDtoBytes(id) {
7
- return base58.decode(id.substring("co_z".length));
8
- }
9
- export function rawCoIDfromBytes(bytes) {
10
- return `co_z${base58.encode(bytes.slice(0, shortHashLength))}`;
11
- }
12
- export function isAgentID(id) {
13
- return (typeof id === "string" &&
14
- id.startsWith("sealer_") &&
15
- id.includes("/signer_"));
16
- }
17
- export function isParentGroupReference(key) {
18
- return key.startsWith("parent_");
19
- }
20
- export function getParentGroupId(key) {
21
- return key.slice("parent_".length);
22
- }
23
- export function isChildGroupReference(key) {
24
- return key.startsWith("child_");
25
- }
26
- export function getChildGroupId(key) {
27
- return key.slice("child_".length);
28
- }
29
- export function getGroupDependentKey(key) {
30
- if (typeof key !== "string")
31
- return undefined;
32
- if (isParentGroupReference(key)) {
33
- return getParentGroupId(key);
34
- }
35
- else if (key.startsWith("co_")) {
36
- return key;
37
- }
38
- return undefined;
39
- }
40
- export function getGroupDependentKeyList(keys) {
41
- const groupDependentKeys = [];
42
- for (const key of keys) {
43
- const value = getGroupDependentKey(key);
44
- if (value) {
45
- groupDependentKeys.push(value);
46
- }
47
- }
48
- return groupDependentKeys;
49
- }
50
- //# sourceMappingURL=ids.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ids.js","sourceRoot":"","sources":["../../src/ids.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAGrC,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAOrD,MAAM,UAAU,SAAS,CAAC,EAAW;IACnC,OAAO,OAAO,EAAE,KAAK,QAAQ,IAAI,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;AACzD,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,EAAW;IACxC,OAAO,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;AACpD,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,KAAiB;IAChD,OAAO,OAAO,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,eAAe,CAAC,CAAC,EAAa,CAAC;AAC5E,CAAC;AAMD,MAAM,UAAU,SAAS,CAAC,EAAU;IAClC,OAAO,CACL,OAAO,EAAE,KAAK,QAAQ;QACtB,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC;QACxB,EAAE,CAAC,QAAQ,CAAC,UAAU,CAAC,CACxB,CAAC;AACJ,CAAC;AAID,MAAM,UAAU,sBAAsB,CACpC,GAAW;IAEX,OAAO,GAAG,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;AACnC,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,GAAyB;IACxD,OAAO,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,CAAmB,CAAC;AACvD,CAAC;AAED,MAAM,UAAU,qBAAqB,CAAC,GAAW;IAC/C,OAAO,GAAG,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;AAClC,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,GAAwB;IACtD,OAAO,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAmB,CAAC;AACtD,CAAC;AAED,MAAM,UAAU,oBAAoB,CAAC,GAAY;IAC/C,IAAI,OAAO,GAAG,KAAK,QAAQ;QAAE,OAAO,SAAS,CAAC;IAE9C,IAAI,sBAAsB,CAAC,GAAG,CAAC,EAAE,CAAC;QAChC,OAAO,gBAAgB,CAAC,GAAG,CAAC,CAAC;IAC/B,CAAC;SAAM,IAAI,GAAG,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC;QACjC,OAAO,GAAc,CAAC;IACxB,CAAC;IAED,OAAO,SAAS,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,wBAAwB,CAAC,IAAe;IACtD,MAAM,kBAAkB,GAAc,EAAE,CAAC;IAEzC,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;QACvB,MAAM,KAAK,GAAG,oBAAoB,CAAC,GAAG,CAAC,CAAC;QAExC,IAAI,KAAK,EAAE,CAAC;YACV,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACjC,CAAC;IACH,CAAC;IAED,OAAO,kBAAkB,CAAC;AAC5B,CAAC"}
@@ -1,3 +0,0 @@
1
- export * from "./exports.js";
2
- export { WasmCrypto } from "./crypto/WasmCrypto.js";
3
- //# sourceMappingURL=index.web.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.web.js","sourceRoot":"","sources":["../../src/index.web.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAC;AAC7B,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC"}
@@ -1,57 +0,0 @@
1
- // adapted from fast-json-stable-stringify (https://github.com/epoberezkin/fast-json-stable-stringify)
2
- export function stableStringify(data) {
3
- const cycles = false;
4
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
5
- const seen = [];
6
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
7
- let node = data;
8
- if (node && node.toJSON && typeof node.toJSON === "function") {
9
- node = node.toJSON();
10
- }
11
- if (node === undefined)
12
- return;
13
- if (typeof node == "number")
14
- return (isFinite(node) ? "" + node : "null");
15
- if (typeof node !== "object") {
16
- if (typeof node === "string" &&
17
- (node.startsWith("encrypted_U") || node.startsWith("binary_U"))) {
18
- return `"${node}"`;
19
- }
20
- return JSON.stringify(node);
21
- }
22
- let i, out;
23
- if (Array.isArray(node)) {
24
- out = "[";
25
- for (i = 0; i < node.length; i++) {
26
- if (i)
27
- out += ",";
28
- out += stableStringify(node[i]) || "null";
29
- }
30
- return (out + "]");
31
- }
32
- if (node === null)
33
- return "null";
34
- if (seen.indexOf(node) !== -1) {
35
- if (cycles)
36
- return JSON.stringify("__cycle__");
37
- throw new TypeError("Converting circular structure to JSON");
38
- }
39
- const seenIndex = seen.push(node) - 1;
40
- const keys = Object.keys(node).sort();
41
- out = "";
42
- for (i = 0; i < keys.length; i++) {
43
- const key = keys[i];
44
- const value = stableStringify(node[key]);
45
- if (!value)
46
- continue;
47
- if (out)
48
- out += ",";
49
- out += JSON.stringify(key) + ":" + value;
50
- }
51
- seen.splice(seenIndex, 1);
52
- return ("{" + out + "}");
53
- }
54
- export function parseJSON(json) {
55
- return JSON.parse(json);
56
- }
57
- //# sourceMappingURL=jsonStringify.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"jsonStringify.js","sourceRoot":"","sources":["../../src/jsonStringify.ts"],"names":[],"mappings":"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"}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=jsonValue.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"jsonValue.js","sourceRoot":"","sources":["../../src/jsonValue.ts"],"names":[],"mappings":""}