@suit-protocol/sdk 0.3.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 (46) hide show
  1. package/README.md +196 -0
  2. package/dist/compliance.d.ts +4 -0
  3. package/dist/compliance.d.ts.map +1 -0
  4. package/dist/compliance.js +92 -0
  5. package/dist/compliance.js.map +1 -0
  6. package/dist/crypto.d.ts +21 -0
  7. package/dist/crypto.d.ts.map +1 -0
  8. package/dist/crypto.js +102 -0
  9. package/dist/crypto.js.map +1 -0
  10. package/dist/index.d.ts +13 -0
  11. package/dist/index.d.ts.map +1 -0
  12. package/dist/index.js +50 -0
  13. package/dist/index.js.map +1 -0
  14. package/dist/pool.d.ts +20 -0
  15. package/dist/pool.d.ts.map +1 -0
  16. package/dist/pool.js +277 -0
  17. package/dist/pool.js.map +1 -0
  18. package/dist/proofs.d.ts +8 -0
  19. package/dist/proofs.d.ts.map +1 -0
  20. package/dist/proofs.js +19 -0
  21. package/dist/proofs.js.map +1 -0
  22. package/dist/relayer.d.ts +4 -0
  23. package/dist/relayer.d.ts.map +1 -0
  24. package/dist/relayer.js +33 -0
  25. package/dist/relayer.js.map +1 -0
  26. package/dist/signer.d.ts +8 -0
  27. package/dist/signer.d.ts.map +1 -0
  28. package/dist/signer.js +20 -0
  29. package/dist/signer.js.map +1 -0
  30. package/dist/sync.d.ts +18 -0
  31. package/dist/sync.d.ts.map +1 -0
  32. package/dist/sync.js +76 -0
  33. package/dist/sync.js.map +1 -0
  34. package/dist/tree.d.ts +5 -0
  35. package/dist/tree.d.ts.map +1 -0
  36. package/dist/tree.js +56 -0
  37. package/dist/tree.js.map +1 -0
  38. package/dist/types.d.ts +132 -0
  39. package/dist/types.d.ts.map +1 -0
  40. package/dist/types.js +4 -0
  41. package/dist/types.js.map +1 -0
  42. package/dist/viewing-key.d.ts +6 -0
  43. package/dist/viewing-key.d.ts.map +1 -0
  44. package/dist/viewing-key.js +140 -0
  45. package/dist/viewing-key.js.map +1 -0
  46. package/package.json +45 -0
