@lendasat/lendaswap-sdk-pure 0.2.41 → 0.2.43

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 (252) hide show
  1. package/dist/_esm-6K2AP5GG.js +3663 -0
  2. package/dist/_esm-6K2AP5GG.js.map +1 -0
  3. package/dist/_esm-UGRDSVEV.cjs +3662 -0
  4. package/dist/_esm-UGRDSVEV.cjs.map +1 -0
  5. package/dist/api/client.d.ts +0 -4
  6. package/dist/api/client.d.ts.map +1 -1
  7. package/dist/base-2KYNAFR3.cjs +109 -0
  8. package/dist/base-2KYNAFR3.cjs.map +1 -0
  9. package/dist/base-HMHH3XPM.js +9 -0
  10. package/dist/base-HMHH3XPM.js.map +1 -0
  11. package/dist/ccip-EBXWV2U3.js +8 -0
  12. package/dist/ccip-EBXWV2U3.js.map +1 -0
  13. package/dist/ccip-PD37NJHA.cjs +26 -0
  14. package/dist/ccip-PD37NJHA.cjs.map +1 -0
  15. package/dist/cctp-bridge/index.cjs +67 -0
  16. package/dist/cctp-bridge/index.cjs.map +1 -0
  17. package/dist/cctp-bridge/index.js +53 -15
  18. package/dist/cctp-bridge/index.js.map +1 -1
  19. package/dist/cctp-inbound/client.d.ts +21 -19
  20. package/dist/cctp-inbound/client.d.ts.map +1 -1
  21. package/dist/cctp-inbound/smartAccount.d.ts +21 -19
  22. package/dist/cctp-inbound/smartAccount.d.ts.map +1 -1
  23. package/dist/chunk-4JXN4UPB.js +554 -0
  24. package/dist/chunk-4JXN4UPB.js.map +1 -0
  25. package/dist/chunk-A4GKKURK.cjs +430 -0
  26. package/dist/chunk-A4GKKURK.cjs.map +1 -0
  27. package/dist/chunk-BZU3R5DJ.cjs +554 -0
  28. package/dist/chunk-BZU3R5DJ.cjs.map +1 -0
  29. package/dist/chunk-DBBCKPZ5.js +421 -0
  30. package/dist/chunk-DBBCKPZ5.js.map +1 -0
  31. package/dist/chunk-DNSJDKTP.cjs +96 -0
  32. package/dist/chunk-DNSJDKTP.cjs.map +1 -0
  33. package/dist/chunk-EIK6BZWG.js +90 -0
  34. package/dist/chunk-EIK6BZWG.js.map +1 -0
  35. package/dist/chunk-GVAPVS4Z.js +6144 -0
  36. package/dist/chunk-GVAPVS4Z.js.map +1 -0
  37. package/dist/chunk-I7TGLGN6.js +46 -0
  38. package/dist/chunk-I7TGLGN6.js.map +1 -0
  39. package/dist/chunk-JBVKWKD4.cjs +50 -0
  40. package/dist/chunk-JBVKWKD4.cjs.map +1 -0
  41. package/dist/chunk-LA3YX2HD.js +47096 -0
  42. package/dist/chunk-LA3YX2HD.js.map +1 -0
  43. package/dist/chunk-PKDJZJMV.cjs +2214 -0
  44. package/dist/chunk-PKDJZJMV.cjs.map +1 -0
  45. package/dist/chunk-PRN5VZOM.js +370 -0
  46. package/dist/chunk-PRN5VZOM.js.map +1 -0
  47. package/dist/chunk-RIOT5VOJ.cjs +47240 -0
  48. package/dist/chunk-RIOT5VOJ.cjs.map +1 -0
  49. package/dist/chunk-WVZSHRV7.cjs +431 -0
  50. package/dist/chunk-WVZSHRV7.cjs.map +1 -0
  51. package/dist/chunk-YLWPBHMV.cjs +6311 -0
  52. package/dist/chunk-YLWPBHMV.cjs.map +1 -0
  53. package/dist/chunk-Z2FCTNRC.js +2210 -0
  54. package/dist/chunk-Z2FCTNRC.js.map +1 -0
  55. package/dist/client.d.ts +68 -1
  56. package/dist/client.d.ts.map +1 -1
  57. package/dist/compose-quote.d.ts +77 -0
  58. package/dist/compose-quote.d.ts.map +1 -0
  59. package/dist/delegate.cjs +23 -0
  60. package/dist/delegate.cjs.map +1 -0
  61. package/dist/delegate.js +8 -269
  62. package/dist/delegate.js.map +1 -1
  63. package/dist/dist-PWXNFVDF.js +8 -0
  64. package/dist/dist-PWXNFVDF.js.map +1 -0
  65. package/dist/dist-VEHYC67F.cjs +550 -0
  66. package/dist/dist-VEHYC67F.cjs.map +1 -0
  67. package/dist/esplora.d.ts +14 -0
  68. package/dist/esplora.d.ts.map +1 -1
  69. package/dist/generated/api.d.ts +235 -38
  70. package/dist/generated/api.d.ts.map +1 -1
  71. package/dist/index.cjs +35461 -0
  72. package/dist/index.cjs.map +1 -0
  73. package/dist/index.d.ts +2 -1
  74. package/dist/index.d.ts.map +1 -1
  75. package/dist/index.js +35312 -32
  76. package/dist/index.js.map +1 -1
  77. package/dist/mine.wasm-LUTPOAD2.js +12 -0
  78. package/dist/mine.wasm-LUTPOAD2.js.map +1 -0
  79. package/dist/mine.wasm-Z3ORSBKN.cjs +12 -0
  80. package/dist/mine.wasm-Z3ORSBKN.cjs.map +1 -0
  81. package/dist/node.cjs +166 -0
  82. package/dist/node.cjs.map +1 -0
  83. package/dist/node.js +159 -18
  84. package/dist/node.js.map +1 -1
  85. package/dist/secp256k1-B6OW5ZCM.js +8 -0
  86. package/dist/secp256k1-B6OW5ZCM.js.map +1 -0
  87. package/dist/secp256k1-PJCSE4N6.cjs +30 -0
  88. package/dist/secp256k1-PJCSE4N6.cjs.map +1 -0
  89. package/dist/tokens.d.ts +2 -1
  90. package/dist/tokens.d.ts.map +1 -1
  91. package/dist/types/chain-config.d.ts +50 -0
  92. package/dist/types/chain-config.d.ts.map +1 -0
  93. package/dist/types/chain.d.ts +11 -0
  94. package/dist/types/chain.d.ts.map +1 -0
  95. package/dist/types/dex-quote.d.ts +85 -0
  96. package/dist/types/dex-quote.d.ts.map +1 -0
  97. package/dist/types/index.d.ts +15 -0
  98. package/dist/types/index.d.ts.map +1 -0
  99. package/dist/types/network-fees.d.ts +43 -0
  100. package/dist/types/network-fees.d.ts.map +1 -0
  101. package/dist/types/quote.d.ts +87 -0
  102. package/dist/types/quote.d.ts.map +1 -0
  103. package/dist/types/swap-pairs.d.ts +37 -0
  104. package/dist/types/swap-pairs.d.ts.map +1 -0
  105. package/dist/version.d.ts +2 -2
  106. package/dist/wallet-4YGTKWNZ.js +7 -0
  107. package/dist/wallet-4YGTKWNZ.js.map +1 -0
  108. package/dist/wallet-SZJDXAY7.cjs +45 -0
  109. package/dist/wallet-SZJDXAY7.cjs.map +1 -0
  110. package/package.json +23 -10
  111. package/dist/api/client.js +0 -13
  112. package/dist/api/client.js.map +0 -1
  113. package/dist/arkade-network.js +0 -40
  114. package/dist/arkade-network.js.map +0 -1
  115. package/dist/arkade.js +0 -61
  116. package/dist/arkade.js.map +0 -1
  117. package/dist/cctp/attestation.js +0 -149
  118. package/dist/cctp/attestation.js.map +0 -1
  119. package/dist/cctp/constants.js +0 -92
  120. package/dist/cctp/constants.js.map +0 -1
  121. package/dist/cctp/fee.js +0 -70
  122. package/dist/cctp/fee.js.map +0 -1
  123. package/dist/cctp/index.js +0 -13
  124. package/dist/cctp/index.js.map +0 -1
  125. package/dist/cctp/types.js +0 -5
  126. package/dist/cctp/types.js.map +0 -1
  127. package/dist/cctp/utils.js +0 -91
  128. package/dist/cctp/utils.js.map +0 -1
  129. package/dist/cctp-bridge/bridge.js +0 -74
  130. package/dist/cctp-bridge/bridge.js.map +0 -1
  131. package/dist/cctp-inbound/approveAndBurn.js +0 -95
  132. package/dist/cctp-inbound/approveAndBurn.js.map +0 -1
  133. package/dist/cctp-inbound/burn.js +0 -66
  134. package/dist/cctp-inbound/burn.js.map +0 -1
  135. package/dist/cctp-inbound/chainMap.js +0 -128
  136. package/dist/cctp-inbound/chainMap.js.map +0 -1
  137. package/dist/cctp-inbound/client.js +0 -125
  138. package/dist/cctp-inbound/client.js.map +0 -1
  139. package/dist/cctp-inbound/eip2612.js +0 -95
  140. package/dist/cctp-inbound/eip2612.js.map +0 -1
  141. package/dist/cctp-inbound/evmSignerAdapter.js +0 -82
  142. package/dist/cctp-inbound/evmSignerAdapter.js.map +0 -1
  143. package/dist/cctp-inbound/fundSwap.js +0 -95
  144. package/dist/cctp-inbound/fundSwap.js.map +0 -1
  145. package/dist/cctp-inbound/index.js +0 -34
  146. package/dist/cctp-inbound/index.js.map +0 -1
  147. package/dist/cctp-inbound/permit2.js +0 -32
  148. package/dist/cctp-inbound/permit2.js.map +0 -1
  149. package/dist/cctp-inbound/preflight.js +0 -84
  150. package/dist/cctp-inbound/preflight.js.map +0 -1
  151. package/dist/cctp-inbound/recover.js +0 -177
  152. package/dist/cctp-inbound/recover.js.map +0 -1
  153. package/dist/cctp-inbound/smartAccount.js +0 -117
  154. package/dist/cctp-inbound/smartAccount.js.map +0 -1
  155. package/dist/cctp-inbound/submit.js +0 -136
  156. package/dist/cctp-inbound/submit.js.map +0 -1
  157. package/dist/cctp-inbound/types.js +0 -5
  158. package/dist/cctp-inbound/types.js.map +0 -1
  159. package/dist/cctp-inbound/userOp.js +0 -151
  160. package/dist/cctp-inbound/userOp.js.map +0 -1
  161. package/dist/client.js +0 -4126
  162. package/dist/client.js.map +0 -1
  163. package/dist/create/arkade-to-lightning.js +0 -76
  164. package/dist/create/arkade-to-lightning.js.map +0 -1
  165. package/dist/create/arkade.js +0 -86
  166. package/dist/create/arkade.js.map +0 -1
  167. package/dist/create/bitcoin-to-arkade.js +0 -76
  168. package/dist/create/bitcoin-to-arkade.js.map +0 -1
  169. package/dist/create/bitcoin.js +0 -77
  170. package/dist/create/bitcoin.js.map +0 -1
  171. package/dist/create/evm-to-arkade.js +0 -80
  172. package/dist/create/evm-to-arkade.js.map +0 -1
  173. package/dist/create/evm-to-bitcoin.js +0 -82
  174. package/dist/create/evm-to-bitcoin.js.map +0 -1
  175. package/dist/create/evm-to-lightning.js +0 -89
  176. package/dist/create/evm-to-lightning.js.map +0 -1
  177. package/dist/create/index.js +0 -21
  178. package/dist/create/index.js.map +0 -1
  179. package/dist/create/lightning-to-arkade.js +0 -69
  180. package/dist/create/lightning-to-arkade.js.map +0 -1
  181. package/dist/create/lightning.js +0 -61
  182. package/dist/create/lightning.js.map +0 -1
  183. package/dist/create/retry.js +0 -71
  184. package/dist/create/retry.js.map +0 -1
  185. package/dist/create/types.js +0 -5
  186. package/dist/create/types.js.map +0 -1
  187. package/dist/escrow/index.js +0 -115
  188. package/dist/escrow/index.js.map +0 -1
  189. package/dist/esplora.js +0 -47
  190. package/dist/esplora.js.map +0 -1
  191. package/dist/evm/coordinator.js +0 -714
  192. package/dist/evm/coordinator.js.map +0 -1
  193. package/dist/evm/htlc.js +0 -278
  194. package/dist/evm/htlc.js.map +0 -1
  195. package/dist/evm/index.js +0 -10
  196. package/dist/evm/index.js.map +0 -1
  197. package/dist/evm/signing.js +0 -70
  198. package/dist/evm/signing.js.map +0 -1
  199. package/dist/evm/wallet.js +0 -133
  200. package/dist/evm/wallet.js.map +0 -1
  201. package/dist/generated/api.js +0 -6
  202. package/dist/generated/api.js.map +0 -1
  203. package/dist/logging.js +0 -130
  204. package/dist/logging.js.map +0 -1
  205. package/dist/price-calculations.js +0 -135
  206. package/dist/price-calculations.js.map +0 -1
  207. package/dist/redeem/arkade.js +0 -416
  208. package/dist/redeem/arkade.js.map +0 -1
  209. package/dist/redeem/ethereum.js +0 -206
  210. package/dist/redeem/ethereum.js.map +0 -1
  211. package/dist/redeem/gasless.js +0 -73
  212. package/dist/redeem/gasless.js.map +0 -1
  213. package/dist/redeem/index.js +0 -189
  214. package/dist/redeem/index.js.map +0 -1
  215. package/dist/redeem/types.js +0 -36
  216. package/dist/redeem/types.js.map +0 -1
  217. package/dist/refund/arkade.js +0 -200
  218. package/dist/refund/arkade.js.map +0 -1
  219. package/dist/refund/collab-arkade-evm.js +0 -307
  220. package/dist/refund/collab-arkade-evm.js.map +0 -1
  221. package/dist/refund/collab-arkade-lightning.js +0 -245
  222. package/dist/refund/collab-arkade-lightning.js.map +0 -1
  223. package/dist/refund/index.js +0 -12
  224. package/dist/refund/index.js.map +0 -1
  225. package/dist/refund/onchain.js +0 -366
  226. package/dist/refund/onchain.js.map +0 -1
  227. package/dist/signer/index.js +0 -249
  228. package/dist/signer/index.js.map +0 -1
  229. package/dist/storage/idb.js +0 -236
  230. package/dist/storage/idb.js.map +0 -1
  231. package/dist/storage/index.js +0 -98
  232. package/dist/storage/index.js.map +0 -1
  233. package/dist/storage/sqlite.js +0 -206
  234. package/dist/storage/sqlite.js.map +0 -1
  235. package/dist/storage/types.js +0 -9
  236. package/dist/storage/types.js.map +0 -1
  237. package/dist/tokens.js +0 -322
  238. package/dist/tokens.js.map +0 -1
  239. package/dist/usd-price.js +0 -96
  240. package/dist/usd-price.js.map +0 -1
  241. package/dist/usdt0-bridge/constants.js +0 -71
  242. package/dist/usdt0-bridge/constants.js.map +0 -1
  243. package/dist/usdt0-bridge/index.js +0 -11
  244. package/dist/usdt0-bridge/index.js.map +0 -1
  245. package/dist/usdt0-bridge/tracking.js +0 -123
  246. package/dist/usdt0-bridge/tracking.js.map +0 -1
  247. package/dist/usdt0-bridge/utils.js +0 -51
  248. package/dist/usdt0-bridge/utils.js.map +0 -1
  249. package/dist/version.js +0 -6
  250. package/dist/version.js.map +0 -1
  251. package/dist/ws.js +0 -145
  252. package/dist/ws.js.map +0 -1
