@atomiqlabs/sdk 8.7.7 → 8.8.4

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 (339) hide show
  1. package/LICENSE +201 -201
  2. package/README.md +1760 -1760
  3. package/dist/SmartChainAssets.d.ts +181 -181
  4. package/dist/SmartChainAssets.js +181 -181
  5. package/dist/bitcoin/coinselect2/accumulative.d.ts +7 -6
  6. package/dist/bitcoin/coinselect2/accumulative.js +52 -52
  7. package/dist/bitcoin/coinselect2/blackjack.d.ts +7 -6
  8. package/dist/bitcoin/coinselect2/blackjack.js +38 -38
  9. package/dist/bitcoin/coinselect2/index.d.ts +20 -19
  10. package/dist/bitcoin/coinselect2/index.js +69 -69
  11. package/dist/bitcoin/coinselect2/utils.d.ts +82 -77
  12. package/dist/bitcoin/coinselect2/utils.js +158 -123
  13. package/dist/bitcoin/wallet/BitcoinWallet.d.ts +113 -130
  14. package/dist/bitcoin/wallet/BitcoinWallet.js +335 -322
  15. package/dist/bitcoin/wallet/IBitcoinWallet.d.ts +116 -78
  16. package/dist/bitcoin/wallet/IBitcoinWallet.js +21 -21
  17. package/dist/bitcoin/wallet/SingleAddressBitcoinWallet.d.ts +106 -101
  18. package/dist/bitcoin/wallet/SingleAddressBitcoinWallet.js +196 -190
  19. package/dist/enums/FeeType.d.ts +15 -15
  20. package/dist/enums/FeeType.js +19 -19
  21. package/dist/enums/SwapAmountType.d.ts +15 -15
  22. package/dist/enums/SwapAmountType.js +19 -19
  23. package/dist/enums/SwapDirection.d.ts +15 -15
  24. package/dist/enums/SwapDirection.js +19 -19
  25. package/dist/enums/SwapSide.d.ts +15 -15
  26. package/dist/enums/SwapSide.js +19 -19
  27. package/dist/enums/SwapType.d.ts +75 -75
  28. package/dist/enums/SwapType.js +79 -79
  29. package/dist/errors/IntermediaryError.d.ts +13 -13
  30. package/dist/errors/IntermediaryError.js +27 -27
  31. package/dist/errors/RequestError.d.ts +32 -32
  32. package/dist/errors/RequestError.js +54 -54
  33. package/dist/errors/UserError.d.ts +8 -8
  34. package/dist/errors/UserError.js +16 -16
  35. package/dist/events/UnifiedSwapEventListener.d.ts +23 -23
  36. package/dist/events/UnifiedSwapEventListener.js +132 -132
  37. package/dist/http/HttpUtils.d.ts +27 -27
  38. package/dist/http/HttpUtils.js +91 -91
  39. package/dist/http/paramcoders/IParamReader.d.ts +8 -8
  40. package/dist/http/paramcoders/IParamReader.js +2 -2
  41. package/dist/http/paramcoders/ParamDecoder.d.ts +44 -44
  42. package/dist/http/paramcoders/ParamDecoder.js +137 -137
  43. package/dist/http/paramcoders/ParamEncoder.d.ts +20 -20
  44. package/dist/http/paramcoders/ParamEncoder.js +36 -36
  45. package/dist/http/paramcoders/SchemaVerifier.d.ts +26 -26
  46. package/dist/http/paramcoders/SchemaVerifier.js +145 -145
  47. package/dist/http/paramcoders/client/ResponseParamDecoder.d.ts +11 -11
  48. package/dist/http/paramcoders/client/ResponseParamDecoder.js +57 -57
  49. package/dist/http/paramcoders/client/StreamParamEncoder.d.ts +13 -13
  50. package/dist/http/paramcoders/client/StreamParamEncoder.js +26 -26
  51. package/dist/http/paramcoders/client/StreamingFetchPromise.d.ts +16 -16
  52. package/dist/http/paramcoders/client/StreamingFetchPromise.js +174 -174
  53. package/dist/index.d.ts +85 -85
  54. package/dist/index.js +158 -158
  55. package/dist/intermediaries/Intermediary.d.ts +178 -178
  56. package/dist/intermediaries/Intermediary.js +166 -166
  57. package/dist/intermediaries/IntermediaryDiscovery.d.ts +211 -211
  58. package/dist/intermediaries/IntermediaryDiscovery.js +424 -424
  59. package/dist/intermediaries/apis/IntermediaryAPI.d.ts +450 -440
  60. package/dist/intermediaries/apis/IntermediaryAPI.js +618 -603
  61. package/dist/intermediaries/apis/TrustedIntermediaryAPI.d.ts +155 -155
  62. package/dist/intermediaries/apis/TrustedIntermediaryAPI.js +137 -137
  63. package/dist/lnurl/LNURL.d.ts +102 -102
  64. package/dist/lnurl/LNURL.js +321 -321
  65. package/dist/prices/RedundantSwapPrice.d.ts +110 -110
  66. package/dist/prices/RedundantSwapPrice.js +222 -222
  67. package/dist/prices/SingleSwapPrice.d.ts +34 -34
  68. package/dist/prices/SingleSwapPrice.js +44 -44
  69. package/dist/prices/SwapPriceWithChain.d.ts +107 -107
  70. package/dist/prices/SwapPriceWithChain.js +128 -128
  71. package/dist/prices/abstract/ICachedSwapPrice.d.ts +28 -28
  72. package/dist/prices/abstract/ICachedSwapPrice.js +62 -62
  73. package/dist/prices/abstract/IPriceProvider.d.ts +81 -81
  74. package/dist/prices/abstract/IPriceProvider.js +74 -74
  75. package/dist/prices/abstract/ISwapPrice.d.ts +168 -168
  76. package/dist/prices/abstract/ISwapPrice.js +279 -279
  77. package/dist/prices/providers/BinancePriceProvider.d.ts +23 -23
  78. package/dist/prices/providers/BinancePriceProvider.js +30 -30
  79. package/dist/prices/providers/CoinGeckoPriceProvider.d.ts +23 -23
  80. package/dist/prices/providers/CoinGeckoPriceProvider.js +29 -29
  81. package/dist/prices/providers/CoinPaprikaPriceProvider.d.ts +25 -25
  82. package/dist/prices/providers/CoinPaprikaPriceProvider.js +29 -29
  83. package/dist/prices/providers/CustomPriceProvider.d.ts +24 -24
  84. package/dist/prices/providers/CustomPriceProvider.js +35 -35
  85. package/dist/prices/providers/KrakenPriceProvider.d.ts +38 -38
  86. package/dist/prices/providers/KrakenPriceProvider.js +45 -45
  87. package/dist/prices/providers/OKXPriceProvider.d.ts +34 -34
  88. package/dist/prices/providers/OKXPriceProvider.js +29 -29
  89. package/dist/prices/providers/abstract/ExchangePriceProvider.d.ts +17 -17
  90. package/dist/prices/providers/abstract/ExchangePriceProvider.js +21 -21
  91. package/dist/prices/providers/abstract/HttpPriceProvider.d.ts +7 -7
  92. package/dist/prices/providers/abstract/HttpPriceProvider.js +12 -12
  93. package/dist/storage/IUnifiedStorage.d.ts +85 -85
  94. package/dist/storage/IUnifiedStorage.js +2 -2
  95. package/dist/storage/UnifiedSwapStorage.d.ts +114 -114
  96. package/dist/storage/UnifiedSwapStorage.js +116 -116
  97. package/dist/storage-browser/IndexedDBUnifiedStorage.d.ts +63 -63
  98. package/dist/storage-browser/IndexedDBUnifiedStorage.js +298 -298
  99. package/dist/storage-browser/LocalStorageManager.d.ts +49 -49
  100. package/dist/storage-browser/LocalStorageManager.js +93 -93
  101. package/dist/swapper/Swapper.d.ts +732 -692
  102. package/dist/swapper/Swapper.js +1713 -1657
  103. package/dist/swapper/SwapperFactory.d.ts +135 -135
  104. package/dist/swapper/SwapperFactory.js +162 -162
  105. package/dist/swapper/SwapperUtils.d.ts +206 -206
  106. package/dist/swapper/SwapperUtils.js +481 -481
  107. package/dist/swapper/SwapperWithChain.d.ts +404 -404
  108. package/dist/swapper/SwapperWithChain.js +469 -469
  109. package/dist/swapper/SwapperWithSigner.d.ts +322 -322
  110. package/dist/swapper/SwapperWithSigner.js +318 -318
  111. package/dist/swaps/IAddressSwap.d.ts +22 -22
  112. package/dist/swaps/IAddressSwap.js +14 -14
  113. package/dist/swaps/IBTCWalletSwap.d.ts +73 -73
  114. package/dist/swaps/IBTCWalletSwap.js +18 -18
  115. package/dist/swaps/IClaimableSwap.d.ts +49 -49
  116. package/dist/swaps/IClaimableSwap.js +15 -15
  117. package/dist/swaps/IClaimableSwapWrapper.d.ts +15 -15
  118. package/dist/swaps/IClaimableSwapWrapper.js +2 -2
  119. package/dist/swaps/IRefundableSwap.d.ts +43 -43
  120. package/dist/swaps/IRefundableSwap.js +14 -14
  121. package/dist/swaps/ISwap.d.ts +392 -392
  122. package/dist/swaps/ISwap.js +349 -349
  123. package/dist/swaps/ISwapWithGasDrop.d.ts +21 -21
  124. package/dist/swaps/ISwapWithGasDrop.js +12 -12
  125. package/dist/swaps/ISwapWrapper.d.ts +285 -285
  126. package/dist/swaps/ISwapWrapper.js +353 -353
  127. package/dist/swaps/escrow_swaps/IEscrowSelfInitSwap.d.ts +98 -98
  128. package/dist/swaps/escrow_swaps/IEscrowSelfInitSwap.js +126 -126
  129. package/dist/swaps/escrow_swaps/IEscrowSwap.d.ts +139 -139
  130. package/dist/swaps/escrow_swaps/IEscrowSwap.js +170 -170
  131. package/dist/swaps/escrow_swaps/IEscrowSwapWrapper.d.ts +128 -128
  132. package/dist/swaps/escrow_swaps/IEscrowSwapWrapper.js +167 -167
  133. package/dist/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.d.ts +105 -105
  134. package/dist/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.js +129 -129
  135. package/dist/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.d.ts +162 -162
  136. package/dist/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.js +190 -190
  137. package/dist/swaps/escrow_swaps/frombtc/IFromBTCWrapper.d.ts +64 -64
  138. package/dist/swaps/escrow_swaps/frombtc/IFromBTCWrapper.js +82 -82
  139. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.d.ts +531 -531
  140. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.js +1285 -1285
  141. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.d.ts +190 -190
  142. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.js +432 -432
  143. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.d.ts +583 -583
  144. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.js +1371 -1371
  145. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.d.ts +235 -235
  146. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.js +525 -525
  147. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.d.ts +458 -458
  148. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.js +1126 -1126
  149. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.d.ts +202 -202
  150. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.js +406 -406
  151. package/dist/swaps/escrow_swaps/tobtc/IToBTCSwap.d.ts +403 -403
  152. package/dist/swaps/escrow_swaps/tobtc/IToBTCSwap.js +924 -924
  153. package/dist/swaps/escrow_swaps/tobtc/IToBTCWrapper.d.ts +68 -68
  154. package/dist/swaps/escrow_swaps/tobtc/IToBTCWrapper.js +117 -117
  155. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.d.ts +127 -127
  156. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.js +256 -256
  157. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.d.ts +251 -251
  158. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.js +536 -536
  159. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.d.ts +73 -73
  160. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.js +155 -155
  161. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.d.ts +132 -132
  162. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.js +286 -286
  163. package/dist/swaps/spv_swaps/SpvFromBTCSwap.d.ts +637 -631
  164. package/dist/swaps/spv_swaps/SpvFromBTCSwap.js +1448 -1444
  165. package/dist/swaps/spv_swaps/SpvFromBTCWrapper.d.ts +257 -225
  166. package/dist/swaps/spv_swaps/SpvFromBTCWrapper.js +947 -822
  167. package/dist/swaps/trusted/ln/LnForGasSwap.d.ts +261 -261
  168. package/dist/swaps/trusted/ln/LnForGasSwap.js +511 -511
  169. package/dist/swaps/trusted/ln/LnForGasWrapper.d.ts +40 -40
  170. package/dist/swaps/trusted/ln/LnForGasWrapper.js +83 -83
  171. package/dist/swaps/trusted/onchain/OnchainForGasSwap.d.ts +342 -342
  172. package/dist/swaps/trusted/onchain/OnchainForGasSwap.js +715 -715
  173. package/dist/swaps/trusted/onchain/OnchainForGasWrapper.d.ts +69 -69
  174. package/dist/swaps/trusted/onchain/OnchainForGasWrapper.js +93 -93
  175. package/dist/types/AmountData.d.ts +10 -10
  176. package/dist/types/AmountData.js +2 -2
  177. package/dist/types/CustomPriceFunction.d.ts +11 -11
  178. package/dist/types/CustomPriceFunction.js +2 -2
  179. package/dist/types/PriceInfoType.d.ts +28 -28
  180. package/dist/types/PriceInfoType.js +57 -57
  181. package/dist/types/SwapExecutionAction.d.ts +88 -88
  182. package/dist/types/SwapExecutionAction.js +2 -2
  183. package/dist/types/SwapStateInfo.d.ts +5 -5
  184. package/dist/types/SwapStateInfo.js +2 -2
  185. package/dist/types/SwapWithSigner.d.ts +17 -17
  186. package/dist/types/SwapWithSigner.js +43 -43
  187. package/dist/types/Token.d.ts +99 -99
  188. package/dist/types/Token.js +76 -76
  189. package/dist/types/TokenAmount.d.ts +69 -69
  190. package/dist/types/TokenAmount.js +60 -60
  191. package/dist/types/fees/Fee.d.ts +50 -50
  192. package/dist/types/fees/Fee.js +2 -2
  193. package/dist/types/fees/FeeBreakdown.d.ts +11 -11
  194. package/dist/types/fees/FeeBreakdown.js +2 -2
  195. package/dist/types/fees/PercentagePPM.d.ts +17 -17
  196. package/dist/types/fees/PercentagePPM.js +18 -18
  197. package/dist/types/lnurl/LNURLPay.d.ts +61 -61
  198. package/dist/types/lnurl/LNURLPay.js +31 -31
  199. package/dist/types/lnurl/LNURLWithdraw.d.ts +48 -48
  200. package/dist/types/lnurl/LNURLWithdraw.js +27 -27
  201. package/dist/types/wallets/LightningInvoiceCreateService.d.ts +24 -24
  202. package/dist/types/wallets/LightningInvoiceCreateService.js +15 -15
  203. package/dist/types/wallets/MinimalBitcoinWalletInterface.d.ts +23 -23
  204. package/dist/types/wallets/MinimalBitcoinWalletInterface.js +2 -2
  205. package/dist/types/wallets/MinimalLightningNetworkWalletInterface.d.ts +9 -9
  206. package/dist/types/wallets/MinimalLightningNetworkWalletInterface.js +2 -2
  207. package/dist/utils/AutomaticClockDriftCorrection.d.ts +1 -1
  208. package/dist/utils/AutomaticClockDriftCorrection.js +70 -70
  209. package/dist/utils/BitcoinUtils.d.ts +16 -14
  210. package/dist/utils/BitcoinUtils.js +141 -102
  211. package/dist/utils/BitcoinWalletUtils.d.ts +7 -7
  212. package/dist/utils/BitcoinWalletUtils.js +14 -14
  213. package/dist/utils/Logger.d.ts +7 -7
  214. package/dist/utils/Logger.js +12 -12
  215. package/dist/utils/RetryUtils.d.ts +22 -22
  216. package/dist/utils/RetryUtils.js +67 -67
  217. package/dist/utils/SwapUtils.d.ts +88 -88
  218. package/dist/utils/SwapUtils.js +72 -72
  219. package/dist/utils/TimeoutUtils.d.ts +17 -17
  220. package/dist/utils/TimeoutUtils.js +55 -55
  221. package/dist/utils/TokenUtils.d.ts +19 -19
  222. package/dist/utils/TokenUtils.js +37 -37
  223. package/dist/utils/TypeUtils.d.ts +7 -7
  224. package/dist/utils/TypeUtils.js +2 -2
  225. package/dist/utils/Utils.d.ts +67 -67
  226. package/dist/utils/Utils.js +208 -208
  227. package/package.json +43 -43
  228. package/src/SmartChainAssets.ts +186 -186
  229. package/src/bitcoin/coinselect2/accumulative.ts +69 -68
  230. package/src/bitcoin/coinselect2/blackjack.ts +50 -49
  231. package/src/bitcoin/coinselect2/index.ts +93 -92
  232. package/src/bitcoin/coinselect2/utils.ts +236 -195
  233. package/src/bitcoin/wallet/BitcoinWallet.ts +439 -427
  234. package/src/bitcoin/wallet/IBitcoinWallet.ts +140 -99
  235. package/src/bitcoin/wallet/SingleAddressBitcoinWallet.ts +225 -217
  236. package/src/enums/FeeType.ts +15 -15
  237. package/src/enums/SwapAmountType.ts +16 -16
  238. package/src/enums/SwapDirection.ts +15 -15
  239. package/src/enums/SwapSide.ts +16 -16
  240. package/src/enums/SwapType.ts +75 -75
  241. package/src/errors/IntermediaryError.ts +28 -28
  242. package/src/errors/RequestError.ts +64 -64
  243. package/src/errors/UserError.ts +15 -15
  244. package/src/events/UnifiedSwapEventListener.ts +173 -173
  245. package/src/http/HttpUtils.ts +91 -91
  246. package/src/http/paramcoders/IParamReader.ts +9 -9
  247. package/src/http/paramcoders/ParamDecoder.ts +145 -145
  248. package/src/http/paramcoders/ParamEncoder.ts +40 -40
  249. package/src/http/paramcoders/SchemaVerifier.ts +153 -153
  250. package/src/http/paramcoders/client/ResponseParamDecoder.ts +57 -57
  251. package/src/http/paramcoders/client/StreamParamEncoder.ts +28 -28
  252. package/src/http/paramcoders/client/StreamingFetchPromise.ts +192 -192
  253. package/src/index.ts +140 -140
  254. package/src/intermediaries/Intermediary.ts +280 -280
  255. package/src/intermediaries/IntermediaryDiscovery.ts +541 -541
  256. package/src/intermediaries/apis/IntermediaryAPI.ts +963 -947
  257. package/src/intermediaries/apis/TrustedIntermediaryAPI.ts +257 -257
  258. package/src/lnurl/LNURL.ts +402 -402
  259. package/src/prices/RedundantSwapPrice.ts +264 -264
  260. package/src/prices/SingleSwapPrice.ts +50 -50
  261. package/src/prices/SwapPriceWithChain.ts +194 -194
  262. package/src/prices/abstract/ICachedSwapPrice.ts +85 -85
  263. package/src/prices/abstract/IPriceProvider.ts +127 -127
  264. package/src/prices/abstract/ISwapPrice.ts +390 -390
  265. package/src/prices/providers/BinancePriceProvider.ts +48 -48
  266. package/src/prices/providers/CoinGeckoPriceProvider.ts +46 -46
  267. package/src/prices/providers/CoinPaprikaPriceProvider.ts +49 -49
  268. package/src/prices/providers/CustomPriceProvider.ts +40 -40
  269. package/src/prices/providers/KrakenPriceProvider.ts +83 -83
  270. package/src/prices/providers/OKXPriceProvider.ts +59 -59
  271. package/src/prices/providers/abstract/ExchangePriceProvider.ts +31 -31
  272. package/src/prices/providers/abstract/HttpPriceProvider.ts +14 -14
  273. package/src/storage/IUnifiedStorage.ts +95 -95
  274. package/src/storage/UnifiedSwapStorage.ts +141 -141
  275. package/src/storage-browser/IndexedDBUnifiedStorage.ts +350 -350
  276. package/src/storage-browser/LocalStorageManager.ts +106 -106
  277. package/src/swapper/Swapper.ts +2488 -2416
  278. package/src/swapper/SwapperFactory.ts +307 -307
  279. package/src/swapper/SwapperUtils.ts +570 -570
  280. package/src/swapper/SwapperWithChain.ts +707 -707
  281. package/src/swapper/SwapperWithSigner.ts +511 -511
  282. package/src/swaps/IAddressSwap.ts +30 -30
  283. package/src/swaps/IBTCWalletSwap.ts +92 -92
  284. package/src/swaps/IClaimableSwap.ts +65 -65
  285. package/src/swaps/IClaimableSwapWrapper.ts +17 -17
  286. package/src/swaps/IRefundableSwap.ts +58 -58
  287. package/src/swaps/ISwap.ts +703 -703
  288. package/src/swaps/ISwapWithGasDrop.ts +25 -25
  289. package/src/swaps/ISwapWrapper.ts +539 -539
  290. package/src/swaps/escrow_swaps/IEscrowSelfInitSwap.ts +217 -217
  291. package/src/swaps/escrow_swaps/IEscrowSwap.ts +269 -269
  292. package/src/swaps/escrow_swaps/IEscrowSwapWrapper.ts +282 -282
  293. package/src/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.ts +169 -169
  294. package/src/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.ts +300 -300
  295. package/src/swaps/escrow_swaps/frombtc/IFromBTCWrapper.ts +107 -107
  296. package/src/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.ts +1473 -1474
  297. package/src/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.ts +601 -601
  298. package/src/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.ts +1582 -1582
  299. package/src/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.ts +750 -750
  300. package/src/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.ts +1299 -1299
  301. package/src/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.ts +610 -610
  302. package/src/swaps/escrow_swaps/tobtc/IToBTCSwap.ts +1096 -1096
  303. package/src/swaps/escrow_swaps/tobtc/IToBTCWrapper.ts +138 -138
  304. package/src/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.ts +304 -304
  305. package/src/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.ts +786 -786
  306. package/src/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.ts +206 -206
  307. package/src/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.ts +401 -401
  308. package/src/swaps/spv_swaps/SpvFromBTCSwap.ts +1812 -1799
  309. package/src/swaps/spv_swaps/SpvFromBTCWrapper.ts +1236 -1060
  310. package/src/swaps/trusted/ln/LnForGasSwap.ts +589 -589
  311. package/src/swaps/trusted/ln/LnForGasWrapper.ts +91 -91
  312. package/src/swaps/trusted/onchain/OnchainForGasSwap.ts +862 -862
  313. package/src/swaps/trusted/onchain/OnchainForGasWrapper.ts +131 -131
  314. package/src/types/AmountData.ts +9 -9
  315. package/src/types/CustomPriceFunction.ts +11 -11
  316. package/src/types/PriceInfoType.ts +66 -66
  317. package/src/types/SwapExecutionAction.ts +99 -99
  318. package/src/types/SwapStateInfo.ts +6 -6
  319. package/src/types/SwapWithSigner.ts +61 -61
  320. package/src/types/Token.ts +163 -163
  321. package/src/types/TokenAmount.ts +132 -132
  322. package/src/types/fees/Fee.ts +56 -56
  323. package/src/types/fees/FeeBreakdown.ts +11 -11
  324. package/src/types/fees/PercentagePPM.ts +26 -26
  325. package/src/types/lnurl/LNURLPay.ts +79 -79
  326. package/src/types/lnurl/LNURLWithdraw.ts +61 -61
  327. package/src/types/wallets/LightningInvoiceCreateService.ts +30 -30
  328. package/src/types/wallets/MinimalBitcoinWalletInterface.ts +21 -21
  329. package/src/types/wallets/MinimalLightningNetworkWalletInterface.ts +9 -9
  330. package/src/utils/AutomaticClockDriftCorrection.ts +71 -71
  331. package/src/utils/BitcoinUtils.ts +132 -91
  332. package/src/utils/BitcoinWalletUtils.ts +15 -15
  333. package/src/utils/Logger.ts +14 -14
  334. package/src/utils/RetryUtils.ts +78 -78
  335. package/src/utils/SwapUtils.ts +99 -99
  336. package/src/utils/TimeoutUtils.ts +49 -49
  337. package/src/utils/TokenUtils.ts +33 -33
  338. package/src/utils/TypeUtils.ts +8 -8
  339. package/src/utils/Utils.ts +212 -212
