@unlink-xyz/core 0.1.0 → 0.1.3-canary.01ac52d

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 (269) hide show
  1. package/README.md +9 -0
  2. package/dist/account/{zkAccount.d.ts → account.d.ts} +36 -5
  3. package/dist/account/account.d.ts.map +1 -0
  4. package/dist/account/accounts.d.ts +42 -0
  5. package/dist/account/accounts.d.ts.map +1 -0
  6. package/dist/account/seed.d.ts +45 -0
  7. package/dist/account/seed.d.ts.map +1 -0
  8. package/dist/account/serialization.d.ts +6 -0
  9. package/dist/account/serialization.d.ts.map +1 -0
  10. package/dist/browser/index.js +56253 -0
  11. package/dist/browser/index.js.map +1 -0
  12. package/dist/browser/wallet/index.js +55974 -0
  13. package/dist/browser/wallet/index.js.map +1 -0
  14. package/dist/clients/broadcaster.d.ts +8 -2
  15. package/dist/clients/broadcaster.d.ts.map +1 -1
  16. package/dist/clients/http.d.ts +6 -0
  17. package/dist/clients/http.d.ts.map +1 -1
  18. package/dist/clients/indexer.d.ts +16 -0
  19. package/dist/clients/indexer.d.ts.map +1 -1
  20. package/dist/config.d.ts +35 -9
  21. package/dist/config.d.ts.map +1 -1
  22. package/dist/constants.d.ts +6 -0
  23. package/dist/constants.d.ts.map +1 -0
  24. package/dist/core.d.ts.map +1 -1
  25. package/dist/crypto/adapters/index.d.ts +17 -0
  26. package/dist/crypto/adapters/index.d.ts.map +1 -0
  27. package/dist/crypto/adapters/polyfills.d.ts +5 -0
  28. package/dist/crypto/adapters/polyfills.d.ts.map +1 -0
  29. package/dist/crypto/encrypt.d.ts +33 -0
  30. package/dist/crypto/encrypt.d.ts.map +1 -0
  31. package/dist/crypto/secure-memory.d.ts +25 -0
  32. package/dist/crypto/secure-memory.d.ts.map +1 -0
  33. package/dist/errors.d.ts +17 -0
  34. package/dist/errors.d.ts.map +1 -1
  35. package/dist/history/index.d.ts +3 -0
  36. package/dist/history/index.d.ts.map +1 -0
  37. package/dist/history/service.d.ts +46 -0
  38. package/dist/history/service.d.ts.map +1 -0
  39. package/dist/history/types.d.ts +21 -0
  40. package/dist/history/types.d.ts.map +1 -0
  41. package/dist/index.d.ts +16 -5
  42. package/dist/index.d.ts.map +1 -1
  43. package/dist/index.js +9969 -16
  44. package/dist/index.js.map +1 -0
  45. package/dist/keys/address.d.ts +13 -0
  46. package/dist/keys/address.d.ts.map +1 -0
  47. package/dist/keys/derive.d.ts +37 -0
  48. package/dist/keys/derive.d.ts.map +1 -0
  49. package/dist/keys/hex.d.ts +14 -0
  50. package/dist/keys/hex.d.ts.map +1 -0
  51. package/dist/keys/index.d.ts +5 -0
  52. package/dist/keys/index.d.ts.map +1 -0
  53. package/dist/keys/mnemonic.d.ts +6 -0
  54. package/dist/keys/mnemonic.d.ts.map +1 -0
  55. package/dist/keys.d.ts +5 -1
  56. package/dist/keys.d.ts.map +1 -1
  57. package/dist/prover/config.d.ts +53 -22
  58. package/dist/prover/config.d.ts.map +1 -1
  59. package/dist/prover/integrity.d.ts +20 -0
  60. package/dist/prover/integrity.d.ts.map +1 -0
  61. package/dist/prover/prover.d.ts +16 -20
  62. package/dist/prover/prover.d.ts.map +1 -1
  63. package/dist/prover/registry.d.ts +3 -30
  64. package/dist/prover/registry.d.ts.map +1 -1
  65. package/dist/state/merkle/hydrator.d.ts +21 -19
  66. package/dist/state/merkle/hydrator.d.ts.map +1 -1
  67. package/dist/state/merkle/index.d.ts +2 -2
  68. package/dist/state/merkle/index.d.ts.map +1 -1
  69. package/dist/state/merkle/merkle-tree.d.ts +8 -0
  70. package/dist/state/merkle/merkle-tree.d.ts.map +1 -1
  71. package/dist/state/store/ciphertext-store.d.ts +11 -0
  72. package/dist/state/store/ciphertext-store.d.ts.map +1 -1
  73. package/dist/state/store/history-store.d.ts +24 -0
  74. package/dist/state/store/history-store.d.ts.map +1 -0
  75. package/dist/state/store/index.d.ts +3 -2
  76. package/dist/state/store/index.d.ts.map +1 -1
  77. package/dist/state/store/job-store.d.ts +7 -7
  78. package/dist/state/store/job-store.d.ts.map +1 -1
  79. package/dist/state/store/jobs.d.ts +70 -25
  80. package/dist/state/store/jobs.d.ts.map +1 -1
  81. package/dist/state/store/leaf-store.d.ts +4 -0
  82. package/dist/state/store/leaf-store.d.ts.map +1 -1
  83. package/dist/state/store/note-store.d.ts +7 -7
  84. package/dist/state/store/note-store.d.ts.map +1 -1
  85. package/dist/state/store/nullifier-store.d.ts +9 -0
  86. package/dist/state/store/nullifier-store.d.ts.map +1 -1
  87. package/dist/state/store/records.d.ts +39 -2
  88. package/dist/state/store/records.d.ts.map +1 -1
  89. package/dist/state/store/root-store.d.ts.map +1 -1
  90. package/dist/state/store/store.d.ts +79 -27
  91. package/dist/state/store/store.d.ts.map +1 -1
  92. package/dist/storage/indexeddb.d.ts.map +1 -1
  93. package/dist/storage/memory.d.ts.map +1 -1
  94. package/dist/transactions/adapter.d.ts +31 -0
  95. package/dist/transactions/adapter.d.ts.map +1 -0
  96. package/dist/transactions/deposit.d.ts +12 -17
  97. package/dist/transactions/deposit.d.ts.map +1 -1
  98. package/dist/transactions/index.d.ts +9 -4
  99. package/dist/transactions/index.d.ts.map +1 -1
  100. package/dist/transactions/note-selection.d.ts +17 -0
  101. package/dist/transactions/note-selection.d.ts.map +1 -0
  102. package/dist/transactions/note-sync.d.ts +5 -33
  103. package/dist/transactions/note-sync.d.ts.map +1 -1
  104. package/dist/transactions/reconcile.d.ts +9 -11
  105. package/dist/transactions/reconcile.d.ts.map +1 -1
  106. package/dist/transactions/transact.d.ts +30 -27
  107. package/dist/transactions/transact.d.ts.map +1 -1
  108. package/dist/transactions/transaction-planner.d.ts +34 -0
  109. package/dist/transactions/transaction-planner.d.ts.map +1 -0
  110. package/dist/transactions/transfer-planner.d.ts +37 -0
  111. package/dist/transactions/transfer-planner.d.ts.map +1 -0
  112. package/dist/transactions/types/deposit.d.ts +67 -0
  113. package/dist/transactions/types/deposit.d.ts.map +1 -0
  114. package/dist/transactions/types/domain.d.ts +70 -0
  115. package/dist/transactions/types/domain.d.ts.map +1 -0
  116. package/dist/transactions/types/index.d.ts +18 -0
  117. package/dist/transactions/types/index.d.ts.map +1 -0
  118. package/dist/transactions/types/options.d.ts +54 -0
  119. package/dist/transactions/types/options.d.ts.map +1 -0
  120. package/dist/transactions/types/planning.d.ts +82 -0
  121. package/dist/transactions/types/planning.d.ts.map +1 -0
  122. package/dist/transactions/types/state-stores.d.ts +151 -0
  123. package/dist/transactions/types/state-stores.d.ts.map +1 -0
  124. package/dist/transactions/types/transact.d.ts +83 -0
  125. package/dist/transactions/types/transact.d.ts.map +1 -0
  126. package/dist/transactions/withdrawal-planner.d.ts +58 -0
  127. package/dist/transactions/withdrawal-planner.d.ts.map +1 -0
  128. package/dist/tsconfig.tsbuildinfo +1 -1
  129. package/dist/tsup.browser.config.d.ts +7 -0
  130. package/dist/tsup.browser.config.d.ts.map +1 -0
  131. package/dist/tsup.config.d.ts +8 -0
  132. package/dist/tsup.config.d.ts.map +1 -0
  133. package/dist/types.d.ts +1 -0
  134. package/dist/types.d.ts.map +1 -1
  135. package/dist/utils/amounts.d.ts +26 -0
  136. package/dist/utils/amounts.d.ts.map +1 -0
  137. package/dist/utils/async.d.ts +9 -0
  138. package/dist/utils/async.d.ts.map +1 -1
  139. package/dist/utils/async.js +38 -11
  140. package/dist/utils/async.js.map +1 -0
  141. package/dist/utils/bigint.d.ts +0 -2
  142. package/dist/utils/bigint.d.ts.map +1 -1
  143. package/dist/utils/format.d.ts +25 -0
  144. package/dist/utils/format.d.ts.map +1 -0
  145. package/dist/utils/notes.d.ts +15 -0
  146. package/dist/utils/notes.d.ts.map +1 -0
  147. package/dist/utils/polling.d.ts +5 -0
  148. package/dist/utils/polling.d.ts.map +1 -1
  149. package/dist/utils/random.d.ts +18 -0
  150. package/dist/utils/random.d.ts.map +1 -0
  151. package/dist/utils/signature.d.ts +6 -0
  152. package/dist/utils/signature.d.ts.map +1 -1
  153. package/dist/utils/validators.d.ts +21 -10
  154. package/dist/utils/validators.d.ts.map +1 -1
  155. package/dist/vitest.config.d.ts +3 -0
  156. package/dist/vitest.config.d.ts.map +1 -0
  157. package/dist/wallet/adapter.d.ts +21 -0
  158. package/dist/wallet/adapter.d.ts.map +1 -0
  159. package/dist/wallet/burner/service.d.ts +32 -0
  160. package/dist/wallet/burner/service.d.ts.map +1 -0
  161. package/dist/wallet/burner/types.d.ts +47 -0
  162. package/dist/wallet/burner/types.d.ts.map +1 -0
  163. package/dist/wallet/index.d.ts +20 -0
  164. package/dist/wallet/index.d.ts.map +1 -0
  165. package/dist/wallet/index.js +9712 -0
  166. package/dist/wallet/index.js.map +1 -0
  167. package/dist/wallet/sdk.d.ts +47 -0
  168. package/dist/wallet/sdk.d.ts.map +1 -0
  169. package/dist/wallet/types.d.ts +455 -0
  170. package/dist/wallet/types.d.ts.map +1 -0
  171. package/dist/wallet/unlink-wallet.d.ts +186 -0
  172. package/dist/wallet/unlink-wallet.d.ts.map +1 -0
  173. package/package.json +40 -14
  174. package/dist/account/zkAccount.d.ts.map +0 -1
  175. package/dist/account/zkAccount.js +0 -128
  176. package/dist/clients/broadcaster.js +0 -23
  177. package/dist/clients/http.js +0 -57
  178. package/dist/clients/indexer.js +0 -67
  179. package/dist/config.js +0 -29
  180. package/dist/core.js +0 -12
  181. package/dist/errors.js +0 -18
  182. package/dist/key-derivation/babyjubjub.d.ts +0 -9
  183. package/dist/key-derivation/babyjubjub.d.ts.map +0 -1
  184. package/dist/key-derivation/babyjubjub.js +0 -9
  185. package/dist/key-derivation/bech32.d.ts +0 -22
  186. package/dist/key-derivation/bech32.d.ts.map +0 -1
  187. package/dist/key-derivation/bech32.js +0 -86
  188. package/dist/key-derivation/bip32.d.ts +0 -17
  189. package/dist/key-derivation/bip32.d.ts.map +0 -1
  190. package/dist/key-derivation/bip32.js +0 -41
  191. package/dist/key-derivation/bip39.d.ts +0 -22
  192. package/dist/key-derivation/bip39.d.ts.map +0 -1
  193. package/dist/key-derivation/bip39.js +0 -56
  194. package/dist/key-derivation/bytes.d.ts +0 -19
  195. package/dist/key-derivation/bytes.d.ts.map +0 -1
  196. package/dist/key-derivation/bytes.js +0 -92
  197. package/dist/key-derivation/hash.d.ts +0 -3
  198. package/dist/key-derivation/hash.d.ts.map +0 -1
  199. package/dist/key-derivation/hash.js +0 -10
  200. package/dist/key-derivation/index.d.ts +0 -8
  201. package/dist/key-derivation/index.d.ts.map +0 -1
  202. package/dist/key-derivation/index.js +0 -7
  203. package/dist/key-derivation/wallet-node.d.ts +0 -45
  204. package/dist/key-derivation/wallet-node.d.ts.map +0 -1
  205. package/dist/key-derivation/wallet-node.js +0 -109
  206. package/dist/keys.js +0 -41
  207. package/dist/prover/config.js +0 -80
  208. package/dist/prover/index.js +0 -1
  209. package/dist/prover/prover.js +0 -274
  210. package/dist/prover/registry.js +0 -57
  211. package/dist/schema.js +0 -14
  212. package/dist/state/ciphertext-store.d.ts +0 -12
  213. package/dist/state/ciphertext-store.d.ts.map +0 -1
  214. package/dist/state/ciphertext-store.js +0 -25
  215. package/dist/state/index.js +0 -2
  216. package/dist/state/leaf-store.d.ts +0 -17
  217. package/dist/state/leaf-store.d.ts.map +0 -1
  218. package/dist/state/leaf-store.js +0 -35
  219. package/dist/state/merkle/hydrator.js +0 -36
  220. package/dist/state/merkle/index.js +0 -2
  221. package/dist/state/merkle/merkle-tree.js +0 -104
  222. package/dist/state/merkle-tree.d.ts +0 -34
  223. package/dist/state/merkle-tree.d.ts.map +0 -1
  224. package/dist/state/merkle-tree.js +0 -104
  225. package/dist/state/note-store.d.ts +0 -37
  226. package/dist/state/note-store.d.ts.map +0 -1
  227. package/dist/state/note-store.js +0 -133
  228. package/dist/state/nullifier-store.d.ts +0 -13
  229. package/dist/state/nullifier-store.d.ts.map +0 -1
  230. package/dist/state/nullifier-store.js +0 -21
  231. package/dist/state/records.d.ts +0 -57
  232. package/dist/state/records.d.ts.map +0 -1
  233. package/dist/state/records.js +0 -1
  234. package/dist/state/root-store.d.ts +0 -13
  235. package/dist/state/root-store.d.ts.map +0 -1
  236. package/dist/state/root-store.js +0 -30
  237. package/dist/state/store/ciphertext-store.js +0 -25
  238. package/dist/state/store/index.js +0 -8
  239. package/dist/state/store/job-store.js +0 -118
  240. package/dist/state/store/jobs.js +0 -1
  241. package/dist/state/store/leaf-store.js +0 -35
  242. package/dist/state/store/note-store.js +0 -142
  243. package/dist/state/store/nullifier-store.js +0 -30
  244. package/dist/state/store/records.js +0 -1
  245. package/dist/state/store/root-store.js +0 -30
  246. package/dist/state/store/store.js +0 -22
  247. package/dist/state/store.d.ts +0 -26
  248. package/dist/state/store.d.ts.map +0 -1
  249. package/dist/state/store.js +0 -19
  250. package/dist/storage/index.js +0 -2
  251. package/dist/storage/indexeddb.js +0 -205
  252. package/dist/storage/memory.js +0 -87
  253. package/dist/transactions/deposit.js +0 -173
  254. package/dist/transactions/index.js +0 -4
  255. package/dist/transactions/note-sync.js +0 -320
  256. package/dist/transactions/reconcile.js +0 -39
  257. package/dist/transactions/transact.js +0 -561
  258. package/dist/transactions/types.d.ts +0 -114
  259. package/dist/transactions/types.d.ts.map +0 -1
  260. package/dist/transactions/types.js +0 -1
  261. package/dist/types.js +0 -1
  262. package/dist/utils/bigint.js +0 -29
  263. package/dist/utils/crypto.d.ts +0 -12
  264. package/dist/utils/crypto.d.ts.map +0 -1
  265. package/dist/utils/crypto.js +0 -39
  266. package/dist/utils/json-codec.js +0 -25
  267. package/dist/utils/polling.js +0 -6
  268. package/dist/utils/signature.js +0 -12
  269. package/dist/utils/validators.js +0 -70
