@unlink-xyz/core 0.1.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.
Files changed (185) hide show
  1. package/dist/account/zkAccount.d.ts +38 -0
  2. package/dist/account/zkAccount.d.ts.map +1 -0
  3. package/dist/account/zkAccount.js +128 -0
  4. package/dist/clients/broadcaster.d.ts +33 -0
  5. package/dist/clients/broadcaster.d.ts.map +1 -0
  6. package/dist/clients/broadcaster.js +23 -0
  7. package/dist/clients/http.d.ts +23 -0
  8. package/dist/clients/http.d.ts.map +1 -0
  9. package/dist/clients/http.js +57 -0
  10. package/dist/clients/indexer.d.ts +44 -0
  11. package/dist/clients/indexer.d.ts.map +1 -0
  12. package/dist/clients/indexer.js +67 -0
  13. package/dist/config.d.ts +12 -0
  14. package/dist/config.d.ts.map +1 -0
  15. package/dist/config.js +29 -0
  16. package/dist/core.d.ts +10 -0
  17. package/dist/core.d.ts.map +1 -0
  18. package/dist/core.js +12 -0
  19. package/dist/errors.d.ts +10 -0
  20. package/dist/errors.d.ts.map +1 -0
  21. package/dist/errors.js +18 -0
  22. package/dist/index.d.ts +18 -0
  23. package/dist/index.d.ts.map +1 -0
  24. package/dist/index.js +16 -0
  25. package/dist/key-derivation/babyjubjub.d.ts +9 -0
  26. package/dist/key-derivation/babyjubjub.d.ts.map +1 -0
  27. package/dist/key-derivation/babyjubjub.js +9 -0
  28. package/dist/key-derivation/bech32.d.ts +22 -0
  29. package/dist/key-derivation/bech32.d.ts.map +1 -0
  30. package/dist/key-derivation/bech32.js +86 -0
  31. package/dist/key-derivation/bip32.d.ts +17 -0
  32. package/dist/key-derivation/bip32.d.ts.map +1 -0
  33. package/dist/key-derivation/bip32.js +41 -0
  34. package/dist/key-derivation/bip39.d.ts +22 -0
  35. package/dist/key-derivation/bip39.d.ts.map +1 -0
  36. package/dist/key-derivation/bip39.js +56 -0
  37. package/dist/key-derivation/bytes.d.ts +19 -0
  38. package/dist/key-derivation/bytes.d.ts.map +1 -0
  39. package/dist/key-derivation/bytes.js +92 -0
  40. package/dist/key-derivation/hash.d.ts +3 -0
  41. package/dist/key-derivation/hash.d.ts.map +1 -0
  42. package/dist/key-derivation/hash.js +10 -0
  43. package/dist/key-derivation/index.d.ts +8 -0
  44. package/dist/key-derivation/index.d.ts.map +1 -0
  45. package/dist/key-derivation/index.js +7 -0
  46. package/dist/key-derivation/wallet-node.d.ts +45 -0
  47. package/dist/key-derivation/wallet-node.d.ts.map +1 -0
  48. package/dist/key-derivation/wallet-node.js +109 -0
  49. package/dist/keys.d.ts +22 -0
  50. package/dist/keys.d.ts.map +1 -0
  51. package/dist/keys.js +41 -0
  52. package/dist/prover/config.d.ts +60 -0
  53. package/dist/prover/config.d.ts.map +1 -0
  54. package/dist/prover/config.js +80 -0
  55. package/dist/prover/index.d.ts +2 -0
  56. package/dist/prover/index.d.ts.map +1 -0
  57. package/dist/prover/index.js +1 -0
  58. package/dist/prover/prover.d.ts +59 -0
  59. package/dist/prover/prover.d.ts.map +1 -0
  60. package/dist/prover/prover.js +274 -0
  61. package/dist/prover/registry.d.ts +39 -0
  62. package/dist/prover/registry.d.ts.map +1 -0
  63. package/dist/prover/registry.js +57 -0
  64. package/dist/schema.d.ts +4 -0
  65. package/dist/schema.d.ts.map +1 -0
  66. package/dist/schema.js +14 -0
  67. package/dist/state/ciphertext-store.d.ts +12 -0
  68. package/dist/state/ciphertext-store.d.ts.map +1 -0
  69. package/dist/state/ciphertext-store.js +25 -0
  70. package/dist/state/index.d.ts +3 -0
  71. package/dist/state/index.d.ts.map +1 -0
  72. package/dist/state/index.js +2 -0
  73. package/dist/state/leaf-store.d.ts +17 -0
  74. package/dist/state/leaf-store.d.ts.map +1 -0
  75. package/dist/state/leaf-store.js +35 -0
  76. package/dist/state/merkle/hydrator.d.ts +27 -0
  77. package/dist/state/merkle/hydrator.d.ts.map +1 -0
  78. package/dist/state/merkle/hydrator.js +36 -0
  79. package/dist/state/merkle/index.d.ts +3 -0
  80. package/dist/state/merkle/index.d.ts.map +1 -0
  81. package/dist/state/merkle/index.js +2 -0
  82. package/dist/state/merkle/merkle-tree.d.ts +34 -0
  83. package/dist/state/merkle/merkle-tree.d.ts.map +1 -0
  84. package/dist/state/merkle/merkle-tree.js +104 -0
  85. package/dist/state/merkle-tree.d.ts +34 -0
  86. package/dist/state/merkle-tree.d.ts.map +1 -0
  87. package/dist/state/merkle-tree.js +104 -0
  88. package/dist/state/note-store.d.ts +37 -0
  89. package/dist/state/note-store.d.ts.map +1 -0
  90. package/dist/state/note-store.js +133 -0
  91. package/dist/state/nullifier-store.d.ts +13 -0
  92. package/dist/state/nullifier-store.d.ts.map +1 -0
  93. package/dist/state/nullifier-store.js +21 -0
  94. package/dist/state/records.d.ts +57 -0
  95. package/dist/state/records.d.ts.map +1 -0
  96. package/dist/state/records.js +1 -0
  97. package/dist/state/root-store.d.ts +13 -0
  98. package/dist/state/root-store.d.ts.map +1 -0
  99. package/dist/state/root-store.js +30 -0
  100. package/dist/state/store/ciphertext-store.d.ts +12 -0
  101. package/dist/state/store/ciphertext-store.d.ts.map +1 -0
  102. package/dist/state/store/ciphertext-store.js +25 -0
  103. package/dist/state/store/index.d.ts +10 -0
  104. package/dist/state/store/index.d.ts.map +1 -0
  105. package/dist/state/store/index.js +8 -0
  106. package/dist/state/store/job-store.d.ts +12 -0
  107. package/dist/state/store/job-store.d.ts.map +1 -0
  108. package/dist/state/store/job-store.js +118 -0
  109. package/dist/state/store/jobs.d.ts +50 -0
  110. package/dist/state/store/jobs.d.ts.map +1 -0
  111. package/dist/state/store/jobs.js +1 -0
  112. package/dist/state/store/leaf-store.d.ts +17 -0
  113. package/dist/state/store/leaf-store.d.ts.map +1 -0
  114. package/dist/state/store/leaf-store.js +35 -0
  115. package/dist/state/store/note-store.d.ts +38 -0
  116. package/dist/state/store/note-store.d.ts.map +1 -0
  117. package/dist/state/store/note-store.js +142 -0
  118. package/dist/state/store/nullifier-store.d.ts +17 -0
  119. package/dist/state/store/nullifier-store.d.ts.map +1 -0
  120. package/dist/state/store/nullifier-store.js +30 -0
  121. package/dist/state/store/records.d.ts +57 -0
  122. package/dist/state/store/records.d.ts.map +1 -0
  123. package/dist/state/store/records.js +1 -0
  124. package/dist/state/store/root-store.d.ts +13 -0
  125. package/dist/state/store/root-store.d.ts.map +1 -0
  126. package/dist/state/store/root-store.js +30 -0
  127. package/dist/state/store/store.d.ts +34 -0
  128. package/dist/state/store/store.d.ts.map +1 -0
  129. package/dist/state/store/store.js +22 -0
  130. package/dist/state/store.d.ts +26 -0
  131. package/dist/state/store.d.ts.map +1 -0
  132. package/dist/state/store.js +19 -0
  133. package/dist/storage/index.d.ts +4 -0
  134. package/dist/storage/index.d.ts.map +1 -0
  135. package/dist/storage/index.js +2 -0
  136. package/dist/storage/indexeddb.d.ts +27 -0
  137. package/dist/storage/indexeddb.d.ts.map +1 -0
  138. package/dist/storage/indexeddb.js +205 -0
  139. package/dist/storage/memory.d.ts +25 -0
  140. package/dist/storage/memory.d.ts.map +1 -0
  141. package/dist/storage/memory.js +87 -0
  142. package/dist/transactions/deposit.d.ts +18 -0
  143. package/dist/transactions/deposit.d.ts.map +1 -0
  144. package/dist/transactions/deposit.js +173 -0
  145. package/dist/transactions/index.d.ts +7 -0
  146. package/dist/transactions/index.d.ts.map +1 -0
  147. package/dist/transactions/index.js +4 -0
  148. package/dist/transactions/note-sync.d.ts +46 -0
  149. package/dist/transactions/note-sync.d.ts.map +1 -0
  150. package/dist/transactions/note-sync.js +320 -0
  151. package/dist/transactions/reconcile.d.ts +22 -0
  152. package/dist/transactions/reconcile.d.ts.map +1 -0
  153. package/dist/transactions/reconcile.js +39 -0
  154. package/dist/transactions/transact.d.ts +34 -0
  155. package/dist/transactions/transact.d.ts.map +1 -0
  156. package/dist/transactions/transact.js +561 -0
  157. package/dist/transactions/types.d.ts +114 -0
  158. package/dist/transactions/types.d.ts.map +1 -0
  159. package/dist/transactions/types.js +1 -0
  160. package/dist/tsconfig.tsbuildinfo +1 -0
  161. package/dist/types.d.ts +27 -0
  162. package/dist/types.d.ts.map +1 -0
  163. package/dist/types.js +1 -0
  164. package/dist/utils/async.d.ts +10 -0
  165. package/dist/utils/async.d.ts.map +1 -0
  166. package/dist/utils/async.js +13 -0
  167. package/dist/utils/bigint.d.ts +9 -0
  168. package/dist/utils/bigint.d.ts.map +1 -0
  169. package/dist/utils/bigint.js +29 -0
  170. package/dist/utils/crypto.d.ts +12 -0
  171. package/dist/utils/crypto.d.ts.map +1 -0
  172. package/dist/utils/crypto.js +39 -0
  173. package/dist/utils/json-codec.d.ts +9 -0
  174. package/dist/utils/json-codec.d.ts.map +1 -0
  175. package/dist/utils/json-codec.js +25 -0
  176. package/dist/utils/polling.d.ts +7 -0
  177. package/dist/utils/polling.d.ts.map +1 -0
  178. package/dist/utils/polling.js +6 -0
  179. package/dist/utils/signature.d.ts +9 -0
  180. package/dist/utils/signature.d.ts.map +1 -0
  181. package/dist/utils/signature.js +12 -0
  182. package/dist/utils/validators.d.ts +30 -0
  183. package/dist/utils/validators.d.ts.map +1 -0
  184. package/dist/utils/validators.js +70 -0
  185. package/package.json +52 -0
