@atomiqlabs/sdk 8.9.1 → 8.9.3

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 (366) hide show
  1. package/LICENSE +201 -201
  2. package/README.md +1760 -1760
  3. package/api/index.d.ts +1 -1
  4. package/api/index.js +3 -3
  5. package/dist/ApiList.d.ts +37 -37
  6. package/dist/ApiList.js +30 -30
  7. package/dist/SmartChainAssets.d.ts +181 -181
  8. package/dist/SmartChainAssets.js +181 -181
  9. package/dist/api/ApiEndpoints.d.ts +393 -393
  10. package/dist/api/ApiEndpoints.js +2 -2
  11. package/dist/api/ApiParser.d.ts +10 -10
  12. package/dist/api/ApiParser.js +134 -134
  13. package/dist/api/ApiTypes.d.ts +157 -157
  14. package/dist/api/ApiTypes.js +75 -75
  15. package/dist/api/SerializedAction.d.ts +40 -40
  16. package/dist/api/SerializedAction.js +59 -59
  17. package/dist/api/SwapperApi.d.ts +50 -50
  18. package/dist/api/SwapperApi.js +431 -431
  19. package/dist/api/index.d.ts +5 -5
  20. package/dist/api/index.js +24 -24
  21. package/dist/bitcoin/coinselect2/accumulative.d.ts +7 -7
  22. package/dist/bitcoin/coinselect2/accumulative.js +52 -52
  23. package/dist/bitcoin/coinselect2/blackjack.d.ts +7 -7
  24. package/dist/bitcoin/coinselect2/blackjack.js +38 -38
  25. package/dist/bitcoin/coinselect2/index.d.ts +20 -20
  26. package/dist/bitcoin/coinselect2/index.js +69 -69
  27. package/dist/bitcoin/coinselect2/utils.d.ts +82 -82
  28. package/dist/bitcoin/coinselect2/utils.js +158 -158
  29. package/dist/bitcoin/wallet/BitcoinWallet.d.ts +113 -113
  30. package/dist/bitcoin/wallet/BitcoinWallet.js +335 -335
  31. package/dist/bitcoin/wallet/IBitcoinWallet.d.ts +116 -116
  32. package/dist/bitcoin/wallet/IBitcoinWallet.js +21 -21
  33. package/dist/bitcoin/wallet/SingleAddressBitcoinWallet.d.ts +106 -106
  34. package/dist/bitcoin/wallet/SingleAddressBitcoinWallet.js +196 -196
  35. package/dist/enums/FeeType.d.ts +15 -15
  36. package/dist/enums/FeeType.js +19 -19
  37. package/dist/enums/SwapAmountType.d.ts +15 -15
  38. package/dist/enums/SwapAmountType.js +19 -19
  39. package/dist/enums/SwapDirection.d.ts +15 -15
  40. package/dist/enums/SwapDirection.js +19 -19
  41. package/dist/enums/SwapSide.d.ts +15 -15
  42. package/dist/enums/SwapSide.js +19 -19
  43. package/dist/enums/SwapType.d.ts +75 -75
  44. package/dist/enums/SwapType.js +79 -79
  45. package/dist/errors/IntermediaryError.d.ts +13 -13
  46. package/dist/errors/IntermediaryError.js +27 -27
  47. package/dist/errors/RequestError.d.ts +32 -32
  48. package/dist/errors/RequestError.js +54 -54
  49. package/dist/errors/UserError.d.ts +8 -8
  50. package/dist/errors/UserError.js +16 -16
  51. package/dist/events/UnifiedSwapEventListener.d.ts +24 -24
  52. package/dist/events/UnifiedSwapEventListener.js +138 -138
  53. package/dist/http/HttpUtils.d.ts +29 -29
  54. package/dist/http/HttpUtils.js +97 -97
  55. package/dist/http/paramcoders/IParamReader.d.ts +8 -8
  56. package/dist/http/paramcoders/IParamReader.js +2 -2
  57. package/dist/http/paramcoders/ParamDecoder.d.ts +44 -44
  58. package/dist/http/paramcoders/ParamDecoder.js +137 -137
  59. package/dist/http/paramcoders/ParamEncoder.d.ts +20 -20
  60. package/dist/http/paramcoders/ParamEncoder.js +36 -36
  61. package/dist/http/paramcoders/SchemaVerifier.d.ts +26 -26
  62. package/dist/http/paramcoders/SchemaVerifier.js +145 -145
  63. package/dist/http/paramcoders/client/ResponseParamDecoder.d.ts +11 -11
  64. package/dist/http/paramcoders/client/ResponseParamDecoder.js +57 -57
  65. package/dist/http/paramcoders/client/StreamParamEncoder.d.ts +13 -13
  66. package/dist/http/paramcoders/client/StreamParamEncoder.js +26 -26
  67. package/dist/http/paramcoders/client/StreamingFetchPromise.d.ts +17 -17
  68. package/dist/http/paramcoders/client/StreamingFetchPromise.js +175 -175
  69. package/dist/index.d.ts +86 -86
  70. package/dist/index.js +159 -159
  71. package/dist/intermediaries/Intermediary.d.ts +178 -178
  72. package/dist/intermediaries/Intermediary.js +166 -166
  73. package/dist/intermediaries/IntermediaryDiscovery.d.ts +216 -216
  74. package/dist/intermediaries/IntermediaryDiscovery.js +424 -424
  75. package/dist/intermediaries/apis/IntermediaryAPI.d.ts +607 -607
  76. package/dist/intermediaries/apis/IntermediaryAPI.js +764 -764
  77. package/dist/intermediaries/apis/TrustedIntermediaryAPI.d.ts +155 -155
  78. package/dist/intermediaries/apis/TrustedIntermediaryAPI.js +137 -137
  79. package/dist/intermediaries/auth/SignedKeyBasedAuth.d.ts +14 -14
  80. package/dist/intermediaries/auth/SignedKeyBasedAuth.js +68 -68
  81. package/dist/lnurl/LNURL.d.ts +102 -102
  82. package/dist/lnurl/LNURL.js +321 -321
  83. package/dist/prices/RedundantSwapPrice.d.ts +110 -110
  84. package/dist/prices/RedundantSwapPrice.js +222 -222
  85. package/dist/prices/SingleSwapPrice.d.ts +34 -34
  86. package/dist/prices/SingleSwapPrice.js +44 -44
  87. package/dist/prices/SwapPriceWithChain.d.ts +107 -107
  88. package/dist/prices/SwapPriceWithChain.js +128 -128
  89. package/dist/prices/abstract/ICachedSwapPrice.d.ts +28 -28
  90. package/dist/prices/abstract/ICachedSwapPrice.js +62 -62
  91. package/dist/prices/abstract/IPriceProvider.d.ts +81 -81
  92. package/dist/prices/abstract/IPriceProvider.js +74 -74
  93. package/dist/prices/abstract/ISwapPrice.d.ts +168 -168
  94. package/dist/prices/abstract/ISwapPrice.js +279 -279
  95. package/dist/prices/providers/BinancePriceProvider.d.ts +23 -23
  96. package/dist/prices/providers/BinancePriceProvider.js +30 -30
  97. package/dist/prices/providers/CoinGeckoPriceProvider.d.ts +23 -23
  98. package/dist/prices/providers/CoinGeckoPriceProvider.js +29 -29
  99. package/dist/prices/providers/CoinPaprikaPriceProvider.d.ts +25 -25
  100. package/dist/prices/providers/CoinPaprikaPriceProvider.js +29 -29
  101. package/dist/prices/providers/CustomPriceProvider.d.ts +24 -24
  102. package/dist/prices/providers/CustomPriceProvider.js +35 -35
  103. package/dist/prices/providers/KrakenPriceProvider.d.ts +38 -38
  104. package/dist/prices/providers/KrakenPriceProvider.js +45 -45
  105. package/dist/prices/providers/OKXPriceProvider.d.ts +34 -34
  106. package/dist/prices/providers/OKXPriceProvider.js +29 -29
  107. package/dist/prices/providers/abstract/ExchangePriceProvider.d.ts +17 -17
  108. package/dist/prices/providers/abstract/ExchangePriceProvider.js +21 -21
  109. package/dist/prices/providers/abstract/HttpPriceProvider.d.ts +7 -7
  110. package/dist/prices/providers/abstract/HttpPriceProvider.js +12 -12
  111. package/dist/storage/IUnifiedStorage.d.ts +127 -127
  112. package/dist/storage/IUnifiedStorage.js +2 -2
  113. package/dist/storage/UnifiedSwapStorage.d.ts +120 -120
  114. package/dist/storage/UnifiedSwapStorage.js +154 -154
  115. package/dist/storage-browser/IndexedDBUnifiedStorage.d.ts +63 -63
  116. package/dist/storage-browser/IndexedDBUnifiedStorage.js +298 -298
  117. package/dist/storage-browser/LocalStorageManager.d.ts +49 -49
  118. package/dist/storage-browser/LocalStorageManager.js +93 -93
  119. package/dist/swapper/Swapper.d.ts +770 -770
  120. package/dist/swapper/Swapper.js +1758 -1758
  121. package/dist/swapper/SwapperFactory.d.ts +135 -135
  122. package/dist/swapper/SwapperFactory.js +162 -162
  123. package/dist/swapper/SwapperUtils.d.ts +222 -222
  124. package/dist/swapper/SwapperUtils.js +519 -519
  125. package/dist/swapper/SwapperWithChain.d.ts +404 -404
  126. package/dist/swapper/SwapperWithChain.js +469 -469
  127. package/dist/swapper/SwapperWithSigner.d.ts +322 -322
  128. package/dist/swapper/SwapperWithSigner.js +318 -318
  129. package/dist/swaps/IAddressSwap.d.ts +22 -22
  130. package/dist/swaps/IAddressSwap.js +14 -14
  131. package/dist/swaps/IBTCWalletSwap.d.ts +73 -73
  132. package/dist/swaps/IBTCWalletSwap.js +18 -18
  133. package/dist/swaps/IClaimableSwap.d.ts +49 -49
  134. package/dist/swaps/IClaimableSwap.js +15 -15
  135. package/dist/swaps/IClaimableSwapWrapper.d.ts +15 -15
  136. package/dist/swaps/IClaimableSwapWrapper.js +2 -2
  137. package/dist/swaps/IRefundableSwap.d.ts +43 -43
  138. package/dist/swaps/IRefundableSwap.js +14 -14
  139. package/dist/swaps/ISwap.d.ts +453 -453
  140. package/dist/swaps/ISwap.js +371 -371
  141. package/dist/swaps/ISwapWithGasDrop.d.ts +21 -21
  142. package/dist/swaps/ISwapWithGasDrop.js +12 -12
  143. package/dist/swaps/ISwapWrapper.d.ts +295 -295
  144. package/dist/swaps/ISwapWrapper.js +373 -373
  145. package/dist/swaps/escrow_swaps/IEscrowSelfInitSwap.d.ts +98 -98
  146. package/dist/swaps/escrow_swaps/IEscrowSelfInitSwap.js +126 -126
  147. package/dist/swaps/escrow_swaps/IEscrowSwap.d.ts +139 -139
  148. package/dist/swaps/escrow_swaps/IEscrowSwap.js +172 -172
  149. package/dist/swaps/escrow_swaps/IEscrowSwapWrapper.d.ts +129 -129
  150. package/dist/swaps/escrow_swaps/IEscrowSwapWrapper.js +167 -167
  151. package/dist/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.d.ts +107 -107
  152. package/dist/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.js +130 -130
  153. package/dist/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.d.ts +162 -162
  154. package/dist/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.js +190 -190
  155. package/dist/swaps/escrow_swaps/frombtc/IFromBTCWrapper.d.ts +64 -64
  156. package/dist/swaps/escrow_swaps/frombtc/IFromBTCWrapper.js +82 -82
  157. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.d.ts +547 -547
  158. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.js +1419 -1419
  159. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.d.ts +192 -192
  160. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.js +432 -432
  161. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.d.ts +650 -650
  162. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.js +1577 -1577
  163. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.d.ts +237 -237
  164. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.js +525 -525
  165. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.d.ts +491 -491
  166. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.js +1463 -1463
  167. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.d.ts +204 -204
  168. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.js +406 -406
  169. package/dist/swaps/escrow_swaps/tobtc/IToBTCSwap.d.ts +446 -446
  170. package/dist/swaps/escrow_swaps/tobtc/IToBTCSwap.js +1097 -1097
  171. package/dist/swaps/escrow_swaps/tobtc/IToBTCWrapper.d.ts +68 -68
  172. package/dist/swaps/escrow_swaps/tobtc/IToBTCWrapper.js +117 -117
  173. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.d.ts +127 -127
  174. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.js +256 -256
  175. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.d.ts +252 -252
  176. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.js +535 -535
  177. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.d.ts +73 -73
  178. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.js +155 -155
  179. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.d.ts +134 -134
  180. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.js +286 -286
  181. package/dist/swaps/spv_swaps/SpvFromBTCSwap.d.ts +694 -694
  182. package/dist/swaps/spv_swaps/SpvFromBTCSwap.js +1687 -1687
  183. package/dist/swaps/spv_swaps/SpvFromBTCWrapper.d.ts +259 -259
  184. package/dist/swaps/spv_swaps/SpvFromBTCWrapper.js +947 -947
  185. package/dist/swaps/trusted/ln/LnForGasSwap.d.ts +302 -302
  186. package/dist/swaps/trusted/ln/LnForGasSwap.js +625 -625
  187. package/dist/swaps/trusted/ln/LnForGasWrapper.d.ts +40 -40
  188. package/dist/swaps/trusted/ln/LnForGasWrapper.js +82 -82
  189. package/dist/swaps/trusted/onchain/OnchainForGasSwap.d.ts +343 -343
  190. package/dist/swaps/trusted/onchain/OnchainForGasSwap.js +698 -698
  191. package/dist/swaps/trusted/onchain/OnchainForGasWrapper.d.ts +71 -71
  192. package/dist/swaps/trusted/onchain/OnchainForGasWrapper.js +93 -93
  193. package/dist/types/AmountData.d.ts +10 -10
  194. package/dist/types/AmountData.js +2 -2
  195. package/dist/types/CustomPriceFunction.d.ts +11 -11
  196. package/dist/types/CustomPriceFunction.js +2 -2
  197. package/dist/types/PriceInfoType.d.ts +28 -28
  198. package/dist/types/PriceInfoType.js +57 -57
  199. package/dist/types/SwapExecutionAction.d.ts +195 -195
  200. package/dist/types/SwapExecutionAction.js +106 -106
  201. package/dist/types/SwapExecutionStep.d.ts +144 -144
  202. package/dist/types/SwapExecutionStep.js +87 -87
  203. package/dist/types/SwapStateInfo.d.ts +5 -5
  204. package/dist/types/SwapStateInfo.js +2 -2
  205. package/dist/types/SwapWithSigner.d.ts +17 -17
  206. package/dist/types/SwapWithSigner.js +43 -43
  207. package/dist/types/Token.d.ts +99 -99
  208. package/dist/types/Token.js +76 -76
  209. package/dist/types/TokenAmount.d.ts +75 -75
  210. package/dist/types/TokenAmount.js +85 -85
  211. package/dist/types/fees/Fee.d.ts +50 -50
  212. package/dist/types/fees/Fee.js +2 -2
  213. package/dist/types/fees/FeeBreakdown.d.ts +11 -11
  214. package/dist/types/fees/FeeBreakdown.js +2 -2
  215. package/dist/types/fees/PercentagePPM.d.ts +17 -17
  216. package/dist/types/fees/PercentagePPM.js +18 -18
  217. package/dist/types/lnurl/LNURLPay.d.ts +61 -61
  218. package/dist/types/lnurl/LNURLPay.js +31 -31
  219. package/dist/types/lnurl/LNURLWithdraw.d.ts +48 -48
  220. package/dist/types/lnurl/LNURLWithdraw.js +27 -27
  221. package/dist/types/wallets/LightningInvoiceCreateService.d.ts +24 -24
  222. package/dist/types/wallets/LightningInvoiceCreateService.js +15 -15
  223. package/dist/types/wallets/MinimalBitcoinWalletInterface.d.ts +23 -23
  224. package/dist/types/wallets/MinimalBitcoinWalletInterface.js +2 -2
  225. package/dist/types/wallets/MinimalLightningNetworkWalletInterface.d.ts +9 -9
  226. package/dist/types/wallets/MinimalLightningNetworkWalletInterface.js +2 -2
  227. package/dist/utils/AutomaticClockDriftCorrection.d.ts +1 -1
  228. package/dist/utils/AutomaticClockDriftCorrection.js +70 -70
  229. package/dist/utils/BitcoinUtils.d.ts +18 -18
  230. package/dist/utils/BitcoinUtils.js +174 -174
  231. package/dist/utils/BitcoinWalletUtils.d.ts +7 -7
  232. package/dist/utils/BitcoinWalletUtils.js +14 -14
  233. package/dist/utils/Logger.d.ts +7 -7
  234. package/dist/utils/Logger.js +12 -12
  235. package/dist/utils/RetryUtils.d.ts +22 -22
  236. package/dist/utils/RetryUtils.js +67 -67
  237. package/dist/utils/SwapUtils.d.ts +88 -88
  238. package/dist/utils/SwapUtils.js +72 -72
  239. package/dist/utils/TimeoutUtils.d.ts +17 -17
  240. package/dist/utils/TimeoutUtils.js +55 -55
  241. package/dist/utils/TokenUtils.d.ts +19 -19
  242. package/dist/utils/TokenUtils.js +37 -37
  243. package/dist/utils/TypeUtils.d.ts +7 -7
  244. package/dist/utils/TypeUtils.js +2 -2
  245. package/dist/utils/Utils.d.ts +69 -69
  246. package/dist/utils/Utils.js +214 -214
  247. package/package.json +46 -46
  248. package/src/SmartChainAssets.ts +186 -186
  249. package/src/api/ApiEndpoints.ts +427 -427
  250. package/src/api/ApiParser.ts +138 -138
  251. package/src/api/ApiTypes.ts +229 -229
  252. package/src/api/SerializedAction.ts +97 -97
  253. package/src/api/SwapperApi.ts +545 -545
  254. package/src/api/index.ts +5 -5
  255. package/src/bitcoin/coinselect2/accumulative.ts +69 -69
  256. package/src/bitcoin/coinselect2/blackjack.ts +50 -50
  257. package/src/bitcoin/coinselect2/index.ts +93 -93
  258. package/src/bitcoin/coinselect2/utils.ts +236 -236
  259. package/src/bitcoin/wallet/BitcoinWallet.ts +439 -439
  260. package/src/bitcoin/wallet/IBitcoinWallet.ts +140 -140
  261. package/src/bitcoin/wallet/SingleAddressBitcoinWallet.ts +225 -225
  262. package/src/enums/FeeType.ts +15 -15
  263. package/src/enums/SwapAmountType.ts +16 -16
  264. package/src/enums/SwapDirection.ts +15 -15
  265. package/src/enums/SwapSide.ts +16 -16
  266. package/src/enums/SwapType.ts +75 -75
  267. package/src/errors/IntermediaryError.ts +28 -28
  268. package/src/errors/RequestError.ts +64 -64
  269. package/src/errors/UserError.ts +15 -15
  270. package/src/events/UnifiedSwapEventListener.ts +181 -181
  271. package/src/http/HttpUtils.ts +97 -97
  272. package/src/http/paramcoders/IParamReader.ts +9 -9
  273. package/src/http/paramcoders/ParamDecoder.ts +145 -145
  274. package/src/http/paramcoders/ParamEncoder.ts +40 -40
  275. package/src/http/paramcoders/SchemaVerifier.ts +153 -153
  276. package/src/http/paramcoders/client/ResponseParamDecoder.ts +57 -57
  277. package/src/http/paramcoders/client/StreamParamEncoder.ts +28 -28
  278. package/src/http/paramcoders/client/StreamingFetchPromise.ts +194 -194
  279. package/src/index.ts +141 -141
  280. package/src/intermediaries/Intermediary.ts +280 -280
  281. package/src/intermediaries/IntermediaryDiscovery.ts +548 -548
  282. package/src/intermediaries/apis/IntermediaryAPI.ts +1247 -1247
  283. package/src/intermediaries/auth/SignedKeyBasedAuth.ts +69 -69
  284. package/src/lnurl/LNURL.ts +402 -402
  285. package/src/prices/RedundantSwapPrice.ts +264 -264
  286. package/src/prices/SingleSwapPrice.ts +50 -50
  287. package/src/prices/SwapPriceWithChain.ts +194 -194
  288. package/src/prices/abstract/ICachedSwapPrice.ts +85 -85
  289. package/src/prices/abstract/IPriceProvider.ts +127 -127
  290. package/src/prices/abstract/ISwapPrice.ts +390 -390
  291. package/src/prices/providers/BinancePriceProvider.ts +48 -48
  292. package/src/prices/providers/CoinGeckoPriceProvider.ts +46 -46
  293. package/src/prices/providers/CoinPaprikaPriceProvider.ts +49 -49
  294. package/src/prices/providers/CustomPriceProvider.ts +40 -40
  295. package/src/prices/providers/KrakenPriceProvider.ts +83 -83
  296. package/src/prices/providers/OKXPriceProvider.ts +59 -59
  297. package/src/prices/providers/abstract/ExchangePriceProvider.ts +31 -31
  298. package/src/prices/providers/abstract/HttpPriceProvider.ts +14 -14
  299. package/src/storage/IUnifiedStorage.ts +136 -136
  300. package/src/storage/UnifiedSwapStorage.ts +175 -175
  301. package/src/storage-browser/IndexedDBUnifiedStorage.ts +350 -350
  302. package/src/storage-browser/LocalStorageManager.ts +106 -106
  303. package/src/swapper/Swapper.ts +2570 -2570
  304. package/src/swapper/SwapperFactory.ts +307 -307
  305. package/src/swapper/SwapperUtils.ts +610 -610
  306. package/src/swapper/SwapperWithChain.ts +707 -707
  307. package/src/swapper/SwapperWithSigner.ts +511 -511
  308. package/src/swaps/IAddressSwap.ts +30 -30
  309. package/src/swaps/IBTCWalletSwap.ts +92 -92
  310. package/src/swaps/IClaimableSwap.ts +65 -65
  311. package/src/swaps/IClaimableSwapWrapper.ts +17 -17
  312. package/src/swaps/IRefundableSwap.ts +58 -58
  313. package/src/swaps/ISwap.ts +775 -775
  314. package/src/swaps/ISwapWithGasDrop.ts +25 -25
  315. package/src/swaps/ISwapWrapper.ts +564 -564
  316. package/src/swaps/escrow_swaps/IEscrowSelfInitSwap.ts +217 -217
  317. package/src/swaps/escrow_swaps/IEscrowSwap.ts +271 -271
  318. package/src/swaps/escrow_swaps/IEscrowSwapWrapper.ts +284 -284
  319. package/src/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.ts +172 -172
  320. package/src/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.ts +300 -300
  321. package/src/swaps/escrow_swaps/frombtc/IFromBTCWrapper.ts +107 -107
  322. package/src/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.ts +1670 -1671
  323. package/src/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.ts +603 -603
  324. package/src/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.ts +1883 -1883
  325. package/src/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.ts +752 -752
  326. package/src/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.ts +1753 -1753
  327. package/src/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.ts +612 -612
  328. package/src/swaps/escrow_swaps/tobtc/IToBTCSwap.ts +1327 -1327
  329. package/src/swaps/escrow_swaps/tobtc/IToBTCWrapper.ts +138 -138
  330. package/src/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.ts +304 -304
  331. package/src/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.ts +787 -787
  332. package/src/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.ts +206 -206
  333. package/src/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.ts +403 -403
  334. package/src/swaps/spv_swaps/SpvFromBTCSwap.ts +2148 -2148
  335. package/src/swaps/spv_swaps/SpvFromBTCWrapper.ts +1238 -1238
  336. package/src/swaps/trusted/ln/LnForGasSwap.ts +753 -753
  337. package/src/swaps/trusted/ln/LnForGasWrapper.ts +90 -90
  338. package/src/swaps/trusted/onchain/OnchainForGasSwap.ts +843 -843
  339. package/src/swaps/trusted/onchain/OnchainForGasWrapper.ts +133 -133
  340. package/src/types/AmountData.ts +9 -9
  341. package/src/types/CustomPriceFunction.ts +11 -11
  342. package/src/types/PriceInfoType.ts +66 -66
  343. package/src/types/SwapExecutionAction.ts +323 -323
  344. package/src/types/SwapExecutionStep.ts +224 -224
  345. package/src/types/SwapStateInfo.ts +6 -6
  346. package/src/types/SwapWithSigner.ts +61 -61
  347. package/src/types/Token.ts +163 -163
  348. package/src/types/TokenAmount.ts +167 -167
  349. package/src/types/fees/Fee.ts +56 -56
  350. package/src/types/fees/FeeBreakdown.ts +11 -11
  351. package/src/types/fees/PercentagePPM.ts +26 -26
  352. package/src/types/lnurl/LNURLPay.ts +79 -79
  353. package/src/types/lnurl/LNURLWithdraw.ts +61 -61
  354. package/src/types/wallets/LightningInvoiceCreateService.ts +30 -30
  355. package/src/types/wallets/MinimalBitcoinWalletInterface.ts +21 -21
  356. package/src/types/wallets/MinimalLightningNetworkWalletInterface.ts +9 -9
  357. package/src/utils/AutomaticClockDriftCorrection.ts +71 -71
  358. package/src/utils/BitcoinUtils.ts +164 -164
  359. package/src/utils/BitcoinWalletUtils.ts +15 -15
  360. package/src/utils/Logger.ts +14 -14
  361. package/src/utils/RetryUtils.ts +78 -78
  362. package/src/utils/SwapUtils.ts +99 -99
  363. package/src/utils/TimeoutUtils.ts +49 -49
  364. package/src/utils/TokenUtils.ts +33 -33
  365. package/src/utils/TypeUtils.ts +8 -8
  366. package/src/utils/Utils.ts +221 -221