package/dist/pool.js ADDED
@@ -0,0 +1,277 @@
1
+ "use strict";
2
+ // SUIT Protocol SDK — SuitPool: the developer-facing API
3
+ //
4
+ // pool.shield(amount) → deposit any amount into the shielded pool
5
+ // pool.withdraw(note, amount, recipient) → withdraw unlinkably
6
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
7
+ if (k2 === undefined) k2 = k;
8
+ var desc = Object.getOwnPropertyDescriptor(m, k);
9
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
10
+ desc = { enumerable: true, get: function() { return m[k]; } };
11
+ }
12
+ Object.defineProperty(o, k2, desc);
13
+ }) : (function(o, m, k, k2) {
14
+ if (k2 === undefined) k2 = k;
15
+ o[k2] = m[k];
16
+ }));
17
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
18
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
19
+ }) : function(o, v) {
20
+ o["default"] = v;
21
+ });
22
+ var __importStar = (this && this.__importStar) || (function () {
23
+ var ownKeys = function(o) {
24
+ ownKeys = Object.getOwnPropertyNames || function (o) {
25
+ var ar = [];
26
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
27
+ return ar;
28
+ };
29
+ return ownKeys(o);
30
+ };
31
+ return function (mod) {
32
+ if (mod && mod.__esModule) return mod;
33
+ var result = {};
34
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
35
+ __setModuleDefault(result, mod);
36
+ return result;
37
+ };
38
+ })();
39
+ Object.defineProperty(exports, "__esModule", { value: true });
40
+ exports.SuitPool = void 0;
41
+ const stellar_sdk_1 = require("@stellar/stellar-sdk");
42
+ const crypto_1 = require("./crypto");
43
+ const tree_1 = require("./tree");
44
+ const proofs_1 = require("./proofs");
45
+ const sync_1 = require("./sync");
46
+ const relayer_1 = require("./relayer");
47
+ const viewing_key_1 = require("./viewing-key");
48
+ class SuitPool {
49
+ constructor(config) {
50
+ this.config = config;
51
+ this.depth = config.depth ?? 16;
52
+ this.decimals = config.decimals ?? 7;
53
+ this.passphrase = config.networkPassphrase ??
54
+ (config.network === 'mainnet' ? stellar_sdk_1.Networks.PUBLIC : stellar_sdk_1.Networks.TESTNET);
55
+ const rpcUrl = config.rpcUrl ??
56
+ (config.network === 'mainnet' ? 'https://mainnet.sorobanrpc.com' : 'https://soroban-testnet.stellar.org');
57
+ this.server = new stellar_sdk_1.rpc.Server(rpcUrl);
58
+ this.syncer = new sync_1.LeafSyncer({ rpcUrl, poolId: config.poolId, startLedger: config.startLedger }, config.leafCache);
59
+ }
60
+ // ── Read-only queries ──
61
+ async getRoot() {
62
+ const val = await this.callView('get_root');
63
+ return val ? (0, crypto_1.bytesToBig)(val) : (0, tree_1.computeZeros)(this.depth)[this.depth];
64
+ }
65
+ async getCount() {
66
+ try {
67
+ return Number(await this.callView('get_count')) || 0;
68
+ }
69
+ catch {
70
+ return 0;
71
+ }
72
+ }
73
+ async getRelayerInfo() {
74
+ if (!this.config.relayerUrl)
75
+ return null;
76
+ return (0, relayer_1.getRelayerInfo)(this.config.relayerUrl);
77
+ }
78
+ async syncLeaves(force = false) {
79
+ return this.syncer.sync(force);
80
+ }
81
+ getNotes() {
82
+ return this.config.noteStore.getNotes(this.config.poolId);
83
+ }
84
+ // ── Shield (deposit) ──
85
+ async shield(amount, onStep) {
86
+ const amt = (0, crypto_1.amountToStroops)(amount, this.decimals);
87
+ if (amt <= 0n)
88
+ throw new Error('Amount must be positive');
89
+ const address = await this.config.signer.getAddress();
90
+ const snarkjs = await Promise.resolve().then(() => __importStar(require('snarkjs')));
91
+ onStep?.('Reading pool state…');
92
+ const countBefore = await this.getCount();
93
+ const root = await this.getRoot();
94
+ onStep?.('Generating secret note…');
95
+ const priv = (0, crypto_1.randomField)(), blinding = (0, crypto_1.randomField)();
96
+ const pk = (0, crypto_1.pubKeyOf)(priv);
97
+ const outCommit = (0, crypto_1.commitHash)(amt, pk, blinding);
98
+ const dPriv = (0, crypto_1.randomField)(), dBlind = (0, crypto_1.randomField)();
99
+ const dPk = (0, crypto_1.pubKeyOf)(dPriv);
100
+ const dummyCommit = (0, crypto_1.commitHash)(0n, dPk, dBlind);
101
+ const inA = (0, proofs_1.dummyInput)(this.depth), inB = (0, proofs_1.dummyInput)(this.depth);
102
+ const extHash = (0, crypto_1.extDataHashField)(address, address, 0n);
103
+ onStep?.('Generating zero-knowledge proof… (~30 s)');
104
+ const { proof } = await snarkjs.groth16.fullProve({
105
+ root: root.toString(),
106
+ publicAmount: amt.toString(),
107
+ extDataHash: extHash.toString(),
108
+ inputNullifier: [inA.nullifier.toString(), inB.nullifier.toString()],
109
+ outputCommitment: [outCommit.toString(), dummyCommit.toString()],
110
+ inAmount: ['0', '0'],
111
+ inPrivateKey: [inA.priv.toString(), inB.priv.toString()],
112
+ inBlinding: [inA.blinding.toString(), inB.blinding.toString()],
113
+ inPathIndices: ['0', '0'],
114
+ inPathElements: [inA.pathElements, inB.pathElements],
115
+ outAmount: [amt.toString(), '0'],
116
+ outPubkey: [pk.toString(), dPk.toString()],
117
+ outBlinding: [blinding.toString(), dBlind.toString()],
118
+ }, this.config.circuitWasmPath, this.config.circuitZkeyPath);
119
+ onStep?.('Submitting to Stellar…');
120
+ const contract = new stellar_sdk_1.Contract(this.config.poolId);
121
+ const op = contract.call('transact', (0, crypto_1.scvBytes)((0, proofs_1.encodeProof)(proof)), (0, crypto_1.scvBytes)((0, crypto_1.be)(root)), (0, stellar_sdk_1.nativeToScVal)(amt, { type: 'i128' }), stellar_sdk_1.xdr.ScVal.scvVec([(0, crypto_1.scvBytes)((0, crypto_1.be)(inA.nullifier)), (0, crypto_1.scvBytes)((0, crypto_1.be)(inB.nullifier))]), stellar_sdk_1.xdr.ScVal.scvVec([(0, crypto_1.scvBytes)((0, crypto_1.be)(outCommit)), (0, crypto_1.scvBytes)((0, crypto_1.be)(dummyCommit))]), new stellar_sdk_1.Address(address).toScVal(), new stellar_sdk_1.Address(address).toScVal(), new stellar_sdk_1.Address(address).toScVal(), (0, stellar_sdk_1.nativeToScVal)(0n, { type: 'i128' }));
122
+ const txHash = await this.signAndSend(address, op, onStep);
123
+ this.syncer.invalidate();
124
+ const note = {
125
+ amount: amt.toString(), privKey: priv.toString(), blinding: blinding.toString(),
126
+ commitment: outCommit.toString(), leafIndex: countBefore, spent: false,
127
+ txHash, ts: Date.now(),
128
+ };
129
+ const notes = [...this.getNotes(), note];
130
+ this.config.noteStore.saveNotes(this.config.poolId, notes);
131
+ await (0, viewing_key_1.appendAuditLog)(this.config.noteStore, this.config.poolId, {
132
+ type: 'shield', amount: amt.toString(), pubKey: pk.toString(),
133
+ blinding: blinding.toString(), commitment: outCommit.toString(),
134
+ leafIndex: countBefore, txHash, timestamp: Date.now(),
135
+ });
136
+ return { txHash, note };
137
+ }
138
+ // ── Withdraw ──
139
+ async withdraw(note, amount, recipient, onStep) {
140
+ const wAmt = (0, crypto_1.amountToStroops)(amount, this.decimals);
141
+ const nAmt = BigInt(note.amount);
142
+ if (wAmt <= 0n)
143
+ throw new Error('Amount must be positive');
144
+ if (wAmt > nAmt)
145
+ throw new Error('Exceeds note balance');
146
+ const address = await this.config.signer.getAddress();
147
+ onStep?.('Contacting relayer…');
148
+ const relayerInfo = this.config.relayerUrl ? await this.getRelayerInfo() : null;
149
+ const useRelayer = !!relayerInfo;
150
+ const relayerAddr = relayerInfo?.relayer || address;
151
+ const fee = useRelayer ? BigInt(relayerInfo.fee || '0') : 0n;
152
+ if (fee < 0n || fee > wAmt)
153
+ throw new Error('Relayer fee out of range.');
154
+ const snarkjs = await Promise.resolve().then(() => __importStar(require('snarkjs')));
155
+ onStep?.('Syncing pool tree from chain…');
156
+ const leaves = await this.syncer.sync(true);
157
+ const commitment = BigInt(note.commitment);
158
+ const leafIndex = leaves.findIndex(l => l === commitment);
159
+ if (leafIndex < 0)
160
+ throw new Error('Note not found in on-chain tree yet — wait for the deposit to index, then retry.');
161
+ const root = (0, tree_1.treeRoot)(leaves, this.depth);
162
+ const path = (0, tree_1.treePath)(leafIndex, leaves, this.depth);
163
+ const priv = BigInt(note.privKey);
164
+ const sig = (0, crypto_1.signHash)(priv, commitment, BigInt(leafIndex));
165
+ const null0 = (0, crypto_1.nullHash)(commitment, BigInt(leafIndex), sig);
166
+ const inDummy = (0, proofs_1.dummyInput)(this.depth);
167
+ const changeAmt = nAmt - wAmt;
168
+ const cPriv = (0, crypto_1.randomField)(), cBlind = (0, crypto_1.randomField)();
169
+ const changeCommit = (0, crypto_1.commitHash)(changeAmt, (0, crypto_1.pubKeyOf)(cPriv), cBlind);
170
+ const zPriv = (0, crypto_1.randomField)(), zBlind = (0, crypto_1.randomField)();
171
+ const zeroCommit = (0, crypto_1.commitHash)(0n, (0, crypto_1.pubKeyOf)(zPriv), zBlind);
172
+ const publicAmount = (crypto_1.P - wAmt) % crypto_1.P;
173
+ const extHash = (0, crypto_1.extDataHashField)(recipient, relayerAddr, fee);
174
+ onStep?.('Generating zero-knowledge proof… (~30 s)');
175
+ const { proof } = await snarkjs.groth16.fullProve({
176
+ root: root.toString(),
177
+ publicAmount: publicAmount.toString(),
178
+ extDataHash: extHash.toString(),
179
+ inputNullifier: [null0.toString(), inDummy.nullifier.toString()],
180
+ outputCommitment: [changeCommit.toString(), zeroCommit.toString()],
181
+ inAmount: [nAmt.toString(), '0'],
182
+ inPrivateKey: [priv.toString(), inDummy.priv.toString()],
183
+ inBlinding: [note.blinding, inDummy.blinding.toString()],
184
+ inPathIndices: [leafIndex.toString(), '0'],
185
+ inPathElements: [path.map(x => x.toString()), inDummy.pathElements],
186
+ outAmount: [changeAmt.toString(), '0'],
187
+ outPubkey: [(0, crypto_1.pubKeyOf)(cPriv).toString(), (0, crypto_1.pubKeyOf)(zPriv).toString()],
188
+ outBlinding: [cBlind.toString(), zBlind.toString()],
189
+ }, this.config.circuitWasmPath, this.config.circuitZkeyPath);
190
+ const proofBytes = (0, proofs_1.encodeProof)(proof);
191
+ let txHash;
192
+ if (useRelayer && this.config.relayerUrl) {
193
+ onStep?.('Submitting via relayer — your wallet never touches the chain…');
194
+ txHash = await (0, relayer_1.relaySubmit)(this.config.relayerUrl, {
195
+ poolId: this.config.poolId,
196
+ proof: (0, crypto_1.toHex)(proofBytes),
197
+ root: (0, crypto_1.toHex)((0, crypto_1.be)(root)),
198
+ extAmount: (-wAmt).toString(),
199
+ nullifiers: [(0, crypto_1.toHex)((0, crypto_1.be)(null0)), (0, crypto_1.toHex)((0, crypto_1.be)(inDummy.nullifier))],
200
+ commitments: [(0, crypto_1.toHex)((0, crypto_1.be)(changeCommit)), (0, crypto_1.toHex)((0, crypto_1.be)(zeroCommit))],
201
+ recipient,
202
+ fee: fee.toString(),
203
+ });
204
+ }
205
+ else {
206
+ onStep?.('Relayer offline — submitting from your wallet (visible)…');
207
+ const contract = new stellar_sdk_1.Contract(this.config.poolId);
208
+ const op = contract.call('transact', (0, crypto_1.scvBytes)(proofBytes), (0, crypto_1.scvBytes)((0, crypto_1.be)(root)), (0, stellar_sdk_1.nativeToScVal)(-wAmt, { type: 'i128' }), stellar_sdk_1.xdr.ScVal.scvVec([(0, crypto_1.scvBytes)((0, crypto_1.be)(null0)), (0, crypto_1.scvBytes)((0, crypto_1.be)(inDummy.nullifier))]), stellar_sdk_1.xdr.ScVal.scvVec([(0, crypto_1.scvBytes)((0, crypto_1.be)(changeCommit)), (0, crypto_1.scvBytes)((0, crypto_1.be)(zeroCommit))]), new stellar_sdk_1.Address(address).toScVal(), new stellar_sdk_1.Address(recipient).toScVal(), new stellar_sdk_1.Address(address).toScVal(), (0, stellar_sdk_1.nativeToScVal)(0n, { type: 'i128' }));
209
+ txHash = await this.signAndSend(address, op, onStep);
210
+ }
211
+ this.syncer.invalidate();
212
+ const notes = this.getNotes().map(n => n.commitment === note.commitment
213
+ ? {
214
+ ...n, spent: true, withdrawTxHash: txHash, recipient,
215
+ withdrawAmount: wAmt.toString(),
216
+ changeCommitment: changeAmt > 0n ? changeCommit.toString() : undefined,
217
+ }
218
+ : n);
219
+ let savedChange = null;
220
+ if (changeAmt > 0n) {
221
+ savedChange = {
222
+ amount: changeAmt.toString(), privKey: cPriv.toString(), blinding: cBlind.toString(),
223
+ commitment: changeCommit.toString(), leafIndex: leaves.length, spent: false,
224
+ txHash, ts: Date.now(),
225
+ };
226
+ notes.push(savedChange);
227
+ }
228
+ this.config.noteStore.saveNotes(this.config.poolId, notes);
229
+ const pk = (0, crypto_1.pubKeyOf)(BigInt(note.privKey));
230
+ await (0, viewing_key_1.appendAuditLog)(this.config.noteStore, this.config.poolId, {
231
+ type: 'withdraw', amount: wAmt.toString(), pubKey: pk.toString(),
232
+ blinding: note.blinding, commitment: note.commitment,
233
+ leafIndex, txHash, timestamp: Date.now(), recipient,
234
+ });
235
+ return { txHash, changeNote: savedChange };
236
+ }
237
+ // ── Internal helpers ──
238
+ async callView(method) {
239
+ const address = await this.config.signer.getAddress();
240
+ const contract = new stellar_sdk_1.Contract(this.config.poolId);
241
+ const account = await this.server.getAccount(address);
242
+ const tx = new stellar_sdk_1.TransactionBuilder(account, { fee: stellar_sdk_1.BASE_FEE, networkPassphrase: this.passphrase })
243
+ .addOperation(contract.call(method)).setTimeout(30).build();
244
+ const sim = await this.server.simulateTransaction(tx);
245
+ if (stellar_sdk_1.rpc.Api.isSimulationError(sim) || !sim.result)
246
+ return null;
247
+ return (0, stellar_sdk_1.scValToNative)(sim.result.retval);
248
+ }
249
+ async signAndSend(address, op, onStep) {
250
+ const account = await this.server.getAccount(address);
251
+ const tx = new stellar_sdk_1.TransactionBuilder(account, {
252
+ fee: (Number(stellar_sdk_1.BASE_FEE) * 1000).toString(),
253
+ networkPassphrase: this.passphrase,
254
+ }).addOperation(op).setTimeout(300).build();
255
+ const sim = await this.server.simulateTransaction(tx);
256
+ if (stellar_sdk_1.rpc.Api.isSimulationError(sim))
257
+ throw new Error(`Simulation: ${sim.error}`);
258
+ const prepared = stellar_sdk_1.rpc.assembleTransaction(tx, sim).build();
259
+ const signedXdr = await this.config.signer.signTransaction(prepared.toXDR(), this.passphrase);
260
+ const signed = stellar_sdk_1.TransactionBuilder.fromXDR(signedXdr, this.passphrase);
261
+ const sent = await this.server.sendTransaction(signed);
262
+ if (sent.status === 'ERROR')
263
+ throw new Error(`Submit: ${JSON.stringify(sent.errorResult)}`);
264
+ for (let i = 0; i < 60; i++) {
265
+ await new Promise(r => setTimeout(r, 1500));
266
+ const got = await this.server.getTransaction(sent.hash);
267
+ if (got.status === stellar_sdk_1.rpc.Api.GetTransactionStatus.SUCCESS)
268
+ return sent.hash;
269
+ if (got.status === stellar_sdk_1.rpc.Api.GetTransactionStatus.FAILED) {
270
+ throw new Error(`Failed on-chain (${sent.hash})`);
271
+ }
272
+ }
273
+ throw new Error('Not confirmed in time');
274
+ }
275
+ }
276
+ exports.SuitPool = SuitPool;
277
+ //# sourceMappingURL=pool.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pool.js","sourceRoot":"","sources":["../src/pool.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ export declare function dummyInput(depth?: number): {
2
+ priv: bigint;
3
+ blinding: bigint;
4
+ nullifier: bigint;
5
+ pathElements: string[];
6
+ };
7
+ export declare function encodeProof(proof: any): Uint8Array;
8
+ //# sourceMappingURL=proofs.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"proofs.d.ts","sourceRoot":"","sources":["../src/proofs.ts"],"names":[],"mappings":"AAKA,wBAAgB,UAAU,CAAC,KAAK,CAAC,EAAE,MAAM;;;;;EAKxC;AAED,wBAAgB,WAAW,CAAC,KAAK,EAAE,GAAG,GAAG,UAAU,CAKlD"}
package/dist/proofs.js ADDED
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ // SUIT Protocol SDK — ZK proof helpers (snarkjs / Transaction circuit)
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.dummyInput = dummyInput;
5
+ exports.encodeProof = encodeProof;
6
+ const crypto_1 = require("./crypto");
7
+ const tree_1 = require("./tree");
8
+ function dummyInput(depth) {
9
+ const priv = (0, crypto_1.randomField)(), blinding = (0, crypto_1.randomField)();
10
+ const c = (0, crypto_1.commitHash)(0n, (0, crypto_1.pubKeyOf)(priv), blinding);
11
+ const sig = (0, crypto_1.signHash)(priv, c, 0n);
12
+ return { priv, blinding, nullifier: (0, crypto_1.nullHash)(c, 0n, sig), pathElements: (0, tree_1.emptyPath)(depth) };
13
+ }
14
+ function encodeProof(proof) {
15
+ const g1 = (p) => (0, crypto_1.concatBytes)([(0, crypto_1.beRaw)(BigInt(p[0])), (0, crypto_1.beRaw)(BigInt(p[1]))]);
16
+ const g2 = (p) => (0, crypto_1.concatBytes)([(0, crypto_1.beRaw)(BigInt(p[0][1])), (0, crypto_1.beRaw)(BigInt(p[0][0])), (0, crypto_1.beRaw)(BigInt(p[1][1])), (0, crypto_1.beRaw)(BigInt(p[1][0]))]);
17
+ return (0, crypto_1.concatBytes)([g1(proof.pi_a), g2(proof.pi_b), g1(proof.pi_c)]);
18
+ }
19
+ //# sourceMappingURL=proofs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"proofs.js","sourceRoot":"","sources":["../src/proofs.ts"],"names":[],"mappings":";AAAA,uEAAuE;;AAKvE,gCAKC;AAED,kCAKC;AAfD,qCAAqG;AACrG,iCAAmC;AAEnC,SAAgB,UAAU,CAAC,KAAc;IACvC,MAAM,IAAI,GAAG,IAAA,oBAAW,GAAE,EAAE,QAAQ,GAAG,IAAA,oBAAW,GAAE,CAAC;IACrD,MAAM,CAAC,GAAG,IAAA,mBAAU,EAAC,EAAE,EAAE,IAAA,iBAAQ,EAAC,IAAI,CAAC,EAAE,QAAQ,CAAC,CAAC;IACnD,MAAM,GAAG,GAAG,IAAA,iBAAQ,EAAC,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;IAClC,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,SAAS,EAAE,IAAA,iBAAQ,EAAC,CAAC,EAAE,EAAE,EAAE,GAAG,CAAC,EAAE,YAAY,EAAE,IAAA,gBAAS,EAAC,KAAK,CAAC,EAAE,CAAC;AAC7F,CAAC;AAED,SAAgB,WAAW,CAAC,KAAU;IACpC,MAAM,EAAE,GAAG,CAAC,CAAW,EAAE,EAAE,CAAC,IAAA,oBAAW,EAAC,CAAC,IAAA,cAAK,EAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,IAAA,cAAK,EAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACpF,MAAM,EAAE,GAAG,CAAC,CAAa,EAAE,EAAE,CAC3B,IAAA,oBAAW,EAAC,CAAC,IAAA,cAAK,EAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,IAAA,cAAK,EAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,IAAA,cAAK,EAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,IAAA,cAAK,EAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAChH,OAAO,IAAA,oBAAW,EAAC,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AACvE,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { RelayerInfo, RelayBundle } from './types';
2
+ export declare function getRelayerInfo(relayerUrl: string): Promise<RelayerInfo | null>;
3
+ export declare function relaySubmit(relayerUrl: string, body: RelayBundle): Promise<string>;
4
+ //# sourceMappingURL=relayer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"relayer.d.ts","sourceRoot":"","sources":["../src/relayer.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAExD,wBAAsB,cAAc,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC,CASpF;AAED,wBAAsB,WAAW,CAAC,UAAU,EAAE,MAAM,EAAE,IAAI,EAAE,WAAW,GAAG,OAAO,CAAC,MAAM,CAAC,CAUxF"}
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+ // SUIT Protocol SDK — Relayer client
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.getRelayerInfo = getRelayerInfo;
5
+ exports.relaySubmit = relaySubmit;
6
+ async function getRelayerInfo(relayerUrl) {
7
+ try {
8
+ const r = await fetch(relayerUrl, { method: 'GET' });
9
+ if (!r.ok)
10
+ return null;
11
+ const j = await r.json();
12
+ return j && typeof j.relayer === 'string'
13
+ ? { relayer: j.relayer, fee: String(j.fee ?? '0') }
14
+ : null;
15
+ }
16
+ catch {
17
+ return null;
18
+ }
19
+ }
20
+ async function relaySubmit(relayerUrl, body) {
21
+ const r = await fetch(relayerUrl, {
22
+ method: 'POST',
23
+ headers: { 'content-type': 'application/json' },
24
+ body: JSON.stringify(body),
25
+ });
26
+ const j = await r.json().catch(() => ({}));
27
+ if (!r.ok || j.error)
28
+ throw new Error(j.error || `Relayer error (${r.status})`);
29
+ if (!j.hash)
30
+ throw new Error('Relayer returned no transaction hash.');
31
+ return j.hash;
32
+ }
33
+ //# sourceMappingURL=relayer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"relayer.js","sourceRoot":"","sources":["../src/relayer.ts"],"names":[],"mappings":";AAAA,qCAAqC;;AAIrC,wCASC;AAED,kCAUC;AArBM,KAAK,UAAU,cAAc,CAAC,UAAkB;IACrD,IAAI,CAAC;QACH,MAAM,CAAC,GAAG,MAAM,KAAK,CAAC,UAAU,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;QACrD,IAAI,CAAC,CAAC,CAAC,EAAE;YAAE,OAAO,IAAI,CAAC;QACvB,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC,IAAI,EAAE,CAAC;QACzB,OAAO,CAAC,IAAI,OAAO,CAAC,CAAC,OAAO,KAAK,QAAQ;YACvC,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,GAAG,EAAE,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,GAAG,CAAC,EAAE;YACnD,CAAC,CAAC,IAAI,CAAC;IACX,CAAC;IAAC,MAAM,CAAC;QAAC,OAAO,IAAI,CAAC;IAAC,CAAC;AAC1B,CAAC;AAEM,KAAK,UAAU,WAAW,CAAC,UAAkB,EAAE,IAAiB;IACrE,MAAM,CAAC,GAAG,MAAM,KAAK,CAAC,UAAU,EAAE;QAChC,MAAM,EAAE,MAAM;QACd,OAAO,EAAE,EAAE,cAAc,EAAE,kBAAkB,EAAE;QAC/C,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;KAC3B,CAAC,CAAC;IACH,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,EAAU,CAAA,CAAC,CAAC;IAClD,IAAI,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,KAAK;QAAE,MAAM,IAAI,KAAK,CAAC,CAAC,CAAC,KAAK,IAAI,kBAAkB,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;IAChF,IAAI,CAAC,CAAC,CAAC,IAAI;QAAE,MAAM,IAAI,KAAK,CAAC,uCAAuC,CAAC,CAAC;IACtE,OAAO,CAAC,CAAC,IAAc,CAAC;AAC1B,CAAC"}
@@ -0,0 +1,8 @@
1
+ import type { Signer } from './types';
2
+ export declare class KeypairSigner implements Signer {
3
+ private kp;
4
+ constructor(secretKey: string);
5
+ getAddress(): Promise<string>;
6
+ signTransaction(preparedXdr: string, networkPassphrase: string): Promise<string>;
7
+ }
8
+ //# sourceMappingURL=signer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"signer.d.ts","sourceRoot":"","sources":["../src/signer.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAEtC,qBAAa,aAAc,YAAW,MAAM;IAC1C,OAAO,CAAC,EAAE,CAAU;gBAER,SAAS,EAAE,MAAM;IAIvB,UAAU,IAAI,OAAO,CAAC,MAAM,CAAC;IAI7B,eAAe,CAAC,WAAW,EAAE,MAAM,EAAE,iBAAiB,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;CAKvF"}
package/dist/signer.js ADDED
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ // SUIT Protocol SDK — Signer implementations
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.KeypairSigner = void 0;
5
+ const stellar_sdk_1 = require("@stellar/stellar-sdk");
6
+ class KeypairSigner {
7
+ constructor(secretKey) {
8
+ this.kp = stellar_sdk_1.Keypair.fromSecret(secretKey);
9
+ }
10
+ async getAddress() {
11
+ return this.kp.publicKey();
12
+ }
13
+ async signTransaction(preparedXdr, networkPassphrase) {
14
+ const tx = stellar_sdk_1.TransactionBuilder.fromXDR(preparedXdr, networkPassphrase);
15
+ tx.sign(this.kp);
16
+ return tx.toXDR();
17
+ }
18
+ }
19
+ exports.KeypairSigner = KeypairSigner;
20
+ //# sourceMappingURL=signer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"signer.js","sourceRoot":"","sources":["../src/signer.ts"],"names":[],"mappings":";AAAA,6CAA6C;;;AAE7C,sDAAmE;AAGnE,MAAa,aAAa;IAGxB,YAAY,SAAiB;QAC3B,IAAI,CAAC,EAAE,GAAG,qBAAO,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;IAC1C,CAAC;IAED,KAAK,CAAC,UAAU;QACd,OAAO,IAAI,CAAC,EAAE,CAAC,SAAS,EAAE,CAAC;IAC7B,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,WAAmB,EAAE,iBAAyB;QAClE,MAAM,EAAE,GAAG,gCAAkB,CAAC,OAAO,CAAC,WAAW,EAAE,iBAAiB,CAAQ,CAAC;QAC7E,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACjB,OAAO,EAAE,CAAC,KAAK,EAAE,CAAC;IACpB,CAAC;CACF;AAhBD,sCAgBC"}
package/dist/sync.d.ts ADDED
@@ -0,0 +1,18 @@
1
+ import type { LeafCache } from './types';
2
+ export interface SyncConfig {
3
+ rpcUrl: string;
4
+ poolId: string;
5
+ startLedger: number;
6
+ }
7
+ export declare class LeafSyncer {
8
+ private server;
9
+ private config;
10
+ private cache;
11
+ private memCache;
12
+ constructor(config: SyncConfig, cache?: LeafCache);
13
+ invalidate(): void;
14
+ sync(force?: boolean): Promise<bigint[]>;
15
+ private loadCache;
16
+ private saveCache;
17
+ }
18
+ //# sourceMappingURL=sync.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sync.d.ts","sourceRoot":"","sources":["../src/sync.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAGzC,MAAM,WAAW,UAAU;IACzB,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,qBAAa,UAAU;IACrB,OAAO,CAAC,MAAM,CAAa;IAC3B,OAAO,CAAC,MAAM,CAAa;IAC3B,OAAO,CAAC,KAAK,CAAmB;IAChC,OAAO,CAAC,QAAQ,CAAyB;gBAE7B,MAAM,EAAE,UAAU,EAAE,KAAK,CAAC,EAAE,SAAS;IAMjD,UAAU;IAIJ,IAAI,CAAC,KAAK,UAAQ,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;IAyC5C,OAAO,CAAC,SAAS;IAQjB,OAAO,CAAC,SAAS;CAMlB"}
package/dist/sync.js ADDED
@@ -0,0 +1,76 @@
1
+ "use strict";
2
+ // SUIT Protocol SDK — On-chain leaf sync from Soroban transact events
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.LeafSyncer = void 0;
5
+ const stellar_sdk_1 = require("@stellar/stellar-sdk");
6
+ const crypto_1 = require("./crypto");
7
+ class LeafSyncer {
8
+ constructor(config, cache) {
9
+ this.memCache = null;
10
+ this.server = new stellar_sdk_1.rpc.Server(config.rpcUrl);
11
+ this.config = config;
12
+ this.cache = cache || null;
13
+ }
14
+ invalidate() {
15
+ this.memCache = null;
16
+ }
17
+ async sync(force = false) {
18
+ if (this.memCache && !force)
19
+ return this.memCache;
20
+ const indexed = this.loadCache();
21
+ const filters = [{ type: 'contract', contractIds: [this.config.poolId], topics: [['*']] }];
22
+ let start = this.config.startLedger;
23
+ try {
24
+ const latest = (await this.server.getLatestLedger()).sequence;
25
+ const minStart = latest - 16000;
26
+ if (start < minStart)
27
+ start = minStart;
28
+ }
29
+ catch { /* use configured start */ }
30
+ const collect = (events) => {
31
+ for (const e of events) {
32
+ try {
33
+ const data = (0, stellar_sdk_1.scValToNative)(e.value);
34
+ if (data && typeof data.leaf_index !== 'undefined' && data.out_commitment_0) {
35
+ const idx = Number(data.leaf_index);
36
+ indexed.set(idx, (0, crypto_1.bytesToBig)(data.out_commitment_0));
37
+ indexed.set(idx + 1, (0, crypto_1.bytesToBig)(data.out_commitment_1));
38
+ }
39
+ }
40
+ catch { /* not a transact event */ }
41
+ }
42
+ };
43
+ let res = await this.server.getEvents({ startLedger: start, filters, limit: 200 });
44
+ collect(res.events);
45
+ while (res.events.length === 200 && res.cursor) {
46
+ res = await this.server.getEvents({ filters, limit: 200, cursor: res.cursor });
47
+ collect(res.events);
48
+ }
49
+ this.saveCache(indexed);
50
+ const maxIdx = indexed.size ? Math.max(...indexed.keys()) : -1;
51
+ const leaves = [];
52
+ for (let i = 0; i <= maxIdx; i++)
53
+ leaves.push(indexed.get(i) ?? 0n);
54
+ this.memCache = leaves;
55
+ return leaves;
56
+ }
57
+ loadCache() {
58
+ const m = new Map();
59
+ if (!this.cache)
60
+ return m;
61
+ const raw = this.cache.load(this.config.poolId);
62
+ for (const [k, v] of raw)
63
+ m.set(k, BigInt(v));
64
+ return m;
65
+ }
66
+ saveCache(indexed) {
67
+ if (!this.cache)
68
+ return;
69
+ const data = new Map();
70
+ for (const [k, v] of indexed)
71
+ data.set(k, v.toString());
72
+ this.cache.save(this.config.poolId, data);
73
+ }
74
+ }
75
+ exports.LeafSyncer = LeafSyncer;
76
+ //# sourceMappingURL=sync.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sync.js","sourceRoot":"","sources":["../src/sync.ts"],"names":[],"mappings":"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"}
package/dist/tree.d.ts ADDED
@@ -0,0 +1,5 @@
1
+ export declare function computeZeros(depth: number): bigint[];
2
+ export declare function treeRoot(leaves: bigint[], depth?: number): bigint;
3
+ export declare function treePath(index: number, leaves: bigint[], depth?: number): bigint[];
4
+ export declare function emptyPath(depth?: number): string[];
5
+ //# sourceMappingURL=tree.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tree.d.ts","sourceRoot":"","sources":["../src/tree.ts"],"names":[],"mappings":"AAMA,wBAAgB,YAAY,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,EAAE,CAIpD;AAED,wBAAgB,QAAQ,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,KAAK,SAAgB,GAAG,MAAM,CAexE;AAED,wBAAgB,QAAQ,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,EAAE,KAAK,SAAgB,GAAG,MAAM,EAAE,CAmBzF;AAED,wBAAgB,SAAS,CAAC,KAAK,SAAgB,GAAG,MAAM,EAAE,CAEzD"}
package/dist/tree.js ADDED
@@ -0,0 +1,56 @@
1
+ "use strict";
2
+ // SUIT Protocol SDK — Depth-16 Poseidon Merkle tree (matches on-chain pool)
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.computeZeros = computeZeros;
5
+ exports.treeRoot = treeRoot;
6
+ exports.treePath = treePath;
7
+ exports.emptyPath = emptyPath;
8
+ const poseidon_lite_1 = require("poseidon-lite");
9
+ const DEFAULT_DEPTH = 16;
10
+ function computeZeros(depth) {
11
+ const zeros = [0n];
12
+ for (let i = 1; i <= depth; i++)
13
+ zeros.push((0, poseidon_lite_1.poseidon2)([zeros[i - 1], zeros[i - 1]]));
14
+ return zeros;
15
+ }
16
+ function treeRoot(leaves, depth = DEFAULT_DEPTH) {
17
+ const zeros = computeZeros(depth);
18
+ if (leaves.length === 0)
19
+ return zeros[depth];
20
+ let layer = leaves.slice();
21
+ for (let d = 0; d < depth; d++) {
22
+ const next = [];
23
+ const len = Math.max(layer.length, 1);
24
+ for (let i = 0; i < len; i += 2) {
25
+ const l = i < layer.length ? layer[i] : zeros[d];
26
+ const r = i + 1 < layer.length ? layer[i + 1] : zeros[d];
27
+ next.push((0, poseidon_lite_1.poseidon2)([l, r]));
28
+ }
29
+ layer = next;
30
+ }
31
+ return layer[0];
32
+ }
33
+ function treePath(index, leaves, depth = DEFAULT_DEPTH) {
34
+ const zeros = computeZeros(depth);
35
+ const path = [];
36
+ let layer = leaves.slice();
37
+ let idx = index;
38
+ for (let d = 0; d < depth; d++) {
39
+ const sib = idx % 2 === 0 ? idx + 1 : idx - 1;
40
+ path.push(sib >= 0 && sib < layer.length ? layer[sib] : zeros[d]);
41
+ const next = [];
42
+ const len = Math.max(layer.length, 1);
43
+ for (let i = 0; i < len; i += 2) {
44
+ const l = i < layer.length ? layer[i] : zeros[d];
45
+ const r = i + 1 < layer.length ? layer[i + 1] : zeros[d];
46
+ next.push((0, poseidon_lite_1.poseidon2)([l, r]));
47
+ }
48
+ layer = next;
49
+ idx = Math.floor(idx / 2);
50
+ }
51
+ return path;
52
+ }
53
+ function emptyPath(depth = DEFAULT_DEPTH) {
54
+ return computeZeros(depth).slice(0, depth).map(z => z.toString());
55
+ }
56
+ //# sourceMappingURL=tree.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tree.js","sourceRoot":"","sources":["../src/tree.ts"],"names":[],"mappings":"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"}