@@ -0,0 +1,421 @@
1
+ import { createRequire } from 'module';
2
+ import { init_btc_signer, init_legacy, init_sha2, networks, ripemd160, sha256, VHTLC, RestArkProvider, RestIndexerProvider, Address, OutScript, ArkAddress, SigHash, Intent, setArkPsbtField, VtxoTaprootTree, SingleKey, ConditionWitness, Transaction2 } from './chunk-LA3YX2HD.js';
3
+ import { init_base, hex, base64 } from './chunk-4JXN4UPB.js';
4
+
5
+ createRequire(import.meta.url);
6
+
7
+ // src/delegate.ts
8
+ init_btc_signer();
9
+ init_legacy();
10
+ init_sha2();
11
+ init_base();
12
+
13
+ // src/arkade-network.ts
14
+ var DEFAULT_ARKADE_URLS = {
15
+ bitcoin: "https://arkade.computer",
16
+ mainnet: "https://arkade.computer",
17
+ signet: "https://mutinynet.arkade.sh",
18
+ mutinynet: "https://mutinynet.arkade.sh"
19
+ };
20
+ function getNetworkName(network) {
21
+ switch (network.toLowerCase()) {
22
+ case "mainnet":
23
+ case "bitcoin":
24
+ return "bitcoin";
25
+ case "testnet":
26
+ return "testnet";
27
+ case "signet":
28
+ return "signet";
29
+ case "mutinynet":
30
+ return "mutinynet";
31
+ case "regtest":
32
+ return "regtest";
33
+ default:
34
+ throw new Error(`Unknown network: ${network}`);
35
+ }
36
+ }
37
+ function getNetworkHrp(networkName) {
38
+ return networks[networkName].hrp;
39
+ }
40
+ function resolveArkadeServerUrl(network, arkadeServerUrl) {
41
+ const networkName = getNetworkName(network);
42
+ return resolveArkadeServerUrlByName(networkName, arkadeServerUrl);
43
+ }
44
+ function resolveArkadeServerUrlByName(networkName, arkadeServerUrl) {
45
+ const serverUrl = arkadeServerUrl ?? DEFAULT_ARKADE_URLS[networkName];
46
+ if (!serverUrl) {
47
+ throw new Error(
48
+ `No Arkade server URL configured for network: ${networkName}`
49
+ );
50
+ }
51
+ return serverUrl;
52
+ }
53
+
54
+ // src/logging.ts
55
+ var LEVEL_VALUE = {
56
+ trace: 10,
57
+ debug: 20,
58
+ info: 30,
59
+ warn: 40,
60
+ error: 50
61
+ };
62
+ var SECRET_FIELD_PATTERN = new RegExp(
63
+ "(^|_|-|\\b)(secret|secretkey|usersecretkey|privatekey|mnemonic|xprv|preimage|signature|authorization|apikey|api_key|bearer)(_|-|\\b|$)",
64
+ "i"
65
+ );
66
+ var REDACTED = "[REDACTED]";
67
+ var noopLogger = Object.freeze({});
68
+ function shouldLog(level, configuredLevel) {
69
+ if (configuredLevel === "silent") return false;
70
+ return LEVEL_VALUE[level] >= LEVEL_VALUE[configuredLevel];
71
+ }
72
+ function serializeError(error) {
73
+ if (error instanceof Error) {
74
+ return {
75
+ name: error.name,
76
+ message: error.message,
77
+ stack: error.stack
78
+ };
79
+ }
80
+ return error;
81
+ }
82
+ function redactLogValue(value) {
83
+ if (typeof value === "bigint") return value.toString();
84
+ if (value instanceof Error) return serializeError(value);
85
+ if (Array.isArray(value)) return value.map(redactLogValue);
86
+ if (value && typeof value === "object") {
87
+ const out = {};
88
+ for (const [key, nested] of Object.entries(
89
+ value
90
+ )) {
91
+ out[key] = SECRET_FIELD_PATTERN.test(key) ? REDACTED : redactLogValue(nested);
92
+ }
93
+ return out;
94
+ }
95
+ return value;
96
+ }
97
+ var SdkLogger = class _SdkLogger {
98
+ #logger;
99
+ #level;
100
+ #context;
101
+ constructor(options = {}, context = {}) {
102
+ this.#logger = options.logger ?? noopLogger;
103
+ this.#level = options.logLevel ?? "silent";
104
+ this.#context = context;
105
+ }
106
+ child(context) {
107
+ return new _SdkLogger(
108
+ { logger: this.#logger, logLevel: this.#level },
109
+ {
110
+ ...this.#context,
111
+ ...context,
112
+ data: {
113
+ ...this.#context.data,
114
+ ...context.data
115
+ }
116
+ }
117
+ );
118
+ }
119
+ trace(record) {
120
+ this.#emit("trace", record);
121
+ }
122
+ debug(record) {
123
+ this.#emit("debug", record);
124
+ }
125
+ info(record) {
126
+ this.#emit("info", record);
127
+ }
128
+ warn(record) {
129
+ this.#emit("warn", record);
130
+ }
131
+ error(record) {
132
+ this.#emit("error", record);
133
+ }
134
+ #emit(level, record) {
135
+ if (!shouldLog(level, this.#level)) return;
136
+ const sink = this.#logger[level];
137
+ if (!sink) return;
138
+ const data = redactLogValue({
139
+ ...this.#context.data,
140
+ ...record.data
141
+ });
142
+ sink({
143
+ level,
144
+ module: record.module ?? this.#context.module,
145
+ operation: record.operation ?? this.#context.operation,
146
+ swapId: record.swapId ?? this.#context.swapId,
147
+ event: record.event,
148
+ message: record.message,
149
+ data: Object.keys(data).length > 0 ? data : void 0,
150
+ error: record.error === void 0 ? void 0 : redactLogValue(record.error)
151
+ });
152
+ }
153
+ };
154
+ function createSdkLogger(options) {
155
+ return new SdkLogger(options);
156
+ }
157
+ function createConsoleLogger() {
158
+ const write = (record) => {
159
+ const { level, message, ...rest } = record;
160
+ const payload = Object.fromEntries(
161
+ Object.entries(rest).filter(([, value]) => value !== void 0)
162
+ );
163
+ const args = Object.keys(payload).length > 0 ? [message, payload] : [message];
164
+ if (level === "trace") console.debug(...args);
165
+ else if (level === "debug") console.debug(...args);
166
+ else if (level === "info") console.info(...args);
167
+ else if (level === "warn") console.warn(...args);
168
+ else console.error(...args);
169
+ };
170
+ return {
171
+ trace: write,
172
+ debug: write,
173
+ info: write,
174
+ warn: write,
175
+ error: write
176
+ };
177
+ }
178
+
179
+ // src/delegate.ts
180
+ var P2A_SCRIPT = new Uint8Array([81, 2, 78, 115]);
181
+ var P2A = { script: P2A_SCRIPT, amount: 0n };
182
+ function secondsToTimelock(seconds) {
183
+ return { type: "seconds", value: BigInt(seconds) };
184
+ }
185
+ function parseXOnlyPubKey(pubKeyHex) {
186
+ const bytes = hex.decode(pubKeyHex);
187
+ if (bytes.length === 33) return bytes.slice(1);
188
+ if (bytes.length === 32) return bytes;
189
+ throw new Error(`Invalid public key length: ${bytes.length}`);
190
+ }
191
+ async function fetchCosignerPk(lendaswapApiUrl) {
192
+ const url = `${lendaswapApiUrl.replace(/\/$/, "")}/api/delegate/cosigner-pk`;
193
+ const res = await fetch(url);
194
+ if (!res.ok) {
195
+ throw new Error(
196
+ `Failed to fetch cosigner pk: ${res.status} ${await res.text()}`
197
+ );
198
+ }
199
+ const body = await res.json();
200
+ return body.cosigner_pk;
201
+ }
202
+ async function delegateClaim(params) {
203
+ const userPkBytes = parseXOnlyPubKey(params.userPubKey);
204
+ const lendaswapPkBytes = parseXOnlyPubKey(params.lendaswapPubKey);
205
+ const serverPkBytes = parseXOnlyPubKey(params.arkadeServerPubKey);
206
+ const preimageBytes = hex.decode(params.preimage);
207
+ const preimageHashBytes = ripemd160(sha256(preimageBytes));
208
+ if (hex.encode(preimageHashBytes) !== hex.encode(ripemd160(hex.decode(params.preimageHash)))) {
209
+ throw new Error("Preimage hash mismatch");
210
+ }
211
+ const networkName = getNetworkName(params.network);
212
+ const vhtlc = new VHTLC.Script({
213
+ sender: lendaswapPkBytes,
214
+ receiver: userPkBytes,
215
+ server: serverPkBytes,
216
+ preimageHash: preimageHashBytes,
217
+ refundLocktime: BigInt(params.refundLocktime),
218
+ unilateralClaimDelay: secondsToTimelock(params.unilateralClaimDelay),
219
+ unilateralRefundDelay: secondsToTimelock(params.unilateralRefundDelay),
220
+ unilateralRefundWithoutReceiverDelay: secondsToTimelock(
221
+ params.unilateralRefundWithoutReceiverDelay
222
+ )
223
+ });
224
+ const hrp = getNetworkHrp(networkName);
225
+ const computedAddr = vhtlc.address(hrp, serverPkBytes).encode();
226
+ if (computedAddr !== params.vhtlcAddress) {
227
+ throw new Error(
228
+ `VHTLC address mismatch: computed ${computedAddr}, expected ${params.vhtlcAddress}`
229
+ );
230
+ }
231
+ return settleDelegate({
232
+ userSecretKey: params.userSecretKey,
233
+ tapLeafScript: vhtlc.claim(),
234
+ tapTree: vhtlc.encode(),
235
+ vhtlcPkScript: hex.encode(vhtlc.pkScript),
236
+ witnessData: preimageBytes,
237
+ destinationAddress: params.destinationAddress,
238
+ networkName,
239
+ lendaswapApiUrl: params.lendaswapApiUrl,
240
+ arkadeServerUrl: params.arkadeServerUrl,
241
+ locktime: void 0,
242
+ swapId: params.swapId,
243
+ preimage: params.preimage,
244
+ logger: params.logger,
245
+ logLevel: params.logLevel
246
+ });
247
+ }
248
+ async function delegateRefund(params) {
249
+ const userPkBytes = parseXOnlyPubKey(params.userPubKey);
250
+ const lendaswapPkBytes = parseXOnlyPubKey(params.lendaswapPubKey);
251
+ const serverPkBytes = parseXOnlyPubKey(params.arkadeServerPubKey);
252
+ const hashLockBytes = hex.decode(params.hashLock);
253
+ const preimageHashBytes = hashLockBytes.length === 32 ? ripemd160(hashLockBytes) : hashLockBytes;
254
+ const networkName = getNetworkName(params.network);
255
+ const vhtlc = new VHTLC.Script({
256
+ sender: userPkBytes,
257
+ receiver: lendaswapPkBytes,
258
+ server: serverPkBytes,
259
+ preimageHash: preimageHashBytes,
260
+ refundLocktime: BigInt(params.refundLocktime),
261
+ unilateralClaimDelay: secondsToTimelock(params.unilateralClaimDelay),
262
+ unilateralRefundDelay: secondsToTimelock(params.unilateralRefundDelay),
263
+ unilateralRefundWithoutReceiverDelay: secondsToTimelock(
264
+ params.unilateralRefundWithoutReceiverDelay
265
+ )
266
+ });
267
+ const hrp = getNetworkHrp(networkName);
268
+ const computedAddr = vhtlc.address(hrp, serverPkBytes).encode();
269
+ if (computedAddr !== params.vhtlcAddress) {
270
+ throw new Error(
271
+ `VHTLC address mismatch: computed ${computedAddr}, expected ${params.vhtlcAddress}`
272
+ );
273
+ }
274
+ return settleDelegate({
275
+ userSecretKey: params.userSecretKey,
276
+ tapLeafScript: vhtlc.refundWithoutReceiver(),
277
+ tapTree: vhtlc.encode(),
278
+ vhtlcPkScript: hex.encode(vhtlc.pkScript),
279
+ witnessData: void 0,
280
+ destinationAddress: params.destinationAddress,
281
+ networkName,
282
+ lendaswapApiUrl: params.lendaswapApiUrl,
283
+ arkadeServerUrl: params.arkadeServerUrl,
284
+ locktime: params.refundLocktime,
285
+ logger: params.logger,
286
+ logLevel: params.logLevel
287
+ });
288
+ }
289
+ async function settleDelegate(opts) {
290
+ const {
291
+ userSecretKey,
292
+ tapLeafScript,
293
+ tapTree,
294
+ vhtlcPkScript,
295
+ witnessData,
296
+ destinationAddress,
297
+ networkName,
298
+ lendaswapApiUrl,
299
+ arkadeServerUrl
300
+ } = opts;
301
+ const logger = createSdkLogger(opts).child({
302
+ module: "delegate",
303
+ operation: "delegate.settle",
304
+ swapId: opts.swapId,
305
+ data: { destinationAddress, networkName }
306
+ });
307
+ const serverUrl = resolveArkadeServerUrlByName(networkName, arkadeServerUrl);
308
+ const arkProvider = new RestArkProvider(serverUrl);
309
+ const indexerProvider = new RestIndexerProvider(serverUrl);
310
+ const serverInfo = await arkProvider.getInfo();
311
+ const cosignerPkHex = await fetchCosignerPk(lendaswapApiUrl);
312
+ const btcNetwork = networks[networkName];
313
+ const forfeitDecoded = Address(btcNetwork).decode(serverInfo.forfeitAddress);
314
+ const forfeitPkScript = OutScript.encode(forfeitDecoded);
315
+ const { vtxos: allVtxos } = await indexerProvider.getVtxos({
316
+ scripts: [vhtlcPkScript]
317
+ });
318
+ const vtxos = allVtxos.filter((v) => !v.isSpent);
319
+ if (vtxos.length === 0) {
320
+ throw new Error("No settleable VTXOs found at the VHTLC address");
321
+ }
322
+ const totalAmount = vtxos.reduce((acc, v) => acc + BigInt(v.value), 0n);
323
+ if (totalAmount === 0n) {
324
+ throw new Error("Total VTXO amount is zero");
325
+ }
326
+ logger.info({
327
+ event: "delegate.settle.vtxos_found",
328
+ message: "Found settleable VTXOs for delegate settlement",
329
+ data: { vtxoCount: vtxos.length, totalAmount }
330
+ });
331
+ const destAddr = ArkAddress.decode(destinationAddress);
332
+ const destPkScript = destAddr.pkScript;
333
+ const now = Math.floor(Date.now() / 1e3);
334
+ const intentMessage = {
335
+ type: "register",
336
+ onchain_output_indexes: [],
337
+ valid_at: now,
338
+ expire_at: now + 120,
339
+ cosigners_public_keys: [cosignerPkHex]
340
+ };
341
+ const pkScriptBytes = hex.decode(vhtlcPkScript);
342
+ const intentInputs = vtxos.map((v) => ({
343
+ txid: hex.decode(v.txid),
344
+ index: v.vout,
345
+ witnessUtxo: {
346
+ script: pkScriptBytes,
347
+ amount: BigInt(v.value)
348
+ },
349
+ tapLeafScript: [tapLeafScript],
350
+ sequence: opts.locktime ? 4294967294 : void 0,
351
+ sighashType: SigHash.ALL
352
+ }));
353
+ const intentProof = Intent.create(intentMessage, intentInputs, [
354
+ { script: destPkScript, amount: totalAmount }
355
+ ]);
356
+ for (let i = 0; i < vtxos.length; i++) {
357
+ setArkPsbtField(intentProof, i + 1, VtxoTaprootTree, tapTree);
358
+ }
359
+ const signer = SingleKey.fromHex(userSecretKey);
360
+ if (witnessData) {
361
+ for (let i = 0; i < vtxos.length; i++) {
362
+ setArkPsbtField(intentProof, i + 1, ConditionWitness, [witnessData]);
363
+ }
364
+ }
365
+ const signedIntentProof = await signer.sign(intentProof);
366
+ const dust = serverInfo.dust;
367
+ const signedForfeitPsbts = [];
368
+ for (const v of vtxos) {
369
+ const vtxoAmount = BigInt(v.value);
370
+ const forfeitTx = new Transaction2({
371
+ version: 3,
372
+ lockTime: 0
373
+ });
374
+ forfeitTx.addInput({
375
+ txid: hex.decode(v.txid),
376
+ index: v.vout,
377
+ witnessUtxo: {
378
+ script: pkScriptBytes,
379
+ amount: vtxoAmount
380
+ },
381
+ tapLeafScript: [tapLeafScript],
382
+ sighashType: SigHash.ALL_ANYONECANPAY
383
+ });
384
+ forfeitTx.addOutput({
385
+ script: forfeitPkScript,
386
+ amount: vtxoAmount + dust
387
+ });
388
+ forfeitTx.addOutput(P2A);
389
+ setArkPsbtField(forfeitTx, 0, VtxoTaprootTree, tapTree);
390
+ if (witnessData) {
391
+ setArkPsbtField(forfeitTx, 0, ConditionWitness, [witnessData]);
392
+ }
393
+ const signedForfeit = await signer.sign(forfeitTx);
394
+ signedForfeitPsbts.push(base64.encode(signedForfeit.toPSBT()));
395
+ }
396
+ const intentProofBase64 = base64.encode(signedIntentProof.toPSBT());
397
+ const intentMessageJson = Intent.encodeMessage(intentMessage);
398
+ const settleUrl = `${lendaswapApiUrl.replace(/\/$/, "")}/api/delegate/settle`;
399
+ const settleRes = await fetch(settleUrl, {
400
+ method: "POST",
401
+ headers: { "Content-Type": "application/json" },
402
+ body: JSON.stringify({
403
+ intent_proof: intentProofBase64,
404
+ intent_message: intentMessageJson,
405
+ forfeit_psbts: signedForfeitPsbts,
406
+ cosigner_pk: cosignerPkHex,
407
+ swap_id: opts.swapId,
408
+ preimage: opts.preimage
409
+ })
410
+ });
411
+ if (!settleRes.ok) {
412
+ const errBody = await settleRes.text();
413
+ throw new Error(`Delegate settle failed: ${settleRes.status} ${errBody}`);
414
+ }
415
+ const result = await settleRes.json();
416
+ return { commitmentTxid: result.commitment_txid };
417
+ }
418
+
419
+ export { SdkLogger, createConsoleLogger, createSdkLogger, delegateClaim, delegateRefund, fetchCosignerPk, getNetworkHrp, getNetworkName, noopLogger, redactLogValue, resolveArkadeServerUrl, resolveArkadeServerUrlByName };
420
+ //# sourceMappingURL=chunk-DBBCKPZ5.js.map
421
+ //# sourceMappingURL=chunk-DBBCKPZ5.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/delegate.ts","../src/arkade-network.ts","../src/logging.ts"],"names":["Transaction"],"mappings":"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","file":"chunk-DBBCKPZ5.js","sourcesContent":["/**\n * Delegate settlement for VHTLC VTXOs.\n *\n * Allows the client to prepare and sign delegate PSBTs (intent + forfeits),\n * then POST them to the lendaswap backend which runs the Ark batch ceremony.\n *\n * This works for spendable, recoverable, AND expired VTXOs — unlike the\n * offchain submitTx/finalizeTx path which only handles spendable VTXOs.\n */\n\nimport {\n ArkAddress,\n type ArkProvider,\n ConditionWitness,\n type IndexerProvider,\n Intent,\n type NetworkName,\n networks,\n RestArkProvider,\n RestIndexerProvider,\n SingleKey,\n setArkPsbtField,\n type TapLeafScript,\n Transaction,\n VHTLC,\n VtxoTaprootTree,\n} from \"@arkade-os/sdk\";\nimport { Address, OutScript, SigHash } from \"@scure/btc-signer\";\n\n// P2A is the zero-value anchor output (OP_1 0x4e73)\nconst P2A_SCRIPT = new Uint8Array([0x51, 0x02, 0x4e, 0x73]);\nconst P2A = { script: P2A_SCRIPT, amount: 0n };\n\nimport { ripemd160 } from \"@noble/hashes/legacy.js\";\nimport { sha256 } from \"@noble/hashes/sha2.js\";\nimport { base64, hex } from \"@scure/base\";\n\nimport {\n getNetworkHrp,\n getNetworkName,\n resolveArkadeServerUrlByName,\n} from \"./arkade-network.js\";\nimport { createSdkLogger, type Logger, type LogLevel } from \"./logging.js\";\n\nfunction secondsToTimelock(\n seconds: number,\n): VHTLC.Options[\"unilateralClaimDelay\"] {\n return { type: \"seconds\" as const, value: BigInt(seconds) };\n}\n\nfunction parseXOnlyPubKey(pubKeyHex: string): Uint8Array {\n const bytes = hex.decode(pubKeyHex);\n if (bytes.length === 33) return bytes.slice(1);\n if (bytes.length === 32) return bytes;\n throw new Error(`Invalid public key length: ${bytes.length}`);\n}\n\n// ---------------------------------------------------------------------------\n// Public API\n// ---------------------------------------------------------------------------\n\nexport interface DelegateClaimParams {\n userSecretKey: string;\n userPubKey: string;\n lendaswapPubKey: string;\n arkadeServerPubKey: string;\n preimage: string;\n preimageHash: string;\n vhtlcAddress: string;\n refundLocktime: number;\n unilateralClaimDelay: number;\n unilateralRefundDelay: number;\n unilateralRefundWithoutReceiverDelay: number;\n /** Destination Arkade address */\n destinationAddress: string;\n network: string;\n /** Lendaswap API base URL (e.g. http://localhost:3333) */\n lendaswapApiUrl: string;\n arkadeServerUrl?: string;\n /** Optional swap ID — enables the backend to mark swap as ClientRedeemed. */\n swapId?: string;\n /** Optional logger sink. Silent by default. */\n logger?: Logger;\n /** Minimum log level to emit. Defaults to `silent`. */\n logLevel?: LogLevel;\n}\n\nexport interface DelegateRefundParams {\n userSecretKey: string;\n userPubKey: string;\n lendaswapPubKey: string;\n arkadeServerPubKey: string;\n hashLock: string;\n vhtlcAddress: string;\n refundLocktime: number;\n unilateralClaimDelay: number;\n unilateralRefundDelay: number;\n unilateralRefundWithoutReceiverDelay: number;\n destinationAddress: string;\n network: string;\n lendaswapApiUrl: string;\n arkadeServerUrl?: string;\n /** Optional logger sink. Silent by default. */\n logger?: Logger;\n /** Minimum log level to emit. Defaults to `silent`. */\n logLevel?: LogLevel;\n}\n\nexport interface DelegateSettleResult {\n commitmentTxid: string;\n}\n\n/**\n * Fetch the backend's static delegate cosigner public key.\n */\nexport async function fetchCosignerPk(\n lendaswapApiUrl: string,\n): Promise<string> {\n const url = `${lendaswapApiUrl.replace(/\\/$/, \"\")}/api/delegate/cosigner-pk`;\n const res = await fetch(url);\n if (!res.ok) {\n throw new Error(\n `Failed to fetch cosigner pk: ${res.status} ${await res.text()}`,\n );\n }\n const body = (await res.json()) as { cosigner_pk: string };\n return body.cosigner_pk;\n}\n\n/**\n * Settle a VHTLC via delegate claim (reveal preimage).\n */\nexport async function delegateClaim(\n params: DelegateClaimParams,\n): Promise<DelegateSettleResult> {\n const userPkBytes = parseXOnlyPubKey(params.userPubKey);\n const lendaswapPkBytes = parseXOnlyPubKey(params.lendaswapPubKey);\n const serverPkBytes = parseXOnlyPubKey(params.arkadeServerPubKey);\n\n const preimageBytes = hex.decode(params.preimage);\n const preimageHashBytes = ripemd160(sha256(preimageBytes));\n\n if (\n hex.encode(preimageHashBytes) !==\n hex.encode(ripemd160(hex.decode(params.preimageHash)))\n ) {\n throw new Error(\"Preimage hash mismatch\");\n }\n\n // Build VHTLC — for claim: lendaswap=sender, user=receiver\n const networkName = getNetworkName(params.network);\n const vhtlc = new VHTLC.Script({\n sender: lendaswapPkBytes,\n receiver: userPkBytes,\n server: serverPkBytes,\n preimageHash: preimageHashBytes,\n refundLocktime: BigInt(params.refundLocktime),\n unilateralClaimDelay: secondsToTimelock(params.unilateralClaimDelay),\n unilateralRefundDelay: secondsToTimelock(params.unilateralRefundDelay),\n unilateralRefundWithoutReceiverDelay: secondsToTimelock(\n params.unilateralRefundWithoutReceiverDelay,\n ),\n });\n\n const hrp = getNetworkHrp(networkName);\n const computedAddr = vhtlc.address(hrp, serverPkBytes).encode();\n if (computedAddr !== params.vhtlcAddress) {\n throw new Error(\n `VHTLC address mismatch: computed ${computedAddr}, expected ${params.vhtlcAddress}`,\n );\n }\n\n return settleDelegate({\n userSecretKey: params.userSecretKey,\n tapLeafScript: vhtlc.claim(),\n tapTree: vhtlc.encode(),\n vhtlcPkScript: hex.encode(vhtlc.pkScript),\n witnessData: preimageBytes,\n destinationAddress: params.destinationAddress,\n networkName,\n lendaswapApiUrl: params.lendaswapApiUrl,\n arkadeServerUrl: params.arkadeServerUrl,\n locktime: undefined,\n swapId: params.swapId,\n preimage: params.preimage,\n logger: params.logger,\n logLevel: params.logLevel,\n });\n}\n\n/**\n * Settle a VHTLC via delegate refund (after locktime expiry).\n */\nexport async function delegateRefund(\n params: DelegateRefundParams,\n): Promise<DelegateSettleResult> {\n const userPkBytes = parseXOnlyPubKey(params.userPubKey);\n const lendaswapPkBytes = parseXOnlyPubKey(params.lendaswapPubKey);\n const serverPkBytes = parseXOnlyPubKey(params.arkadeServerPubKey);\n\n const hashLockBytes = hex.decode(params.hashLock);\n const preimageHashBytes =\n hashLockBytes.length === 32 ? ripemd160(hashLockBytes) : hashLockBytes;\n\n // Build VHTLC — for refund: user=sender, lendaswap=receiver\n const networkName = getNetworkName(params.network);\n const vhtlc = new VHTLC.Script({\n sender: userPkBytes,\n receiver: lendaswapPkBytes,\n server: serverPkBytes,\n preimageHash: preimageHashBytes,\n refundLocktime: BigInt(params.refundLocktime),\n unilateralClaimDelay: secondsToTimelock(params.unilateralClaimDelay),\n unilateralRefundDelay: secondsToTimelock(params.unilateralRefundDelay),\n unilateralRefundWithoutReceiverDelay: secondsToTimelock(\n params.unilateralRefundWithoutReceiverDelay,\n ),\n });\n\n const hrp = getNetworkHrp(networkName);\n const computedAddr = vhtlc.address(hrp, serverPkBytes).encode();\n if (computedAddr !== params.vhtlcAddress) {\n throw new Error(\n `VHTLC address mismatch: computed ${computedAddr}, expected ${params.vhtlcAddress}`,\n );\n }\n\n return settleDelegate({\n userSecretKey: params.userSecretKey,\n tapLeafScript: vhtlc.refundWithoutReceiver(),\n tapTree: vhtlc.encode(),\n vhtlcPkScript: hex.encode(vhtlc.pkScript),\n witnessData: undefined,\n destinationAddress: params.destinationAddress,\n networkName,\n lendaswapApiUrl: params.lendaswapApiUrl,\n arkadeServerUrl: params.arkadeServerUrl,\n locktime: params.refundLocktime,\n logger: params.logger,\n logLevel: params.logLevel,\n });\n}\n\n// ---------------------------------------------------------------------------\n// Internal\n// ---------------------------------------------------------------------------\n\ninterface SettleDelegateOpts {\n userSecretKey: string;\n tapLeafScript: TapLeafScript;\n tapTree: Uint8Array;\n vhtlcPkScript: string;\n witnessData: Uint8Array | undefined;\n destinationAddress: string;\n networkName: NetworkName;\n lendaswapApiUrl: string;\n arkadeServerUrl: string | undefined;\n locktime: number | undefined;\n swapId?: string;\n preimage?: string;\n logger?: Logger;\n logLevel?: LogLevel;\n}\n\nasync function settleDelegate(\n opts: SettleDelegateOpts,\n): Promise<DelegateSettleResult> {\n const {\n userSecretKey,\n tapLeafScript,\n tapTree,\n vhtlcPkScript,\n witnessData,\n destinationAddress,\n networkName,\n lendaswapApiUrl,\n arkadeServerUrl,\n } = opts;\n\n const logger = createSdkLogger(opts).child({\n module: \"delegate\",\n operation: \"delegate.settle\",\n swapId: opts.swapId,\n data: { destinationAddress, networkName },\n });\n\n const serverUrl = resolveArkadeServerUrlByName(networkName, arkadeServerUrl);\n\n const arkProvider: ArkProvider = new RestArkProvider(serverUrl);\n const indexerProvider: IndexerProvider = new RestIndexerProvider(serverUrl);\n const serverInfo = await arkProvider.getInfo();\n\n // Fetch cosigner pk from lendaswap backend\n const cosignerPkHex = await fetchCosignerPk(lendaswapApiUrl);\n\n // Decode forfeit address (bech32) to pkScript\n const btcNetwork = networks[networkName];\n const forfeitDecoded = Address(btcNetwork).decode(serverInfo.forfeitAddress);\n const forfeitPkScript = OutScript.encode(forfeitDecoded);\n\n // Fetch VTXOs — include all (not just spendable)\n const { vtxos: allVtxos } = await indexerProvider.getVtxos({\n scripts: [vhtlcPkScript],\n });\n\n // Filter to unspent VTXOs\n const vtxos = allVtxos.filter((v) => !v.isSpent);\n\n if (vtxos.length === 0) {\n throw new Error(\"No settleable VTXOs found at the VHTLC address\");\n }\n\n const totalAmount = vtxos.reduce((acc, v) => acc + BigInt(v.value), 0n);\n if (totalAmount === 0n) {\n throw new Error(\"Total VTXO amount is zero\");\n }\n\n logger.info({\n event: \"delegate.settle.vtxos_found\",\n message: \"Found settleable VTXOs for delegate settlement\",\n data: { vtxoCount: vtxos.length, totalAmount },\n });\n\n // Parse destination (Ark address → taproot pkScript)\n const destAddr = ArkAddress.decode(destinationAddress);\n const destPkScript = destAddr.pkScript;\n\n // Build intent message\n const now = Math.floor(Date.now() / 1000);\n const intentMessage: Intent.RegisterMessage = {\n type: \"register\",\n onchain_output_indexes: [],\n valid_at: now,\n expire_at: now + 120,\n cosigners_public_keys: [cosignerPkHex],\n };\n\n // Build intent inputs from VTXOs\n const pkScriptBytes = hex.decode(vhtlcPkScript);\n const intentInputs = vtxos.map((v) => ({\n txid: hex.decode(v.txid),\n index: v.vout,\n witnessUtxo: {\n script: pkScriptBytes,\n amount: BigInt(v.value),\n },\n tapLeafScript: [tapLeafScript],\n sequence: opts.locktime ? 0xfffffffe : undefined,\n sighashType: SigHash.ALL,\n }));\n\n // Build intent proof PSBT\n const intentProof = Intent.create(intentMessage, intentInputs, [\n { script: destPkScript, amount: totalAmount },\n ]);\n\n // Set VtxoTaprootTree on each real input (skip input 0 which is the toSpend ref)\n for (let i = 0; i < vtxos.length; i++) {\n setArkPsbtField(intentProof, i + 1, VtxoTaprootTree, tapTree);\n }\n\n // Sign intent proof\n const signer = SingleKey.fromHex(userSecretKey);\n\n // Set condition witness (preimage) if claiming\n if (witnessData) {\n for (let i = 0; i < vtxos.length; i++) {\n setArkPsbtField(intentProof, i + 1, ConditionWitness, [witnessData]);\n }\n }\n\n const signedIntentProof = await signer.sign(intentProof);\n\n // Build and sign delegate forfeit PSBTs.\n // Delegate forfeits have 1 input (the VTXO) with SIGHASH_ALL|ANYONECANPAY.\n // The connector input is added later by the cosigner during batch finalization.\n // Output amount = vtxo_amount + connector_dust (anticipating the connector).\n const dust = serverInfo.dust;\n const signedForfeitPsbts: string[] = [];\n\n for (const v of vtxos) {\n const vtxoAmount = BigInt(v.value);\n\n const forfeitTx = new Transaction({\n version: 3,\n lockTime: 0,\n });\n\n forfeitTx.addInput({\n txid: hex.decode(v.txid),\n index: v.vout,\n witnessUtxo: {\n script: pkScriptBytes,\n amount: vtxoAmount,\n },\n tapLeafScript: [tapLeafScript],\n sighashType: SigHash.ALL_ANYONECANPAY,\n });\n\n // Main output: VTXO amount + connector dust → forfeit address\n forfeitTx.addOutput({\n script: forfeitPkScript,\n amount: vtxoAmount + dust,\n });\n\n // Anchor output (P2A)\n forfeitTx.addOutput(P2A);\n\n // Set taproot tree\n setArkPsbtField(forfeitTx, 0, VtxoTaprootTree, tapTree);\n\n if (witnessData) {\n setArkPsbtField(forfeitTx, 0, ConditionWitness, [witnessData]);\n }\n\n const signedForfeit = await signer.sign(forfeitTx);\n signedForfeitPsbts.push(base64.encode(signedForfeit.toPSBT()));\n }\n\n // Serialize intent proof\n const intentProofBase64 = base64.encode(signedIntentProof.toPSBT());\n const intentMessageJson = Intent.encodeMessage(intentMessage);\n\n // POST to backend\n const settleUrl = `${lendaswapApiUrl.replace(/\\/$/, \"\")}/api/delegate/settle`;\n const settleRes = await fetch(settleUrl, {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({\n intent_proof: intentProofBase64,\n intent_message: intentMessageJson,\n forfeit_psbts: signedForfeitPsbts,\n cosigner_pk: cosignerPkHex,\n swap_id: opts.swapId,\n preimage: opts.preimage,\n }),\n });\n\n if (!settleRes.ok) {\n const errBody = await settleRes.text();\n throw new Error(`Delegate settle failed: ${settleRes.status} ${errBody}`);\n }\n\n const result = (await settleRes.json()) as { commitment_txid: string };\n return { commitmentTxid: result.commitment_txid };\n}\n","import { type NetworkName, networks } from \"@arkade-os/sdk\";\n\n/** Default Arkade server URL by network */\nexport const DEFAULT_ARKADE_URLS: Record<string, string> = {\n bitcoin: \"https://arkade.computer\",\n mainnet: \"https://arkade.computer\",\n signet: \"https://mutinynet.arkade.sh\",\n mutinynet: \"https://mutinynet.arkade.sh\",\n};\n\nexport function getNetworkName(network: string): NetworkName {\n switch (network.toLowerCase()) {\n case \"mainnet\":\n case \"bitcoin\":\n return \"bitcoin\";\n case \"testnet\":\n return \"testnet\";\n case \"signet\":\n return \"signet\";\n case \"mutinynet\":\n return \"mutinynet\";\n case \"regtest\":\n return \"regtest\";\n default:\n throw new Error(`Unknown network: ${network}`);\n }\n}\n\nexport function getNetworkHrp(networkName: NetworkName): string {\n return networks[networkName].hrp;\n}\n\nexport function resolveArkadeServerUrl(\n network: string,\n arkadeServerUrl?: string,\n): string {\n const networkName = getNetworkName(network);\n return resolveArkadeServerUrlByName(networkName, arkadeServerUrl);\n}\n\nexport function resolveArkadeServerUrlByName(\n networkName: NetworkName,\n arkadeServerUrl?: string,\n): string {\n const serverUrl = arkadeServerUrl ?? DEFAULT_ARKADE_URLS[networkName];\n if (!serverUrl) {\n throw new Error(\n `No Arkade server URL configured for network: ${networkName}`,\n );\n }\n return serverUrl;\n}\n","export type LogLevel = \"trace\" | \"debug\" | \"info\" | \"warn\" | \"error\" | \"silent\";\n\nexport type ActiveLogLevel = Exclude<LogLevel, \"silent\">;\n\nexport interface LogRecord {\n level: ActiveLogLevel;\n message: string;\n event?: string;\n module?: string;\n operation?: string;\n swapId?: string;\n data?: Record<string, unknown>;\n error?: unknown;\n}\n\nexport interface Logger {\n trace?(record: LogRecord): void;\n debug?(record: LogRecord): void;\n info?(record: LogRecord): void;\n warn?(record: LogRecord): void;\n error?(record: LogRecord): void;\n}\n\nexport interface LoggerOptions {\n logger?: Logger;\n logLevel?: LogLevel;\n}\n\nexport interface LogContext {\n module?: string;\n operation?: string;\n swapId?: string;\n data?: Record<string, unknown>;\n}\n\nconst LEVEL_VALUE: Record<ActiveLogLevel, number> = {\n trace: 10,\n debug: 20,\n info: 30,\n warn: 40,\n error: 50,\n};\n\nconst SECRET_FIELD_PATTERN = new RegExp(\n \"(^|_|-|\\\\b)\" +\n \"(secret|secretkey|usersecretkey|privatekey|mnemonic|xprv|\" +\n \"preimage|signature|authorization|apikey|api_key|bearer)\" +\n \"(_|-|\\\\b|$)\",\n \"i\",\n);\n\nconst REDACTED = \"[REDACTED]\";\n\nexport const noopLogger: Logger = Object.freeze({});\n\nfunction shouldLog(level: ActiveLogLevel, configuredLevel: LogLevel): boolean {\n if (configuredLevel === \"silent\") return false;\n return LEVEL_VALUE[level] >= LEVEL_VALUE[configuredLevel];\n}\n\nfunction serializeError(error: unknown): unknown {\n if (error instanceof Error) {\n return {\n name: error.name,\n message: error.message,\n stack: error.stack,\n };\n }\n return error;\n}\n\nexport function redactLogValue(value: unknown): unknown {\n if (typeof value === \"bigint\") return value.toString();\n if (value instanceof Error) return serializeError(value);\n if (Array.isArray(value)) return value.map(redactLogValue);\n if (value && typeof value === \"object\") {\n const out: Record<string, unknown> = {};\n for (const [key, nested] of Object.entries(\n value as Record<string, unknown>,\n )) {\n out[key] = SECRET_FIELD_PATTERN.test(key)\n ? REDACTED\n : redactLogValue(nested);\n }\n return out;\n }\n return value;\n}\n\nexport class SdkLogger {\n readonly #logger: Logger;\n readonly #level: LogLevel;\n readonly #context: LogContext;\n\n constructor(options: LoggerOptions = {}, context: LogContext = {}) {\n this.#logger = options.logger ?? noopLogger;\n this.#level = options.logLevel ?? \"silent\";\n this.#context = context;\n }\n\n child(context: LogContext): SdkLogger {\n return new SdkLogger(\n { logger: this.#logger, logLevel: this.#level },\n {\n ...this.#context,\n ...context,\n data: {\n ...this.#context.data,\n ...context.data,\n },\n },\n );\n }\n\n trace(record: Omit<LogRecord, \"level\">): void {\n this.#emit(\"trace\", record);\n }\n\n debug(record: Omit<LogRecord, \"level\">): void {\n this.#emit(\"debug\", record);\n }\n\n info(record: Omit<LogRecord, \"level\">): void {\n this.#emit(\"info\", record);\n }\n\n warn(record: Omit<LogRecord, \"level\">): void {\n this.#emit(\"warn\", record);\n }\n\n error(record: Omit<LogRecord, \"level\">): void {\n this.#emit(\"error\", record);\n }\n\n #emit(level: ActiveLogLevel, record: Omit<LogRecord, \"level\">): void {\n if (!shouldLog(level, this.#level)) return;\n\n const sink = this.#logger[level];\n if (!sink) return;\n\n const data = redactLogValue({\n ...this.#context.data,\n ...record.data,\n }) as Record<string, unknown>;\n\n sink({\n level,\n module: record.module ?? this.#context.module,\n operation: record.operation ?? this.#context.operation,\n swapId: record.swapId ?? this.#context.swapId,\n event: record.event,\n message: record.message,\n data: Object.keys(data).length > 0 ? data : undefined,\n error:\n record.error === undefined ? undefined : redactLogValue(record.error),\n });\n }\n}\n\nexport function createSdkLogger(options?: LoggerOptions): SdkLogger {\n return new SdkLogger(options);\n}\n\nexport function createConsoleLogger(): Logger {\n const write = (record: LogRecord) => {\n const { level, message, ...rest } = record;\n const payload = Object.fromEntries(\n Object.entries(rest).filter(([, value]) => value !== undefined),\n );\n const args =\n Object.keys(payload).length > 0 ? [message, payload] : [message];\n if (level === \"trace\") console.debug(...args);\n else if (level === \"debug\") console.debug(...args);\n else if (level === \"info\") console.info(...args);\n else if (level === \"warn\") console.warn(...args);\n else console.error(...args);\n };\n\n return {\n trace: write,\n debug: write,\n info: write,\n warn: write,\n error: write,\n };\n}\n"]}
@@ -0,0 +1,96 @@
1
+ 'use strict';
2
+
3
+ // src/evm/wallet.ts
4
+ function padAddress(addr) {
5
+ return addr.replace(/^0x/i, "").toLowerCase().padStart(64, "0");
6
+ }
7
+ function encodeUint256(value) {
8
+ return value.toString(16).padStart(64, "0");
9
+ }
10
+ var ALLOWANCE_SELECTOR = "0xdd62ed3e";
11
+ var BALANCE_SELECTOR = "0x70a08231";
12
+ var APPROVE_SELECTOR = "0x095ea7b3";
13
+ var TRANSFER_SELECTOR = "0xa9059cbb";
14
+ var MAX_UINT256 = BigInt(
15
+ "0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"
16
+ );
17
+ function encodeAllowanceCall(tokenAddress, owner, spender) {
18
+ return {
19
+ to: tokenAddress,
20
+ data: `${ALLOWANCE_SELECTOR}${padAddress(owner)}${padAddress(spender)}`
21
+ };
22
+ }
23
+ function encodeBalanceOfCall(tokenAddress, account) {
24
+ return {
25
+ to: tokenAddress,
26
+ data: `${BALANCE_SELECTOR}${padAddress(account)}`
27
+ };
28
+ }
29
+ function encodeMaxApproveData(tokenAddress, spender) {
30
+ return {
31
+ to: tokenAddress,
32
+ data: `${APPROVE_SELECTOR}${padAddress(spender)}${encodeUint256(MAX_UINT256)}`
33
+ };
34
+ }
35
+ function encodeTransferCall(tokenAddress, to, amount) {
36
+ return {
37
+ to: tokenAddress,
38
+ data: `${TRANSFER_SELECTOR}${padAddress(to)}${encodeUint256(amount)}`
39
+ };
40
+ }
41
+ function decodeUint256(hex) {
42
+ const clean = hex.replace(/^0x/i, "");
43
+ if (clean.length === 0) return 0n;
44
+ return BigInt(`0x${clean}`);
45
+ }
46
+ async function simulateTransaction(signer, tx, label) {
47
+ try {
48
+ await signer.call({ to: tx.to, data: tx.data, from: signer.address });
49
+ } catch (err) {
50
+ const msg = err instanceof Error ? err.message : String(err);
51
+ const match = msg.match(/reverted with.*?:\s*(.+)/i) ?? msg.match(/reason:\s*(.+)/i);
52
+ const reason = match?.[1]?.trim() ?? msg;
53
+ throw new Error(`${label} would revert: ${reason}`);
54
+ }
55
+ }
56
+ async function getRevertReason(signer, txHash, blockNumber) {
57
+ try {
58
+ const tx = await signer.getTransaction(txHash);
59
+ if (!tx.to) return "Transaction reverted";
60
+ await signer.call({
61
+ to: tx.to,
62
+ data: tx.input,
63
+ from: tx.from,
64
+ blockNumber
65
+ });
66
+ return "Transaction reverted";
67
+ } catch (err) {
68
+ const msg = err instanceof Error ? err.message : String(err);
69
+ const match = msg.match(/reverted with.*?:\s*(.+)/i) ?? msg.match(/reason:\s*(.+)/i);
70
+ return match?.[1]?.trim() ?? msg;
71
+ }
72
+ }
73
+ function isUserRejection(error) {
74
+ const msg = error instanceof Error ? error.message : String(error);
75
+ return /user rejected|user denied|rejected the request/i.test(msg);
76
+ }
77
+ function parseSignature(signature) {
78
+ const hex = signature.replace(/^0x/, "");
79
+ return {
80
+ r: `0x${hex.slice(0, 64)}`,
81
+ s: `0x${hex.slice(64, 128)}`,
82
+ v: Number.parseInt(hex.slice(128, 130), 16)
83
+ };
84
+ }
85
+
86
+ exports.decodeUint256 = decodeUint256;
87
+ exports.encodeAllowanceCall = encodeAllowanceCall;
88
+ exports.encodeBalanceOfCall = encodeBalanceOfCall;
89
+ exports.encodeMaxApproveData = encodeMaxApproveData;
90
+ exports.encodeTransferCall = encodeTransferCall;
91
+ exports.getRevertReason = getRevertReason;
92
+ exports.isUserRejection = isUserRejection;
93
+ exports.parseSignature = parseSignature;
94
+ exports.simulateTransaction = simulateTransaction;
95
+ //# sourceMappingURL=chunk-DNSJDKTP.cjs.map
96
+ //# sourceMappingURL=chunk-DNSJDKTP.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/evm/wallet.ts"],"names":[],"mappings":"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","file":"chunk-DNSJDKTP.cjs","sourcesContent":["/**\n * EVM wallet / signer abstraction.\n *\n * Consumers inject an implementation that wraps their wallet library\n * (wagmi, viem, ethers, etc.). The SDK uses this interface to sign\n * typed data and send transactions without depending on any specific\n * EVM library.\n */\n\n// ── EIP-712 typed data ───────────────────────────────────────────────────────\n\n/** Generic EIP-712 typed data that can be passed to a wallet for signing. */\nexport interface EIP712TypedData {\n domain: {\n name?: string;\n version?: string;\n chainId?: number;\n verifyingContract?: string;\n };\n types: Record<string, Array<{ name: string; type: string }>>;\n primaryType: string;\n message: Record<string, unknown>;\n}\n\n// ── Signer interface ─────────────────────────────────────────────────────────\n\n/**\n * Minimal EVM signer that the SDK needs to fund and refund swaps.\n *\n * Example implementation using wagmi/viem:\n * ```ts\n * const signer: EvmSigner = {\n * address: walletClient.account.address,\n * chainId: walletClient.chain.id,\n * signTypedData: (td) => walletClient.signTypedData({ ...td, account: walletClient.account }),\n * sendTransaction: (tx) => walletClient.sendTransaction({ to: tx.to, data: tx.data, chain, gas: tx.gas }),\n * waitForReceipt: (hash) => publicClient.waitForTransactionReceipt({ hash }),\n * getTransaction: (hash) => publicClient.getTransaction({ hash }),\n * call: (tx) => publicClient.call({ to: tx.to, data: tx.data, account: tx.from, blockNumber: tx.blockNumber }),\n * };\n * ```\n */\nexport interface EvmSigner {\n /** The connected wallet address (checksummed or lowercase hex). */\n address: string;\n /** Current chain ID the wallet is connected to. */\n chainId: number;\n\n /**\n * Sign EIP-712 typed data.\n * Must return the 65-byte hex signature (0x-prefixed).\n */\n signTypedData(typedData: EIP712TypedData): Promise<string>;\n\n /**\n * Sign a raw message hash (personal_sign style).\n *\n * **Required for the CCTP-inbound flow** — Kernel signs the UserOp\n * hash via `signMessage({ raw })` on the owner. The direct-Permit2\n * path does not call this, so existing consumers can leave it\n * unimplemented.\n *\n * For wagmi/Privy/viem consumers this is a one-liner:\n * `(m) => walletClient.signMessage({ account, message: m })`.\n *\n * Must return the 65-byte hex signature (0x-prefixed).\n */\n signMessage?(message: { raw: string }): Promise<string>;\n\n /**\n * Sign an EIP-7702 authorization tuple.\n *\n * **Required for the CCTP-inbound flow under 7702** — the user's EOA\n * delegates to a Kernel implementation on its first UserOp; the\n * signed authorization rides along with the UserOp and is installed\n * on-chain by the bundler. Subsequent UserOps from the same EOA\n * skip this once delegation exists.\n *\n * The signature is over `keccak256(0x05 || rlp([chainId, address,\n * nonce]))` with **no** EIP-191 prefix — getting this wrong silently\n * fails at submission. viem / wagmi / Privy walletClients implement\n * it correctly via `walletClient.signAuthorization(...)`.\n *\n * For viem consumers this is a one-liner:\n * `(a) => walletClient.signAuthorization({ account, ...a })`.\n */\n signAuthorization?(authorization: {\n chainId: number;\n contractAddress: string;\n nonce: number;\n }): Promise<{\n r: string;\n s: string;\n v?: number;\n yParity: number;\n chainId: number;\n address: string;\n nonce: number;\n }>;\n\n /**\n * Send a raw transaction and return the transaction hash (0x-prefixed).\n *\n * @param tx.to - Target contract address (0x-prefixed)\n * @param tx.data - ABI-encoded calldata (0x-prefixed)\n * @param tx.gas - Optional gas limit; the SDK provides sensible defaults\n */\n sendTransaction(tx: {\n to: string;\n data: string;\n gas?: bigint;\n }): Promise<string>;\n\n /**\n * Wait for a transaction to be mined and return the receipt.\n *\n * The implementation should handle transaction replacements (speed-up /\n * cancel) — e.g. viem's `waitForTransactionReceipt` and ethers'\n * `provider.waitForTransaction` both do this automatically.\n *\n * @param hash - Transaction hash to wait for (0x-prefixed)\n */\n waitForReceipt(hash: string): Promise<TxReceipt>;\n\n /**\n * Get a transaction by hash. Used internally to replay reverted\n * transactions and extract on-chain revert reasons.\n *\n * @param hash - Transaction hash (0x-prefixed)\n */\n getTransaction(hash: string): Promise<{\n /** Target address, or null for contract creation */\n to: string | null;\n /** ABI-encoded calldata (0x-prefixed) */\n input: string;\n /** Sender address */\n from: string;\n }>;\n\n /**\n * Simulate a call via `eth_call`. Used internally to dry-run\n * transactions before sending and to extract revert reasons.\n *\n * @param tx.to - Target contract address (0x-prefixed)\n * @param tx.data - ABI-encoded calldata (0x-prefixed)\n * @param tx.from - Optional sender address for simulation context\n * @param tx.blockNumber - Optional block number to simulate against\n */\n call(tx: {\n to: string;\n data: string;\n from?: string;\n blockNumber?: bigint;\n }): Promise<string>;\n}\n\n// ── Transaction receipt ──────────────────────────────────────────────────────\n\nexport interface TxReceipt {\n status: \"success\" | \"reverted\";\n blockNumber: bigint;\n transactionHash: string;\n}\n\n// ── Helpers ──────────────────────────────────────────────────────────────────\n\n/**\n * Normalise a 20-byte address to a 32-byte ABI-encoded word (no 0x prefix).\n */\nfunction padAddress(addr: string): string {\n return addr.replace(/^0x/i, \"\").toLowerCase().padStart(64, \"0\");\n}\n\n/**\n * Encode a uint256 as a 32-byte ABI word (no 0x prefix).\n */\nfunction encodeUint256(value: bigint): string {\n return value.toString(16).padStart(64, \"0\");\n}\n\n// ERC-20 function selectors\nconst ALLOWANCE_SELECTOR = \"0xdd62ed3e\"; // allowance(address,address)\nconst BALANCE_SELECTOR = \"0x70a08231\"; // balanceOf(address)\nconst APPROVE_SELECTOR = \"0x095ea7b3\"; // approve(address,uint256)\nconst TRANSFER_SELECTOR = \"0xa9059cbb\"; // transfer(address,uint256)\n\nconst MAX_UINT256 = BigInt(\n \"0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff\",\n);\n\n/**\n * Encode an `allowance(owner, spender)` call.\n */\nexport function encodeAllowanceCall(\n tokenAddress: string,\n owner: string,\n spender: string,\n): { to: string; data: string } {\n return {\n to: tokenAddress,\n data: `${ALLOWANCE_SELECTOR}${padAddress(owner)}${padAddress(spender)}`,\n };\n}\n\n/**\n * Encode a `balanceOf(account)` call.\n */\nexport function encodeBalanceOfCall(\n tokenAddress: string,\n account: string,\n): { to: string; data: string } {\n return {\n to: tokenAddress,\n data: `${BALANCE_SELECTOR}${padAddress(account)}`,\n };\n}\n\n/**\n * Encode an `approve(spender, type(uint256).max)` transaction.\n */\nexport function encodeMaxApproveData(\n tokenAddress: string,\n spender: string,\n): { to: string; data: string } {\n return {\n to: tokenAddress,\n data: `${APPROVE_SELECTOR}${padAddress(spender)}${encodeUint256(MAX_UINT256)}`,\n };\n}\n\n/**\n * Encode a `transfer(to, amount)` transaction.\n */\nexport function encodeTransferCall(\n tokenAddress: string,\n to: string,\n amount: bigint,\n): { to: string; data: string } {\n return {\n to: tokenAddress,\n data: `${TRANSFER_SELECTOR}${padAddress(to)}${encodeUint256(amount)}`,\n };\n}\n\n/**\n * Decode a 32-byte ABI-encoded uint256 from a hex string.\n */\nexport function decodeUint256(hex: string): bigint {\n const clean = hex.replace(/^0x/i, \"\");\n if (clean.length === 0) return 0n;\n return BigInt(`0x${clean}`);\n}\n\n// ── Simulation ───────────────────────────────────────────────────────────────\n\n/**\n * Simulate a transaction via `eth_call`. Throws with the revert reason\n * if the call would fail, so callers don't burn gas on doomed transactions.\n */\nexport async function simulateTransaction(\n signer: EvmSigner,\n tx: { to: string; data: string },\n label: string,\n): Promise<void> {\n try {\n await signer.call({ to: tx.to, data: tx.data, from: signer.address });\n } catch (err: unknown) {\n const msg = err instanceof Error ? err.message : String(err);\n const match =\n msg.match(/reverted with.*?:\\s*(.+)/i) ?? msg.match(/reason:\\s*(.+)/i);\n const reason = match?.[1]?.trim() ?? msg;\n throw new Error(`${label} would revert: ${reason}`);\n }\n}\n\n// ── Revert reason extraction ─────────────────────────────────────────────────\n\n/**\n * Replay a reverted transaction to extract the on-chain revert reason.\n */\nexport async function getRevertReason(\n signer: EvmSigner,\n txHash: string,\n blockNumber: bigint,\n): Promise<string> {\n try {\n const tx = await signer.getTransaction(txHash);\n if (!tx.to) return \"Transaction reverted\";\n await signer.call({\n to: tx.to,\n data: tx.input,\n from: tx.from,\n blockNumber,\n });\n return \"Transaction reverted\";\n } catch (err: unknown) {\n const msg = err instanceof Error ? err.message : String(err);\n const match =\n msg.match(/reverted with.*?:\\s*(.+)/i) ?? msg.match(/reason:\\s*(.+)/i);\n return match?.[1]?.trim() ?? msg;\n }\n}\n\n// ── Error classification ─────────────────────────────────────────────────────\n\n/**\n * Returns true if the error message indicates the user rejected the\n * transaction in their wallet (MetaMask, etc.).\n */\nexport function isUserRejection(error: unknown): boolean {\n const msg = error instanceof Error ? error.message : String(error);\n return /user rejected|user denied|rejected the request/i.test(msg);\n}\n\n// ── Signature parsing ────────────────────────────────────────────────────────\n\n/**\n * Parse a 65-byte hex signature into its `v`, `r`, `s` components.\n */\nexport function parseSignature(signature: string): {\n v: number;\n r: string;\n s: string;\n} {\n const hex = signature.replace(/^0x/, \"\");\n return {\n r: `0x${hex.slice(0, 64)}`,\n s: `0x${hex.slice(64, 128)}`,\n v: Number.parseInt(hex.slice(128, 130), 16),\n };\n}\n"]}