@@ -1,535 +1,535 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.ToBTCLNWrapper = void 0;
4
- const bolt11_1 = require("@atomiqlabs/bolt11");
5
- const ToBTCLNSwap_1 = require("./ToBTCLNSwap");
6
- const IToBTCWrapper_1 = require("../IToBTCWrapper");
7
- const UserError_1 = require("../../../../errors/UserError");
8
- const base_1 = require("@atomiqlabs/base");
9
- const Intermediary_1 = require("../../../../intermediaries/Intermediary");
10
- const IntermediaryError_1 = require("../../../../errors/IntermediaryError");
11
- const SwapType_1 = require("../../../../enums/SwapType");
12
- const Utils_1 = require("../../../../utils/Utils");
13
- const RequestError_1 = require("../../../../errors/RequestError");
14
- const LNURL_1 = require("../../../../lnurl/LNURL");
15
- const IToBTCSwap_1 = require("../IToBTCSwap");
16
- const sha2_1 = require("@noble/hashes/sha2");
17
- const RetryUtils_1 = require("../../../../utils/RetryUtils");
18
- /**
19
- * Escrow based (HTLC) swap for Smart chains -> Bitcoin lightning
20
- *
21
- * @category Swaps/Smart chain → Lightning
22
- */
23
- class ToBTCLNWrapper extends IToBTCWrapper_1.IToBTCWrapper {
24
- constructor(chainIdentifier, unifiedStorage, unifiedChainEvents, chain, prices, tokens, versionedContracts, lpApi, options, events) {
25
- super(chainIdentifier, unifiedStorage, unifiedChainEvents, chain, prices, tokens, lpApi, {
26
- ...options,
27
- paymentTimeoutSeconds: options?.paymentTimeoutSeconds ?? 5 * 24 * 60 * 60,
28
- lightningBaseFee: options?.lightningBaseFee ?? 10,
29
- lightningFeePPM: options?.lightningFeePPM ?? 2000
30
- }, versionedContracts, events);
31
- this.TYPE = SwapType_1.SwapType.TO_BTCLN;
32
- /**
33
- * @internal
34
- */
35
- this._swapDeserializer = ToBTCLNSwap_1.ToBTCLNSwap;
36
- }
37
- toRequiredSwapOptions(amountData, options, pricePreFetchPromise, abortSignal) {
38
- const expirySeconds = options?.expirySeconds ?? this._options.paymentTimeoutSeconds;
39
- const maxRoutingBaseFee = options?.maxRoutingBaseFee ?? BigInt(this._options.lightningBaseFee);
40
- const maxRoutingPPM = options?.maxRoutingFeePercentage != null
41
- ? BigInt(Math.floor(options.maxRoutingFeePercentage * 10000))
42
- : options?.maxRoutingPPM ?? BigInt(this._options.lightningFeePPM);
43
- let maxFee;
44
- if (options?.maxFee != null) {
45
- maxFee = options.maxFee;
46
- }
47
- else if (amountData.exactIn) {
48
- if (pricePreFetchPromise != null) {
49
- maxFee = pricePreFetchPromise
50
- .then(val => this._prices.getFromBtcSwapAmount(this.chainIdentifier, maxRoutingBaseFee, amountData.token, abortSignal, val))
51
- .then(_maxBaseFee => this.calculateFeeForAmount(amountData.amount, _maxBaseFee, maxRoutingPPM));
52
- }
53
- else {
54
- maxFee = this._prices.getFromBtcSwapAmount(this.chainIdentifier, maxRoutingBaseFee, amountData.token, abortSignal)
55
- .then(_maxBaseFee => this.calculateFeeForAmount(amountData.amount, _maxBaseFee, maxRoutingPPM));
56
- }
57
- }
58
- else {
59
- maxFee = this.calculateFeeForAmount(amountData.amount, maxRoutingBaseFee, maxRoutingPPM);
60
- }
61
- return {
62
- expiryTimestamp: options?.expiryTimestamp ?? BigInt(Math.floor(Date.now() / 1000) + expirySeconds),
63
- maxFee
64
- };
65
- }
66
- /**
67
- * Verifies whether a given payment hash was already paid by checking the local
68
- * storage of known swaps
69
- *
70
- * @param paymentHash Payment hash to check
71
- *
72
- * @private
73
- */
74
- async checkPaymentHashWasPaid(paymentHash) {
75
- const swaps = await this.unifiedStorage.query([[{ key: "type", value: this.TYPE }, { key: "paymentHash", value: paymentHash }]], (obj) => new this._swapDeserializer(this, obj));
76
- for (let value of swaps) {
77
- if (value._state === IToBTCSwap_1.ToBTCSwapState.CLAIMED || value._state === IToBTCSwap_1.ToBTCSwapState.SOFT_CLAIMED)
78
- throw new UserError_1.UserError("Lightning invoice was already paid!");
79
- }
80
- }
81
- /**
82
- * Calculates maximum lightning network routing fee based on amount
83
- *
84
- * @param amount BTC amount of the swap in satoshis
85
- * @param overrideBaseFee Override wrapper's default base fee
86
- * @param overrideFeePPM Override wrapper's default PPM
87
- *
88
- * @returns Maximum lightning routing fee in sats
89
- *
90
- * @private
91
- */
92
- calculateFeeForAmount(amount, overrideBaseFee, overrideFeePPM) {
93
- return BigInt(overrideBaseFee ?? this._options.lightningBaseFee)
94
- + (amount * BigInt(overrideFeePPM ?? this._options.lightningFeePPM) / 1000000n);
95
- }
96
- /**
97
- * Verifies returned LP data
98
- *
99
- * @param signer
100
- * @param resp Response as returned by the LP
101
- * @param parsedPr Parsed bolt11 lightning invoice
102
- * @param token Smart chain token to be used in the swap
103
- * @param lp
104
- * @param calculatedOptions Swap options computed from the swap create options
105
- * @param data Parsed swap data returned by the LP
106
- * @param requiredTotal Required total to be paid on the input (for exactIn swaps)
107
- *
108
- * @throws {IntermediaryError} In case the response is not valid
109
- *
110
- * @private
111
- */
112
- async verifyReturnedData(signer, resp, parsedPr, token, lp, calculatedOptions, data, requiredTotal) {
113
- if (resp.routingFeeSats > await calculatedOptions.maxFee)
114
- throw new IntermediaryError_1.IntermediaryError("Invalid max fee sats returned");
115
- if (requiredTotal != null && resp.total !== requiredTotal)
116
- throw new IntermediaryError_1.IntermediaryError("Invalid data returned - total amount");
117
- if (parsedPr.tagsObject.payment_hash == null)
118
- throw new Error("Swap invoice doesn't contain payment hash field!");
119
- const claimHash = this._contract(lp.getContractVersion(this.chainIdentifier)).getHashForHtlc(Buffer.from(parsedPr.tagsObject.payment_hash, "hex"));
120
- if (data.getAmount() !== resp.total ||
121
- !Buffer.from(data.getClaimHash(), "hex").equals(claimHash) ||
122
- data.getExpiry() !== calculatedOptions.expiryTimestamp ||
123
- data.getType() !== base_1.ChainSwapType.HTLC ||
124
- !data.isPayIn() ||
125
- !data.isToken(token) ||
126
- !data.isClaimer(lp.getAddress(this.chainIdentifier)) ||
127
- !data.isOfferer(signer) ||
128
- data.getTotalDeposit() !== 0n) {
129
- throw new IntermediaryError_1.IntermediaryError("Invalid data returned");
130
- }
131
- }
132
- /**
133
- * Returns the quote/swap from a given intermediary
134
- *
135
- * @param signer Smartchain signer initiating the swap
136
- * @param amountData
137
- * @param lp Intermediary
138
- * @param pr bolt11 lightning network invoice
139
- * @param parsedPr Parsed bolt11 lightning network invoice
140
- * @param calculatedOptions Swap options computed from the swap create options
141
- * @param preFetches
142
- * @param abort Abort signal or controller, if AbortController is passed it is used as-is, when AbortSignal is passed
143
- * it is extended with extendAbortController and then used
144
- * @param additionalParams Additional params that should be sent to the LP
145
- *
146
- * @private
147
- */
148
- async getIntermediaryQuote(signer, amountData, lp, pr, parsedPr, calculatedOptions, preFetches, abort, additionalParams) {
149
- if (lp.services[SwapType_1.SwapType.TO_BTCLN] == null)
150
- throw new Error("LP service for processing to btcln swaps not found!");
151
- const version = lp.getContractVersion(this.chainIdentifier);
152
- const abortController = abort instanceof AbortController ? abort : (0, Utils_1.extendAbortController)(abort);
153
- const reputationPromise = this.preFetchIntermediaryReputation(amountData, lp, abortController, version);
154
- try {
155
- const { signDataPromise, resp } = await (0, RetryUtils_1.tryWithRetries)(async (retryCount) => {
156
- const { signDataPrefetch, response } = this._lpApi.initToBTCLN(this.chainIdentifier, lp.url, {
157
- offerer: signer,
158
- pr,
159
- maxFee: await calculatedOptions.maxFee,
160
- expiryTimestamp: calculatedOptions.expiryTimestamp,
161
- token: amountData.token,
162
- feeRate: (0, Utils_1.throwIfUndefined)(preFetches.feeRatePromise[version], "Network fee rate pre-fetch failed!"),
163
- additionalParams
164
- }, this._options.postRequestTimeout, abortController.signal, retryCount > 0 ? false : undefined);
165
- let signDataPromise = preFetches.signDataPrefetchPromise?.[version];
166
- if (signDataPromise == null) {
167
- signDataPromise = this.preFetchSignData(signDataPrefetch, version);
168
- }
169
- else
170
- signDataPrefetch.catch(() => { });
171
- return {
172
- signDataPromise,
173
- resp: await response
174
- };
175
- }, undefined, e => e instanceof RequestError_1.RequestError, abortController.signal);
176
- if (parsedPr.millisatoshis == null)
177
- throw new Error("Swap invoice doesn't have msat amount field!");
178
- const amountOut = (BigInt(parsedPr.millisatoshis) + 999n) / 1000n;
179
- const totalFee = resp.swapFee + resp.maxFee;
180
- const data = new (this._swapDataDeserializer(version))(resp.data);
181
- data.setOfferer(signer);
182
- await this.verifyReturnedData(signer, resp, parsedPr, amountData.token, lp, calculatedOptions, data);
183
- const swapFeeBtc = resp.swapFee * amountOut / (data.getAmount() - totalFee);
184
- const [pricingInfo, signatureExpiry, reputation] = await Promise.all([
185
- this.verifyReturnedPrice(lp.services[SwapType_1.SwapType.TO_BTCLN], true, amountOut, data.getAmount(), amountData.token, { networkFee: resp.maxFee, swapFeeBtc }, preFetches.pricePreFetchPromise, preFetches.usdPricePrefetchPromise, abortController.signal),
186
- this.verifyReturnedSignature(signer, data, resp, preFetches.feeRatePromise[version], signDataPromise, version, abortController.signal),
187
- reputationPromise
188
- ]);
189
- abortController.signal.throwIfAborted();
190
- if (reputation != null)
191
- lp.reputation[amountData.token.toString()] = reputation;
192
- const quote = new ToBTCLNSwap_1.ToBTCLNSwap(this, {
193
- pricingInfo,
194
- url: lp.url,
195
- expiry: signatureExpiry,
196
- swapFee: resp.swapFee,
197
- swapFeeBtc,
198
- feeRate: (await preFetches.feeRatePromise[version]),
199
- signatureData: resp,
200
- data,
201
- networkFee: resp.maxFee,
202
- networkFeeBtc: resp.routingFeeSats,
203
- confidence: resp.confidence,
204
- pr,
205
- exactIn: false,
206
- contractVersion: version
207
- });
208
- return quote;
209
- }
210
- catch (e) {
211
- abortController.abort(e);
212
- throw e;
213
- }
214
- }
215
- /**
216
- * Returns a newly created Smart chain -> Lightning swap using the HTLC based escrow swap protocol,
217
- * the amount is parsed from the provided lightning network payment request (bolt11 invoice)
218
- *
219
- * @param signer Source chain signer address initiating the swap
220
- * @param recipient BOLT11 payment request (bitcoin lightning invoice) you wish to pay
221
- * @param amountData Token to swap
222
- * @param lps An array of intermediaries (LPs) to get the quotes from
223
- * @param options Optional additional quote options
224
- * @param additionalParams Optional additional parameters sent to the LP when creating the swap
225
- * @param abortSignal Abort signal
226
- * @param preFetches Optional existing pre-fetch promises for the swap (only used internally for LNURL swaps)
227
- */
228
- async create(signer, recipient, amountData, lps, options, additionalParams, abortSignal, preFetches) {
229
- const parsedPr = (0, bolt11_1.decode)(recipient);
230
- if (parsedPr.millisatoshis == null)
231
- throw new UserError_1.UserError("Must be an invoice with amount");
232
- const amountOut = (BigInt(parsedPr.millisatoshis) + 999n) / 1000n;
233
- const lpVersions = Intermediary_1.Intermediary.getContractVersionsForLps(this.chainIdentifier, lps);
234
- const _options = this.toRequiredSwapOptions({ ...amountData, amount: amountOut }, options);
235
- if (parsedPr.tagsObject.payment_hash == null)
236
- throw new Error("Provided lightning invoice doesn't contain payment hash field!");
237
- await this.checkPaymentHashWasPaid(parsedPr.tagsObject.payment_hash);
238
- const _hash = (0, Utils_1.mapArrayToObject)(lpVersions, (contractVersion) => {
239
- return this._contract(contractVersion).getHashForHtlc(Buffer.from(parsedPr.tagsObject.payment_hash, "hex")).toString("hex");
240
- });
241
- const _abortController = (0, Utils_1.extendAbortController)(abortSignal);
242
- const _preFetches = preFetches ?? {
243
- pricePreFetchPromise: this.preFetchPrice(amountData, _abortController.signal),
244
- feeRatePromise: this.preFetchFeeRate(signer, amountData, _hash, _abortController, lpVersions),
245
- usdPricePrefetchPromise: this.preFetchUsdPrice(_abortController.signal),
246
- signDataPrefetchPromise: (0, Utils_1.mapArrayToObject)(lpVersions, (contractVersion) => {
247
- return this._contract(contractVersion).preFetchBlockDataForSignatures == null ?
248
- this.preFetchSignData(Promise.resolve(true), contractVersion) :
249
- undefined;
250
- })
251
- };
252
- return lps.map(lp => {
253
- return {
254
- intermediary: lp,
255
- quote: this.getIntermediaryQuote(signer, amountData, lp, recipient, parsedPr, _options, _preFetches, _abortController.signal, additionalParams)
256
- };
257
- });
258
- }
259
- /**
260
- * Parses and fetches lnurl pay params from the specified lnurl
261
- *
262
- * @param lnurl LNURL to be parsed and fetched
263
- * @param abortSignal Abort signal
264
- * @throws {UserError} if the LNURL is invalid or if it's not a LNURL-pay
265
- *
266
- * @private
267
- */
268
- async getLNURLPay(lnurl, abortSignal) {
269
- if (typeof (lnurl) !== "string")
270
- return lnurl;
271
- const res = await LNURL_1.LNURL.getLNURL(lnurl, true, this._options.getRequestTimeout, abortSignal);
272
- if (res == null)
273
- throw new UserError_1.UserError("Invalid LNURL");
274
- if (res.tag !== "payRequest")
275
- throw new UserError_1.UserError("Not a LNURL-pay");
276
- return res;
277
- }
278
- /**
279
- * Returns the quote/swap from the given LP
280
- *
281
- * @param signer Source chain signer address initiating the swap
282
- * @param amountData Token to swap
283
- * @param invoiceCreateService Service for creating fixed amount invoices
284
- * @param lp Intermediary (LPs) to get the quote from
285
- * @param dummyPr Dummy minimum value bolt11 lightning invoice returned from the LNURL-pay, used to estimate
286
- * network fees for an actual invoice
287
- * @param calculatedOptions Swap options computed from the swap create options
288
- * @param preFetches Optional existing pre-fetch promises for the swap (only used internally for LNURL swaps)
289
- * @param abortSignal Abort signal
290
- * @param additionalParams Additional params to be sent to the intermediary
291
- *
292
- * @private
293
- */
294
- async getIntermediaryQuoteExactIn(signer, amountData, invoiceCreateService, lp, dummyPr, calculatedOptions, preFetches, abortSignal, additionalParams) {
295
- if (lp.services[SwapType_1.SwapType.TO_BTCLN] == null)
296
- throw new Error("LP service for processing to btcln swaps not found!");
297
- const version = lp.getContractVersion(this.chainIdentifier);
298
- const abortController = (0, Utils_1.extendAbortController)(abortSignal);
299
- const reputationPromise = this.preFetchIntermediaryReputation(amountData, lp, abortController, version);
300
- try {
301
- const { signDataPromise, prepareResp } = await (0, RetryUtils_1.tryWithRetries)(async (retryCount) => {
302
- const { signDataPrefetch, response } = this._lpApi.prepareToBTCLNExactIn(this.chainIdentifier, lp.url, {
303
- token: amountData.token,
304
- offerer: signer,
305
- pr: dummyPr,
306
- amount: amountData.amount,
307
- maxFee: await calculatedOptions.maxFee,
308
- expiryTimestamp: calculatedOptions.expiryTimestamp,
309
- additionalParams
310
- }, this._options.postRequestTimeout, abortController.signal, retryCount > 0 ? false : undefined);
311
- return {
312
- signDataPromise: this.preFetchSignData(signDataPrefetch, version),
313
- prepareResp: await response
314
- };
315
- }, undefined, e => e instanceof RequestError_1.RequestError, abortController.signal);
316
- if (prepareResp.amount <= 0n)
317
- throw new IntermediaryError_1.IntermediaryError("Invalid amount returned (zero or negative)");
318
- if (invoiceCreateService.minMsats != null) {
319
- if (prepareResp.amount < invoiceCreateService.minMsats / 1000n)
320
- throw new UserError_1.UserError("Amount less than minimum");
321
- }
322
- if (invoiceCreateService.maxMSats != null) {
323
- if (prepareResp.amount > invoiceCreateService.maxMSats / 1000n)
324
- throw new UserError_1.UserError("Amount more than maximum");
325
- }
326
- const invoice = await invoiceCreateService.getInvoice(Number(prepareResp.amount), abortController.signal);
327
- const parsedInvoice = (0, bolt11_1.decode)(invoice);
328
- const resp = await (0, RetryUtils_1.tryWithRetries)((retryCount) => this._lpApi.initToBTCLNExactIn(lp.url, {
329
- pr: invoice,
330
- reqId: prepareResp.reqId,
331
- feeRate: (0, Utils_1.throwIfUndefined)(preFetches.feeRatePromise[version], "Network fee rate pre-fetch failed!"),
332
- additionalParams
333
- }, this._options.postRequestTimeout, abortController.signal, retryCount > 0 ? false : undefined), undefined, RequestError_1.RequestError, abortController.signal);
334
- if (parsedInvoice.millisatoshis == null)
335
- throw new Error("Swap invoice doesn't have msat amount field!");
336
- const amountOut = (BigInt(parsedInvoice.millisatoshis) + 999n) / 1000n;
337
- const totalFee = resp.swapFee + resp.maxFee;
338
- const data = new (this._swapDataDeserializer(version))(resp.data);
339
- data.setOfferer(signer);
340
- await this.verifyReturnedData(signer, resp, parsedInvoice, amountData.token, lp, calculatedOptions, data, amountData.amount);
341
- const swapFeeBtc = resp.swapFee * amountOut / (data.getAmount() - totalFee);
342
- const [pricingInfo, signatureExpiry, reputation] = await Promise.all([
343
- this.verifyReturnedPrice(lp.services[SwapType_1.SwapType.TO_BTCLN], true, prepareResp.amount, data.getAmount(), amountData.token, { networkFee: resp.maxFee, swapFeeBtc }, preFetches.pricePreFetchPromise, preFetches.usdPricePrefetchPromise, abortSignal),
344
- this.verifyReturnedSignature(signer, data, resp, preFetches.feeRatePromise[version], signDataPromise, version, abortController.signal),
345
- reputationPromise
346
- ]);
347
- abortController.signal.throwIfAborted();
348
- if (reputation != null)
349
- lp.reputation[amountData.token.toString()] = reputation;
350
- const quote = new ToBTCLNSwap_1.ToBTCLNSwap(this, {
351
- pricingInfo,
352
- url: lp.url,
353
- expiry: signatureExpiry,
354
- swapFee: resp.swapFee,
355
- swapFeeBtc,
356
- feeRate: (await preFetches.feeRatePromise[version]),
357
- signatureData: resp,
358
- data,
359
- networkFee: resp.maxFee,
360
- networkFeeBtc: resp.routingFeeSats,
361
- confidence: resp.confidence,
362
- pr: invoice,
363
- exactIn: true,
364
- contractVersion: version
365
- });
366
- return quote;
367
- }
368
- catch (e) {
369
- abortController.abort(e);
370
- throw e;
371
- }
372
- }
373
- /**
374
- * Returns a newly created Smart chain -> Lightning swap using the HTLC based escrow swap protocol via
375
- * invoice creation service. This allows exactIn swaps by requesting the desired fixed amount lightning
376
- * network invoice from the service.
377
- *
378
- * @param signer Source chain signer address initiating the swap
379
- * @param invoiceCreateServicePromise Service to request destination lightning network invoices from
380
- * @param amountData Amount, token and exact input/output data for to swap
381
- * @param lps An array of intermediaries (LPs) to get the quotes from
382
- * @param options Optional additional quote options
383
- * @param additionalParams Optional additional parameters sent to the LP when creating the swap
384
- * @param abortSignal Abort signal
385
- */
386
- async createViaInvoiceCreateService(signer, invoiceCreateServicePromise, amountData, lps, options, additionalParams, abortSignal) {
387
- if (!this.isInitialized)
388
- throw new Error("Not initialized, call init() first!");
389
- const lpVersions = Intermediary_1.Intermediary.getContractVersionsForLps(this.chainIdentifier, lps);
390
- const _abortController = (0, Utils_1.extendAbortController)(abortSignal);
391
- const pricePreFetchPromise = this.preFetchPrice(amountData, _abortController.signal);
392
- const usdPricePrefetchPromise = this.preFetchUsdPrice(_abortController.signal);
393
- const feeRatePromise = this.preFetchFeeRate(signer, amountData, undefined, _abortController, lpVersions);
394
- const signDataPrefetchPromise = (0, Utils_1.mapArrayToObject)(lpVersions, (contractVersion) => {
395
- return this._contract(contractVersion).preFetchBlockDataForSignatures == null ?
396
- this.preFetchSignData(Promise.resolve(true), contractVersion) :
397
- undefined;
398
- });
399
- const _options = this.toRequiredSwapOptions(amountData, options, pricePreFetchPromise, _abortController.signal);
400
- try {
401
- const invoiceCreateService = await invoiceCreateServicePromise;
402
- if (amountData.exactIn) {
403
- const dummyInvoice = await invoiceCreateService.getInvoice(invoiceCreateService.minMsats == null ? 1 : Number(invoiceCreateService.minMsats / 1000n), _abortController.signal);
404
- return lps.map(lp => {
405
- return {
406
- quote: this.getIntermediaryQuoteExactIn(signer, amountData, invoiceCreateService, lp, dummyInvoice, _options, {
407
- pricePreFetchPromise,
408
- usdPricePrefetchPromise,
409
- feeRatePromise
410
- }, _abortController.signal, additionalParams),
411
- intermediary: lp
412
- };
413
- });
414
- }
415
- else {
416
- if (invoiceCreateService.minMsats != null) {
417
- if (amountData.amount < invoiceCreateService.minMsats / 1000n)
418
- throw new UserError_1.UserError("Amount less than minimum");
419
- }
420
- if (invoiceCreateService.maxMSats != null) {
421
- if (amountData.amount > invoiceCreateService.maxMSats / 1000n)
422
- throw new UserError_1.UserError("Amount more than maximum");
423
- }
424
- const invoice = await invoiceCreateService.getInvoice(Number(amountData.amount), _abortController.signal);
425
- return (await this.create(signer, invoice, { ...amountData, exactIn: false }, lps, options, additionalParams, _abortController.signal, {
426
- feeRatePromise,
427
- pricePreFetchPromise,
428
- usdPricePrefetchPromise,
429
- signDataPrefetchPromise
430
- }));
431
- }
432
- }
433
- catch (e) {
434
- _abortController.abort(e);
435
- throw e;
436
- }
437
- }
438
- /**
439
- * Returns a newly created Smart chain -> Lightning swap using the HTLC based escrow swap protocol. Pays to
440
- * an LNURL-pay link. This allows exactIn swaps by requesting the desired fixed amount lightning
441
- * network invoice from the LNURL service.
442
- *
443
- * @param signer Source chain signer address initiating the swap
444
- * @param lnurl LNURL-pay link of the recipient
445
- * @param amountData Amount, token and exact input/output data for to swap
446
- * @param lps An array of intermediaries (LPs) to get the quotes from
447
- * @param options Optional additional quote options
448
- * @param additionalParams Optional additional parameters sent to the LP when creating the swap
449
- * @param abortSignal Abort signal
450
- */
451
- async createViaLNURL(signer, lnurl, amountData, lps, options, additionalParams, abortSignal) {
452
- let successActions = {};
453
- const _abortController = (0, Utils_1.extendAbortController)(abortSignal);
454
- const invoiceCreateService = (async () => {
455
- let payRequest = await this.getLNURLPay(lnurl, _abortController.signal);
456
- if (options?.comment != null &&
457
- (payRequest.commentAllowed == null || options.comment.length > payRequest.commentAllowed))
458
- throw new UserError_1.UserError("Comment not allowed or too long");
459
- return {
460
- getInvoice: async (amountSats, abortSignal) => {
461
- const { invoice, successAction } = await LNURL_1.LNURL.useLNURLPay(payRequest, BigInt(amountSats), options?.comment, this._options.getRequestTimeout, abortSignal);
462
- if (successAction != null)
463
- successActions[invoice] = successAction;
464
- return invoice;
465
- },
466
- minMsats: BigInt(payRequest.minSendable),
467
- maxMsats: BigInt(payRequest.maxSendable),
468
- url: payRequest.url
469
- };
470
- })();
471
- const quotes = await this.createViaInvoiceCreateService(signer, invoiceCreateService, amountData, lps, options, additionalParams, _abortController.signal);
472
- _abortController.signal.throwIfAborted();
473
- const resolved = await invoiceCreateService;
474
- _abortController.signal.throwIfAborted();
475
- return quotes.map(value => ({
476
- quote: value.quote.then(quote => {
477
- let _successAction;
478
- const quoteAddress = quote.getOutputAddress();
479
- if (quoteAddress != null) {
480
- const successAction = successActions[quoteAddress];
481
- if (successAction != null)
482
- _successAction = successAction;
483
- }
484
- quote._setLNURLData(resolved.url, _successAction);
485
- return quote;
486
- }),
487
- intermediary: value.intermediary
488
- }));
489
- }
490
- /**
491
- * @inheritDoc
492
- */
493
- async recoverFromSwapDataAndState(init, state, contractVersion, lp) {
494
- const data = init.data;
495
- let paymentHash = data.getHTLCHashHint();
496
- let secret;
497
- if (state.type === base_1.SwapCommitStateType.PAID) {
498
- secret = await state.getClaimResult();
499
- paymentHash = Buffer.from((0, sha2_1.sha256)(Buffer.from(secret, "hex"))).toString("hex");
500
- }
501
- const swapInit = {
502
- pricingInfo: {
503
- isValid: true,
504
- satsBaseFee: 0n,
505
- swapPriceUSatPerToken: 100000000000000n,
506
- realPriceUSatPerToken: 100000000000000n,
507
- differencePPM: 0n,
508
- feePPM: 0n,
509
- },
510
- url: lp?.url,
511
- expiry: 0,
512
- swapFee: 0n,
513
- swapFeeBtc: 0n,
514
- feeRate: "",
515
- signatureData: undefined,
516
- data,
517
- networkFee: 0n,
518
- networkFeeBtc: 0n,
519
- confidence: 0,
520
- pr: paymentHash ?? undefined,
521
- exactIn: false,
522
- contractVersion
523
- };
524
- const swap = new ToBTCLNSwap_1.ToBTCLNSwap(this, swapInit);
525
- swap._commitTxId = await init.getInitTxId();
526
- const blockData = await init.getTxBlock();
527
- swap.createdAt = blockData.blockTime * 1000;
528
- swap._setInitiated();
529
- swap._state = IToBTCSwap_1.ToBTCSwapState.COMMITED;
530
- await swap._sync(false, false, state);
531
- await swap._save();
532
- return swap;
533
- }
534
- }
535
- exports.ToBTCLNWrapper = ToBTCLNWrapper;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ToBTCLNWrapper = void 0;
4
+ const bolt11_1 = require("@atomiqlabs/bolt11");
5
+ const ToBTCLNSwap_1 = require("./ToBTCLNSwap");
6
+ const IToBTCWrapper_1 = require("../IToBTCWrapper");
7
+ const UserError_1 = require("../../../../errors/UserError");
8
+ const base_1 = require("@atomiqlabs/base");
9
+ const Intermediary_1 = require("../../../../intermediaries/Intermediary");
10
+ const IntermediaryError_1 = require("../../../../errors/IntermediaryError");
11
+ const SwapType_1 = require("../../../../enums/SwapType");
12
+ const Utils_1 = require("../../../../utils/Utils");
13
+ const RequestError_1 = require("../../../../errors/RequestError");
14
+ const LNURL_1 = require("../../../../lnurl/LNURL");
15
+ const IToBTCSwap_1 = require("../IToBTCSwap");
16
+ const sha2_1 = require("@noble/hashes/sha2");
17
+ const RetryUtils_1 = require("../../../../utils/RetryUtils");
18
+ /**
19
+ * Escrow based (HTLC) swap for Smart chains -> Bitcoin lightning
20
+ *
21
+ * @category Swaps/Smart chain → Lightning
22
+ */
23
+ class ToBTCLNWrapper extends IToBTCWrapper_1.IToBTCWrapper {
24
+ constructor(chainIdentifier, unifiedStorage, unifiedChainEvents, chain, prices, tokens, versionedContracts, lpApi, options, events) {
25
+ super(chainIdentifier, unifiedStorage, unifiedChainEvents, chain, prices, tokens, lpApi, {
26
+ ...options,
27
+ paymentTimeoutSeconds: options?.paymentTimeoutSeconds ?? 5 * 24 * 60 * 60,
28
+ lightningBaseFee: options?.lightningBaseFee ?? 10,
29
+ lightningFeePPM: options?.lightningFeePPM ?? 2000
30
+ }, versionedContracts, events);
31
+ this.TYPE = SwapType_1.SwapType.TO_BTCLN;
32
+ /**
33
+ * @internal
34
+ */
35
+ this._swapDeserializer = ToBTCLNSwap_1.ToBTCLNSwap;
36
+ }
37
+ toRequiredSwapOptions(amountData, options, pricePreFetchPromise, abortSignal) {
38
+ const expirySeconds = options?.expirySeconds ?? this._options.paymentTimeoutSeconds;
39
+ const maxRoutingBaseFee = options?.maxRoutingBaseFee ?? BigInt(this._options.lightningBaseFee);
40
+ const maxRoutingPPM = options?.maxRoutingFeePercentage != null
41
+ ? BigInt(Math.floor(options.maxRoutingFeePercentage * 10000))
42
+ : options?.maxRoutingPPM ?? BigInt(this._options.lightningFeePPM);
43
+ let maxFee;
44
+ if (options?.maxFee != null) {
45
+ maxFee = options.maxFee;
46
+ }
47
+ else if (amountData.exactIn) {
48
+ if (pricePreFetchPromise != null) {
49
+ maxFee = pricePreFetchPromise
50
+ .then(val => this._prices.getFromBtcSwapAmount(this.chainIdentifier, maxRoutingBaseFee, amountData.token, abortSignal, val))
51
+ .then(_maxBaseFee => this.calculateFeeForAmount(amountData.amount, _maxBaseFee, maxRoutingPPM));
52
+ }
53
+ else {
54
+ maxFee = this._prices.getFromBtcSwapAmount(this.chainIdentifier, maxRoutingBaseFee, amountData.token, abortSignal)
55
+ .then(_maxBaseFee => this.calculateFeeForAmount(amountData.amount, _maxBaseFee, maxRoutingPPM));
56
+ }
57
+ }
58
+ else {
59
+ maxFee = this.calculateFeeForAmount(amountData.amount, maxRoutingBaseFee, maxRoutingPPM);
60
+ }
61
+ return {
62
+ expiryTimestamp: options?.expiryTimestamp ?? BigInt(Math.floor(Date.now() / 1000) + expirySeconds),
63
+ maxFee
64
+ };
65
+ }
66
+ /**
67
+ * Verifies whether a given payment hash was already paid by checking the local
68
+ * storage of known swaps
69
+ *
70
+ * @param paymentHash Payment hash to check
71
+ *
72
+ * @private
73
+ */
74
+ async checkPaymentHashWasPaid(paymentHash) {
75
+ const swaps = await this.unifiedStorage.query([[{ key: "type", value: this.TYPE }, { key: "paymentHash", value: paymentHash }]], (obj) => new this._swapDeserializer(this, obj));
76
+ for (let value of swaps) {
77
+ if (value._state === IToBTCSwap_1.ToBTCSwapState.CLAIMED || value._state === IToBTCSwap_1.ToBTCSwapState.SOFT_CLAIMED)
78
+ throw new UserError_1.UserError("Lightning invoice was already paid!");
79
+ }
80
+ }
81
+ /**
82
+ * Calculates maximum lightning network routing fee based on amount
83
+ *
84
+ * @param amount BTC amount of the swap in satoshis
85
+ * @param overrideBaseFee Override wrapper's default base fee
86
+ * @param overrideFeePPM Override wrapper's default PPM
87
+ *
88
+ * @returns Maximum lightning routing fee in sats
89
+ *
90
+ * @private
91
+ */
92
+ calculateFeeForAmount(amount, overrideBaseFee, overrideFeePPM) {
93
+ return BigInt(overrideBaseFee ?? this._options.lightningBaseFee)
94
+ + (amount * BigInt(overrideFeePPM ?? this._options.lightningFeePPM) / 1000000n);
95
+ }
96
+ /**
97
+ * Verifies returned LP data
98
+ *
99
+ * @param signer
100
+ * @param resp Response as returned by the LP
101
+ * @param parsedPr Parsed bolt11 lightning invoice
102
+ * @param token Smart chain token to be used in the swap
103
+ * @param lp
104
+ * @param calculatedOptions Swap options computed from the swap create options
105
+ * @param data Parsed swap data returned by the LP
106
+ * @param requiredTotal Required total to be paid on the input (for exactIn swaps)
107
+ *
108
+ * @throws {IntermediaryError} In case the response is not valid
109
+ *
110
+ * @private
111
+ */
112
+ async verifyReturnedData(signer, resp, parsedPr, token, lp, calculatedOptions, data, requiredTotal) {
113
+ if (resp.routingFeeSats > await calculatedOptions.maxFee)
114
+ throw new IntermediaryError_1.IntermediaryError("Invalid max fee sats returned");
115
+ if (requiredTotal != null && resp.total !== requiredTotal)
116
+ throw new IntermediaryError_1.IntermediaryError("Invalid data returned - total amount");
117
+ if (parsedPr.tagsObject.payment_hash == null)
118
+ throw new Error("Swap invoice doesn't contain payment hash field!");
119
+ const claimHash = this._contract(lp.getContractVersion(this.chainIdentifier)).getHashForHtlc(Buffer.from(parsedPr.tagsObject.payment_hash, "hex"));
120
+ if (data.getAmount() !== resp.total ||
121
+ !Buffer.from(data.getClaimHash(), "hex").equals(claimHash) ||
122
+ data.getExpiry() !== calculatedOptions.expiryTimestamp ||
123
+ data.getType() !== base_1.ChainSwapType.HTLC ||
124
+ !data.isPayIn() ||
125
+ !data.isToken(token) ||
126
+ !data.isClaimer(lp.getAddress(this.chainIdentifier)) ||
127
+ !data.isOfferer(signer) ||
128
+ data.getTotalDeposit() !== 0n) {
129
+ throw new IntermediaryError_1.IntermediaryError("Invalid data returned");
130
+ }
131
+ }
132
+ /**
133
+ * Returns the quote/swap from a given intermediary
134
+ *
135
+ * @param signer Smartchain signer initiating the swap
136
+ * @param amountData
137
+ * @param lp Intermediary
138
+ * @param pr bolt11 lightning network invoice
139
+ * @param parsedPr Parsed bolt11 lightning network invoice
140
+ * @param calculatedOptions Swap options computed from the swap create options
141
+ * @param preFetches
142
+ * @param abort Abort signal or controller, if AbortController is passed it is used as-is, when AbortSignal is passed
143
+ * it is extended with extendAbortController and then used
144
+ * @param additionalParams Additional params that should be sent to the LP
145
+ *
146
+ * @private
147
+ */
148
+ async getIntermediaryQuote(signer, amountData, lp, pr, parsedPr, calculatedOptions, preFetches, abort, additionalParams) {
149
+ if (lp.services[SwapType_1.SwapType.TO_BTCLN] == null)
150
+ throw new Error("LP service for processing to btcln swaps not found!");
151
+ const version = lp.getContractVersion(this.chainIdentifier);
152
+ const abortController = abort instanceof AbortController ? abort : (0, Utils_1.extendAbortController)(abort);
153
+ const reputationPromise = this.preFetchIntermediaryReputation(amountData, lp, abortController, version);
154
+ try {
155
+ const { signDataPromise, resp } = await (0, RetryUtils_1.tryWithRetries)(async (retryCount) => {
156
+ const { signDataPrefetch, response } = this._lpApi.initToBTCLN(this.chainIdentifier, lp.url, {
157
+ offerer: signer,
158
+ pr,
159
+ maxFee: await calculatedOptions.maxFee,
160
+ expiryTimestamp: calculatedOptions.expiryTimestamp,
161
+ token: amountData.token,
162
+ feeRate: (0, Utils_1.throwIfUndefined)(preFetches.feeRatePromise[version], "Network fee rate pre-fetch failed!"),
163
+ additionalParams
164
+ }, this._options.postRequestTimeout, abortController.signal, retryCount > 0 ? false : undefined);
165
+ let signDataPromise = preFetches.signDataPrefetchPromise?.[version];
166
+ if (signDataPromise == null) {
167
+ signDataPromise = this.preFetchSignData(signDataPrefetch, version);
168
+ }
169
+ else
170
+ signDataPrefetch.catch(() => { });
171
+ return {
172
+ signDataPromise,
173
+ resp: await response
174
+ };
175
+ }, undefined, e => e instanceof RequestError_1.RequestError, abortController.signal);
176
+ if (parsedPr.millisatoshis == null)
177
+ throw new Error("Swap invoice doesn't have msat amount field!");
178
+ const amountOut = (BigInt(parsedPr.millisatoshis) + 999n) / 1000n;
179
+ const totalFee = resp.swapFee + resp.maxFee;
180
+ const data = new (this._swapDataDeserializer(version))(resp.data);
181
+ data.setOfferer(signer);
182
+ await this.verifyReturnedData(signer, resp, parsedPr, amountData.token, lp, calculatedOptions, data);
183
+ const swapFeeBtc = resp.swapFee * amountOut / (data.getAmount() - totalFee);
184
+ const [pricingInfo, signatureExpiry, reputation] = await Promise.all([
185
+ this.verifyReturnedPrice(lp.services[SwapType_1.SwapType.TO_BTCLN], true, amountOut, data.getAmount(), amountData.token, { networkFee: resp.maxFee, swapFeeBtc }, preFetches.pricePreFetchPromise, preFetches.usdPricePrefetchPromise, abortController.signal),
186
+ this.verifyReturnedSignature(signer, data, resp, preFetches.feeRatePromise[version], signDataPromise, version, abortController.signal),
187
+ reputationPromise
188
+ ]);
189
+ abortController.signal.throwIfAborted();
190
+ if (reputation != null)
191
+ lp.reputation[amountData.token.toString()] = reputation;
192
+ const quote = new ToBTCLNSwap_1.ToBTCLNSwap(this, {
193
+ pricingInfo,
194
+ url: lp.url,
195
+ expiry: signatureExpiry,
196
+ swapFee: resp.swapFee,
197
+ swapFeeBtc,
198
+ feeRate: (await preFetches.feeRatePromise[version]),
199
+ signatureData: resp,
200
+ data,
201
+ networkFee: resp.maxFee,
202
+ networkFeeBtc: resp.routingFeeSats,
203
+ confidence: resp.confidence,
204
+ pr,
205
+ exactIn: false,
206
+ contractVersion: version
207
+ });
208
+ return quote;
209
+ }
210
+ catch (e) {
211
+ abortController.abort(e);
212
+ throw e;
213
+ }
214
+ }
215
+ /**
216
+ * Returns a newly created Smart chain -> Lightning swap using the HTLC based escrow swap protocol,
217
+ * the amount is parsed from the provided lightning network payment request (bolt11 invoice)
218
+ *
219
+ * @param signer Source chain signer address initiating the swap
220
+ * @param recipient BOLT11 payment request (bitcoin lightning invoice) you wish to pay
221
+ * @param amountData Token to swap
222
+ * @param lps An array of intermediaries (LPs) to get the quotes from
223
+ * @param options Optional additional quote options
224
+ * @param additionalParams Optional additional parameters sent to the LP when creating the swap
225
+ * @param abortSignal Abort signal
226
+ * @param preFetches Optional existing pre-fetch promises for the swap (only used internally for LNURL swaps)
227
+ */
228
+ async create(signer, recipient, amountData, lps, options, additionalParams, abortSignal, preFetches) {
229
+ const parsedPr = (0, bolt11_1.decode)(recipient);
230
+ if (parsedPr.millisatoshis == null)
231
+ throw new UserError_1.UserError("Must be an invoice with amount");
232
+ const amountOut = (BigInt(parsedPr.millisatoshis) + 999n) / 1000n;
233
+ const lpVersions = Intermediary_1.Intermediary.getContractVersionsForLps(this.chainIdentifier, lps);
234
+ const _options = this.toRequiredSwapOptions({ ...amountData, amount: amountOut }, options);
235
+ if (parsedPr.tagsObject.payment_hash == null)
236
+ throw new Error("Provided lightning invoice doesn't contain payment hash field!");
237
+ await this.checkPaymentHashWasPaid(parsedPr.tagsObject.payment_hash);
238
+ const _hash = (0, Utils_1.mapArrayToObject)(lpVersions, (contractVersion) => {
239
+ return this._contract(contractVersion).getHashForHtlc(Buffer.from(parsedPr.tagsObject.payment_hash, "hex")).toString("hex");
240
+ });
241
+ const _abortController = (0, Utils_1.extendAbortController)(abortSignal);
242
+ const _preFetches = preFetches ?? {
243
+ pricePreFetchPromise: this.preFetchPrice(amountData, _abortController.signal),
244
+ feeRatePromise: this.preFetchFeeRate(signer, amountData, _hash, _abortController, lpVersions),
245
+ usdPricePrefetchPromise: this.preFetchUsdPrice(_abortController.signal),
246
+ signDataPrefetchPromise: (0, Utils_1.mapArrayToObject)(lpVersions, (contractVersion) => {
247
+ return this._contract(contractVersion).preFetchBlockDataForSignatures == null ?
248
+ this.preFetchSignData(Promise.resolve(true), contractVersion) :
249
+ undefined;
250
+ })
251
+ };
252
+ return lps.map(lp => {
253
+ return {
254
+ intermediary: lp,
255
+ quote: this.getIntermediaryQuote(signer, amountData, lp, recipient, parsedPr, _options, _preFetches, _abortController.signal, additionalParams)
256
+ };
257
+ });
258
+ }
259
+ /**
260
+ * Parses and fetches lnurl pay params from the specified lnurl
261
+ *
262
+ * @param lnurl LNURL to be parsed and fetched
263
+ * @param abortSignal Abort signal
264
+ * @throws {UserError} if the LNURL is invalid or if it's not a LNURL-pay
265
+ *
266
+ * @private
267
+ */
268
+ async getLNURLPay(lnurl, abortSignal) {
269
+ if (typeof (lnurl) !== "string")
270
+ return lnurl;
271
+ const res = await LNURL_1.LNURL.getLNURL(lnurl, true, this._options.getRequestTimeout, abortSignal);
272
+ if (res == null)
273
+ throw new UserError_1.UserError("Invalid LNURL");
274
+ if (res.tag !== "payRequest")
275
+ throw new UserError_1.UserError("Not a LNURL-pay");
276
+ return res;
277
+ }
278
+ /**
279
+ * Returns the quote/swap from the given LP
280
+ *
281
+ * @param signer Source chain signer address initiating the swap
282
+ * @param amountData Token to swap
283
+ * @param invoiceCreateService Service for creating fixed amount invoices
284
+ * @param lp Intermediary (LPs) to get the quote from
285
+ * @param dummyPr Dummy minimum value bolt11 lightning invoice returned from the LNURL-pay, used to estimate
286
+ * network fees for an actual invoice
287
+ * @param calculatedOptions Swap options computed from the swap create options
288
+ * @param preFetches Optional existing pre-fetch promises for the swap (only used internally for LNURL swaps)
289
+ * @param abortSignal Abort signal
290
+ * @param additionalParams Additional params to be sent to the intermediary
291
+ *
292
+ * @private
293
+ */
294
+ async getIntermediaryQuoteExactIn(signer, amountData, invoiceCreateService, lp, dummyPr, calculatedOptions, preFetches, abortSignal, additionalParams) {
295
+ if (lp.services[SwapType_1.SwapType.TO_BTCLN] == null)
296
+ throw new Error("LP service for processing to btcln swaps not found!");
297
+ const version = lp.getContractVersion(this.chainIdentifier);
298
+ const abortController = (0, Utils_1.extendAbortController)(abortSignal);
299
+ const reputationPromise = this.preFetchIntermediaryReputation(amountData, lp, abortController, version);
300
+ try {
301
+ const { signDataPromise, prepareResp } = await (0, RetryUtils_1.tryWithRetries)(async (retryCount) => {
302
+ const { signDataPrefetch, response } = this._lpApi.prepareToBTCLNExactIn(this.chainIdentifier, lp.url, {
303
+ token: amountData.token,
304
+ offerer: signer,
305
+ pr: dummyPr,
306
+ amount: amountData.amount,
307
+ maxFee: await calculatedOptions.maxFee,
308
+ expiryTimestamp: calculatedOptions.expiryTimestamp,
309
+ additionalParams
310
+ }, this._options.postRequestTimeout, abortController.signal, retryCount > 0 ? false : undefined);
311
+ return {
312
+ signDataPromise: this.preFetchSignData(signDataPrefetch, version),
313
+ prepareResp: await response
314
+ };
315
+ }, undefined, e => e instanceof RequestError_1.RequestError, abortController.signal);
316
+ if (prepareResp.amount <= 0n)
317
+ throw new IntermediaryError_1.IntermediaryError("Invalid amount returned (zero or negative)");
318
+ if (invoiceCreateService.minMsats != null) {
319
+ if (prepareResp.amount < invoiceCreateService.minMsats / 1000n)
320
+ throw new UserError_1.UserError("Amount less than minimum");
321
+ }
322
+ if (invoiceCreateService.maxMSats != null) {
323
+ if (prepareResp.amount > invoiceCreateService.maxMSats / 1000n)
324
+ throw new UserError_1.UserError("Amount more than maximum");
325
+ }
326
+ const invoice = await invoiceCreateService.getInvoice(Number(prepareResp.amount), abortController.signal);
327
+ const parsedInvoice = (0, bolt11_1.decode)(invoice);
328
+ const resp = await (0, RetryUtils_1.tryWithRetries)((retryCount) => this._lpApi.initToBTCLNExactIn(lp.url, {
329
+ pr: invoice,
330
+ reqId: prepareResp.reqId,
331
+ feeRate: (0, Utils_1.throwIfUndefined)(preFetches.feeRatePromise[version], "Network fee rate pre-fetch failed!"),
332
+ additionalParams
333
+ }, this._options.postRequestTimeout, abortController.signal, retryCount > 0 ? false : undefined), undefined, RequestError_1.RequestError, abortController.signal);
334
+ if (parsedInvoice.millisatoshis == null)
335
+ throw new Error("Swap invoice doesn't have msat amount field!");
336
+ const amountOut = (BigInt(parsedInvoice.millisatoshis) + 999n) / 1000n;
337
+ const totalFee = resp.swapFee + resp.maxFee;
338
+ const data = new (this._swapDataDeserializer(version))(resp.data);
339
+ data.setOfferer(signer);
340
+ await this.verifyReturnedData(signer, resp, parsedInvoice, amountData.token, lp, calculatedOptions, data, amountData.amount);
341
+ const swapFeeBtc = resp.swapFee * amountOut / (data.getAmount() - totalFee);
342
+ const [pricingInfo, signatureExpiry, reputation] = await Promise.all([
343
+ this.verifyReturnedPrice(lp.services[SwapType_1.SwapType.TO_BTCLN], true, prepareResp.amount, data.getAmount(), amountData.token, { networkFee: resp.maxFee, swapFeeBtc }, preFetches.pricePreFetchPromise, preFetches.usdPricePrefetchPromise, abortSignal),
344
+ this.verifyReturnedSignature(signer, data, resp, preFetches.feeRatePromise[version], signDataPromise, version, abortController.signal),
345
+ reputationPromise
346
+ ]);
347
+ abortController.signal.throwIfAborted();
348
+ if (reputation != null)
349
+ lp.reputation[amountData.token.toString()] = reputation;
350
+ const quote = new ToBTCLNSwap_1.ToBTCLNSwap(this, {
351
+ pricingInfo,
352
+ url: lp.url,
353
+ expiry: signatureExpiry,
354
+ swapFee: resp.swapFee,
355
+ swapFeeBtc,
356
+ feeRate: (await preFetches.feeRatePromise[version]),
357
+ signatureData: resp,
358
+ data,
359
+ networkFee: resp.maxFee,
360
+ networkFeeBtc: resp.routingFeeSats,
361
+ confidence: resp.confidence,
362
+ pr: invoice,
363
+ exactIn: true,
364
+ contractVersion: version
365
+ });
366
+ return quote;
367
+ }
368
+ catch (e) {
369
+ abortController.abort(e);
370
+ throw e;
371
+ }
372
+ }
373
+ /**
374
+ * Returns a newly created Smart chain -> Lightning swap using the HTLC based escrow swap protocol via
375
+ * invoice creation service. This allows exactIn swaps by requesting the desired fixed amount lightning
376
+ * network invoice from the service.
377
+ *
378
+ * @param signer Source chain signer address initiating the swap
379
+ * @param invoiceCreateServicePromise Service to request destination lightning network invoices from
380
+ * @param amountData Amount, token and exact input/output data for to swap
381
+ * @param lps An array of intermediaries (LPs) to get the quotes from
382
+ * @param options Optional additional quote options
383
+ * @param additionalParams Optional additional parameters sent to the LP when creating the swap
384
+ * @param abortSignal Abort signal
385
+ */
386
+ async createViaInvoiceCreateService(signer, invoiceCreateServicePromise, amountData, lps, options, additionalParams, abortSignal) {
387
+ if (!this.isInitialized)
388
+ throw new Error("Not initialized, call init() first!");
389
+ const lpVersions = Intermediary_1.Intermediary.getContractVersionsForLps(this.chainIdentifier, lps);
390
+ const _abortController = (0, Utils_1.extendAbortController)(abortSignal);
391
+ const pricePreFetchPromise = this.preFetchPrice(amountData, _abortController.signal);
392
+ const usdPricePrefetchPromise = this.preFetchUsdPrice(_abortController.signal);
393
+ const feeRatePromise = this.preFetchFeeRate(signer, amountData, undefined, _abortController, lpVersions);
394
+ const signDataPrefetchPromise = (0, Utils_1.mapArrayToObject)(lpVersions, (contractVersion) => {
395
+ return this._contract(contractVersion).preFetchBlockDataForSignatures == null ?
396
+ this.preFetchSignData(Promise.resolve(true), contractVersion) :
397
+ undefined;
398
+ });
399
+ const _options = this.toRequiredSwapOptions(amountData, options, pricePreFetchPromise, _abortController.signal);
400
+ try {
401
+ const invoiceCreateService = await invoiceCreateServicePromise;
402
+ if (amountData.exactIn) {
403
+ const dummyInvoice = await invoiceCreateService.getInvoice(invoiceCreateService.minMsats == null ? 1 : Number(invoiceCreateService.minMsats / 1000n), _abortController.signal);
404
+ return lps.map(lp => {
405
+ return {
406
+ quote: this.getIntermediaryQuoteExactIn(signer, amountData, invoiceCreateService, lp, dummyInvoice, _options, {
407
+ pricePreFetchPromise,
408
+ usdPricePrefetchPromise,
409
+ feeRatePromise
410
+ }, _abortController.signal, additionalParams),
411
+ intermediary: lp
412
+ };
413
+ });
414
+ }
415
+ else {
416
+ if (invoiceCreateService.minMsats != null) {
417
+ if (amountData.amount < invoiceCreateService.minMsats / 1000n)
418
+ throw new UserError_1.UserError("Amount less than minimum");
419
+ }
420
+ if (invoiceCreateService.maxMSats != null) {
421
+ if (amountData.amount > invoiceCreateService.maxMSats / 1000n)
422
+ throw new UserError_1.UserError("Amount more than maximum");
423
+ }
424
+ const invoice = await invoiceCreateService.getInvoice(Number(amountData.amount), _abortController.signal);
425
+ return (await this.create(signer, invoice, { ...amountData, exactIn: false }, lps, options, additionalParams, _abortController.signal, {
426
+ feeRatePromise,
427
+ pricePreFetchPromise,
428
+ usdPricePrefetchPromise,
429
+ signDataPrefetchPromise
430
+ }));
431
+ }
432
+ }
433
+ catch (e) {
434
+ _abortController.abort(e);
435
+ throw e;
436
+ }
437
+ }
438
+ /**
439
+ * Returns a newly created Smart chain -> Lightning swap using the HTLC based escrow swap protocol. Pays to
440
+ * an LNURL-pay link. This allows exactIn swaps by requesting the desired fixed amount lightning
441
+ * network invoice from the LNURL service.
442
+ *
443
+ * @param signer Source chain signer address initiating the swap
444
+ * @param lnurl LNURL-pay link of the recipient
445
+ * @param amountData Amount, token and exact input/output data for to swap
446
+ * @param lps An array of intermediaries (LPs) to get the quotes from
447
+ * @param options Optional additional quote options
448
+ * @param additionalParams Optional additional parameters sent to the LP when creating the swap
449
+ * @param abortSignal Abort signal
450
+ */
451
+ async createViaLNURL(signer, lnurl, amountData, lps, options, additionalParams, abortSignal) {
452
+ let successActions = {};
453
+ const _abortController = (0, Utils_1.extendAbortController)(abortSignal);
454
+ const invoiceCreateService = (async () => {
455
+ let payRequest = await this.getLNURLPay(lnurl, _abortController.signal);
456
+ if (options?.comment != null &&
457
+ (payRequest.commentAllowed == null || options.comment.length > payRequest.commentAllowed))
458
+ throw new UserError_1.UserError("Comment not allowed or too long");
459
+ return {
460
+ getInvoice: async (amountSats, abortSignal) => {
461
+ const { invoice, successAction } = await LNURL_1.LNURL.useLNURLPay(payRequest, BigInt(amountSats), options?.comment, this._options.getRequestTimeout, abortSignal);
462
+ if (successAction != null)
463
+ successActions[invoice] = successAction;
464
+ return invoice;
465
+ },
466
+ minMsats: BigInt(payRequest.minSendable),
467
+ maxMsats: BigInt(payRequest.maxSendable),
468
+ url: payRequest.url
469
+ };
470
+ })();
471
+ const quotes = await this.createViaInvoiceCreateService(signer, invoiceCreateService, amountData, lps, options, additionalParams, _abortController.signal);
472
+ _abortController.signal.throwIfAborted();
473
+ const resolved = await invoiceCreateService;
474
+ _abortController.signal.throwIfAborted();
475
+ return quotes.map(value => ({
476
+ quote: value.quote.then(quote => {
477
+ let _successAction;
478
+ const quoteAddress = quote.getOutputAddress();
479
+ if (quoteAddress != null) {
480
+ const successAction = successActions[quoteAddress];
481
+ if (successAction != null)
482
+ _successAction = successAction;
483
+ }
484
+ quote._setLNURLData(resolved.url, _successAction);
485
+ return quote;
486
+ }),
487
+ intermediary: value.intermediary
488
+ }));
489
+ }
490
+ /**
491
+ * @inheritDoc
492
+ */
493
+ async recoverFromSwapDataAndState(init, state, contractVersion, lp) {
494
+ const data = init.data;
495
+ let paymentHash = data.getHTLCHashHint();
496
+ let secret;
497
+ if (state.type === base_1.SwapCommitStateType.PAID) {
498
+ secret = await state.getClaimResult();
499
+ paymentHash = Buffer.from((0, sha2_1.sha256)(Buffer.from(secret, "hex"))).toString("hex");
500
+ }
501
+ const swapInit = {
502
+ pricingInfo: {
503
+ isValid: true,
504
+ satsBaseFee: 0n,
505
+ swapPriceUSatPerToken: 100000000000000n,
506
+ realPriceUSatPerToken: 100000000000000n,
507
+ differencePPM: 0n,
508
+ feePPM: 0n,
509
+ },
510
+ url: lp?.url,
511
+ expiry: 0,
512
+ swapFee: 0n,
513
+ swapFeeBtc: 0n,
514
+ feeRate: "",
515
+ signatureData: undefined,
516
+ data,
517
+ networkFee: 0n,
518
+ networkFeeBtc: 0n,
519
+ confidence: 0,
520
+ pr: paymentHash ?? undefined,
521
+ exactIn: false,
522
+ contractVersion
523
+ };
524
+ const swap = new ToBTCLNSwap_1.ToBTCLNSwap(this, swapInit);
525
+ swap._commitTxId = await init.getInitTxId();
526
+ const blockData = await init.getTxBlock();
527
+ swap.createdAt = blockData.blockTime * 1000;
528
+ swap._setInitiated();
529
+ swap._state = IToBTCSwap_1.ToBTCSwapState.COMMITED;
530
+ await swap._sync(false, false, state);
531
+ await swap._save();
532
+ return swap;
533
+ }
534
+ }
535
+ exports.ToBTCLNWrapper = ToBTCLNWrapper;