@@ -1,525 +1,525 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.FromBTCLNAutoWrapper = void 0;
4
- const bolt11_1 = require("@atomiqlabs/bolt11");
5
- const base_1 = require("@atomiqlabs/base");
6
- const Intermediary_1 = require("../../../../intermediaries/Intermediary");
7
- const buffer_1 = require("buffer");
8
- const UserError_1 = require("../../../../errors/UserError");
9
- const IntermediaryError_1 = require("../../../../errors/IntermediaryError");
10
- const SwapType_1 = require("../../../../enums/SwapType");
11
- const Utils_1 = require("../../../../utils/Utils");
12
- const IntermediaryAPI_1 = require("../../../../intermediaries/apis/IntermediaryAPI");
13
- const RequestError_1 = require("../../../../errors/RequestError");
14
- const FromBTCLNAutoSwap_1 = require("./FromBTCLNAutoSwap");
15
- const IFromBTCLNWrapper_1 = require("../IFromBTCLNWrapper");
16
- const RetryUtils_1 = require("../../../../utils/RetryUtils");
17
- const sha2_1 = require("@noble/hashes/sha2");
18
- /**
19
- * New escrow based (HTLC) swaps for Bitcoin Lightning -> Smart chain swaps not requiring manual settlement on
20
- * the destination by the user, and instead letting the LP initiate the escrow. Permissionless watchtower network
21
- * handles the claiming of HTLC, with the swap secret broadcasted over Nostr. Also adds a possibility for the user
22
- * to receive a native token on the destination chain as part of the swap (a "gas drop" feature).
23
- *
24
- * @category Swaps/Lightning → Smart chain
25
- */
26
- class FromBTCLNAutoWrapper extends IFromBTCLNWrapper_1.IFromBTCLNWrapper {
27
- /**
28
- * @param chainIdentifier
29
- * @param unifiedStorage Storage interface for the current environment
30
- * @param unifiedChainEvents On-chain event listener
31
- * @param chain
32
- * @param prices Swap pricing handler
33
- * @param tokens
34
- * @param versionedContracts
35
- * @param lnApi
36
- * @param messenger
37
- * @param options
38
- * @param events Instance to use for emitting events
39
- */
40
- constructor(chainIdentifier, unifiedStorage, unifiedChainEvents, chain, prices, tokens, versionedContracts, lnApi, messenger, options, events) {
41
- super(chainIdentifier, unifiedStorage, unifiedChainEvents, chain, prices, tokens, versionedContracts, lnApi, {
42
- ...options,
43
- safetyFactor: options?.safetyFactor ?? 2,
44
- bitcoinBlocktime: options?.bitcoinBlocktime ?? 10 * 60,
45
- unsafeSkipLnNodeCheck: options?.unsafeSkipLnNodeCheck ?? false
46
- }, events);
47
- this.TYPE = SwapType_1.SwapType.FROM_BTCLN_AUTO;
48
- /**
49
- * @internal
50
- */
51
- this.tickSwapState = [
52
- FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.PR_CREATED,
53
- FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.QUOTE_SOFT_EXPIRED,
54
- FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.PR_PAID,
55
- FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.CLAIM_COMMITED
56
- ];
57
- /**
58
- * @internal
59
- */
60
- this._pendingSwapStates = [
61
- FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.PR_CREATED,
62
- FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.QUOTE_SOFT_EXPIRED,
63
- FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.PR_PAID,
64
- FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.CLAIM_COMMITED,
65
- FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.EXPIRED
66
- ];
67
- /**
68
- * @internal
69
- */
70
- this._claimableSwapStates = [FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.CLAIM_COMMITED];
71
- /**
72
- * @internal
73
- */
74
- this._swapDeserializer = FromBTCLNAutoSwap_1.FromBTCLNAutoSwap;
75
- this._messenger = messenger;
76
- }
77
- /**
78
- * @inheritDoc
79
- * @internal
80
- */
81
- async processEventInitialize(swap, event) {
82
- if (swap._state === FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.PR_PAID || swap._state === FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.PR_CREATED || swap._state === FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.QUOTE_SOFT_EXPIRED) {
83
- if (swap._data == null) {
84
- //Obtain data from the initialize event
85
- const eventData = await event.swapData();
86
- if (eventData == null) {
87
- this.logger.error("processEventInitialize(" + swap.getId() + "): Error when fetching swap data for swap, null returned!");
88
- return false;
89
- }
90
- try {
91
- await swap._saveRealSwapData(eventData, false);
92
- this.logger.info("processEventInitialize(" + swap.getId() + "): Successfully taken swap data from on-chain event!");
93
- }
94
- catch (e) {
95
- this.logger.error("processEventInitialize(" + swap.getId() + "): Error when saving swap data for swap: ", e);
96
- return false;
97
- }
98
- }
99
- if (swap._getEscrowHash() !== event.escrowHash) {
100
- this.logger.error("processEventInitialize(" + swap.getId() + "): Error when processing event, escrow hashes don't match!");
101
- return false;
102
- }
103
- swap._commitedAt ??= Date.now();
104
- swap._state = FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.CLAIM_COMMITED;
105
- if (swap.hasSecretPreimage())
106
- swap._broadcastSecret().catch(e => {
107
- this.logger.error("processEventInitialize(" + swap.getId() + "): Error when broadcasting swap secret: ", e);
108
- });
109
- return true;
110
- }
111
- return false;
112
- }
113
- /**
114
- * @inheritDoc
115
- * @internal
116
- */
117
- processEventClaim(swap, event) {
118
- if (swap._state !== FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.FAILED && swap._state !== FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.CLAIM_CLAIMED) {
119
- swap._state = FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.CLAIM_CLAIMED;
120
- swap._setSwapSecret(event.result);
121
- return Promise.resolve(true);
122
- }
123
- return Promise.resolve(false);
124
- }
125
- /**
126
- * @inheritDoc
127
- * @internal
128
- */
129
- processEventRefund(swap, event) {
130
- if (swap._state !== FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.CLAIM_CLAIMED && swap._state !== FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.FAILED) {
131
- swap._state = FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.FAILED;
132
- return Promise.resolve(true);
133
- }
134
- return Promise.resolve(false);
135
- }
136
- /**
137
- * Pre-fetches claimer (watchtower) bounty data for the swap. Doesn't throw, instead returns null and aborts the
138
- * provided abortController
139
- *
140
- * @param signer Smartchain signer address initiating the swap
141
- * @param amountData
142
- * @param options Options as passed to the swap creation function
143
- * @param abortController
144
- *
145
- * @param contractVersions
146
- * @private
147
- */
148
- preFetchClaimerBounty(signer, amountData, options, abortController, contractVersions) {
149
- return (0, Utils_1.mapArrayToObject)(contractVersions, async (contractVersion) => {
150
- if (options.unsafeZeroWatchtowerFee)
151
- return 0n;
152
- const dummyAmount = BigInt(Math.floor(Math.random() * 0x1000000));
153
- const dummySwapData = await this._contract(contractVersion).createSwapData(base_1.ChainSwapType.HTLC, this._chain.randomAddress(), signer, amountData.token, dummyAmount, this._contract(contractVersion).getHashForHtlc((0, Utils_1.randomBytes)(32)).toString("hex"), this.getRandomSequence(), BigInt(Math.floor(Date.now() / 1000)), false, true, BigInt(Math.floor(Math.random() * 0x10000)), BigInt(Math.floor(Math.random() * 0x10000)));
154
- try {
155
- const result = await this._contract(contractVersion).getClaimFee(this._chain.randomAddress(), dummySwapData);
156
- return result * BigInt(Math.floor(options.feeSafetyFactor * 1000000)) / 1000000n;
157
- }
158
- catch (e) {
159
- abortController.abort(e);
160
- }
161
- });
162
- }
163
- /**
164
- * Verifies response returned from intermediary
165
- *
166
- * @param resp Response as returned by the intermediary
167
- * @param amountData
168
- * @param lp Intermediary
169
- * @param options Options as passed to the swap creation function
170
- * @param decodedPr Decoded bolt11 lightning network invoice
171
- * @param paymentHash Expected payment hash of the bolt11 lightning network invoice
172
- * @param claimerBounty Claimer bounty as request by the user
173
- *
174
- * @throws {IntermediaryError} in case the response is invalid
175
- *
176
- * @private
177
- */
178
- verifyReturnedData(resp, amountData, lp, options, decodedPr, paymentHash, claimerBounty) {
179
- if (lp.getAddress(this.chainIdentifier) !== resp.intermediaryKey)
180
- throw new IntermediaryError_1.IntermediaryError("Invalid intermediary address/pubkey");
181
- if (options.descriptionHash != null && decodedPr.tagsObject.purpose_commit_hash !== options.descriptionHash.toString("hex"))
182
- throw new IntermediaryError_1.IntermediaryError("Invalid pr returned - description hash");
183
- if (options.description != null && decodedPr.tagsObject.description !== options.description)
184
- throw new IntermediaryError_1.IntermediaryError("Invalid pr returned - description");
185
- if (decodedPr.tagsObject.payment_hash == null ||
186
- !buffer_1.Buffer.from(decodedPr.tagsObject.payment_hash, "hex").equals(paymentHash))
187
- throw new IntermediaryError_1.IntermediaryError("Invalid pr returned - payment hash");
188
- if (decodedPr.millisatoshis == null)
189
- throw new IntermediaryError_1.IntermediaryError("Invalid pr returned - msat field");
190
- const amountIn = (BigInt(decodedPr.millisatoshis) + 999n) / 1000n;
191
- if (resp.btcAmountGas + resp.btcAmountSwap !== amountIn)
192
- throw new IntermediaryError_1.IntermediaryError("Invalid total btc returned");
193
- if (resp.gasSwapFeeBtc + resp.swapFeeBtc !== resp.totalFeeBtc)
194
- throw new IntermediaryError_1.IntermediaryError("Invalid total btc fee returned");
195
- if (resp.claimerBounty !== claimerBounty)
196
- throw new IntermediaryError_1.IntermediaryError("Invalid claimer bounty");
197
- if (resp.totalGas !== options.gasAmount)
198
- throw new IntermediaryError_1.IntermediaryError("Invalid total gas amount");
199
- if (!amountData.exactIn) {
200
- if (resp.total != amountData.amount)
201
- throw new IntermediaryError_1.IntermediaryError("Invalid amount returned");
202
- }
203
- else {
204
- if (amountIn !== amountData.amount)
205
- throw new IntermediaryError_1.IntermediaryError("Invalid payment request returned, amount mismatch");
206
- }
207
- }
208
- /**
209
- * Returns a newly created Lightning -> Smart chain swap using the HTLC based escrow swap protocol,
210
- * where watchtowers handle the automatic settlement of the swap on the destination chain. Also allows
211
- * specifying additional "gas drop" native token that the receipient receives on the destination chain
212
- * in the `options` argument. The user has to pay a bolt11 invoice on the input lightning network side.
213
- *
214
- * @param recipient Recipient's address on the destination chain
215
- * @param amountData Amount, token and exact input/output data for to swap
216
- * @param lps An array of intermediaries (LPs) to get the quotes from
217
- * @param options Optional additional quote options
218
- * @param additionalParams Optional additional parameters sent to the LP when creating the swap
219
- * @param abortSignal Abort signal
220
- * @param preFetches Optional pre-fetches for speeding up the quoting process (mainly used internally)
221
- */
222
- create(recipient, amountData, lps, options, additionalParams, abortSignal, preFetches) {
223
- if (!this.isInitialized)
224
- throw new Error("Not initialized, call init() first!");
225
- const _options = {
226
- paymentHash: (0, Utils_1.parseHashValueExact32Bytes)(options?.paymentHash, "payment hash"),
227
- unsafeSkipLnNodeCheck: options?.unsafeSkipLnNodeCheck ?? this._options.unsafeSkipLnNodeCheck,
228
- gasAmount: this.parseGasAmount(options?.gasAmount),
229
- feeSafetyFactor: options?.feeSafetyFactor ?? 1.25,
230
- unsafeZeroWatchtowerFee: options?.unsafeZeroWatchtowerFee ?? false,
231
- description: options?.description,
232
- descriptionHash: (0, Utils_1.parseHashValueExact32Bytes)(options?.descriptionHash, "description hash")
233
- };
234
- if (_options.gasAmount !== 0n &&
235
- (this._chain.shouldGetNativeTokenDrop != null
236
- ? !this._chain.shouldGetNativeTokenDrop(amountData.token)
237
- : amountData.token === this._chain.getNativeCurrencyAddress()))
238
- throw new UserError_1.UserError("Cannot specify `gasAmount` for swaps to a native token!");
239
- if (_options.description != null && buffer_1.Buffer.byteLength(_options.description, "utf8") > 500)
240
- throw new UserError_1.UserError("Invalid description length");
241
- const lpVersions = Intermediary_1.Intermediary.getContractVersionsForLps(this.chainIdentifier, lps);
242
- let secret;
243
- let paymentHash;
244
- if (_options?.paymentHash != null) {
245
- paymentHash = _options.paymentHash;
246
- }
247
- else {
248
- ({ secret, paymentHash } = this.getSecretAndHash());
249
- }
250
- const _hash = (0, Utils_1.mapArrayToObject)(lpVersions, (contractVersion) => {
251
- return this._contract(contractVersion).getHashForHtlc(paymentHash).toString("hex");
252
- });
253
- const nativeTokenAddress = this._chain.getNativeCurrencyAddress();
254
- const _abortController = (0, Utils_1.extendAbortController)(abortSignal);
255
- const _preFetches = preFetches ?? {
256
- pricePrefetchPromise: this.preFetchPrice(amountData, _abortController.signal),
257
- usdPricePrefetchPromise: this.preFetchUsdPrice(_abortController.signal),
258
- claimerBountyPrefetch: this.preFetchClaimerBounty(recipient, amountData, _options, _abortController, lpVersions),
259
- gasTokenPricePrefetchPromise: _options.gasAmount !== 0n || !_options.unsafeZeroWatchtowerFee ?
260
- this.preFetchPrice({ token: nativeTokenAddress }, _abortController.signal) :
261
- undefined
262
- };
263
- return lps.map(lp => {
264
- return {
265
- intermediary: lp,
266
- quote: (async () => {
267
- if (lp.services[SwapType_1.SwapType.FROM_BTCLN_AUTO] == null)
268
- throw new Error("LP service for processing from btcln auto swaps not found!");
269
- const version = lp.getContractVersion(this.chainIdentifier);
270
- const abortController = (0, Utils_1.extendAbortController)(_abortController.signal);
271
- const liquidityPromise = this.preFetchIntermediaryLiquidity(amountData, lp, abortController, version);
272
- const { lnCapacityPromise, resp } = await (0, RetryUtils_1.tryWithRetries)(async (retryCount) => {
273
- const { lnPublicKey, response } = IntermediaryAPI_1.IntermediaryAPI.initFromBTCLNAuto(this.chainIdentifier, lp.url, {
274
- paymentHash,
275
- amount: amountData.amount,
276
- claimer: recipient,
277
- token: amountData.token.toString(),
278
- description: _options.description,
279
- descriptionHash: _options.descriptionHash,
280
- exactOut: !amountData.exactIn,
281
- additionalParams,
282
- gasToken: this._chain.getNativeCurrencyAddress(),
283
- gasAmount: _options.gasAmount,
284
- claimerBounty: (0, Utils_1.throwIfUndefined)(_preFetches.claimerBountyPrefetch[version])
285
- }, this._options.postRequestTimeout, abortController.signal, retryCount > 0 ? false : undefined);
286
- let lnCapacityPromise;
287
- if (!_options.unsafeSkipLnNodeCheck) {
288
- lnCapacityPromise = this.preFetchLnCapacity(lnPublicKey);
289
- }
290
- else
291
- lnPublicKey.catch(() => { });
292
- return {
293
- lnCapacityPromise,
294
- resp: await response
295
- };
296
- }, undefined, RequestError_1.RequestError, abortController.signal);
297
- const decodedPr = (0, bolt11_1.decode)(resp.pr);
298
- if (decodedPr.millisatoshis == null)
299
- throw new IntermediaryError_1.IntermediaryError("Invalid returned swap invoice, no msat amount field");
300
- if (decodedPr.timeExpireDate == null)
301
- throw new IntermediaryError_1.IntermediaryError("Invalid returned swap invoice, no expiry date field");
302
- const amountIn = (BigInt(decodedPr.millisatoshis) + 999n) / 1000n;
303
- const claimerBounty = (await _preFetches.claimerBountyPrefetch[version]);
304
- try {
305
- this.verifyReturnedData(resp, amountData, lp, _options, decodedPr, paymentHash, claimerBounty);
306
- const [pricingInfo, gasPricingInfo] = await Promise.all([
307
- this.verifyReturnedPrice(lp.services[SwapType_1.SwapType.FROM_BTCLN_AUTO], false, resp.btcAmountSwap, resp.total, amountData.token, { swapFeeBtc: resp.swapFeeBtc }, _preFetches.pricePrefetchPromise, _preFetches.usdPricePrefetchPromise, abortController.signal),
308
- _options.gasAmount === 0n ? Promise.resolve(undefined) : this.verifyReturnedPrice({ ...lp.services[SwapType_1.SwapType.FROM_BTCLN_AUTO], swapBaseFee: 0 }, //Base fee should be charged only on the amount, not on gas
309
- false, resp.btcAmountGas, resp.totalGas + resp.claimerBounty, nativeTokenAddress, { swapFeeBtc: resp.gasSwapFeeBtc }, _preFetches.gasTokenPricePrefetchPromise, _preFetches.usdPricePrefetchPromise, abortController.signal),
310
- this.verifyIntermediaryLiquidity(resp.total, (0, Utils_1.throwIfUndefined)(liquidityPromise)),
311
- _options.unsafeSkipLnNodeCheck ? Promise.resolve() : this.verifyLnNodeCapacity(lp, decodedPr, lnCapacityPromise, abortController.signal)
312
- ]);
313
- const swapInit = {
314
- pricingInfo,
315
- url: lp.url,
316
- expiry: decodedPr.timeExpireDate * 1000,
317
- swapFee: resp.swapFee,
318
- gasSwapFee: resp.gasSwapFee,
319
- swapFeeBtc: resp.swapFeeBtc,
320
- gasSwapFeeBtc: resp.gasSwapFeeBtc,
321
- btcAmountGas: resp.btcAmountGas,
322
- btcAmountSwap: resp.btcAmountSwap,
323
- gasPricingInfo,
324
- initialSwapData: await this._contract(version).createSwapData(base_1.ChainSwapType.HTLC, lp.getAddress(this.chainIdentifier), recipient, amountData.token, resp.total, _hash[version], this.getRandomSequence(), BigInt(Math.floor(Date.now() / 1000)), false, true, _options.gasAmount + resp.claimerBounty, resp.claimerBounty, nativeTokenAddress),
325
- pr: resp.pr,
326
- secret: secret?.toString("hex"),
327
- exactIn: amountData.exactIn ?? true,
328
- contractVersion: version
329
- };
330
- const quote = new FromBTCLNAutoSwap_1.FromBTCLNAutoSwap(this, swapInit);
331
- return quote;
332
- }
333
- catch (e) {
334
- abortController.abort(e);
335
- throw e;
336
- }
337
- })()
338
- };
339
- });
340
- }
341
- /**
342
- * Returns a newly created Lightning -> Smart chain swap using the HTLC based escrow swap protocol,
343
- * where watchtowers handle the automatic settlement of the swap on the destination chain. Also allows
344
- * specifying additional "gas drop" native token that the receipient receives on the destination chain
345
- * in the `options` argument. The swap is created with an LNURL-withdraw link which will be used to pay
346
- * the generated bolt11 invoice automatically when {@link FromBTCLNSwap.waitForPayment} is called on the
347
- * swap.
348
- *
349
- * @param recipient Recipient's address on the destination chain
350
- * @param lnurl LNURL-withdraw link to pull the funds from
351
- * @param amountData Amount, token and exact input/output data for to swap
352
- * @param lps An array of intermediaries (LPs) to get the quotes from
353
- * @param options Optional additional quote options
354
- * @param additionalParams Optional additional parameters sent to the LP when creating the swap
355
- * @param abortSignal Abort signal
356
- */
357
- async createViaLNURL(recipient, lnurl, amountData, lps, options, additionalParams, abortSignal) {
358
- if (!this.isInitialized)
359
- throw new Error("Not initialized, call init() first!");
360
- const _options = {
361
- paymentHash: (0, Utils_1.parseHashValueExact32Bytes)(options?.paymentHash, "payment hash"),
362
- unsafeSkipLnNodeCheck: options?.unsafeSkipLnNodeCheck ?? this._options.unsafeSkipLnNodeCheck,
363
- gasAmount: this.parseGasAmount(options?.gasAmount),
364
- feeSafetyFactor: options?.feeSafetyFactor ?? 1.25,
365
- unsafeZeroWatchtowerFee: options?.unsafeZeroWatchtowerFee ?? false,
366
- description: options?.description,
367
- descriptionHash: (0, Utils_1.parseHashValueExact32Bytes)(options?.descriptionHash, "description hash")
368
- };
369
- const lpVersions = Intermediary_1.Intermediary.getContractVersionsForLps(this.chainIdentifier, lps);
370
- const abortController = (0, Utils_1.extendAbortController)(abortSignal);
371
- const preFetches = {
372
- pricePrefetchPromise: this.preFetchPrice(amountData, abortController.signal),
373
- usdPricePrefetchPromise: this.preFetchUsdPrice(abortController.signal),
374
- gasTokenPricePrefetchPromise: _options.gasAmount !== 0n || !_options.unsafeZeroWatchtowerFee ?
375
- this.preFetchPrice({ token: this._chain.getNativeCurrencyAddress() }, abortController.signal) :
376
- undefined,
377
- claimerBountyPrefetch: this.preFetchClaimerBounty(recipient, amountData, _options, abortController, lpVersions)
378
- };
379
- try {
380
- const exactOutAmountPromise = !amountData.exactIn ? preFetches.pricePrefetchPromise.then(price => this._prices.getToBtcSwapAmount(this.chainIdentifier, amountData.amount, amountData.token, abortController.signal, price)).catch(e => {
381
- abortController.abort(e);
382
- return undefined;
383
- }) : undefined;
384
- const withdrawRequest = await this.getLNURLWithdraw(lnurl, abortController.signal);
385
- const min = BigInt(withdrawRequest.minWithdrawable) / 1000n;
386
- const max = BigInt(withdrawRequest.maxWithdrawable) / 1000n;
387
- if (amountData.exactIn) {
388
- if (amountData.amount < min)
389
- throw new UserError_1.UserError("Amount less than LNURL-withdraw minimum");
390
- if (amountData.amount > max)
391
- throw new UserError_1.UserError("Amount more than LNURL-withdraw maximum");
392
- }
393
- else {
394
- const amount = (await exactOutAmountPromise);
395
- abortController.signal.throwIfAborted();
396
- if ((amount * 95n / 100n) < min)
397
- throw new UserError_1.UserError("Amount less than LNURL-withdraw minimum");
398
- if ((amount * 105n / 100n) > max)
399
- throw new UserError_1.UserError("Amount more than LNURL-withdraw maximum");
400
- }
401
- return this.create(recipient, amountData, lps, _options, additionalParams, abortSignal, preFetches).map(data => {
402
- return {
403
- quote: data.quote.then(quote => {
404
- quote._setLNURLData(withdrawRequest.url, withdrawRequest.k1, withdrawRequest.callback);
405
- const amountIn = quote.getInput().rawAmount;
406
- if (amountIn < min)
407
- throw new UserError_1.UserError("Amount less than LNURL-withdraw minimum");
408
- if (amountIn > max)
409
- throw new UserError_1.UserError("Amount more than LNURL-withdraw maximum");
410
- return quote;
411
- }),
412
- intermediary: data.intermediary
413
- };
414
- });
415
- }
416
- catch (e) {
417
- abortController.abort(e);
418
- throw e;
419
- }
420
- }
421
- /**
422
- * @inheritDoc
423
- * @internal
424
- */
425
- async _checkPastSwaps(pastSwaps) {
426
- const changedSwapSet = new Set();
427
- const swapExpiredStatus = {};
428
- const checkStatusSwaps = {};
429
- await Promise.all(pastSwaps.map(async (pastSwap) => {
430
- if (pastSwap._shouldCheckIntermediary()) {
431
- try {
432
- const result = await pastSwap._checkIntermediaryPaymentReceived(false);
433
- if (result != null) {
434
- changedSwapSet.add(pastSwap);
435
- }
436
- }
437
- catch (e) {
438
- this.logger.error(`_checkPastSwaps(): Failed to contact LP regarding swap ${pastSwap.getId()}, error: `, e);
439
- }
440
- }
441
- if (pastSwap._shouldFetchExpiryStatus()) {
442
- //Check expiry
443
- swapExpiredStatus[pastSwap.getId()] = await pastSwap._verifyQuoteDefinitelyExpired();
444
- }
445
- if (pastSwap._shouldFetchOnchainState()) {
446
- //Add to swaps for which status should be checked
447
- if (pastSwap._data != null)
448
- (checkStatusSwaps[pastSwap._contractVersion ?? "v1"] ??= []).push(pastSwap);
449
- }
450
- }));
451
- for (let version in checkStatusSwaps) {
452
- if (this._versionedContracts[version] == null) {
453
- this.logger.warn(`_checkPastSwaps(): No contract was found for ${this.chainIdentifier} version ${version}! Skipping these swaps!`);
454
- continue;
455
- }
456
- const _checkStatusSwap = checkStatusSwaps[version];
457
- const swapStatuses = await this._contract(version).getCommitStatuses(_checkStatusSwap.map(val => ({ signer: val._getInitiator(), swapData: val._data })));
458
- for (let pastSwap of _checkStatusSwap) {
459
- const shouldSave = await pastSwap._sync(false, swapExpiredStatus[pastSwap.getId()], swapStatuses[pastSwap.getEscrowHash()], true);
460
- if (shouldSave) {
461
- changedSwapSet.add(pastSwap);
462
- }
463
- }
464
- }
465
- const changedSwaps = [];
466
- const removeSwaps = [];
467
- changedSwapSet.forEach(val => {
468
- if (val.isQuoteExpired()) {
469
- removeSwaps.push(val);
470
- }
471
- else {
472
- changedSwaps.push(val);
473
- }
474
- });
475
- return {
476
- changedSwaps,
477
- removeSwaps
478
- };
479
- }
480
- /**
481
- * @inheritDoc
482
- */
483
- async recoverFromSwapDataAndState(init, state, contractVersion, lp) {
484
- const data = init.data;
485
- let paymentHash = data.getHTLCHashHint();
486
- let secret;
487
- if (state.type === base_1.SwapCommitStateType.PAID) {
488
- secret = await state.getClaimResult();
489
- paymentHash = buffer_1.Buffer.from((0, sha2_1.sha256)(buffer_1.Buffer.from(secret, "hex"))).toString("hex");
490
- }
491
- const swapInit = {
492
- pricingInfo: {
493
- isValid: true,
494
- satsBaseFee: 0n,
495
- swapPriceUSatPerToken: 100000000000000n,
496
- realPriceUSatPerToken: 100000000000000n,
497
- differencePPM: 0n,
498
- feePPM: 0n,
499
- },
500
- url: lp?.url,
501
- expiry: 0,
502
- swapFee: 0n,
503
- swapFeeBtc: 0n,
504
- gasSwapFee: 0n,
505
- gasSwapFeeBtc: 0n,
506
- initialSwapData: data,
507
- data,
508
- pr: paymentHash ?? undefined,
509
- secret,
510
- exactIn: false,
511
- contractVersion
512
- };
513
- const swap = new FromBTCLNAutoSwap_1.FromBTCLNAutoSwap(this, swapInit);
514
- swap._commitTxId = await init.getInitTxId();
515
- const blockData = await init.getTxBlock();
516
- swap.createdAt = blockData.blockTime * 1000;
517
- swap._commitedAt = blockData.blockTime * 1000;
518
- swap._setInitiated();
519
- swap._state = FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.CLAIM_COMMITED;
520
- await swap._sync(false, false, state);
521
- await swap._save();
522
- return swap;
523
- }
524
- }
525
- exports.FromBTCLNAutoWrapper = FromBTCLNAutoWrapper;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FromBTCLNAutoWrapper = void 0;
4
+ const bolt11_1 = require("@atomiqlabs/bolt11");
5
+ const base_1 = require("@atomiqlabs/base");
6
+ const Intermediary_1 = require("../../../../intermediaries/Intermediary");
7
+ const buffer_1 = require("buffer");
8
+ const UserError_1 = require("../../../../errors/UserError");
9
+ const IntermediaryError_1 = require("../../../../errors/IntermediaryError");
10
+ const SwapType_1 = require("../../../../enums/SwapType");
11
+ const Utils_1 = require("../../../../utils/Utils");
12
+ const IntermediaryAPI_1 = require("../../../../intermediaries/apis/IntermediaryAPI");
13
+ const RequestError_1 = require("../../../../errors/RequestError");
14
+ const FromBTCLNAutoSwap_1 = require("./FromBTCLNAutoSwap");
15
+ const IFromBTCLNWrapper_1 = require("../IFromBTCLNWrapper");
16
+ const RetryUtils_1 = require("../../../../utils/RetryUtils");
17
+ const sha2_1 = require("@noble/hashes/sha2");
18
+ /**
19
+ * New escrow based (HTLC) swaps for Bitcoin Lightning -> Smart chain swaps not requiring manual settlement on
20
+ * the destination by the user, and instead letting the LP initiate the escrow. Permissionless watchtower network
21
+ * handles the claiming of HTLC, with the swap secret broadcasted over Nostr. Also adds a possibility for the user
22
+ * to receive a native token on the destination chain as part of the swap (a "gas drop" feature).
23
+ *
24
+ * @category Swaps/Lightning → Smart chain
25
+ */
26
+ class FromBTCLNAutoWrapper extends IFromBTCLNWrapper_1.IFromBTCLNWrapper {
27
+ /**
28
+ * @param chainIdentifier
29
+ * @param unifiedStorage Storage interface for the current environment
30
+ * @param unifiedChainEvents On-chain event listener
31
+ * @param chain
32
+ * @param prices Swap pricing handler
33
+ * @param tokens
34
+ * @param versionedContracts
35
+ * @param lnApi
36
+ * @param messenger
37
+ * @param options
38
+ * @param events Instance to use for emitting events
39
+ */
40
+ constructor(chainIdentifier, unifiedStorage, unifiedChainEvents, chain, prices, tokens, versionedContracts, lnApi, messenger, options, events) {
41
+ super(chainIdentifier, unifiedStorage, unifiedChainEvents, chain, prices, tokens, versionedContracts, lnApi, {
42
+ ...options,
43
+ safetyFactor: options?.safetyFactor ?? 2,
44
+ bitcoinBlocktime: options?.bitcoinBlocktime ?? 10 * 60,
45
+ unsafeSkipLnNodeCheck: options?.unsafeSkipLnNodeCheck ?? false
46
+ }, events);
47
+ this.TYPE = SwapType_1.SwapType.FROM_BTCLN_AUTO;
48
+ /**
49
+ * @internal
50
+ */
51
+ this.tickSwapState = [
52
+ FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.PR_CREATED,
53
+ FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.QUOTE_SOFT_EXPIRED,
54
+ FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.PR_PAID,
55
+ FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.CLAIM_COMMITED
56
+ ];
57
+ /**
58
+ * @internal
59
+ */
60
+ this._pendingSwapStates = [
61
+ FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.PR_CREATED,
62
+ FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.QUOTE_SOFT_EXPIRED,
63
+ FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.PR_PAID,
64
+ FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.CLAIM_COMMITED,
65
+ FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.EXPIRED
66
+ ];
67
+ /**
68
+ * @internal
69
+ */
70
+ this._claimableSwapStates = [FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.CLAIM_COMMITED];
71
+ /**
72
+ * @internal
73
+ */
74
+ this._swapDeserializer = FromBTCLNAutoSwap_1.FromBTCLNAutoSwap;
75
+ this._messenger = messenger;
76
+ }
77
+ /**
78
+ * @inheritDoc
79
+ * @internal
80
+ */
81
+ async processEventInitialize(swap, event) {
82
+ if (swap._state === FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.PR_PAID || swap._state === FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.PR_CREATED || swap._state === FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.QUOTE_SOFT_EXPIRED) {
83
+ if (swap._data == null) {
84
+ //Obtain data from the initialize event
85
+ const eventData = await event.swapData();
86
+ if (eventData == null) {
87
+ this.logger.error("processEventInitialize(" + swap.getId() + "): Error when fetching swap data for swap, null returned!");
88
+ return false;
89
+ }
90
+ try {
91
+ await swap._saveRealSwapData(eventData, false);
92
+ this.logger.info("processEventInitialize(" + swap.getId() + "): Successfully taken swap data from on-chain event!");
93
+ }
94
+ catch (e) {
95
+ this.logger.error("processEventInitialize(" + swap.getId() + "): Error when saving swap data for swap: ", e);
96
+ return false;
97
+ }
98
+ }
99
+ if (swap._getEscrowHash() !== event.escrowHash) {
100
+ this.logger.error("processEventInitialize(" + swap.getId() + "): Error when processing event, escrow hashes don't match!");
101
+ return false;
102
+ }
103
+ swap._commitedAt ??= Date.now();
104
+ swap._state = FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.CLAIM_COMMITED;
105
+ if (swap.hasSecretPreimage())
106
+ swap._broadcastSecret().catch(e => {
107
+ this.logger.error("processEventInitialize(" + swap.getId() + "): Error when broadcasting swap secret: ", e);
108
+ });
109
+ return true;
110
+ }
111
+ return false;
112
+ }
113
+ /**
114
+ * @inheritDoc
115
+ * @internal
116
+ */
117
+ processEventClaim(swap, event) {
118
+ if (swap._state !== FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.FAILED && swap._state !== FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.CLAIM_CLAIMED) {
119
+ swap._state = FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.CLAIM_CLAIMED;
120
+ swap._setSwapSecret(event.result);
121
+ return Promise.resolve(true);
122
+ }
123
+ return Promise.resolve(false);
124
+ }
125
+ /**
126
+ * @inheritDoc
127
+ * @internal
128
+ */
129
+ processEventRefund(swap, event) {
130
+ if (swap._state !== FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.CLAIM_CLAIMED && swap._state !== FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.FAILED) {
131
+ swap._state = FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.FAILED;
132
+ return Promise.resolve(true);
133
+ }
134
+ return Promise.resolve(false);
135
+ }
136
+ /**
137
+ * Pre-fetches claimer (watchtower) bounty data for the swap. Doesn't throw, instead returns null and aborts the
138
+ * provided abortController
139
+ *
140
+ * @param signer Smartchain signer address initiating the swap
141
+ * @param amountData
142
+ * @param options Options as passed to the swap creation function
143
+ * @param abortController
144
+ *
145
+ * @param contractVersions
146
+ * @private
147
+ */
148
+ preFetchClaimerBounty(signer, amountData, options, abortController, contractVersions) {
149
+ return (0, Utils_1.mapArrayToObject)(contractVersions, async (contractVersion) => {
150
+ if (options.unsafeZeroWatchtowerFee)
151
+ return 0n;
152
+ const dummyAmount = BigInt(Math.floor(Math.random() * 0x1000000));
153
+ const dummySwapData = await this._contract(contractVersion).createSwapData(base_1.ChainSwapType.HTLC, this._chain.randomAddress(), signer, amountData.token, dummyAmount, this._contract(contractVersion).getHashForHtlc((0, Utils_1.randomBytes)(32)).toString("hex"), this.getRandomSequence(), BigInt(Math.floor(Date.now() / 1000)), false, true, BigInt(Math.floor(Math.random() * 0x10000)), BigInt(Math.floor(Math.random() * 0x10000)));
154
+ try {
155
+ const result = await this._contract(contractVersion).getClaimFee(this._chain.randomAddress(), dummySwapData);
156
+ return result * BigInt(Math.floor(options.feeSafetyFactor * 1000000)) / 1000000n;
157
+ }
158
+ catch (e) {
159
+ abortController.abort(e);
160
+ }
161
+ });
162
+ }
163
+ /**
164
+ * Verifies response returned from intermediary
165
+ *
166
+ * @param resp Response as returned by the intermediary
167
+ * @param amountData
168
+ * @param lp Intermediary
169
+ * @param options Options as passed to the swap creation function
170
+ * @param decodedPr Decoded bolt11 lightning network invoice
171
+ * @param paymentHash Expected payment hash of the bolt11 lightning network invoice
172
+ * @param claimerBounty Claimer bounty as request by the user
173
+ *
174
+ * @throws {IntermediaryError} in case the response is invalid
175
+ *
176
+ * @private
177
+ */
178
+ verifyReturnedData(resp, amountData, lp, options, decodedPr, paymentHash, claimerBounty) {
179
+ if (lp.getAddress(this.chainIdentifier) !== resp.intermediaryKey)
180
+ throw new IntermediaryError_1.IntermediaryError("Invalid intermediary address/pubkey");
181
+ if (options.descriptionHash != null && decodedPr.tagsObject.purpose_commit_hash !== options.descriptionHash.toString("hex"))
182
+ throw new IntermediaryError_1.IntermediaryError("Invalid pr returned - description hash");
183
+ if (options.description != null && decodedPr.tagsObject.description !== options.description)
184
+ throw new IntermediaryError_1.IntermediaryError("Invalid pr returned - description");
185
+ if (decodedPr.tagsObject.payment_hash == null ||
186
+ !buffer_1.Buffer.from(decodedPr.tagsObject.payment_hash, "hex").equals(paymentHash))
187
+ throw new IntermediaryError_1.IntermediaryError("Invalid pr returned - payment hash");
188
+ if (decodedPr.millisatoshis == null)
189
+ throw new IntermediaryError_1.IntermediaryError("Invalid pr returned - msat field");
190
+ const amountIn = (BigInt(decodedPr.millisatoshis) + 999n) / 1000n;
191
+ if (resp.btcAmountGas + resp.btcAmountSwap !== amountIn)
192
+ throw new IntermediaryError_1.IntermediaryError("Invalid total btc returned");
193
+ if (resp.gasSwapFeeBtc + resp.swapFeeBtc !== resp.totalFeeBtc)
194
+ throw new IntermediaryError_1.IntermediaryError("Invalid total btc fee returned");
195
+ if (resp.claimerBounty !== claimerBounty)
196
+ throw new IntermediaryError_1.IntermediaryError("Invalid claimer bounty");
197
+ if (resp.totalGas !== options.gasAmount)
198
+ throw new IntermediaryError_1.IntermediaryError("Invalid total gas amount");
199
+ if (!amountData.exactIn) {
200
+ if (resp.total != amountData.amount)
201
+ throw new IntermediaryError_1.IntermediaryError("Invalid amount returned");
202
+ }
203
+ else {
204
+ if (amountIn !== amountData.amount)
205
+ throw new IntermediaryError_1.IntermediaryError("Invalid payment request returned, amount mismatch");
206
+ }
207
+ }
208
+ /**
209
+ * Returns a newly created Lightning -> Smart chain swap using the HTLC based escrow swap protocol,
210
+ * where watchtowers handle the automatic settlement of the swap on the destination chain. Also allows
211
+ * specifying additional "gas drop" native token that the receipient receives on the destination chain
212
+ * in the `options` argument. The user has to pay a bolt11 invoice on the input lightning network side.
213
+ *
214
+ * @param recipient Recipient's address on the destination chain
215
+ * @param amountData Amount, token and exact input/output data for to swap
216
+ * @param lps An array of intermediaries (LPs) to get the quotes from
217
+ * @param options Optional additional quote options
218
+ * @param additionalParams Optional additional parameters sent to the LP when creating the swap
219
+ * @param abortSignal Abort signal
220
+ * @param preFetches Optional pre-fetches for speeding up the quoting process (mainly used internally)
221
+ */
222
+ create(recipient, amountData, lps, options, additionalParams, abortSignal, preFetches) {
223
+ if (!this.isInitialized)
224
+ throw new Error("Not initialized, call init() first!");
225
+ const _options = {
226
+ paymentHash: (0, Utils_1.parseHashValueExact32Bytes)(options?.paymentHash, "payment hash"),
227
+ unsafeSkipLnNodeCheck: options?.unsafeSkipLnNodeCheck ?? this._options.unsafeSkipLnNodeCheck,
228
+ gasAmount: this.parseGasAmount(options?.gasAmount),
229
+ feeSafetyFactor: options?.feeSafetyFactor ?? 1.25,
230
+ unsafeZeroWatchtowerFee: options?.unsafeZeroWatchtowerFee ?? false,
231
+ description: options?.description,
232
+ descriptionHash: (0, Utils_1.parseHashValueExact32Bytes)(options?.descriptionHash, "description hash")
233
+ };
234
+ if (_options.gasAmount !== 0n &&
235
+ (this._chain.shouldGetNativeTokenDrop != null
236
+ ? !this._chain.shouldGetNativeTokenDrop(amountData.token)
237
+ : amountData.token === this._chain.getNativeCurrencyAddress()))
238
+ throw new UserError_1.UserError("Cannot specify `gasAmount` for swaps to a native token!");
239
+ if (_options.description != null && buffer_1.Buffer.byteLength(_options.description, "utf8") > 500)
240
+ throw new UserError_1.UserError("Invalid description length");
241
+ const lpVersions = Intermediary_1.Intermediary.getContractVersionsForLps(this.chainIdentifier, lps);
242
+ let secret;
243
+ let paymentHash;
244
+ if (_options?.paymentHash != null) {
245
+ paymentHash = _options.paymentHash;
246
+ }
247
+ else {
248
+ ({ secret, paymentHash } = this.getSecretAndHash());
249
+ }
250
+ const _hash = (0, Utils_1.mapArrayToObject)(lpVersions, (contractVersion) => {
251
+ return this._contract(contractVersion).getHashForHtlc(paymentHash).toString("hex");
252
+ });
253
+ const nativeTokenAddress = this._chain.getNativeCurrencyAddress();
254
+ const _abortController = (0, Utils_1.extendAbortController)(abortSignal);
255
+ const _preFetches = preFetches ?? {
256
+ pricePrefetchPromise: this.preFetchPrice(amountData, _abortController.signal),
257
+ usdPricePrefetchPromise: this.preFetchUsdPrice(_abortController.signal),
258
+ claimerBountyPrefetch: this.preFetchClaimerBounty(recipient, amountData, _options, _abortController, lpVersions),
259
+ gasTokenPricePrefetchPromise: _options.gasAmount !== 0n || !_options.unsafeZeroWatchtowerFee ?
260
+ this.preFetchPrice({ token: nativeTokenAddress }, _abortController.signal) :
261
+ undefined
262
+ };
263
+ return lps.map(lp => {
264
+ return {
265
+ intermediary: lp,
266
+ quote: (async () => {
267
+ if (lp.services[SwapType_1.SwapType.FROM_BTCLN_AUTO] == null)
268
+ throw new Error("LP service for processing from btcln auto swaps not found!");
269
+ const version = lp.getContractVersion(this.chainIdentifier);
270
+ const abortController = (0, Utils_1.extendAbortController)(_abortController.signal);
271
+ const liquidityPromise = this.preFetchIntermediaryLiquidity(amountData, lp, abortController, version);
272
+ const { lnCapacityPromise, resp } = await (0, RetryUtils_1.tryWithRetries)(async (retryCount) => {
273
+ const { lnPublicKey, response } = IntermediaryAPI_1.IntermediaryAPI.initFromBTCLNAuto(this.chainIdentifier, lp.url, {
274
+ paymentHash,
275
+ amount: amountData.amount,
276
+ claimer: recipient,
277
+ token: amountData.token.toString(),
278
+ description: _options.description,
279
+ descriptionHash: _options.descriptionHash,
280
+ exactOut: !amountData.exactIn,
281
+ additionalParams,
282
+ gasToken: this._chain.getNativeCurrencyAddress(),
283
+ gasAmount: _options.gasAmount,
284
+ claimerBounty: (0, Utils_1.throwIfUndefined)(_preFetches.claimerBountyPrefetch[version])
285
+ }, this._options.postRequestTimeout, abortController.signal, retryCount > 0 ? false : undefined);
286
+ let lnCapacityPromise;
287
+ if (!_options.unsafeSkipLnNodeCheck) {
288
+ lnCapacityPromise = this.preFetchLnCapacity(lnPublicKey);
289
+ }
290
+ else
291
+ lnPublicKey.catch(() => { });
292
+ return {
293
+ lnCapacityPromise,
294
+ resp: await response
295
+ };
296
+ }, undefined, RequestError_1.RequestError, abortController.signal);
297
+ const decodedPr = (0, bolt11_1.decode)(resp.pr);
298
+ if (decodedPr.millisatoshis == null)
299
+ throw new IntermediaryError_1.IntermediaryError("Invalid returned swap invoice, no msat amount field");
300
+ if (decodedPr.timeExpireDate == null)
301
+ throw new IntermediaryError_1.IntermediaryError("Invalid returned swap invoice, no expiry date field");
302
+ const amountIn = (BigInt(decodedPr.millisatoshis) + 999n) / 1000n;
303
+ const claimerBounty = (await _preFetches.claimerBountyPrefetch[version]);
304
+ try {
305
+ this.verifyReturnedData(resp, amountData, lp, _options, decodedPr, paymentHash, claimerBounty);
306
+ const [pricingInfo, gasPricingInfo] = await Promise.all([
307
+ this.verifyReturnedPrice(lp.services[SwapType_1.SwapType.FROM_BTCLN_AUTO], false, resp.btcAmountSwap, resp.total, amountData.token, { swapFeeBtc: resp.swapFeeBtc }, _preFetches.pricePrefetchPromise, _preFetches.usdPricePrefetchPromise, abortController.signal),
308
+ _options.gasAmount === 0n ? Promise.resolve(undefined) : this.verifyReturnedPrice({ ...lp.services[SwapType_1.SwapType.FROM_BTCLN_AUTO], swapBaseFee: 0 }, //Base fee should be charged only on the amount, not on gas
309
+ false, resp.btcAmountGas, resp.totalGas + resp.claimerBounty, nativeTokenAddress, { swapFeeBtc: resp.gasSwapFeeBtc }, _preFetches.gasTokenPricePrefetchPromise, _preFetches.usdPricePrefetchPromise, abortController.signal),
310
+ this.verifyIntermediaryLiquidity(resp.total, (0, Utils_1.throwIfUndefined)(liquidityPromise)),
311
+ _options.unsafeSkipLnNodeCheck ? Promise.resolve() : this.verifyLnNodeCapacity(lp, decodedPr, lnCapacityPromise, abortController.signal)
312
+ ]);
313
+ const swapInit = {
314
+ pricingInfo,
315
+ url: lp.url,
316
+ expiry: decodedPr.timeExpireDate * 1000,
317
+ swapFee: resp.swapFee,
318
+ gasSwapFee: resp.gasSwapFee,
319
+ swapFeeBtc: resp.swapFeeBtc,
320
+ gasSwapFeeBtc: resp.gasSwapFeeBtc,
321
+ btcAmountGas: resp.btcAmountGas,
322
+ btcAmountSwap: resp.btcAmountSwap,
323
+ gasPricingInfo,
324
+ initialSwapData: await this._contract(version).createSwapData(base_1.ChainSwapType.HTLC, lp.getAddress(this.chainIdentifier), recipient, amountData.token, resp.total, _hash[version], this.getRandomSequence(), BigInt(Math.floor(Date.now() / 1000)), false, true, _options.gasAmount + resp.claimerBounty, resp.claimerBounty, nativeTokenAddress),
325
+ pr: resp.pr,
326
+ secret: secret?.toString("hex"),
327
+ exactIn: amountData.exactIn ?? true,
328
+ contractVersion: version
329
+ };
330
+ const quote = new FromBTCLNAutoSwap_1.FromBTCLNAutoSwap(this, swapInit);
331
+ return quote;
332
+ }
333
+ catch (e) {
334
+ abortController.abort(e);
335
+ throw e;
336
+ }
337
+ })()
338
+ };
339
+ });
340
+ }
341
+ /**
342
+ * Returns a newly created Lightning -> Smart chain swap using the HTLC based escrow swap protocol,
343
+ * where watchtowers handle the automatic settlement of the swap on the destination chain. Also allows
344
+ * specifying additional "gas drop" native token that the receipient receives on the destination chain
345
+ * in the `options` argument. The swap is created with an LNURL-withdraw link which will be used to pay
346
+ * the generated bolt11 invoice automatically when {@link FromBTCLNSwap.waitForPayment} is called on the
347
+ * swap.
348
+ *
349
+ * @param recipient Recipient's address on the destination chain
350
+ * @param lnurl LNURL-withdraw link to pull the funds from
351
+ * @param amountData Amount, token and exact input/output data for to swap
352
+ * @param lps An array of intermediaries (LPs) to get the quotes from
353
+ * @param options Optional additional quote options
354
+ * @param additionalParams Optional additional parameters sent to the LP when creating the swap
355
+ * @param abortSignal Abort signal
356
+ */
357
+ async createViaLNURL(recipient, lnurl, amountData, lps, options, additionalParams, abortSignal) {
358
+ if (!this.isInitialized)
359
+ throw new Error("Not initialized, call init() first!");
360
+ const _options = {
361
+ paymentHash: (0, Utils_1.parseHashValueExact32Bytes)(options?.paymentHash, "payment hash"),
362
+ unsafeSkipLnNodeCheck: options?.unsafeSkipLnNodeCheck ?? this._options.unsafeSkipLnNodeCheck,
363
+ gasAmount: this.parseGasAmount(options?.gasAmount),
364
+ feeSafetyFactor: options?.feeSafetyFactor ?? 1.25,
365
+ unsafeZeroWatchtowerFee: options?.unsafeZeroWatchtowerFee ?? false,
366
+ description: options?.description,
367
+ descriptionHash: (0, Utils_1.parseHashValueExact32Bytes)(options?.descriptionHash, "description hash")
368
+ };
369
+ const lpVersions = Intermediary_1.Intermediary.getContractVersionsForLps(this.chainIdentifier, lps);
370
+ const abortController = (0, Utils_1.extendAbortController)(abortSignal);
371
+ const preFetches = {
372
+ pricePrefetchPromise: this.preFetchPrice(amountData, abortController.signal),
373
+ usdPricePrefetchPromise: this.preFetchUsdPrice(abortController.signal),
374
+ gasTokenPricePrefetchPromise: _options.gasAmount !== 0n || !_options.unsafeZeroWatchtowerFee ?
375
+ this.preFetchPrice({ token: this._chain.getNativeCurrencyAddress() }, abortController.signal) :
376
+ undefined,
377
+ claimerBountyPrefetch: this.preFetchClaimerBounty(recipient, amountData, _options, abortController, lpVersions)
378
+ };
379
+ try {
380
+ const exactOutAmountPromise = !amountData.exactIn ? preFetches.pricePrefetchPromise.then(price => this._prices.getToBtcSwapAmount(this.chainIdentifier, amountData.amount, amountData.token, abortController.signal, price)).catch(e => {
381
+ abortController.abort(e);
382
+ return undefined;
383
+ }) : undefined;
384
+ const withdrawRequest = await this.getLNURLWithdraw(lnurl, abortController.signal);
385
+ const min = BigInt(withdrawRequest.minWithdrawable) / 1000n;
386
+ const max = BigInt(withdrawRequest.maxWithdrawable) / 1000n;
387
+ if (amountData.exactIn) {
388
+ if (amountData.amount < min)
389
+ throw new UserError_1.UserError("Amount less than LNURL-withdraw minimum");
390
+ if (amountData.amount > max)
391
+ throw new UserError_1.UserError("Amount more than LNURL-withdraw maximum");
392
+ }
393
+ else {
394
+ const amount = (await exactOutAmountPromise);
395
+ abortController.signal.throwIfAborted();
396
+ if ((amount * 95n / 100n) < min)
397
+ throw new UserError_1.UserError("Amount less than LNURL-withdraw minimum");
398
+ if ((amount * 105n / 100n) > max)
399
+ throw new UserError_1.UserError("Amount more than LNURL-withdraw maximum");
400
+ }
401
+ return this.create(recipient, amountData, lps, _options, additionalParams, abortSignal, preFetches).map(data => {
402
+ return {
403
+ quote: data.quote.then(quote => {
404
+ quote._setLNURLData(withdrawRequest.url, withdrawRequest.k1, withdrawRequest.callback);
405
+ const amountIn = quote.getInput().rawAmount;
406
+ if (amountIn < min)
407
+ throw new UserError_1.UserError("Amount less than LNURL-withdraw minimum");
408
+ if (amountIn > max)
409
+ throw new UserError_1.UserError("Amount more than LNURL-withdraw maximum");
410
+ return quote;
411
+ }),
412
+ intermediary: data.intermediary
413
+ };
414
+ });
415
+ }
416
+ catch (e) {
417
+ abortController.abort(e);
418
+ throw e;
419
+ }
420
+ }
421
+ /**
422
+ * @inheritDoc
423
+ * @internal
424
+ */
425
+ async _checkPastSwaps(pastSwaps) {
426
+ const changedSwapSet = new Set();
427
+ const swapExpiredStatus = {};
428
+ const checkStatusSwaps = {};
429
+ await Promise.all(pastSwaps.map(async (pastSwap) => {
430
+ if (pastSwap._shouldCheckIntermediary()) {
431
+ try {
432
+ const result = await pastSwap._checkIntermediaryPaymentReceived(false);
433
+ if (result != null) {
434
+ changedSwapSet.add(pastSwap);
435
+ }
436
+ }
437
+ catch (e) {
438
+ this.logger.error(`_checkPastSwaps(): Failed to contact LP regarding swap ${pastSwap.getId()}, error: `, e);
439
+ }
440
+ }
441
+ if (pastSwap._shouldFetchExpiryStatus()) {
442
+ //Check expiry
443
+ swapExpiredStatus[pastSwap.getId()] = await pastSwap._verifyQuoteDefinitelyExpired();
444
+ }
445
+ if (pastSwap._shouldFetchOnchainState()) {
446
+ //Add to swaps for which status should be checked
447
+ if (pastSwap._data != null)
448
+ (checkStatusSwaps[pastSwap._contractVersion ?? "v1"] ??= []).push(pastSwap);
449
+ }
450
+ }));
451
+ for (let version in checkStatusSwaps) {
452
+ if (this._versionedContracts[version] == null) {
453
+ this.logger.warn(`_checkPastSwaps(): No contract was found for ${this.chainIdentifier} version ${version}! Skipping these swaps!`);
454
+ continue;
455
+ }
456
+ const _checkStatusSwap = checkStatusSwaps[version];
457
+ const swapStatuses = await this._contract(version).getCommitStatuses(_checkStatusSwap.map(val => ({ signer: val._getInitiator(), swapData: val._data })));
458
+ for (let pastSwap of _checkStatusSwap) {
459
+ const shouldSave = await pastSwap._sync(false, swapExpiredStatus[pastSwap.getId()], swapStatuses[pastSwap.getEscrowHash()], true);
460
+ if (shouldSave) {
461
+ changedSwapSet.add(pastSwap);
462
+ }
463
+ }
464
+ }
465
+ const changedSwaps = [];
466
+ const removeSwaps = [];
467
+ changedSwapSet.forEach(val => {
468
+ if (val.isQuoteExpired()) {
469
+ removeSwaps.push(val);
470
+ }
471
+ else {
472
+ changedSwaps.push(val);
473
+ }
474
+ });
475
+ return {
476
+ changedSwaps,
477
+ removeSwaps
478
+ };
479
+ }
480
+ /**
481
+ * @inheritDoc
482
+ */
483
+ async recoverFromSwapDataAndState(init, state, contractVersion, lp) {
484
+ const data = init.data;
485
+ let paymentHash = data.getHTLCHashHint();
486
+ let secret;
487
+ if (state.type === base_1.SwapCommitStateType.PAID) {
488
+ secret = await state.getClaimResult();
489
+ paymentHash = buffer_1.Buffer.from((0, sha2_1.sha256)(buffer_1.Buffer.from(secret, "hex"))).toString("hex");
490
+ }
491
+ const swapInit = {
492
+ pricingInfo: {
493
+ isValid: true,
494
+ satsBaseFee: 0n,
495
+ swapPriceUSatPerToken: 100000000000000n,
496
+ realPriceUSatPerToken: 100000000000000n,
497
+ differencePPM: 0n,
498
+ feePPM: 0n,
499
+ },
500
+ url: lp?.url,
501
+ expiry: 0,
502
+ swapFee: 0n,
503
+ swapFeeBtc: 0n,
504
+ gasSwapFee: 0n,
505
+ gasSwapFeeBtc: 0n,
506
+ initialSwapData: data,
507
+ data,
508
+ pr: paymentHash ?? undefined,
509
+ secret,
510
+ exactIn: false,
511
+ contractVersion
512
+ };
513
+ const swap = new FromBTCLNAutoSwap_1.FromBTCLNAutoSwap(this, swapInit);
514
+ swap._commitTxId = await init.getInitTxId();
515
+ const blockData = await init.getTxBlock();
516
+ swap.createdAt = blockData.blockTime * 1000;
517
+ swap._commitedAt = blockData.blockTime * 1000;
518
+ swap._setInitiated();
519
+ swap._state = FromBTCLNAutoSwap_1.FromBTCLNAutoSwapState.CLAIM_COMMITED;
520
+ await swap._sync(false, false, state);
521
+ await swap._save();
522
+ return swap;
523
+ }
524
+ }
525
+ exports.FromBTCLNAutoWrapper = FromBTCLNAutoWrapper;