@@ -0,0 +1,186 @@
1
+ import type { AccountView } from "../account/account.js";
2
+ import type { RelayStatusResponse } from "../clients/broadcaster.js";
3
+ import type { HistoryEntry } from "../history/types.js";
4
+ import type { NoteRecord } from "../state/store/records.js";
5
+ import type { DepositRelayResult, DepositSyncResult, TransactRelayResult, TransactSyncResult } from "../transactions/types/index.js";
6
+ import type { BurnerAccount, BurnerSendParams } from "./burner/types.js";
7
+ import type { AdapterExecuteResult, SignerOverride, SimpleAdapterExecuteParams, SimpleBurnerFundParams, SimpleBurnerSweepToPoolParams, SimpleDepositParams, SimpleTransactParams, SimpleTransferParams, SimpleWithdrawParams, TransferPlanResult, TransferResult, UnlinkWalletConfig, WalletAccountAPI, WalletSDK, WalletSDKEvent, WithdrawPlanResult, WithdrawResult } from "./types.js";
8
+ /**
9
+ * High-level wallet API that bakes `chainId` and `poolAddress` at construction time.
10
+ *
11
+ * Replaces `createWalletSDK` / `createBrowserWalletSDK` with a single entry point
12
+ * that absorbs initialization (storage, rng, core migration, chain config resolution).
13
+ *
14
+ * @example
15
+ * ```ts
16
+ * // Chain mode (auto-resolves chainId, gateway, pool, artifacts):
17
+ * const wallet = await UnlinkWallet.create({
18
+ * chain: "monad-testnet",
19
+ * });
20
+ *
21
+ * // Explicit mode (custom/local deployments):
22
+ * const wallet = await UnlinkWallet.create({
23
+ * chainId: 10143,
24
+ * poolAddress: "0x...",
25
+ * gatewayUrl: "http://localhost:3000",
26
+ * storage: createSqliteStorage({ path: "wallet.db" }),
27
+ * });
28
+ *
29
+ * // Operations — no chainId/poolAddress needed:
30
+ * await wallet.seed.create();
31
+ * await wallet.accounts.create();
32
+ * await wallet.deposit({ depositor: "0x...", deposits: [{ token, amount }] });
33
+ * await wallet.transfer({ transfers: [{ token, recipient, amount }] });
34
+ * await wallet.getBalances();
35
+ * await wallet.sync();
36
+ * ```
37
+ */
38
+ export declare class UnlinkWallet {
39
+ /** @internal */
40
+ private readonly sdk;
41
+ /** Chain ID this wallet operates on. */
42
+ readonly chainId: number;
43
+ /** Pool contract address this wallet transacts with. */
44
+ readonly poolAddress: string;
45
+ private constructor();
46
+ /**
47
+ * Create a new UnlinkWallet instance.
48
+ *
49
+ * Handles all initialization internally:
50
+ * - Resolves chain config (if using `chain` instead of explicit URLs)
51
+ * - Auto-detects storage (IndexedDB in browser) and rng (crypto.getRandomValues)
52
+ * - Runs schema migration via `initCore()`
53
+ * - Creates the internal SDK
54
+ */
55
+ static create(config: UnlinkWalletConfig): Promise<UnlinkWallet>;
56
+ /** Seed management (create, import, export, delete mnemonic). */
57
+ get seed(): WalletSDK["seed"];
58
+ /** Account management (create, list, switch accounts). */
59
+ get accounts(): WalletAccountAPI;
60
+ /**
61
+ * Request a deposit (1 or more tokens).
62
+ * Returns calldata the depositor must submit on-chain via their EOA.
63
+ */
64
+ deposit(params: SimpleDepositParams): Promise<DepositRelayResult>;
65
+ /** Wait for a deposit to be confirmed on-chain. */
66
+ confirmDeposit(relayId: string): Promise<DepositSyncResult>;
67
+ /**
68
+ * Execute a private transfer (1 or more recipients).
69
+ * Handles note selection, circuit selection, and proof generation automatically.
70
+ */
71
+ transfer(params: SimpleTransferParams, overrides?: SignerOverride): Promise<TransferResult>;
72
+ /**
73
+ * Get a transfer plan without executing (for preview/confirmation UIs).
74
+ */
75
+ planTransfer(params: SimpleTransferParams, account?: AccountView): Promise<TransferPlanResult>;
76
+ /** Execute a pre-built transfer plan. */
77
+ executeTransfer(plans: TransferPlanResult, overrides?: SignerOverride): Promise<TransferResult>;
78
+ /**
79
+ * Execute a withdrawal (1 or more recipients).
80
+ * Handles note selection, circuit selection, and proof generation automatically.
81
+ */
82
+ withdraw(params: SimpleWithdrawParams, overrides?: SignerOverride): Promise<WithdrawResult>;
83
+ /**
84
+ * Get a withdrawal plan without executing (for preview/confirmation UIs).
85
+ */
86
+ planWithdraw(params: SimpleWithdrawParams, account?: AccountView): Promise<WithdrawPlanResult>;
87
+ /** Execute a pre-built withdrawal plan. */
88
+ executeWithdraw(plans: WithdrawPlanResult, overrides?: SignerOverride): Promise<WithdrawResult>;
89
+ /** Wait for a transfer or withdrawal to be confirmed on-chain. */
90
+ confirmTransaction(relayId: string): Promise<TransactSyncResult>;
91
+ /**
92
+ * Get balance for a specific token (defaults to all tokens if no token specified).
93
+ * @param token Token address. If omitted, returns balance for all tokens via getBalances().
94
+ */
95
+ getBalance(token: string, overrides?: {
96
+ account: AccountView;
97
+ }): Promise<bigint>;
98
+ /** Get balances for all tokens. */
99
+ getBalances(overrides?: {
100
+ account: AccountView;
101
+ }): Promise<Record<string, bigint>>;
102
+ /** Get transaction history. */
103
+ getHistory(options?: {
104
+ includeSelfSends?: boolean;
105
+ }, overrides?: {
106
+ account: AccountView;
107
+ }): Promise<HistoryEntry[]>;
108
+ /** Get UTXO notes for the active account (or override account). */
109
+ getNotes(overrides?: {
110
+ account: AccountView;
111
+ }): Promise<NoteRecord[]>;
112
+ /**
113
+ * Sync notes from the blockchain.
114
+ * Automatically resolves the active account (no need to pass it).
115
+ */
116
+ sync(options?: {
117
+ forceFullResync?: boolean;
118
+ }, overrides?: {
119
+ account: AccountView;
120
+ }): Promise<void>;
121
+ /** Start auto-sync at the given interval (default: 5000ms). */
122
+ startAutoSync(intervalMs?: number): void;
123
+ /** Stop auto-sync. */
124
+ stopAutoSync(): void;
125
+ /** Get the current status of a transaction. */
126
+ getTxStatus(txId: string): Promise<RelayStatusResponse>;
127
+ /** Start tracking a transaction for status-changed events. */
128
+ trackTx(txId: string): void;
129
+ /** Stop tracking a transaction. */
130
+ untrackTx(txId: string): void;
131
+ /**
132
+ * Subscribe to wallet events (notes-updated, sync-error, tx-status-changed, etc.).
133
+ * @returns Unsubscribe function.
134
+ */
135
+ on(listener: (event: WalletSDKEvent) => void): () => void;
136
+ /**
137
+ * Burner account operations (BIP-44 derived EOAs for DeFi interactions).
138
+ * chainId/poolAddress are injected automatically for fund/sweepToPool.
139
+ */
140
+ readonly burner: {
141
+ /** Derive burner address for a given index. */
142
+ addressOf: (index: number) => Promise<BurnerAccount>;
143
+ /** Send a transaction from burner at index. */
144
+ send: (index: number, tx: BurnerSendParams) => Promise<{
145
+ txHash: string;
146
+ }>;
147
+ /** Export the raw private key (0x-prefixed hex) for wallet import. */
148
+ exportKey: (index: number) => Promise<string>;
149
+ /** Withdraw from shielded pool to fund this burner. */
150
+ fund: (index: number, params: SimpleBurnerFundParams) => Promise<WithdrawResult>;
151
+ /** Approve + deposit tokens from burner back into shielded pool. */
152
+ sweepToPool: (index: number, params: SimpleBurnerSweepToPoolParams) => Promise<{
153
+ txHash: string;
154
+ }>;
155
+ /** Get ERC-20 token balance of any address. */
156
+ getTokenBalance: (address: string, token: string) => Promise<bigint>;
157
+ /** Get native ETH balance of any address. */
158
+ getBalance: (address: string) => Promise<bigint>;
159
+ };
160
+ /**
161
+ * Private DeFi adapter operations.
162
+ * chainId/poolAddress are injected automatically.
163
+ */
164
+ readonly adapter: {
165
+ /**
166
+ * Execute an atomic unshield -> call(s) -> reshield flow through an adapter.
167
+ */
168
+ execute: (params: SimpleAdapterExecuteParams, opts?: {
169
+ skipBroadcast?: boolean;
170
+ }, overrides?: SignerOverride) => Promise<AdapterExecuteResult>;
171
+ };
172
+ /**
173
+ * Advanced escape hatch for raw JoinSplit transaction building.
174
+ * Use this for custom transaction construction (e.g. swap adapters).
175
+ */
176
+ readonly advanced: {
177
+ /** Build and submit raw JoinSplit transactions. */
178
+ transact: (params: SimpleTransactParams, opts?: {
179
+ skipBroadcast?: boolean;
180
+ }) => Promise<TransactRelayResult>;
181
+ /** Wait for a raw transaction to be confirmed on-chain. */
182
+ reconcile: (relayId: string) => Promise<TransactSyncResult>;
183
+ };
184
+ private requireActiveAccount;
185
+ }
186
+ //# sourceMappingURL=unlink-wallet.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"unlink-wallet.d.ts","sourceRoot":"","sources":["../../wallet/unlink-wallet.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,36 +1,61 @@
1
1
  {
2
2
  "name": "@unlink-xyz/core",
3
- "version": "0.1.0",
3
+ "version": "0.1.3-canary.01ac52d",
4
4
  "type": "module",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
7
7
  "exports": {
8
8
  ".": {
9
- "import": "./dist/index.js",
10
- "types": "./dist/index.d.ts"
9
+ "browser": {
10
+ "import": "./dist/browser/index.js",
11
+ "types": "./dist/index.d.ts"
12
+ },
13
+ "default": {
14
+ "import": "./dist/index.js",
15
+ "types": "./dist/index.d.ts"
16
+ }
17
+ },
18
+ "./wallet": {
19
+ "browser": {
20
+ "import": "./dist/browser/wallet/index.js",
21
+ "types": "./dist/wallet/index.d.ts"
22
+ },
23
+ "default": {
24
+ "import": "./dist/wallet/index.js",
25
+ "types": "./dist/wallet/index.d.ts"
26
+ }
27
+ },
28
+ "./utils/async.js": {
29
+ "import": "./dist/utils/async.js",
30
+ "types": "./dist/utils/async.d.ts"
11
31
  }
12
32
  },
13
- "files": ["dist"],
33
+ "files": [
34
+ "dist"
35
+ ],
14
36
  "publishConfig": {
15
- "access": "restricted"
37
+ "access": "public"
16
38
  },
17
39
  "scripts": {
18
- "build": "tsc -p tsconfig.json",
40
+ "build": "tsc -p tsconfig.json --emitDeclarationOnly && tsup && tsup --config tsup.browser.config.ts",
19
41
  "lint": "eslint .",
20
42
  "lint:fix": "eslint . --fix",
21
43
  "format": "prettier . --write",
22
44
  "format:check": "prettier . --check",
23
- "test": "tsc -p tsconfig.json && vitest run --test-timeout 0",
24
- "setup:artifacts": "./setup-artifacts.sh"
45
+ "test": "tsc --noEmit && vitest run --test-timeout 0",
46
+ "setup:artifacts": "bash ./scripts/setup-artifacts.sh",
47
+ "clean": "rm -rf dist *.tsbuildinfo",
48
+ "typecheck": "tsc --noEmit"
25
49
  },
26
50
  "dependencies": {
27
- "@noble/ed25519": "3.0.0",
51
+ "@noble/curves": "^2.0.1",
28
52
  "@noble/hashes": "2.0.0",
29
- "@railgun-community/circomlibjs": "0.0.8",
30
53
  "@scure/base": "2.0.0",
31
54
  "@scure/bip39": "2.0.1",
32
55
  "@types/snarkjs": "^0.7.9",
56
+ "@zk-kit/eddsa-poseidon": "^1.1.0",
33
57
  "@zk-kit/imt": "2.0.0-beta.8",
58
+ "buffer": "^6.0.3",
34
59
  "ethereum-cryptography": "3.2.0",
35
60
  "ethers": "6.15.0",
36
61
  "ky": "^1.14.0",
@@ -39,13 +64,14 @@
39
64
  "uuid": "^13.0.0"
40
65
  },
41
66
  "devDependencies": {
42
- "@eslint/eslintrc": "^3.1.0",
67
+ "@esbuild-plugins/node-globals-polyfill": "^0.2.3",
68
+ "@esbuild-plugins/node-modules-polyfill": "^0.2.2",
43
69
  "@types/node": "^22.0.0",
44
- "@typescript-eslint/eslint-plugin": "^7.18.0",
45
- "@typescript-eslint/parser": "^7.18.0",
46
- "eslint": "^8.57.1",
70
+ "eslint": "^9.19.0",
47
71
  "fake-indexeddb": "6.2.4",
72
+ "poseidon-lite": "^0.3.0",
48
73
  "prettier": "^3.5.3",
74
+ "tsup": "^8.3.5",
49
75
  "typescript": "^5.9.2",
50
76
  "vitest": "4.0.1"
51
77
  }
@@ -1 +0,0 @@
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"}
@@ -1,128 +0,0 @@
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
- }
@@ -1,23 +0,0 @@
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
- }
@@ -1,57 +0,0 @@
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
- }
@@ -1,67 +0,0 @@
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
- }
package/dist/config.js DELETED
@@ -1,29 +0,0 @@
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.js DELETED
@@ -1,12 +0,0 @@
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
- }
package/dist/errors.js DELETED
@@ -1,18 +0,0 @@
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
- }
@@ -1,9 +0,0 @@
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
@@ -1 +0,0 @@
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"}
@@ -1,9 +0,0 @@
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
- }