@@ -0,0 +1,38 @@
1
+ import { type SpendingKeyPair, type ViewingKeyPair } from "../key-derivation/wallet-node.js";
2
+ import type { Storage } from "../types.js";
3
+ export type MasterSeedCrypto = {
4
+ encrypt(seed: Uint8Array): Promise<Uint8Array> | Uint8Array;
5
+ decrypt(payload: Uint8Array): Promise<Uint8Array> | Uint8Array;
6
+ };
7
+ export type GenerateMasterSeedOptions = {
8
+ storage: Storage;
9
+ rng: (n: number) => Uint8Array;
10
+ crypto?: MasterSeedCrypto;
11
+ overwrite?: boolean;
12
+ mnemonicPassphrase: string;
13
+ };
14
+ export declare const MASTER_SEED_LENGTH = 64;
15
+ export declare const MASTER_SEED_KEY = "cfg:wallet:master_seed/v1";
16
+ export declare const MASTER_MNEMONIC_KEY = "cfg:wallet:master_mnemonic/v1";
17
+ export type ZkAccount = {
18
+ spendingKeyPair: SpendingKeyPair;
19
+ viewingKeyPair: ViewingKeyPair;
20
+ nullifyingKey: bigint;
21
+ masterPublicKey: bigint;
22
+ };
23
+ export declare function deriveZkAccount(masterSeed: Uint8Array, accountIndex?: number): Promise<ZkAccount>;
24
+ export declare function deriveZkAccountFromMnemonic(mnemonic: string, accountIndex?: number, password?: string): Promise<ZkAccount>;
25
+ export declare function generateMasterSeed({ storage, rng, crypto, overwrite, mnemonicPassphrase, }: GenerateMasterSeedOptions): Promise<Uint8Array>;
26
+ export declare function loadMasterSeed(storage: Storage, crypto?: MasterSeedCrypto): Promise<Uint8Array | null>;
27
+ export declare function storeMasterSeed(storage: Storage, seed: Uint8Array, crypto?: MasterSeedCrypto): Promise<void>;
28
+ export declare function loadMasterMnemonic(storage: Storage, crypto?: MasterSeedCrypto): Promise<string | null>;
29
+ export type ImportMasterMnemonicOptions = {
30
+ storage: Storage;
31
+ mnemonic: string;
32
+ crypto?: MasterSeedCrypto;
33
+ overwrite?: boolean;
34
+ password?: string;
35
+ };
36
+ export declare function importMasterMnemonic({ storage, mnemonic, crypto, overwrite, password, }: ImportMasterMnemonicOptions): Promise<Uint8Array>;
37
+ export declare function storeMasterMnemonic(storage: Storage, mnemonic: string, crypto?: MasterSeedCrypto): Promise<void>;
38
+ //# sourceMappingURL=zkAccount.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"zkAccount.d.ts","sourceRoot":"","sources":["../../account/zkAccount.ts"],"names":[],"mappings":"AAEA,OAAO,EAGL,KAAK,eAAe,EACpB,KAAK,cAAc,EACpB,MAAM,kCAAkC,CAAC;AAC1C,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAE3C,MAAM,MAAM,gBAAgB,GAAG;IAC7B,OAAO,CAAC,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC,GAAG,UAAU,CAAC;IAC5D,OAAO,CAAC,OAAO,EAAE,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC,GAAG,UAAU,CAAC;CAChE,CAAC;AAEF,MAAM,MAAM,yBAAyB,GAAG;IACtC,OAAO,EAAE,OAAO,CAAC;IACjB,GAAG,EAAE,CAAC,CAAC,EAAE,MAAM,KAAK,UAAU,CAAC;IAC/B,MAAM,CAAC,EAAE,gBAAgB,CAAC;IAC1B,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,kBAAkB,EAAE,MAAM,CAAC;CAC5B,CAAC;AAEF,eAAO,MAAM,kBAAkB,KAAK,CAAC;AACrC,eAAO,MAAM,eAAe,8BAA8B,CAAC;AAC3D,eAAO,MAAM,mBAAmB,kCAAkC,CAAC;AAOnE,MAAM,MAAM,SAAS,GAAG;IACtB,eAAe,EAAE,eAAe,CAAC;IACjC,cAAc,EAAE,cAAc,CAAC;IAC/B,aAAa,EAAE,MAAM,CAAC;IACtB,eAAe,EAAE,MAAM,CAAC;CACzB,CAAC;AAEF,wBAAsB,eAAe,CACnC,UAAU,EAAE,UAAU,EACtB,YAAY,GAAE,MAAU,GACvB,OAAO,CAAC,SAAS,CAAC,CAqBpB;AAED,wBAAsB,2BAA2B,CAC/C,QAAQ,EAAE,MAAM,EAChB,YAAY,GAAE,MAAU,EACxB,QAAQ,GAAE,MAAW,GACpB,OAAO,CAAC,SAAS,CAAC,CAIpB;AAWD,wBAAsB,kBAAkB,CAAC,EACvC,OAAO,EACP,GAAG,EACH,MAAiC,EACjC,SAAiB,EACjB,kBAAkB,GACnB,EAAE,yBAAyB,GAAG,OAAO,CAAC,UAAU,CAAC,CA0BjD;AAED,wBAAsB,cAAc,CAClC,OAAO,EAAE,OAAO,EAChB,MAAM,GAAE,gBAA2C,GAClD,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC,CAK5B;AAED,wBAAsB,eAAe,CACnC,OAAO,EAAE,OAAO,EAChB,IAAI,EAAE,UAAU,EAChB,MAAM,GAAE,gBAA2C,GAClD,OAAO,CAAC,IAAI,CAAC,CAOf;AAED,wBAAsB,kBAAkB,CACtC,OAAO,EAAE,OAAO,EAChB,MAAM,GAAE,gBAA2C,GAClD,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAMxB;AAED,MAAM,MAAM,2BAA2B,GAAG;IACxC,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,CAAC,EAAE,gBAAgB,CAAC;IAC1B,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF,wBAAsB,oBAAoB,CAAC,EACzC,OAAO,EACP,QAAQ,EACR,MAAiC,EACjC,SAAiB,EACjB,QAAa,GACd,EAAE,2BAA2B,GAAG,OAAO,CAAC,UAAU,CAAC,CAenD;AAED,wBAAsB,mBAAmB,CACvC,OAAO,EAAE,OAAO,EAChB,QAAQ,EAAE,MAAM,EAChB,MAAM,GAAE,gBAA2C,GAClD,OAAO,CAAC,IAAI,CAAC,CAOf"}
@@ -0,0 +1,128 @@
1
+ import { Mnemonic } from "../key-derivation/bip39.js";
2
+ import { ByteUtils } from "../key-derivation/bytes.js";
3
+ import { deriveNodesFromSeed, WalletNode, } from "../key-derivation/wallet-node.js";
4
+ export const MASTER_SEED_LENGTH = 64;
5
+ export const MASTER_SEED_KEY = "cfg:wallet:master_seed/v1";
6
+ export const MASTER_MNEMONIC_KEY = "cfg:wallet:master_mnemonic/v1";
7
+ const MNEMONIC_ENTROPY_BYTES = 32;
8
+ const textEncoder = new TextEncoder();
9
+ const textDecoder = new TextDecoder();
10
+ export async function deriveZkAccount(masterSeed, accountIndex = 0) {
11
+ const seed = normalizeMasterSeed(masterSeed);
12
+ if (!Number.isInteger(accountIndex) || accountIndex < 0) {
13
+ throw new Error("accountIndex must be a non-negative integer");
14
+ }
15
+ const { spending, viewing } = deriveNodesFromSeed(seed, accountIndex);
16
+ const spendingKeyPair = spending.getSpendingKeyPair();
17
+ const viewingKeyPair = await viewing.getViewingKeyPair();
18
+ const nullifyingKey = WalletNode.getNullifyingKey(viewingKeyPair.privateKey);
19
+ const masterPublicKey = WalletNode.getMasterPublicKey(spendingKeyPair.pubkey, nullifyingKey);
20
+ return {
21
+ spendingKeyPair,
22
+ viewingKeyPair,
23
+ nullifyingKey,
24
+ masterPublicKey,
25
+ };
26
+ }
27
+ export async function deriveZkAccountFromMnemonic(mnemonic, accountIndex = 0, password = "") {
28
+ const normalized = normalizeMnemonic(mnemonic);
29
+ const seed = mnemonicToSeed(normalized, password);
30
+ return deriveZkAccount(seed, accountIndex);
31
+ }
32
+ const identityMasterSeedCrypto = {
33
+ encrypt(seed) {
34
+ return clone(seed);
35
+ },
36
+ decrypt(payload) {
37
+ return clone(payload);
38
+ },
39
+ };
40
+ export async function generateMasterSeed({ storage, rng, crypto = identityMasterSeedCrypto, overwrite = false, mnemonicPassphrase, }) {
41
+ if (!overwrite) {
42
+ const existingSeed = await loadMasterSeed(storage, crypto);
43
+ if (existingSeed)
44
+ return existingSeed;
45
+ const existingMnemonic = await loadMasterMnemonic(storage, crypto);
46
+ if (existingMnemonic) {
47
+ const seedFromMnemonic = mnemonicToSeed(existingMnemonic, mnemonicPassphrase);
48
+ await storeMasterSeed(storage, seedFromMnemonic, crypto);
49
+ return seedFromMnemonic;
50
+ }
51
+ }
52
+ const entropy = rng(MNEMONIC_ENTROPY_BYTES);
53
+ if (entropy.length !== MNEMONIC_ENTROPY_BYTES) {
54
+ throw new Error(`mnemonic entropy must be ${MNEMONIC_ENTROPY_BYTES} bytes`);
55
+ }
56
+ const mnemonic = Mnemonic.fromEntropy(ByteUtils.bytesToHex(entropy));
57
+ await storeMasterMnemonic(storage, mnemonic, crypto);
58
+ const seed = mnemonicToSeed(mnemonic, mnemonicPassphrase);
59
+ await storeMasterSeed(storage, seed, crypto);
60
+ return seed;
61
+ }
62
+ export async function loadMasterSeed(storage, crypto = identityMasterSeedCrypto) {
63
+ const stored = await storage.get(MASTER_SEED_KEY);
64
+ if (!stored)
65
+ return null;
66
+ const plaintext = await crypto.decrypt(stored);
67
+ return normalizeMasterSeed(plaintext);
68
+ }
69
+ export async function storeMasterSeed(storage, seed, crypto = identityMasterSeedCrypto) {
70
+ const normalized = normalizeMasterSeed(seed);
71
+ const encrypted = await crypto.encrypt(normalized);
72
+ if (!(encrypted instanceof Uint8Array)) {
73
+ throw new Error("master seed encryptor must return Uint8Array");
74
+ }
75
+ await storage.put(MASTER_SEED_KEY, clone(encrypted));
76
+ }
77
+ export async function loadMasterMnemonic(storage, crypto = identityMasterSeedCrypto) {
78
+ const stored = await storage.get(MASTER_MNEMONIC_KEY);
79
+ if (!stored)
80
+ return null;
81
+ const plaintext = await crypto.decrypt(stored);
82
+ const mnemonic = textDecoder.decode(plaintext);
83
+ return normalizeMnemonic(mnemonic);
84
+ }
85
+ export async function importMasterMnemonic({ storage, mnemonic, crypto = identityMasterSeedCrypto, overwrite = false, password = "", }) {
86
+ if (!overwrite) {
87
+ const existing = await loadMasterMnemonic(storage, crypto);
88
+ if (existing) {
89
+ throw new Error("master mnemonic already exists; set overwrite to true to replace it");
90
+ }
91
+ }
92
+ const normalized = normalizeMnemonic(mnemonic);
93
+ const seed = mnemonicToSeed(normalized, password);
94
+ await storeMasterMnemonic(storage, normalized, crypto);
95
+ await storeMasterSeed(storage, seed, crypto);
96
+ return seed;
97
+ }
98
+ export async function storeMasterMnemonic(storage, mnemonic, crypto = identityMasterSeedCrypto) {
99
+ const normalized = normalizeMnemonic(mnemonic);
100
+ const encrypted = await crypto.encrypt(textEncoder.encode(normalized));
101
+ if (!(encrypted instanceof Uint8Array)) {
102
+ throw new Error("master mnemonic encryptor must return Uint8Array");
103
+ }
104
+ await storage.put(MASTER_MNEMONIC_KEY, clone(encrypted));
105
+ }
106
+ function clone(bytes) {
107
+ return new Uint8Array(bytes);
108
+ }
109
+ function normalizeMasterSeed(seed) {
110
+ if (!(seed instanceof Uint8Array)) {
111
+ throw new Error("master seed must be a Uint8Array");
112
+ }
113
+ if (seed.length !== MASTER_SEED_LENGTH) {
114
+ throw new Error(`master seed must be ${MASTER_SEED_LENGTH} bytes`);
115
+ }
116
+ return clone(seed);
117
+ }
118
+ function normalizeMnemonic(mnemonic) {
119
+ const formatted = mnemonic.trim().replace(/\s+/g, " ");
120
+ if (!Mnemonic.validate(formatted)) {
121
+ throw new Error("invalid BIP-39 mnemonic phrase");
122
+ }
123
+ return formatted;
124
+ }
125
+ function mnemonicToSeed(mnemonic, password = "") {
126
+ const seedHex = Mnemonic.toSeed(mnemonic, password);
127
+ return ByteUtils.hexStringToBytes(seedHex);
128
+ }
@@ -0,0 +1,33 @@
1
+ import type { FetchLike } from "./http.js";
2
+ export type BroadcasterRelayPayload = {
3
+ kind: "call_data";
4
+ to: string;
5
+ data: string;
6
+ };
7
+ export type SubmitRelayParams = {
8
+ clientTxId: string;
9
+ chainId: number;
10
+ payload: BroadcasterRelayPayload;
11
+ };
12
+ export type SubmitRelayResponse = {
13
+ id: string;
14
+ accepted: boolean;
15
+ message?: string | null;
16
+ };
17
+ export type RelayState = "pending" | "broadcasting" | "succeeded" | "failed" | "dead";
18
+ export type RelayStatusResponse = {
19
+ id: string;
20
+ state: RelayState;
21
+ txHash?: string | null;
22
+ receipt?: unknown;
23
+ error?: string | null;
24
+ };
25
+ type BroadcasterClientDeps = {
26
+ fetch: FetchLike;
27
+ };
28
+ export declare function createBroadcasterClient(baseUrl: string, deps: BroadcasterClientDeps): {
29
+ submitRelay(params: SubmitRelayParams): Promise<SubmitRelayResponse>;
30
+ getRelayStatus(relayId: string): Promise<RelayStatusResponse>;
31
+ };
32
+ export {};
33
+ //# sourceMappingURL=broadcaster.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"broadcaster.d.ts","sourceRoot":"","sources":["../../clients/broadcaster.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAG3C,MAAM,MAAM,uBAAuB,GAAG;IACpC,IAAI,EAAE,WAAW,CAAC;IAClB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;CACd,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG;IAC9B,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,uBAAuB,CAAC;CAClC,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG;IAChC,EAAE,EAAE,MAAM,CAAC;IACX,QAAQ,EAAE,OAAO,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CACzB,CAAC;AAEF,MAAM,MAAM,UAAU,GAClB,SAAS,GACT,cAAc,GACd,WAAW,GACX,QAAQ,GACR,MAAM,CAAC;AAEX,MAAM,MAAM,mBAAmB,GAAG;IAChC,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,UAAU,CAAC;IAClB,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACvB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;CACvB,CAAC;AAEF,KAAK,qBAAqB,GAAG;IAC3B,KAAK,EAAE,SAAS,CAAC;CAClB,CAAC;AAEF,wBAAgB,uBAAuB,CACrC,OAAO,EAAE,MAAM,EACf,IAAI,EAAE,qBAAqB;wBAKC,iBAAiB;4BAYb,MAAM;EAOvC"}
@@ -0,0 +1,23 @@
1
+ import { createJsonHttpClient } from "./http.js";
2
+ export function createBroadcasterClient(baseUrl, deps) {
3
+ const http = createJsonHttpClient(baseUrl, deps);
4
+ return {
5
+ async submitRelay(params) {
6
+ return http.request({
7
+ method: "POST",
8
+ path: "/relays",
9
+ json: {
10
+ client_tx_id: params.clientTxId,
11
+ chain_id: params.chainId,
12
+ ...params.payload,
13
+ },
14
+ });
15
+ },
16
+ async getRelayStatus(relayId) {
17
+ return http.request({
18
+ method: "GET",
19
+ path: `/relays/${relayId}`,
20
+ });
21
+ },
22
+ };
23
+ }
@@ -0,0 +1,23 @@
1
+ export type FetchLike = (input: RequestInfo | URL, init?: RequestInit) => Promise<Response>;
2
+ export type JsonHttpDeps = {
3
+ fetch: FetchLike;
4
+ };
5
+ export type JsonRequestOptions = {
6
+ method: "GET" | "POST" | "PUT" | "PATCH" | "DELETE";
7
+ path: string;
8
+ query?: Record<string, string | number | boolean | undefined>;
9
+ json?: unknown;
10
+ body?: BodyInit;
11
+ headers?: HeadersInit;
12
+ signal?: AbortSignal;
13
+ };
14
+ export type JsonHttpClient = {
15
+ request<T>(opts: JsonRequestOptions): Promise<T>;
16
+ };
17
+ export declare class HttpError extends Error {
18
+ readonly status: number;
19
+ readonly body: unknown;
20
+ constructor(message: string, status: number, body: unknown);
21
+ }
22
+ export declare function createJsonHttpClient(baseUrl: string, deps: JsonHttpDeps): JsonHttpClient;
23
+ //# sourceMappingURL=http.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"http.d.ts","sourceRoot":"","sources":["../../clients/http.ts"],"names":[],"mappings":"AAEA,MAAM,MAAM,SAAS,GAAG,CACtB,KAAK,EAAE,WAAW,GAAG,GAAG,EACxB,IAAI,CAAC,EAAE,WAAW,KACf,OAAO,CAAC,QAAQ,CAAC,CAAC;AAEvB,MAAM,MAAM,YAAY,GAAG;IAAE,KAAK,EAAE,SAAS,CAAA;CAAE,CAAC;AAEhD,MAAM,MAAM,kBAAkB,GAAG;IAC/B,MAAM,EAAE,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,OAAO,GAAG,QAAQ,CAAC;IACpD,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,SAAS,CAAC,CAAC;IAC9D,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,IAAI,CAAC,EAAE,QAAQ,CAAC;IAChB,OAAO,CAAC,EAAE,WAAW,CAAC;IACtB,MAAM,CAAC,EAAE,WAAW,CAAC;CACtB,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG;IAC3B,OAAO,CAAC,CAAC,EAAE,IAAI,EAAE,kBAAkB,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;CAClD,CAAC;AAEF,qBAAa,SAAU,SAAQ,KAAK;IAClC,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC;gBAEX,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO;CAK3D;AAWD,wBAAgB,oBAAoB,CAClC,OAAO,EAAE,MAAM,EACf,IAAI,EAAE,YAAY,GACjB,cAAc,CA+ChB"}
@@ -0,0 +1,57 @@
1
+ import ky, { HTTPError, TimeoutError } from "ky";
2
+ export class HttpError extends Error {
3
+ status;
4
+ body;
5
+ constructor(message, status, body) {
6
+ super(message);
7
+ this.status = status;
8
+ this.body = body;
9
+ }
10
+ }
11
+ async function readErrorBodySafe(res) {
12
+ try {
13
+ return await res.clone().json();
14
+ }
15
+ catch {
16
+ const text = await res.text();
17
+ return text || null;
18
+ }
19
+ }
20
+ export function createJsonHttpClient(baseUrl, deps) {
21
+ if (!baseUrl)
22
+ throw new Error("baseUrl is required");
23
+ if (!deps?.fetch)
24
+ throw new Error("deps.fetch is required");
25
+ // Ensure `fetch` is invoked with a global `this` to avoid "Illegal invocation"
26
+ // errors in some browser environments when the function is extracted. // TODO: can we fix this in another way?
27
+ const fetchImpl = (...args) => deps.fetch.apply(globalThis, args);
28
+ const api = ky.create({
29
+ prefixUrl: baseUrl.replace(/\/+$/, ""),
30
+ fetch: fetchImpl,
31
+ });
32
+ return {
33
+ async request(opts) {
34
+ try {
35
+ const res = api(opts.path.replace(/^\//, ""), {
36
+ method: opts.method,
37
+ searchParams: opts.query,
38
+ json: opts.json,
39
+ body: opts.body,
40
+ headers: opts.headers,
41
+ signal: opts.signal,
42
+ });
43
+ return await res.json();
44
+ }
45
+ catch (err) {
46
+ if (err instanceof HTTPError) {
47
+ const body = await readErrorBodySafe(err.response);
48
+ throw new HttpError(`HTTP ${err.response.status} ${err.response.statusText}`.trim(), err.response.status, body);
49
+ }
50
+ if (err instanceof TimeoutError) {
51
+ throw new HttpError("HTTP timeout", 408, null);
52
+ }
53
+ throw new HttpError(err instanceof Error ? err.message : "Network error", 0, null);
54
+ }
55
+ },
56
+ };
57
+ }
@@ -0,0 +1,44 @@
1
+ import type { FetchLike } from "./http.js";
2
+ export type CommitmentRecord = {
3
+ index: number;
4
+ commitment: string;
5
+ ciphertext: [string, string, string];
6
+ root: string;
7
+ txHash: string;
8
+ insertedAt: number;
9
+ };
10
+ export type IndexerNullifierRecord = {
11
+ nullifier: string;
12
+ txHash: string;
13
+ spentAt: number;
14
+ chainId: number;
15
+ };
16
+ export type CommitmentBatchResponse = {
17
+ chainId: number;
18
+ commitments: CommitmentRecord[];
19
+ latestRoot: string | null;
20
+ };
21
+ export type FetchCommitmentsParams = {
22
+ chainId: number;
23
+ start?: number;
24
+ limit?: number;
25
+ };
26
+ export type GetCommitmentParams = {
27
+ chainId: number;
28
+ commitment: string;
29
+ };
30
+ export type GetNullifierParams = {
31
+ chainId: number;
32
+ nullifier: string;
33
+ };
34
+ type IndexerClientDeps = {
35
+ fetch: FetchLike;
36
+ };
37
+ export declare function createIndexerClient(baseUrl: string, deps: IndexerClientDeps): {
38
+ fetchCommitmentBatch(params: FetchCommitmentsParams): Promise<CommitmentBatchResponse>;
39
+ getCommitment(params: GetCommitmentParams): Promise<CommitmentRecord>;
40
+ getNullifier(params: GetNullifierParams): Promise<IndexerNullifierRecord | null>;
41
+ getNullifierCount(chainId: number): Promise<number>;
42
+ };
43
+ export {};
44
+ //# sourceMappingURL=indexer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"indexer.d.ts","sourceRoot":"","sources":["../../clients/indexer.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAc3C,MAAM,MAAM,gBAAgB,GAAG;IAC7B,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;IACrC,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,MAAM,CAAC;CACpB,CAAC;AASF,MAAM,MAAM,sBAAsB,GAAG;IACnC,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;CACjB,CAAC;AAQF,MAAM,MAAM,uBAAuB,GAAG;IACpC,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,EAAE,gBAAgB,EAAE,CAAC;IAChC,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;CAC3B,CAAC;AAEF,MAAM,MAAM,sBAAsB,GAAG;IACnC,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG;IAChC,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,kBAAkB,GAAG;IAC/B,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC;AAOF,KAAK,iBAAiB,GAAG;IACvB,KAAK,EAAE,SAAS,CAAC;CAClB,CAAC;AAEF,wBAAgB,mBAAmB,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,iBAAiB;iCAyB9D,sBAAsB,GAC7B,OAAO,CAAC,uBAAuB,CAAC;0BAgBzB,mBAAmB,GAC1B,OAAO,CAAC,gBAAgB,CAAC;yBAQlB,kBAAkB,GACzB,OAAO,CAAC,sBAAsB,GAAG,IAAI,CAAC;+BAcR,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;EAQ5D"}
@@ -0,0 +1,67 @@
1
+ import { isNotFoundError } from "../utils/async.js";
2
+ import { createJsonHttpClient } from "./http.js";
3
+ export function createIndexerClient(baseUrl, deps) {
4
+ const http = createJsonHttpClient(baseUrl, deps);
5
+ // Converts the snake_case record from the REST API into the camelCase shape
6
+ // the rest of the SDK consumes.
7
+ const normalizeRecord = (record) => ({
8
+ index: record.leaf_index,
9
+ commitment: record.commitment,
10
+ ciphertext: [...record.ciphertext],
11
+ root: record.root,
12
+ txHash: record.tx_hash,
13
+ insertedAt: record.inserted_at,
14
+ });
15
+ const normalizeNullifierRecord = (record) => ({
16
+ nullifier: record.nullifier,
17
+ txHash: record.tx_hash,
18
+ spentAt: record.spent_at,
19
+ chainId: record.chain_id,
20
+ });
21
+ return {
22
+ async fetchCommitmentBatch(params) {
23
+ const raw = await http.request({
24
+ method: "GET",
25
+ path: `/chains/${params.chainId}/commitments`,
26
+ query: {
27
+ start: params.start,
28
+ limit: params.limit,
29
+ },
30
+ });
31
+ return {
32
+ chainId: raw.chain_id,
33
+ commitments: raw.commitments.map(normalizeRecord),
34
+ latestRoot: raw.latest_root,
35
+ };
36
+ },
37
+ async getCommitment(params) {
38
+ const raw = await http.request({
39
+ method: "GET",
40
+ path: `/chains/${params.chainId}/commitments/${params.commitment}`,
41
+ });
42
+ return normalizeRecord(raw);
43
+ },
44
+ async getNullifier(params) {
45
+ try {
46
+ const raw = await http.request({
47
+ method: "GET",
48
+ path: `/chains/${params.chainId}/nullifiers/${params.nullifier}`,
49
+ });
50
+ return normalizeNullifierRecord(raw);
51
+ }
52
+ catch (err) {
53
+ if (isNotFoundError(err)) {
54
+ return null; // Nullifier not spent on-chain
55
+ }
56
+ throw err;
57
+ }
58
+ },
59
+ async getNullifierCount(chainId) {
60
+ const raw = await http.request({
61
+ method: "GET",
62
+ path: `/chains/${chainId}/nullifiers/count`,
63
+ });
64
+ return raw.count;
65
+ },
66
+ };
67
+ }
@@ -0,0 +1,12 @@
1
+ export declare const serviceConfig: {
2
+ /**
3
+ * Base URL for the Broadcaster HTTP API (default: http://localhost:8081).
4
+ */
5
+ broadcasterBaseUrl: string;
6
+ /**
7
+ * Base URL for the Indexer HTTP API (default: http://localhost:8082).
8
+ */
9
+ indexerBaseUrl: string;
10
+ };
11
+ export type ServiceConfig = typeof serviceConfig;
12
+ //# sourceMappingURL=config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../config.ts"],"names":[],"mappings":"AAyBA,eAAO,MAAM,aAAa;IACxB;;OAEG;;IAGH;;OAEG;;CAGJ,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG,OAAO,aAAa,CAAC"}
package/dist/config.js ADDED
@@ -0,0 +1,29 @@
1
+ const DEFAULT_RPC_URL = "http://localhost:3000";
2
+ function readEnv(key) {
3
+ if (typeof process !== "undefined" && process?.env) {
4
+ return process.env[key];
5
+ }
6
+ // Support environments where process isn't defined but a shim sets globalThis.process
7
+ const globalProcess = globalThis.process;
8
+ return globalProcess?.env?.[key];
9
+ }
10
+ function readServiceUrl(envKey, fallback) {
11
+ const raw = readEnv(envKey);
12
+ if (!raw)
13
+ return fallback;
14
+ const trimmed = raw.trim();
15
+ if (!trimmed) {
16
+ throw new Error(`${envKey} must not be empty when set`);
17
+ }
18
+ return trimmed.replace(/\/+$/, "");
19
+ }
20
+ export const serviceConfig = {
21
+ /**
22
+ * Base URL for the Broadcaster HTTP API (default: http://localhost:8081).
23
+ */
24
+ broadcasterBaseUrl: readServiceUrl("UNLINK_RPC_URL", DEFAULT_RPC_URL) + "/broadcaster",
25
+ /**
26
+ * Base URL for the Indexer HTTP API (default: http://localhost:8082).
27
+ */
28
+ indexerBaseUrl: readServiceUrl("UNLINK_RPC_URL", DEFAULT_RPC_URL) + "/indexer",
29
+ };
package/dist/core.d.ts ADDED
@@ -0,0 +1,10 @@
1
+ import type { Storage } from "./types.js";
2
+ export type CoreDeps = {
3
+ storage: Storage;
4
+ rng: (n: number) => Uint8Array;
5
+ };
6
+ export declare function initCore(deps: CoreDeps): Promise<{
7
+ storage: Storage;
8
+ rng: (n: number) => Uint8Array;
9
+ }>;
10
+ //# sourceMappingURL=core.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"core.d.ts","sourceRoot":"","sources":["../core.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AAE1C,MAAM,MAAM,QAAQ,GAAG;IACrB,OAAO,EAAE,OAAO,CAAC;IACjB,GAAG,EAAE,CAAC,CAAC,EAAE,MAAM,KAAK,UAAU,CAAC;CAChC,CAAC;AAEF,wBAAsB,QAAQ,CAAC,IAAI,EAAE,QAAQ;;aAHlC,MAAM,KAAK,UAAU;GAW/B"}
package/dist/core.js ADDED
@@ -0,0 +1,12 @@
1
+ import { migrate } from "./schema.js";
2
+ export async function initCore(deps) {
3
+ if (!deps?.storage)
4
+ throw new Error("storage dep required");
5
+ if (!deps?.rng)
6
+ throw new Error("rng dep required");
7
+ await migrate(deps.storage);
8
+ return {
9
+ storage: deps.storage,
10
+ rng: deps.rng,
11
+ };
12
+ }
@@ -0,0 +1,10 @@
1
+ export declare class CoreError extends Error {
2
+ constructor(message: string);
3
+ }
4
+ export declare class KeyValidationError extends CoreError {
5
+ constructor(message: string);
6
+ }
7
+ export declare class SchemaMismatchError extends CoreError {
8
+ constructor(current: number, expected: number);
9
+ }
10
+ //# sourceMappingURL=errors.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../errors.ts"],"names":[],"mappings":"AAAA,qBAAa,SAAU,SAAQ,KAAK;gBACtB,OAAO,EAAE,MAAM;CAI5B;AAED,qBAAa,kBAAmB,SAAQ,SAAS;gBACnC,OAAO,EAAE,MAAM;CAI5B;AAED,qBAAa,mBAAoB,SAAQ,SAAS;gBACpC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM;CAI9C"}
package/dist/errors.js ADDED
@@ -0,0 +1,18 @@
1
+ export class CoreError extends Error {
2
+ constructor(message) {
3
+ super(message);
4
+ this.name = "CoreError";
5
+ }
6
+ }
7
+ export class KeyValidationError extends CoreError {
8
+ constructor(message) {
9
+ super(message);
10
+ this.name = "KeyValidationError";
11
+ }
12
+ }
13
+ export class SchemaMismatchError extends CoreError {
14
+ constructor(current, expected) {
15
+ super(`schema mismatch (current ${current}, expected ${expected})`);
16
+ this.name = "SchemaMismatchError";
17
+ }
18
+ }
@@ -0,0 +1,18 @@
1
+ export * from "./types.js";
2
+ export * from "./errors.js";
3
+ export * from "./keys.js";
4
+ export * from "./storage/index.js";
5
+ export * from "./schema.js";
6
+ export * from "./core.js";
7
+ export * from "./state/index.js";
8
+ export * from "./utils/validators.js";
9
+ export * from "./utils/bigint.js";
10
+ export * from "./account/zkAccount.js";
11
+ export * from "./key-derivation/index.js";
12
+ export * from "./transactions/index.js";
13
+ export { createJobReconciler } from "./transactions/reconcile.js";
14
+ export { serviceConfig } from "./config.js";
15
+ export type { ServiceConfig } from "./config.js";
16
+ export * from "./clients/broadcaster.js";
17
+ export * from "./clients/indexer.js";
18
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,WAAW,CAAC;AAC1B,cAAc,oBAAoB,CAAC;AACnC,cAAc,aAAa,CAAC;AAC5B,cAAc,WAAW,CAAC;AAC1B,cAAc,kBAAkB,CAAC;AACjC,cAAc,uBAAuB,CAAC;AACtC,cAAc,mBAAmB,CAAC;AAClC,cAAc,wBAAwB,CAAC;AACvC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,yBAAyB,CAAC;AACxC,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAC;AAClE,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAC5C,YAAY,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AACjD,cAAc,0BAA0B,CAAC;AACzC,cAAc,sBAAsB,CAAC"}
package/dist/index.js ADDED
@@ -0,0 +1,16 @@
1
+ export * from "./types.js";
2
+ export * from "./errors.js";
3
+ export * from "./keys.js";
4
+ export * from "./storage/index.js";
5
+ export * from "./schema.js";
6
+ export * from "./core.js";
7
+ export * from "./state/index.js";
8
+ export * from "./utils/validators.js";
9
+ export * from "./utils/bigint.js";
10
+ export * from "./account/zkAccount.js";
11
+ export * from "./key-derivation/index.js";
12
+ export * from "./transactions/index.js";
13
+ export { createJobReconciler } from "./transactions/reconcile.js";
14
+ export { serviceConfig } from "./config.js";
15
+ export * from "./clients/broadcaster.js";
16
+ export * from "./clients/indexer.js";
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Lightweight wrapper exposing the BabyJubJub point packing helpers we rely on for
3
+ * derivation and address encoding. Re-exported for consumers that need raw curve ops.
4
+ */
5
+ export declare class Babyjubjub {
6
+ static packPoint: (point: [bigint, bigint]) => Uint8Array;
7
+ static unpackPoint: (bytes: Uint8Array) => [bigint, bigint];
8
+ }
9
+ //# sourceMappingURL=babyjubjub.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"babyjubjub.d.ts","sourceRoot":"","sources":["../../key-derivation/babyjubjub.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,qBAAa,UAAU;IACrB,MAAM,CAAC,SAAS,0CAAqB;IAErC,MAAM,CAAC,WAAW,0CAAuB;CAC1C"}
@@ -0,0 +1,9 @@
1
+ import { babyjub } from "@railgun-community/circomlibjs";
2
+ /**
3
+ * Lightweight wrapper exposing the BabyJubJub point packing helpers we rely on for
4
+ * derivation and address encoding. Re-exported for consumers that need raw curve ops.
5
+ */
6
+ export class Babyjubjub {
7
+ static packPoint = babyjub.packPoint;
8
+ static unpackPoint = babyjub.unpackPoint;
9
+ }
@@ -0,0 +1,22 @@
1
+ export type Chain = {
2
+ type: number;
3
+ id: number;
4
+ };
5
+ export type AddressData = {
6
+ masterPublicKey: bigint;
7
+ viewingPublicKey: Uint8Array;
8
+ chain?: Chain;
9
+ version?: number;
10
+ };
11
+ export declare const ADDRESS_VERSION = 1;
12
+ export declare const ADDRESS_LENGTH_LIMIT = 127;
13
+ export declare const ALL_CHAINS_NETWORK_ID = "ffffffffffffffff";
14
+ /**
15
+ * Encode address metadata into a Bech32m string with the 0zk prefix.
16
+ */
17
+ export declare const encodeAddress: (addressData: AddressData) => string;
18
+ /**
19
+ * Decode and validate a Bech32m address, returning the structured payload.
20
+ */
21
+ export declare const decodeAddress: (address: string) => AddressData;
22
+ //# sourceMappingURL=bech32.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bech32.d.ts","sourceRoot":"","sources":["../../key-derivation/bech32.ts"],"names":[],"mappings":"AAIA,MAAM,MAAM,KAAK,GAAG;IAClB,IAAI,EAAE,MAAM,CAAC;IACb,EAAE,EAAE,MAAM,CAAC;CACZ,CAAC;AAEF,MAAM,MAAM,WAAW,GAAG;IACxB,eAAe,EAAE,MAAM,CAAC;IACxB,gBAAgB,EAAE,UAAU,CAAC;IAC7B,KAAK,CAAC,EAAE,KAAK,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF,eAAO,MAAM,eAAe,IAAI,CAAC;AACjC,eAAO,MAAM,oBAAoB,MAAM,CAAC;AACxC,eAAO,MAAM,qBAAqB,qBAAqB,CAAC;AA0CxD;;GAEG;AACH,eAAO,MAAM,aAAa,GAAI,aAAa,WAAW,KAAG,MAmBxD,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,aAAa,GAAI,SAAS,MAAM,KAAG,WAoC/C,CAAC"}