@atomiqlabs/sdk 7.0.12 → 8.0.7

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 (364) hide show
  1. package/README.md +45 -29
  2. package/dist/SmartChainAssets.d.ts +11 -3
  3. package/dist/SmartChainAssets.js +7 -3
  4. package/dist/bitcoin/BitcoinRpcWithAddressIndex.d.ts +68 -0
  5. package/dist/bitcoin/BitcoinRpcWithAddressIndex.js +2 -0
  6. package/dist/bitcoin/LightningNetworkApi.d.ts +12 -0
  7. package/dist/bitcoin/LightningNetworkApi.js +2 -0
  8. package/dist/bitcoin/coinselect2/accumulative.d.ts +6 -0
  9. package/dist/bitcoin/coinselect2/accumulative.js +52 -0
  10. package/dist/bitcoin/coinselect2/blackjack.d.ts +6 -0
  11. package/dist/bitcoin/coinselect2/blackjack.js +38 -0
  12. package/dist/bitcoin/coinselect2/index.d.ts +19 -0
  13. package/dist/bitcoin/coinselect2/index.js +69 -0
  14. package/dist/bitcoin/coinselect2/utils.d.ts +71 -0
  15. package/dist/bitcoin/coinselect2/utils.js +123 -0
  16. package/dist/bitcoin/mempool/MempoolApi.d.ts +350 -0
  17. package/dist/bitcoin/mempool/MempoolApi.js +311 -0
  18. package/dist/bitcoin/mempool/MempoolBitcoinBlock.d.ts +44 -0
  19. package/dist/bitcoin/mempool/MempoolBitcoinBlock.js +48 -0
  20. package/dist/bitcoin/mempool/MempoolBitcoinRpc.d.ts +119 -0
  21. package/dist/bitcoin/mempool/MempoolBitcoinRpc.js +361 -0
  22. package/dist/bitcoin/mempool/synchronizer/MempoolBtcRelaySynchronizer.d.ts +22 -0
  23. package/dist/bitcoin/mempool/synchronizer/MempoolBtcRelaySynchronizer.js +105 -0
  24. package/dist/bitcoin/wallet/BitcoinWallet.d.ts +93 -0
  25. package/dist/bitcoin/wallet/BitcoinWallet.js +273 -0
  26. package/dist/bitcoin/wallet/IBitcoinWallet.d.ts +28 -0
  27. package/dist/bitcoin/wallet/IBitcoinWallet.js +20 -0
  28. package/dist/bitcoin/wallet/MinimalBitcoinWalletInterface.d.ts +21 -0
  29. package/dist/bitcoin/wallet/MinimalBitcoinWalletInterface.js +2 -0
  30. package/dist/bitcoin/wallet/MinimalLightningNetworkWalletInterface.d.ts +7 -0
  31. package/dist/bitcoin/wallet/MinimalLightningNetworkWalletInterface.js +2 -0
  32. package/dist/bitcoin/wallet/SingleAddressBitcoinWallet.d.ts +40 -0
  33. package/dist/bitcoin/wallet/SingleAddressBitcoinWallet.js +86 -0
  34. package/dist/enums/FeeType.d.ts +8 -0
  35. package/dist/enums/FeeType.js +12 -0
  36. package/dist/enums/SwapAmountType.d.ts +8 -0
  37. package/dist/enums/SwapAmountType.js +12 -0
  38. package/dist/enums/SwapDirection.d.ts +8 -0
  39. package/dist/enums/SwapDirection.js +12 -0
  40. package/dist/enums/SwapType.d.ts +14 -0
  41. package/dist/enums/SwapType.js +18 -0
  42. package/dist/errors/IntermediaryError.d.ts +9 -0
  43. package/dist/errors/IntermediaryError.js +26 -0
  44. package/dist/errors/PaymentAuthError.d.ts +11 -0
  45. package/dist/errors/PaymentAuthError.js +23 -0
  46. package/dist/errors/RequestError.d.ts +18 -0
  47. package/dist/errors/RequestError.js +46 -0
  48. package/dist/errors/UserError.d.ts +7 -0
  49. package/dist/errors/UserError.js +15 -0
  50. package/dist/events/UnifiedSwapEventListener.d.ts +23 -0
  51. package/dist/events/UnifiedSwapEventListener.js +130 -0
  52. package/dist/http/HttpUtils.d.ts +27 -0
  53. package/dist/http/HttpUtils.js +91 -0
  54. package/dist/http/paramcoders/IParamReader.d.ts +8 -0
  55. package/dist/http/paramcoders/IParamReader.js +2 -0
  56. package/dist/http/paramcoders/ParamDecoder.d.ts +44 -0
  57. package/dist/http/paramcoders/ParamDecoder.js +132 -0
  58. package/dist/http/paramcoders/ParamEncoder.d.ts +20 -0
  59. package/dist/http/paramcoders/ParamEncoder.js +31 -0
  60. package/dist/http/paramcoders/SchemaVerifier.d.ts +26 -0
  61. package/dist/http/paramcoders/SchemaVerifier.js +145 -0
  62. package/dist/http/paramcoders/client/ResponseParamDecoder.d.ts +11 -0
  63. package/dist/http/paramcoders/client/ResponseParamDecoder.js +57 -0
  64. package/dist/http/paramcoders/client/StreamParamEncoder.d.ts +13 -0
  65. package/dist/http/paramcoders/client/StreamParamEncoder.js +26 -0
  66. package/dist/http/paramcoders/client/StreamingFetchPromise.d.ts +16 -0
  67. package/dist/http/paramcoders/client/StreamingFetchPromise.js +174 -0
  68. package/dist/index.d.ts +82 -4
  69. package/dist/index.js +128 -4
  70. package/dist/intermediaries/Intermediary.d.ts +111 -0
  71. package/dist/intermediaries/Intermediary.js +115 -0
  72. package/dist/intermediaries/IntermediaryDiscovery.d.ts +166 -0
  73. package/dist/intermediaries/IntermediaryDiscovery.js +390 -0
  74. package/dist/intermediaries/apis/IntermediaryAPI.d.ts +436 -0
  75. package/dist/intermediaries/apis/IntermediaryAPI.js +600 -0
  76. package/dist/intermediaries/apis/TrustedIntermediaryAPI.d.ts +154 -0
  77. package/dist/intermediaries/apis/TrustedIntermediaryAPI.js +136 -0
  78. package/dist/lnurl/LNURL.d.ts +102 -0
  79. package/dist/lnurl/LNURL.js +321 -0
  80. package/dist/prices/RedundantSwapPrice.d.ts +89 -0
  81. package/dist/prices/RedundantSwapPrice.js +202 -0
  82. package/dist/prices/SingleSwapPrice.d.ts +31 -0
  83. package/dist/prices/SingleSwapPrice.js +41 -0
  84. package/dist/prices/SwapPriceWithChain.d.ts +70 -0
  85. package/dist/prices/SwapPriceWithChain.js +91 -0
  86. package/dist/prices/abstract/ICachedSwapPrice.d.ts +28 -0
  87. package/dist/prices/abstract/ICachedSwapPrice.js +62 -0
  88. package/dist/prices/abstract/IPriceProvider.d.ts +81 -0
  89. package/dist/prices/abstract/IPriceProvider.js +74 -0
  90. package/dist/prices/abstract/ISwapPrice.d.ts +117 -0
  91. package/dist/prices/abstract/ISwapPrice.js +219 -0
  92. package/dist/prices/providers/BinancePriceProvider.d.ts +16 -0
  93. package/dist/prices/providers/BinancePriceProvider.js +23 -0
  94. package/dist/prices/providers/CoinGeckoPriceProvider.d.ts +17 -0
  95. package/dist/prices/providers/CoinGeckoPriceProvider.js +23 -0
  96. package/dist/prices/providers/CoinPaprikaPriceProvider.d.ts +19 -0
  97. package/dist/prices/providers/CoinPaprikaPriceProvider.js +23 -0
  98. package/dist/prices/providers/CustomPriceProvider.d.ts +13 -0
  99. package/dist/prices/providers/CustomPriceProvider.js +24 -0
  100. package/dist/prices/providers/KrakenPriceProvider.d.ts +29 -0
  101. package/dist/prices/providers/KrakenPriceProvider.js +36 -0
  102. package/dist/prices/providers/OKXPriceProvider.d.ts +28 -0
  103. package/dist/prices/providers/OKXPriceProvider.js +23 -0
  104. package/dist/prices/providers/abstract/ExchangePriceProvider.d.ts +14 -0
  105. package/dist/prices/providers/abstract/ExchangePriceProvider.js +18 -0
  106. package/dist/prices/providers/abstract/HttpPriceProvider.d.ts +7 -0
  107. package/dist/prices/providers/abstract/HttpPriceProvider.js +12 -0
  108. package/dist/storage/IUnifiedStorage.d.ts +73 -0
  109. package/dist/storage/IUnifiedStorage.js +2 -0
  110. package/dist/storage/UnifiedSwapStorage.d.ts +82 -0
  111. package/dist/storage/UnifiedSwapStorage.js +83 -0
  112. package/dist/storage-browser/IndexedDBUnifiedStorage.d.ts +39 -0
  113. package/dist/storage-browser/IndexedDBUnifiedStorage.js +275 -0
  114. package/dist/{storage → storage-browser}/LocalStorageManager.d.ts +1 -0
  115. package/dist/{storage → storage-browser}/LocalStorageManager.js +2 -1
  116. package/dist/swapper/Swapper.d.ts +533 -0
  117. package/dist/swapper/Swapper.js +1566 -0
  118. package/dist/swapper/SwapperFactory.d.ts +87 -0
  119. package/dist/{SwapperFactory.js → swapper/SwapperFactory.js} +37 -19
  120. package/dist/swapper/SwapperUtils.d.ts +153 -0
  121. package/dist/swapper/SwapperUtils.js +420 -0
  122. package/dist/swapper/SwapperWithChain.d.ts +214 -0
  123. package/dist/swapper/SwapperWithChain.js +315 -0
  124. package/dist/swapper/SwapperWithSigner.d.ts +178 -0
  125. package/dist/swapper/SwapperWithSigner.js +172 -0
  126. package/dist/swaps/IAddressSwap.d.ts +13 -0
  127. package/dist/swaps/IAddressSwap.js +13 -0
  128. package/dist/swaps/IBTCWalletSwap.d.ts +55 -0
  129. package/dist/swaps/IBTCWalletSwap.js +17 -0
  130. package/dist/swaps/IClaimableSwap.d.ts +17 -0
  131. package/dist/swaps/IClaimableSwap.js +14 -0
  132. package/dist/swaps/IClaimableSwapWrapper.d.ts +5 -0
  133. package/dist/swaps/IClaimableSwapWrapper.js +2 -0
  134. package/dist/swaps/IRefundableSwap.d.ts +17 -0
  135. package/dist/swaps/IRefundableSwap.js +13 -0
  136. package/dist/swaps/ISwap.d.ts +207 -0
  137. package/dist/swaps/ISwap.js +264 -0
  138. package/dist/swaps/ISwapWithGasDrop.d.ts +15 -0
  139. package/dist/swaps/ISwapWithGasDrop.js +11 -0
  140. package/dist/swaps/ISwapWrapper.d.ts +153 -0
  141. package/dist/swaps/ISwapWrapper.js +227 -0
  142. package/dist/swaps/escrow_swaps/IEscrowSelfInitSwap.d.ts +53 -0
  143. package/dist/swaps/escrow_swaps/IEscrowSelfInitSwap.js +116 -0
  144. package/dist/swaps/escrow_swaps/IEscrowSwap.d.ts +70 -0
  145. package/dist/swaps/escrow_swaps/IEscrowSwap.js +132 -0
  146. package/dist/swaps/escrow_swaps/IEscrowSwapWrapper.d.ts +85 -0
  147. package/dist/swaps/escrow_swaps/IEscrowSwapWrapper.js +122 -0
  148. package/dist/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.d.ts +86 -0
  149. package/dist/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.js +115 -0
  150. package/dist/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.d.ts +93 -0
  151. package/dist/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.js +121 -0
  152. package/dist/swaps/escrow_swaps/frombtc/IFromBTCWrapper.d.ts +45 -0
  153. package/dist/swaps/escrow_swaps/frombtc/IFromBTCWrapper.js +65 -0
  154. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.d.ts +263 -0
  155. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.js +933 -0
  156. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.d.ts +110 -0
  157. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.js +307 -0
  158. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.d.ts +236 -0
  159. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.js +898 -0
  160. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.d.ts +125 -0
  161. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.js +393 -0
  162. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.d.ts +245 -0
  163. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.js +841 -0
  164. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.d.ts +120 -0
  165. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.js +294 -0
  166. package/dist/swaps/escrow_swaps/tobtc/IToBTCSwap.d.ts +228 -0
  167. package/dist/swaps/escrow_swaps/tobtc/IToBTCSwap.js +721 -0
  168. package/dist/swaps/escrow_swaps/tobtc/IToBTCWrapper.d.ts +37 -0
  169. package/dist/swaps/escrow_swaps/tobtc/IToBTCWrapper.js +93 -0
  170. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.d.ts +86 -0
  171. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.js +213 -0
  172. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.d.ts +170 -0
  173. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.js +520 -0
  174. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.d.ts +50 -0
  175. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.js +109 -0
  176. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.d.ts +93 -0
  177. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.js +217 -0
  178. package/dist/swaps/spv_swaps/SpvFromBTCSwap.d.ts +315 -0
  179. package/dist/swaps/spv_swaps/SpvFromBTCSwap.js +1098 -0
  180. package/dist/swaps/spv_swaps/SpvFromBTCWrapper.d.ts +125 -0
  181. package/dist/swaps/spv_swaps/SpvFromBTCWrapper.js +631 -0
  182. package/dist/swaps/trusted/ln/LnForGasSwap.d.ts +107 -0
  183. package/dist/swaps/trusted/ln/LnForGasSwap.js +343 -0
  184. package/dist/swaps/trusted/ln/LnForGasWrapper.d.ts +21 -0
  185. package/dist/swaps/trusted/ln/LnForGasWrapper.js +62 -0
  186. package/dist/swaps/trusted/onchain/OnchainForGasSwap.d.ts +164 -0
  187. package/dist/swaps/trusted/onchain/OnchainForGasSwap.js +520 -0
  188. package/dist/swaps/trusted/onchain/OnchainForGasWrapper.d.ts +48 -0
  189. package/dist/swaps/trusted/onchain/OnchainForGasWrapper.js +74 -0
  190. package/dist/types/AmountData.d.ts +9 -0
  191. package/dist/types/AmountData.js +2 -0
  192. package/dist/types/CustomPriceFunction.d.ts +5 -0
  193. package/dist/types/CustomPriceFunction.js +2 -0
  194. package/dist/types/PriceInfoType.d.ts +28 -0
  195. package/dist/types/PriceInfoType.js +57 -0
  196. package/dist/types/SwapExecutionAction.d.ts +7 -0
  197. package/dist/types/SwapExecutionAction.js +2 -0
  198. package/dist/types/SwapWithSigner.d.ts +14 -0
  199. package/dist/types/SwapWithSigner.js +40 -0
  200. package/dist/types/Token.d.ts +53 -0
  201. package/dist/types/Token.js +58 -0
  202. package/dist/types/TokenAmount.d.ts +57 -0
  203. package/dist/types/TokenAmount.js +47 -0
  204. package/dist/types/fees/Fee.d.ts +49 -0
  205. package/dist/types/fees/Fee.js +2 -0
  206. package/dist/types/fees/FeeBreakdown.d.ts +10 -0
  207. package/dist/types/fees/FeeBreakdown.js +2 -0
  208. package/dist/types/fees/PercentagePPM.d.ts +15 -0
  209. package/dist/types/fees/PercentagePPM.js +17 -0
  210. package/dist/types/lnurl/LNURLPay.d.ts +54 -0
  211. package/dist/types/lnurl/LNURLPay.js +28 -0
  212. package/dist/types/lnurl/LNURLWithdraw.d.ts +42 -0
  213. package/dist/types/lnurl/LNURLWithdraw.js +24 -0
  214. package/dist/utils/AutomaticClockDriftCorrection.d.ts +1 -0
  215. package/dist/utils/AutomaticClockDriftCorrection.js +70 -0
  216. package/dist/utils/BitcoinUtils.d.ts +13 -0
  217. package/dist/utils/BitcoinUtils.js +98 -0
  218. package/dist/utils/BitcoinWalletUtils.d.ts +7 -0
  219. package/dist/utils/BitcoinWalletUtils.js +14 -0
  220. package/dist/utils/Logger.d.ts +7 -0
  221. package/dist/utils/Logger.js +12 -0
  222. package/dist/utils/RetryUtils.d.ts +21 -0
  223. package/dist/utils/RetryUtils.js +66 -0
  224. package/dist/utils/SwapUtils.d.ts +31 -0
  225. package/dist/utils/SwapUtils.js +18 -0
  226. package/dist/{Utils.d.ts → utils/TimeoutUtils.d.ts} +9 -3
  227. package/dist/utils/TimeoutUtils.js +55 -0
  228. package/dist/utils/TokenUtils.d.ts +11 -0
  229. package/dist/utils/TokenUtils.js +29 -0
  230. package/dist/utils/TypeUtils.d.ts +7 -0
  231. package/dist/utils/TypeUtils.js +2 -0
  232. package/dist/utils/Utils.d.ts +57 -0
  233. package/dist/utils/Utils.js +178 -0
  234. package/package.json +14 -6
  235. package/src/SmartChainAssets.ts +11 -3
  236. package/src/bitcoin/BitcoinRpcWithAddressIndex.ts +87 -0
  237. package/src/bitcoin/LightningNetworkApi.ts +16 -0
  238. package/src/bitcoin/coinselect2/accumulative.ts +68 -0
  239. package/src/bitcoin/coinselect2/blackjack.ts +49 -0
  240. package/src/bitcoin/coinselect2/index.ts +92 -0
  241. package/src/bitcoin/coinselect2/utils.ts +189 -0
  242. package/src/bitcoin/mempool/MempoolApi.ts +554 -0
  243. package/src/bitcoin/mempool/MempoolBitcoinBlock.ts +88 -0
  244. package/src/bitcoin/mempool/MempoolBitcoinRpc.ts +437 -0
  245. package/src/bitcoin/mempool/synchronizer/MempoolBtcRelaySynchronizer.ts +134 -0
  246. package/src/bitcoin/wallet/BitcoinWallet.ts +375 -0
  247. package/src/bitcoin/wallet/IBitcoinWallet.ts +44 -0
  248. package/src/bitcoin/wallet/MinimalBitcoinWalletInterface.ts +19 -0
  249. package/src/bitcoin/wallet/MinimalLightningNetworkWalletInterface.ts +7 -0
  250. package/src/bitcoin/wallet/SingleAddressBitcoinWallet.ts +108 -0
  251. package/src/enums/FeeType.ts +9 -0
  252. package/src/enums/SwapAmountType.ts +9 -0
  253. package/src/enums/SwapDirection.ts +9 -0
  254. package/src/enums/SwapType.ts +15 -0
  255. package/src/errors/IntermediaryError.ts +24 -0
  256. package/src/errors/PaymentAuthError.ts +26 -0
  257. package/src/errors/RequestError.ts +51 -0
  258. package/src/errors/UserError.ts +14 -0
  259. package/src/events/UnifiedSwapEventListener.ts +171 -0
  260. package/src/http/HttpUtils.ts +92 -0
  261. package/src/http/paramcoders/IParamReader.ts +10 -0
  262. package/src/http/paramcoders/ParamDecoder.ts +142 -0
  263. package/src/http/paramcoders/ParamEncoder.ts +37 -0
  264. package/src/http/paramcoders/SchemaVerifier.ts +153 -0
  265. package/src/http/paramcoders/client/ResponseParamDecoder.ts +58 -0
  266. package/src/http/paramcoders/client/StreamParamEncoder.ts +29 -0
  267. package/src/http/paramcoders/client/StreamingFetchPromise.ts +193 -0
  268. package/src/index.ts +102 -4
  269. package/src/intermediaries/Intermediary.ts +204 -0
  270. package/src/intermediaries/IntermediaryDiscovery.ts +485 -0
  271. package/src/intermediaries/apis/IntermediaryAPI.ts +940 -0
  272. package/src/intermediaries/apis/TrustedIntermediaryAPI.ts +257 -0
  273. package/src/lnurl/LNURL.ts +403 -0
  274. package/src/prices/RedundantSwapPrice.ts +245 -0
  275. package/src/prices/SingleSwapPrice.ts +47 -0
  276. package/src/prices/SwapPriceWithChain.ts +157 -0
  277. package/src/prices/abstract/ICachedSwapPrice.ts +86 -0
  278. package/src/prices/abstract/IPriceProvider.ts +128 -0
  279. package/src/prices/abstract/ISwapPrice.ts +328 -0
  280. package/src/prices/providers/BinancePriceProvider.ts +41 -0
  281. package/src/prices/providers/CoinGeckoPriceProvider.ts +40 -0
  282. package/src/prices/providers/CoinPaprikaPriceProvider.ts +44 -0
  283. package/src/prices/providers/CustomPriceProvider.ts +29 -0
  284. package/src/prices/providers/KrakenPriceProvider.ts +74 -0
  285. package/src/prices/providers/OKXPriceProvider.ts +53 -0
  286. package/src/prices/providers/abstract/ExchangePriceProvider.ts +29 -0
  287. package/src/prices/providers/abstract/HttpPriceProvider.ts +15 -0
  288. package/src/storage/IUnifiedStorage.ts +83 -0
  289. package/src/storage/UnifiedSwapStorage.ts +104 -0
  290. package/src/storage-browser/IndexedDBUnifiedStorage.ts +328 -0
  291. package/src/{storage → storage-browser}/LocalStorageManager.ts +2 -1
  292. package/src/swapper/Swapper.ts +2107 -0
  293. package/src/{SwapperFactory.ts → swapper/SwapperFactory.ts} +113 -72
  294. package/src/swapper/SwapperUtils.ts +510 -0
  295. package/src/swapper/SwapperWithChain.ts +464 -0
  296. package/src/swapper/SwapperWithSigner.ts +300 -0
  297. package/src/swaps/IAddressSwap.ts +20 -0
  298. package/src/swaps/IBTCWalletSwap.ts +77 -0
  299. package/src/swaps/IClaimableSwap.ts +30 -0
  300. package/src/swaps/IClaimableSwapWrapper.ts +9 -0
  301. package/src/swaps/IRefundableSwap.ts +29 -0
  302. package/src/swaps/ISwap.ts +490 -0
  303. package/src/swaps/ISwapWithGasDrop.ts +19 -0
  304. package/src/swaps/ISwapWrapper.ts +344 -0
  305. package/src/swaps/escrow_swaps/IEscrowSelfInitSwap.ts +168 -0
  306. package/src/swaps/escrow_swaps/IEscrowSwap.ts +197 -0
  307. package/src/swaps/escrow_swaps/IEscrowSwapWrapper.ts +210 -0
  308. package/src/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.ts +150 -0
  309. package/src/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.ts +219 -0
  310. package/src/swaps/escrow_swaps/frombtc/IFromBTCWrapper.ts +84 -0
  311. package/src/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.ts +1082 -0
  312. package/src/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.ts +429 -0
  313. package/src/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.ts +1078 -0
  314. package/src/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.ts +549 -0
  315. package/src/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.ts +974 -0
  316. package/src/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.ts +443 -0
  317. package/src/swaps/escrow_swaps/tobtc/IToBTCSwap.ts +860 -0
  318. package/src/swaps/escrow_swaps/tobtc/IToBTCWrapper.ts +104 -0
  319. package/src/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.ts +256 -0
  320. package/src/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.ts +716 -0
  321. package/src/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.ts +151 -0
  322. package/src/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.ts +299 -0
  323. package/src/swaps/spv_swaps/SpvFromBTCSwap.ts +1394 -0
  324. package/src/swaps/spv_swaps/SpvFromBTCWrapper.ts +796 -0
  325. package/src/swaps/trusted/ln/LnForGasSwap.ts +402 -0
  326. package/src/swaps/trusted/ln/LnForGasWrapper.ts +70 -0
  327. package/src/swaps/trusted/onchain/OnchainForGasSwap.ts +633 -0
  328. package/src/swaps/trusted/onchain/OnchainForGasWrapper.ts +110 -0
  329. package/src/types/AmountData.ts +9 -0
  330. package/src/types/CustomPriceFunction.ts +5 -0
  331. package/src/types/PriceInfoType.ts +67 -0
  332. package/src/types/SwapExecutionAction.ts +8 -0
  333. package/src/types/SwapWithSigner.ts +57 -0
  334. package/src/types/Token.ts +90 -0
  335. package/src/types/TokenAmount.ts +110 -0
  336. package/src/types/fees/Fee.ts +55 -0
  337. package/src/types/fees/FeeBreakdown.ts +11 -0
  338. package/src/types/fees/PercentagePPM.ts +24 -0
  339. package/src/types/lnurl/LNURLPay.ts +72 -0
  340. package/src/types/lnurl/LNURLWithdraw.ts +55 -0
  341. package/src/utils/AutomaticClockDriftCorrection.ts +71 -0
  342. package/src/utils/BitcoinUtils.ts +86 -0
  343. package/src/utils/BitcoinWalletUtils.ts +16 -0
  344. package/src/utils/Logger.ts +15 -0
  345. package/src/utils/RetryUtils.ts +71 -0
  346. package/src/utils/SwapUtils.ts +38 -0
  347. package/src/utils/TimeoutUtils.ts +50 -0
  348. package/src/utils/TokenUtils.ts +25 -0
  349. package/src/utils/TypeUtils.ts +9 -0
  350. package/src/utils/Utils.ts +182 -0
  351. package/dist/SwapperFactory.d.ts +0 -52
  352. package/dist/Utils.js +0 -37
  353. package/dist/fs-storage/FileSystemStorageManager.d.ts +0 -15
  354. package/dist/fs-storage/FileSystemStorageManager.js +0 -60
  355. package/dist/fs-storage/index.d.ts +0 -1
  356. package/dist/fs-storage/index.js +0 -17
  357. package/src/SmartChainAssets.js +0 -75
  358. package/src/SwapperFactory.js +0 -120
  359. package/src/Utils.js +0 -37
  360. package/src/Utils.ts +0 -31
  361. package/src/fs-storage/FileSystemStorageManager.ts +0 -71
  362. package/src/fs-storage/index.ts +0 -1
  363. package/src/index.js +0 -21
  364. package/src/storage/LocalStorageManager.js +0 -72
@@ -0,0 +1,933 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FromBTCLNSwap = exports.isFromBTCLNSwapInit = exports.FromBTCLNSwapState = void 0;
4
+ const bolt11_1 = require("@atomiqlabs/bolt11");
5
+ const IFromBTCSelfInitSwap_1 = require("../IFromBTCSelfInitSwap");
6
+ const SwapType_1 = require("../../../../enums/SwapType");
7
+ const base_1 = require("@atomiqlabs/base");
8
+ const buffer_1 = require("buffer");
9
+ const LNURL_1 = require("../../../../lnurl/LNURL");
10
+ const UserError_1 = require("../../../../errors/UserError");
11
+ const IntermediaryAPI_1 = require("../../../../intermediaries/apis/IntermediaryAPI");
12
+ const IntermediaryError_1 = require("../../../../errors/IntermediaryError");
13
+ const Utils_1 = require("../../../../utils/Utils");
14
+ const IEscrowSelfInitSwap_1 = require("../../IEscrowSelfInitSwap");
15
+ const TokenAmount_1 = require("../../../../types/TokenAmount");
16
+ const Token_1 = require("../../../../types/Token");
17
+ const Logger_1 = require("../../../../utils/Logger");
18
+ const TimeoutUtils_1 = require("../../../../utils/TimeoutUtils");
19
+ const LNURLWithdraw_1 = require("../../../../types/lnurl/LNURLWithdraw");
20
+ /**
21
+ * State enum for FromBTCLN swaps
22
+ * @category Swaps
23
+ */
24
+ var FromBTCLNSwapState;
25
+ (function (FromBTCLNSwapState) {
26
+ FromBTCLNSwapState[FromBTCLNSwapState["FAILED"] = -4] = "FAILED";
27
+ FromBTCLNSwapState[FromBTCLNSwapState["QUOTE_EXPIRED"] = -3] = "QUOTE_EXPIRED";
28
+ FromBTCLNSwapState[FromBTCLNSwapState["QUOTE_SOFT_EXPIRED"] = -2] = "QUOTE_SOFT_EXPIRED";
29
+ FromBTCLNSwapState[FromBTCLNSwapState["EXPIRED"] = -1] = "EXPIRED";
30
+ FromBTCLNSwapState[FromBTCLNSwapState["PR_CREATED"] = 0] = "PR_CREATED";
31
+ FromBTCLNSwapState[FromBTCLNSwapState["PR_PAID"] = 1] = "PR_PAID";
32
+ FromBTCLNSwapState[FromBTCLNSwapState["CLAIM_COMMITED"] = 2] = "CLAIM_COMMITED";
33
+ FromBTCLNSwapState[FromBTCLNSwapState["CLAIM_CLAIMED"] = 3] = "CLAIM_CLAIMED";
34
+ })(FromBTCLNSwapState = exports.FromBTCLNSwapState || (exports.FromBTCLNSwapState = {}));
35
+ function isFromBTCLNSwapInit(obj) {
36
+ return typeof obj.pr === "string" &&
37
+ typeof obj.secret === "string" &&
38
+ (obj.lnurl == null || typeof (obj.lnurl) === "string") &&
39
+ (obj.lnurlK1 == null || typeof (obj.lnurlK1) === "string") &&
40
+ (obj.lnurlCallback == null || typeof (obj.lnurlCallback) === "string") &&
41
+ (0, IEscrowSelfInitSwap_1.isIEscrowSelfInitSwapInit)(obj);
42
+ }
43
+ exports.isFromBTCLNSwapInit = isFromBTCLNSwapInit;
44
+ class FromBTCLNSwap extends IFromBTCSelfInitSwap_1.IFromBTCSelfInitSwap {
45
+ getSwapData() {
46
+ return this.data ?? this.initialSwapData;
47
+ }
48
+ constructor(wrapper, initOrObject) {
49
+ if (isFromBTCLNSwapInit(initOrObject) && initOrObject.url != null)
50
+ initOrObject.url += "/frombtcln";
51
+ super(wrapper, initOrObject);
52
+ this.inputToken = Token_1.BitcoinTokens.BTCLN;
53
+ this.TYPE = SwapType_1.SwapType.FROM_BTCLN;
54
+ this.lnurlFailSignal = new AbortController();
55
+ this.prPosted = false;
56
+ if (isFromBTCLNSwapInit(initOrObject)) {
57
+ this.state = FromBTCLNSwapState.PR_CREATED;
58
+ this.pr = initOrObject.pr;
59
+ this.secret = initOrObject.secret;
60
+ this.initialSwapData = initOrObject.initialSwapData;
61
+ this.lnurl = initOrObject.lnurl;
62
+ this.lnurlK1 = initOrObject.lnurlK1;
63
+ this.lnurlCallback = initOrObject.lnurlCallback;
64
+ }
65
+ else {
66
+ this.pr = initOrObject.pr;
67
+ this.secret = initOrObject.secret;
68
+ if (initOrObject.initialSwapData == null) {
69
+ this.initialSwapData = this.data;
70
+ }
71
+ else {
72
+ this.initialSwapData = base_1.SwapData.deserialize(initOrObject.initialSwapData);
73
+ }
74
+ this.lnurl = initOrObject.lnurl;
75
+ this.lnurlK1 = initOrObject.lnurlK1;
76
+ this.lnurlCallback = initOrObject.lnurlCallback;
77
+ this.prPosted = initOrObject.prPosted;
78
+ if (this.state === FromBTCLNSwapState.PR_CREATED && this.data != null) {
79
+ this.initialSwapData = this.data;
80
+ delete this.data;
81
+ }
82
+ }
83
+ this.tryRecomputeSwapPrice();
84
+ this.logger = (0, Logger_1.getLogger)("FromBTCLN(" + this.getIdentifierHashString() + "): ");
85
+ }
86
+ upgradeVersion() {
87
+ if (this.version == null) {
88
+ switch (this.state) {
89
+ case -2:
90
+ this.state = FromBTCLNSwapState.QUOTE_EXPIRED;
91
+ break;
92
+ case -1:
93
+ this.state = FromBTCLNSwapState.FAILED;
94
+ break;
95
+ case 0:
96
+ this.state = FromBTCLNSwapState.PR_CREATED;
97
+ break;
98
+ case 1:
99
+ this.state = FromBTCLNSwapState.PR_PAID;
100
+ break;
101
+ case 2:
102
+ this.state = FromBTCLNSwapState.CLAIM_COMMITED;
103
+ break;
104
+ case 3:
105
+ this.state = FromBTCLNSwapState.CLAIM_CLAIMED;
106
+ break;
107
+ }
108
+ this.version = 1;
109
+ }
110
+ }
111
+ //////////////////////////////
112
+ //// Getters & utils
113
+ getIdentifierHash() {
114
+ const paymentHashBuffer = this.getPaymentHash();
115
+ if (this.randomNonce == null)
116
+ return paymentHashBuffer;
117
+ return buffer_1.Buffer.concat([paymentHashBuffer, buffer_1.Buffer.from(this.randomNonce, "hex")]);
118
+ }
119
+ getPaymentHash() {
120
+ const decodedPR = (0, bolt11_1.decode)(this.pr);
121
+ if (decodedPR.tagsObject.payment_hash == null)
122
+ throw new Error("Swap invoice doesn't contain payment hash field!");
123
+ return buffer_1.Buffer.from(decodedPR.tagsObject.payment_hash, "hex");
124
+ }
125
+ canCommit() {
126
+ return this.state === FromBTCLNSwapState.PR_PAID;
127
+ }
128
+ getInputAddress() {
129
+ return this.lnurl ?? this.pr;
130
+ }
131
+ getInputTxId() {
132
+ return this.getPaymentHash().toString("hex");
133
+ }
134
+ /**
135
+ * Returns the lightning network BOLT11 invoice that needs to be paid as an input to the swap
136
+ */
137
+ getAddress() {
138
+ return this.pr;
139
+ }
140
+ getHyperlink() {
141
+ return "lightning:" + this.pr.toUpperCase();
142
+ }
143
+ /**
144
+ * Returns the timeout time (in UNIX milliseconds) when the swap will definitelly be considered as expired
145
+ * if the LP doesn't make it expired sooner
146
+ */
147
+ getDefinitiveExpiryTime() {
148
+ const decoded = (0, bolt11_1.decode)(this.pr);
149
+ if (decoded.timeExpireDate == null)
150
+ throw new Error("Swap invoice doesn't contain expiry date field!");
151
+ const finalCltvExpiryDelta = decoded.tagsObject.min_final_cltv_expiry ?? 144;
152
+ const finalCltvExpiryDelay = finalCltvExpiryDelta * this.wrapper.options.bitcoinBlocktime * this.wrapper.options.safetyFactor;
153
+ return (decoded.timeExpireDate + finalCltvExpiryDelay) * 1000;
154
+ }
155
+ /**
156
+ * Returns timeout time (in UNIX milliseconds) when the LN invoice will expire
157
+ */
158
+ getTimeoutTime() {
159
+ const decoded = (0, bolt11_1.decode)(this.pr);
160
+ if (decoded.timeExpireDate == null)
161
+ throw new Error("Swap invoice doesn't contain expiry date field!");
162
+ return (decoded.timeExpireDate * 1000);
163
+ }
164
+ /**
165
+ * Returns timeout time (in UNIX milliseconds) when the swap htlc will expire
166
+ */
167
+ getHtlcTimeoutTime() {
168
+ if (this.data == null)
169
+ return -1;
170
+ return Number(this.wrapper.getHtlcTimeout(this.data)) * 1000;
171
+ }
172
+ isFinished() {
173
+ return this.state === FromBTCLNSwapState.CLAIM_CLAIMED || this.state === FromBTCLNSwapState.QUOTE_EXPIRED || this.state === FromBTCLNSwapState.FAILED;
174
+ }
175
+ isClaimable() {
176
+ return this.state === FromBTCLNSwapState.CLAIM_COMMITED;
177
+ }
178
+ isSuccessful() {
179
+ return this.state === FromBTCLNSwapState.CLAIM_CLAIMED;
180
+ }
181
+ isFailed() {
182
+ return this.state === FromBTCLNSwapState.FAILED || this.state === FromBTCLNSwapState.EXPIRED;
183
+ }
184
+ isQuoteExpired() {
185
+ return this.state === FromBTCLNSwapState.QUOTE_EXPIRED;
186
+ }
187
+ isQuoteSoftExpired() {
188
+ return this.state === FromBTCLNSwapState.QUOTE_EXPIRED || this.state === FromBTCLNSwapState.QUOTE_SOFT_EXPIRED;
189
+ }
190
+ _verifyQuoteDefinitelyExpired() {
191
+ if (this.state === FromBTCLNSwapState.PR_CREATED || (this.state === FromBTCLNSwapState.QUOTE_SOFT_EXPIRED && this.signatureData == null)) {
192
+ return Promise.resolve(this.getDefinitiveExpiryTime() < Date.now());
193
+ }
194
+ return super._verifyQuoteDefinitelyExpired();
195
+ }
196
+ verifyQuoteValid() {
197
+ if (this.state === FromBTCLNSwapState.PR_CREATED ||
198
+ (this.state === FromBTCLNSwapState.QUOTE_SOFT_EXPIRED && this.signatureData == null)) {
199
+ return Promise.resolve(this.getTimeoutTime() > Date.now());
200
+ }
201
+ return super.verifyQuoteValid();
202
+ }
203
+ //////////////////////////////
204
+ //// Amounts & fees
205
+ getInputToken() {
206
+ return Token_1.BitcoinTokens.BTCLN;
207
+ }
208
+ getInput() {
209
+ const parsed = (0, bolt11_1.decode)(this.pr);
210
+ if (parsed.millisatoshis == null)
211
+ throw new Error("Swap invoice doesn't contain msat amount field!");
212
+ const amount = (BigInt(parsed.millisatoshis) + 999n) / 1000n;
213
+ return (0, TokenAmount_1.toTokenAmount)(amount, this.inputToken, this.wrapper.prices, this.pricingInfo);
214
+ }
215
+ async getSmartChainNetworkFee() {
216
+ return (0, TokenAmount_1.toTokenAmount)(await this.getCommitAndClaimFee(), this.wrapper.getNativeToken(), this.wrapper.prices, this.pricingInfo);
217
+ }
218
+ async hasEnoughForTxFees() {
219
+ const [balance, feeRate] = await Promise.all([
220
+ this.wrapper.contract.getBalance(this._getInitiator(), this.wrapper.chain.getNativeCurrencyAddress(), false),
221
+ this.feeRate != null ? Promise.resolve(this.feeRate) : this.wrapper.contract.getInitFeeRate(this.getSwapData().getOfferer(), this.getSwapData().getClaimer(), this.getSwapData().getToken(), this.getSwapData().getClaimHash())
222
+ ]);
223
+ const commitFee = await this.wrapper.contract.getCommitFee(this._getInitiator(), this.getSwapData(), feeRate);
224
+ const claimFee = await this.wrapper.contract.getClaimFee(this._getInitiator(), this.getSwapData(), feeRate);
225
+ const totalFee = commitFee + claimFee + this.getSwapData().getTotalDeposit();
226
+ return {
227
+ enoughBalance: balance >= totalFee,
228
+ balance: (0, TokenAmount_1.toTokenAmount)(balance, this.wrapper.getNativeToken(), this.wrapper.prices, this.pricingInfo),
229
+ required: (0, TokenAmount_1.toTokenAmount)(totalFee, this.wrapper.getNativeToken(), this.wrapper.prices, this.pricingInfo)
230
+ };
231
+ }
232
+ //////////////////////////////
233
+ //// Execution
234
+ /**
235
+ * Executes the swap with the provided bitcoin lightning network wallet or LNURL
236
+ *
237
+ * @param dstSigner Signer on the destination network, needs to have the same address as the one specified when
238
+ * quote was created, this is required for legacy swaps because the destination wallet needs to actively claim
239
+ * the swap funds on the destination (this also means you need native token to cover gas costs)
240
+ * @param walletOrLnurlWithdraw Bitcoin lightning wallet to use to pay the lightning network invoice, or an LNURL-withdraw
241
+ * link, wallet is not required and the LN invoice can be paid externally as well (just pass null or undefined here)
242
+ * @param callbacks Callbacks to track the progress of the swap
243
+ * @param options Optional options for the swap like feeRate, AbortSignal, and timeouts/intervals
244
+ */
245
+ async execute(dstSigner, walletOrLnurlWithdraw, callbacks, options) {
246
+ if (this.state === FromBTCLNSwapState.FAILED)
247
+ throw new Error("Swap failed!");
248
+ if (this.state === FromBTCLNSwapState.EXPIRED)
249
+ throw new Error("Swap HTLC expired!");
250
+ if (this.state === FromBTCLNSwapState.QUOTE_EXPIRED || this.state === FromBTCLNSwapState.QUOTE_SOFT_EXPIRED)
251
+ throw new Error("Swap quote expired!");
252
+ if (this.state === FromBTCLNSwapState.CLAIM_CLAIMED)
253
+ throw new Error("Swap already settled!");
254
+ let abortSignal = options?.abortSignal;
255
+ if (this.state === FromBTCLNSwapState.PR_CREATED) {
256
+ if (walletOrLnurlWithdraw != null && this.lnurl == null) {
257
+ if (typeof (walletOrLnurlWithdraw) === "string" || (0, LNURLWithdraw_1.isLNURLWithdraw)(walletOrLnurlWithdraw)) {
258
+ await this.settleWithLNURLWithdraw(walletOrLnurlWithdraw);
259
+ }
260
+ else {
261
+ const paymentPromise = walletOrLnurlWithdraw.payInvoice(this.pr);
262
+ const abortController = new AbortController();
263
+ paymentPromise.catch(e => abortController.abort(e));
264
+ if (options?.abortSignal != null)
265
+ options.abortSignal.addEventListener("abort", () => abortController.abort(options?.abortSignal?.reason));
266
+ abortSignal = abortController.signal;
267
+ }
268
+ }
269
+ const paymentSuccess = await this.waitForPayment(callbacks?.onSourceTransactionReceived, options?.lightningTxCheckIntervalSeconds, abortSignal);
270
+ if (!paymentSuccess)
271
+ throw new Error("Failed to receive lightning network payment");
272
+ }
273
+ if (this.state === FromBTCLNSwapState.PR_PAID || this.state === FromBTCLNSwapState.CLAIM_COMMITED) {
274
+ if (this.canCommitAndClaimInOneShot()) {
275
+ await this.commitAndClaim(dstSigner, options?.abortSignal, undefined, callbacks?.onDestinationCommitSent, callbacks?.onDestinationClaimSent);
276
+ }
277
+ else {
278
+ if (this.state === FromBTCLNSwapState.PR_PAID) {
279
+ await this.commit(dstSigner, options?.abortSignal, undefined, callbacks?.onDestinationCommitSent);
280
+ if (options?.delayBetweenCommitAndClaimSeconds != null)
281
+ await (0, TimeoutUtils_1.timeoutPromise)(options.delayBetweenCommitAndClaimSeconds * 1000, options?.abortSignal);
282
+ }
283
+ if (this.state === FromBTCLNSwapState.CLAIM_COMMITED) {
284
+ await this.claim(dstSigner, options?.abortSignal, callbacks?.onDestinationClaimSent);
285
+ }
286
+ }
287
+ }
288
+ // @ts-ignore
289
+ if (this.state === FromBTCLNSwapState.CLAIM_CLAIMED) {
290
+ if (callbacks?.onSwapSettled != null)
291
+ callbacks.onSwapSettled(this.getOutputTxId());
292
+ }
293
+ }
294
+ async txsExecute(options) {
295
+ if (this.state === FromBTCLNSwapState.PR_CREATED) {
296
+ if (!await this.verifyQuoteValid())
297
+ throw new Error("Quote already expired or close to expiry!");
298
+ return [
299
+ {
300
+ name: "Payment",
301
+ description: "Initiates the swap by paying up the lightning network invoice",
302
+ chain: "LIGHTNING",
303
+ txs: [
304
+ {
305
+ address: this.pr,
306
+ hyperlink: this.getHyperlink()
307
+ }
308
+ ]
309
+ }
310
+ ];
311
+ }
312
+ if (this.state === FromBTCLNSwapState.PR_PAID) {
313
+ if (!await this.verifyQuoteValid())
314
+ throw new Error("Quote already expired or close to expiry!");
315
+ const txsCommit = await this.txsCommit(options?.skipChecks);
316
+ const txsClaim = await this._txsClaim(undefined);
317
+ return [
318
+ {
319
+ name: "Commit",
320
+ description: `Creates the HTLC escrow on the ${this.chainIdentifier} side`,
321
+ chain: this.chainIdentifier,
322
+ txs: txsCommit
323
+ },
324
+ {
325
+ name: "Claim",
326
+ description: `Settles & claims the funds from the HTLC escrow on the ${this.chainIdentifier} side`,
327
+ chain: this.chainIdentifier,
328
+ txs: txsClaim
329
+ },
330
+ ];
331
+ }
332
+ if (this.state === FromBTCLNSwapState.CLAIM_COMMITED) {
333
+ const txsClaim = await this.txsClaim();
334
+ return [
335
+ {
336
+ name: "Claim",
337
+ description: `Settles & claims the funds from the HTLC escrow on the ${this.chainIdentifier} side`,
338
+ chain: this.chainIdentifier,
339
+ txs: txsClaim
340
+ },
341
+ ];
342
+ }
343
+ throw new Error("Invalid swap state to obtain execution txns, required PR_CREATED, PR_PAID or CLAIM_COMMITED");
344
+ }
345
+ //////////////////////////////
346
+ //// Payment
347
+ /**
348
+ * Checks whether the LP received the LN payment and we can continue by committing & claiming the HTLC on-chain
349
+ *
350
+ * @param save If the new swap state should be saved
351
+ */
352
+ async _checkIntermediaryPaymentReceived(save = true) {
353
+ if (this.state === FromBTCLNSwapState.PR_PAID ||
354
+ this.state === FromBTCLNSwapState.CLAIM_COMMITED ||
355
+ this.state === FromBTCLNSwapState.CLAIM_CLAIMED ||
356
+ this.state === FromBTCLNSwapState.FAILED)
357
+ return true;
358
+ if (this.state === FromBTCLNSwapState.QUOTE_EXPIRED || (this.state === FromBTCLNSwapState.QUOTE_SOFT_EXPIRED && this.signatureData != null))
359
+ return false;
360
+ if (this.url == null)
361
+ return false;
362
+ const resp = await IntermediaryAPI_1.IntermediaryAPI.getPaymentAuthorization(this.url, this.getPaymentHash().toString("hex"));
363
+ switch (resp.code) {
364
+ case IntermediaryAPI_1.PaymentAuthorizationResponseCodes.AUTH_DATA:
365
+ const data = new this.wrapper.swapDataDeserializer(resp.data.data);
366
+ try {
367
+ await this.checkIntermediaryReturnedAuthData(this._getInitiator(), data, resp.data);
368
+ this.expiry = await this.wrapper.contract.getInitAuthorizationExpiry(data, resp.data);
369
+ this.state = FromBTCLNSwapState.PR_PAID;
370
+ this.data = data;
371
+ this.signatureData = {
372
+ prefix: resp.data.prefix,
373
+ timeout: resp.data.timeout,
374
+ signature: resp.data.signature
375
+ };
376
+ this.initiated = true;
377
+ if (save)
378
+ await this._saveAndEmit();
379
+ return true;
380
+ }
381
+ catch (e) { }
382
+ return null;
383
+ case IntermediaryAPI_1.PaymentAuthorizationResponseCodes.EXPIRED:
384
+ this.state = FromBTCLNSwapState.QUOTE_EXPIRED;
385
+ this.initiated = true;
386
+ if (save)
387
+ await this._saveAndEmit();
388
+ return false;
389
+ default:
390
+ return null;
391
+ }
392
+ }
393
+ /**
394
+ * Checks the data returned by the intermediary in the payment auth request
395
+ *
396
+ * @param signer Smart chain signer's address initiating the swap
397
+ * @param data Parsed swap data as returned by the intermediary
398
+ * @param signature Signature data as returned by the intermediary
399
+ * @protected
400
+ * @throws {IntermediaryError} If the returned are not valid
401
+ * @throws {SignatureVerificationError} If the returned signature is not valid
402
+ * @throws {Error} If the swap is already committed on-chain
403
+ */
404
+ async checkIntermediaryReturnedAuthData(signer, data, signature) {
405
+ data.setClaimer(signer);
406
+ if (data.getType() !== base_1.ChainSwapType.HTLC)
407
+ throw new IntermediaryError_1.IntermediaryError("Invalid swap type");
408
+ if (!data.isOfferer(this.getSwapData().getOfferer()))
409
+ throw new IntermediaryError_1.IntermediaryError("Invalid offerer used");
410
+ if (!data.isClaimer(this._getInitiator()))
411
+ throw new IntermediaryError_1.IntermediaryError("Invalid claimer used");
412
+ if (!data.isToken(this.getSwapData().getToken()))
413
+ throw new IntermediaryError_1.IntermediaryError("Invalid token used");
414
+ if (data.getSecurityDeposit() > this.getSwapData().getSecurityDeposit())
415
+ throw new IntermediaryError_1.IntermediaryError("Invalid security deposit!");
416
+ if (data.getClaimerBounty() !== 0n)
417
+ throw new IntermediaryError_1.IntermediaryError("Invalid claimer bounty!");
418
+ if (data.getAmount() < this.getSwapData().getAmount())
419
+ throw new IntermediaryError_1.IntermediaryError("Invalid amount received!");
420
+ if (data.getClaimHash() !== this.getSwapData().getClaimHash())
421
+ throw new IntermediaryError_1.IntermediaryError("Invalid payment hash used!");
422
+ if (!data.isDepositToken(this.getSwapData().getDepositToken()))
423
+ throw new IntermediaryError_1.IntermediaryError("Invalid deposit token used!");
424
+ if (data.hasSuccessAction())
425
+ throw new IntermediaryError_1.IntermediaryError("Invalid has success action");
426
+ await Promise.all([
427
+ this.wrapper.contract.isValidInitAuthorization(this._getInitiator(), data, signature, this.feeRate),
428
+ this.wrapper.contract.getCommitStatus(data.getClaimer(), data)
429
+ .then(status => {
430
+ if (status?.type !== base_1.SwapCommitStateType.NOT_COMMITED)
431
+ throw new Error("Swap already committed on-chain!");
432
+ })
433
+ ]);
434
+ }
435
+ /**
436
+ * Waits till an LN payment is received by the intermediary and client can continue commiting & claiming the HTLC
437
+ *
438
+ * @param onPaymentReceived Callback as for when the LP reports having received the ln payment
439
+ * @param abortSignal Abort signal to stop waiting for payment
440
+ * @param checkIntervalSeconds How often to poll the intermediary for answer
441
+ */
442
+ async waitForPayment(onPaymentReceived, checkIntervalSeconds, abortSignal) {
443
+ checkIntervalSeconds ??= 5;
444
+ if (this.state !== FromBTCLNSwapState.PR_CREATED &&
445
+ (this.state !== FromBTCLNSwapState.QUOTE_SOFT_EXPIRED || this.signatureData != null))
446
+ throw new Error("Must be in PR_CREATED state!");
447
+ if (this.url == null)
448
+ throw new Error("LP URL not known, cannot await the payment!");
449
+ const abortController = new AbortController();
450
+ if (abortSignal != null)
451
+ abortSignal.addEventListener("abort", () => abortController.abort(abortSignal.reason));
452
+ let save = false;
453
+ if (this.lnurl != null && this.lnurlK1 != null && this.lnurlCallback != null && !this.prPosted) {
454
+ LNURL_1.LNURL.postInvoiceToLNURLWithdraw({ k1: this.lnurlK1, callback: this.lnurlCallback }, this.pr).catch(e => {
455
+ this.lnurlFailSignal.abort(e);
456
+ });
457
+ this.prPosted = true;
458
+ save ||= true;
459
+ }
460
+ if (!this.initiated) {
461
+ this.initiated = true;
462
+ save ||= true;
463
+ }
464
+ if (save)
465
+ await this._saveAndEmit();
466
+ let lnurlFailListener = () => abortController.abort(this.lnurlFailSignal.signal.reason);
467
+ this.lnurlFailSignal.signal.addEventListener("abort", lnurlFailListener);
468
+ this.lnurlFailSignal.signal.throwIfAborted();
469
+ let resp = { code: IntermediaryAPI_1.PaymentAuthorizationResponseCodes.PENDING, msg: "" };
470
+ while (!abortController.signal.aborted && resp.code === IntermediaryAPI_1.PaymentAuthorizationResponseCodes.PENDING) {
471
+ resp = await IntermediaryAPI_1.IntermediaryAPI.getPaymentAuthorization(this.url, this.getPaymentHash().toString("hex"));
472
+ if (resp.code === IntermediaryAPI_1.PaymentAuthorizationResponseCodes.PENDING)
473
+ await (0, TimeoutUtils_1.timeoutPromise)(checkIntervalSeconds * 1000, abortController.signal);
474
+ }
475
+ this.lnurlFailSignal.signal.removeEventListener("abort", lnurlFailListener);
476
+ abortController.signal.throwIfAborted();
477
+ if (resp.code === IntermediaryAPI_1.PaymentAuthorizationResponseCodes.AUTH_DATA) {
478
+ const sigData = resp.data;
479
+ const swapData = new this.wrapper.swapDataDeserializer(resp.data.data);
480
+ await this.checkIntermediaryReturnedAuthData(this._getInitiator(), swapData, sigData);
481
+ this.expiry = await this.wrapper.contract.getInitAuthorizationExpiry(swapData, sigData);
482
+ if (onPaymentReceived != null)
483
+ onPaymentReceived(this.getInputTxId());
484
+ if (this.state === FromBTCLNSwapState.PR_CREATED || this.state === FromBTCLNSwapState.QUOTE_SOFT_EXPIRED) {
485
+ this.data = swapData;
486
+ this.signatureData = {
487
+ prefix: sigData.prefix,
488
+ timeout: sigData.timeout,
489
+ signature: sigData.signature
490
+ };
491
+ await this._saveAndEmit(FromBTCLNSwapState.PR_PAID);
492
+ }
493
+ return true;
494
+ }
495
+ if (this.state === FromBTCLNSwapState.PR_CREATED || this.state === FromBTCLNSwapState.QUOTE_SOFT_EXPIRED) {
496
+ if (resp.code === IntermediaryAPI_1.PaymentAuthorizationResponseCodes.EXPIRED) {
497
+ await this._saveAndEmit(FromBTCLNSwapState.QUOTE_EXPIRED);
498
+ }
499
+ return false;
500
+ }
501
+ throw new IntermediaryError_1.IntermediaryError("Invalid response from the LP");
502
+ }
503
+ //////////////////////////////
504
+ //// Commit
505
+ /**
506
+ * Commits the swap on-chain, locking the tokens from the intermediary in an HTLC
507
+ *
508
+ * @param _signer Signer to sign the transactions with, must be the same as used in the initialization
509
+ * @param abortSignal Abort signal to stop waiting for the transaction confirmation and abort
510
+ * @param skipChecks Skip checks like making sure init signature is still valid and swap wasn't commited yet
511
+ * (this is handled when swap is created (quoted), if you commit right after quoting, you can use skipChecks=true)
512
+ * @param onBeforeTxSent
513
+ * @throws {Error} If invalid signer is provided that doesn't match the swap data
514
+ */
515
+ async commit(_signer, abortSignal, skipChecks, onBeforeTxSent) {
516
+ const signer = (0, base_1.isAbstractSigner)(_signer) ? _signer : await this.wrapper.chain.wrapSigner(_signer);
517
+ this.checkSigner(signer);
518
+ let txCount = 0;
519
+ const txs = await this.txsCommit(skipChecks);
520
+ const result = await this.wrapper.chain.sendAndConfirm(signer, txs, true, abortSignal, undefined, (txId) => {
521
+ txCount++;
522
+ if (onBeforeTxSent != null && txCount === txs.length)
523
+ onBeforeTxSent(txId);
524
+ return Promise.resolve();
525
+ });
526
+ this.commitTxId = result[result.length - 1];
527
+ if (this.state === FromBTCLNSwapState.PR_PAID || this.state === FromBTCLNSwapState.QUOTE_SOFT_EXPIRED) {
528
+ await this._saveAndEmit(FromBTCLNSwapState.CLAIM_COMMITED);
529
+ }
530
+ return this.commitTxId;
531
+ }
532
+ async waitTillCommited(abortSignal) {
533
+ if (this.state === FromBTCLNSwapState.CLAIM_COMMITED || this.state === FromBTCLNSwapState.CLAIM_CLAIMED)
534
+ return Promise.resolve();
535
+ if (this.state !== FromBTCLNSwapState.PR_PAID && (this.state !== FromBTCLNSwapState.QUOTE_SOFT_EXPIRED && this.signatureData != null))
536
+ throw new Error("Invalid state");
537
+ const abortController = (0, Utils_1.extendAbortController)(abortSignal);
538
+ const result = await Promise.race([
539
+ this.watchdogWaitTillCommited(undefined, abortController.signal),
540
+ this.waitTillState(FromBTCLNSwapState.CLAIM_COMMITED, "gte", abortController.signal).then(() => 0)
541
+ ]);
542
+ abortController.abort();
543
+ if (result === 0)
544
+ this.logger.debug("waitTillCommited(): Resolved from state changed");
545
+ if (result === true)
546
+ this.logger.debug("waitTillCommited(): Resolved from watchdog - commited");
547
+ if (result === false) {
548
+ this.logger.debug("waitTillCommited(): Resolved from watchdog - signature expired");
549
+ if (this.state === FromBTCLNSwapState.PR_PAID ||
550
+ this.state === FromBTCLNSwapState.QUOTE_SOFT_EXPIRED) {
551
+ await this._saveAndEmit(FromBTCLNSwapState.QUOTE_EXPIRED);
552
+ }
553
+ return;
554
+ }
555
+ if (this.state === FromBTCLNSwapState.PR_PAID ||
556
+ this.state === FromBTCLNSwapState.QUOTE_SOFT_EXPIRED) {
557
+ await this._saveAndEmit(FromBTCLNSwapState.CLAIM_COMMITED);
558
+ }
559
+ }
560
+ //////////////////////////////
561
+ //// Claim
562
+ /**
563
+ * Unsafe txs claim getter without state checking!
564
+ *
565
+ * @param _signer
566
+ * @private
567
+ */
568
+ async _txsClaim(_signer) {
569
+ if (this.data == null)
570
+ throw new Error("Unknown data, wrong state?");
571
+ return this.wrapper.contract.txsClaimWithSecret(_signer == null ?
572
+ this._getInitiator() :
573
+ ((0, base_1.isAbstractSigner)(_signer) ? _signer : await this.wrapper.chain.wrapSigner(_signer)), this.data, this.secret, true, true);
574
+ }
575
+ /**
576
+ * Returns transactions required for claiming the HTLC and finishing the swap by revealing the HTLC secret
577
+ * (hash preimage)
578
+ *
579
+ * @param _signer Optional signer address to use for claiming the swap, can also be different from the initializer
580
+ * @throws {Error} If in invalid state (must be CLAIM_COMMITED)
581
+ */
582
+ async txsClaim(_signer) {
583
+ if (this.state !== FromBTCLNSwapState.CLAIM_COMMITED)
584
+ throw new Error("Must be in CLAIM_COMMITED state!");
585
+ return this._txsClaim(_signer);
586
+ }
587
+ /**
588
+ * Claims and finishes the swap
589
+ *
590
+ * @param _signer Signer to sign the transactions with, can also be different to the initializer
591
+ * @param abortSignal Abort signal to stop waiting for transaction confirmation
592
+ * @param onBeforeTxSent
593
+ */
594
+ async claim(_signer, abortSignal, onBeforeTxSent) {
595
+ const signer = (0, base_1.isAbstractSigner)(_signer) ? _signer : await this.wrapper.chain.wrapSigner(_signer);
596
+ let txCount = 0;
597
+ const result = await this.wrapper.chain.sendAndConfirm(signer, await this.txsClaim(), true, abortSignal, undefined, (txId) => {
598
+ txCount++;
599
+ if (onBeforeTxSent != null && txCount === 1)
600
+ onBeforeTxSent(txId);
601
+ return Promise.resolve();
602
+ });
603
+ this.claimTxId = result[0];
604
+ if (this.state === FromBTCLNSwapState.CLAIM_COMMITED || this.state === FromBTCLNSwapState.EXPIRED || this.state === FromBTCLNSwapState.FAILED) {
605
+ await this._saveAndEmit(FromBTCLNSwapState.CLAIM_CLAIMED);
606
+ }
607
+ return result[0];
608
+ }
609
+ /**
610
+ * Waits till the swap is successfully claimed
611
+ *
612
+ * @param maxWaitTimeSeconds Maximum time in seconds to wait for the swap to be settled
613
+ * @param abortSignal AbortSignal
614
+ * @throws {Error} If swap is in invalid state (must be BTC_TX_CONFIRMED)
615
+ * @throws {Error} If the LP refunded sooner than we were able to claim
616
+ * @returns {boolean} whether the swap was claimed in time or not
617
+ */
618
+ async waitTillClaimed(maxWaitTimeSeconds, abortSignal) {
619
+ if (this.state === FromBTCLNSwapState.CLAIM_CLAIMED)
620
+ return Promise.resolve(true);
621
+ if (this.state !== FromBTCLNSwapState.CLAIM_COMMITED)
622
+ throw new Error("Invalid state (not CLAIM_COMMITED)");
623
+ const abortController = new AbortController();
624
+ if (abortSignal != null)
625
+ abortSignal.addEventListener("abort", () => abortController.abort(abortSignal.reason));
626
+ let timedOut = false;
627
+ if (maxWaitTimeSeconds != null) {
628
+ const timeout = setTimeout(() => {
629
+ timedOut = true;
630
+ abortController.abort();
631
+ }, maxWaitTimeSeconds * 1000);
632
+ abortController.signal.addEventListener("abort", () => clearTimeout(timeout));
633
+ }
634
+ let res;
635
+ try {
636
+ res = await Promise.race([
637
+ this.watchdogWaitTillResult(undefined, abortController.signal),
638
+ this.waitTillState(FromBTCLNSwapState.CLAIM_CLAIMED, "eq", abortController.signal).then(() => 0),
639
+ this.waitTillState(FromBTCLNSwapState.EXPIRED, "eq", abortController.signal).then(() => 1),
640
+ ]);
641
+ abortController.abort();
642
+ }
643
+ catch (e) {
644
+ abortController.abort();
645
+ if (timedOut)
646
+ return false;
647
+ throw e;
648
+ }
649
+ if (res === 0) {
650
+ this.logger.debug("waitTillClaimed(): Resolved from state change (CLAIM_CLAIMED)");
651
+ return true;
652
+ }
653
+ if (res === 1) {
654
+ this.logger.debug("waitTillClaimed(): Resolved from state change (EXPIRED)");
655
+ throw new Error("Swap expired during claiming");
656
+ }
657
+ this.logger.debug("waitTillClaimed(): Resolved from watchdog");
658
+ if (res?.type === base_1.SwapCommitStateType.PAID) {
659
+ if (this.state !== FromBTCLNSwapState.CLAIM_CLAIMED) {
660
+ this.claimTxId = await res.getClaimTxId();
661
+ await this._saveAndEmit(FromBTCLNSwapState.CLAIM_CLAIMED);
662
+ }
663
+ }
664
+ if (res?.type === base_1.SwapCommitStateType.NOT_COMMITED || res?.type === base_1.SwapCommitStateType.EXPIRED) {
665
+ if (this.state !== FromBTCLNSwapState.CLAIM_CLAIMED &&
666
+ this.state !== FromBTCLNSwapState.FAILED) {
667
+ if (res.getRefundTxId != null)
668
+ this.refundTxId = await res.getRefundTxId();
669
+ await this._saveAndEmit(FromBTCLNSwapState.FAILED);
670
+ }
671
+ throw new Error("Swap expired while waiting for claim!");
672
+ }
673
+ return true;
674
+ }
675
+ //////////////////////////////
676
+ //// Commit & claim
677
+ /**
678
+ * Estimated transaction fee for commit & claim txs combined
679
+ */
680
+ async getCommitAndClaimFee() {
681
+ const swapContract = this.wrapper.contract;
682
+ const feeRate = this.feeRate ?? await swapContract.getInitFeeRate(this.getSwapData().getOfferer(), this.getSwapData().getClaimer(), this.getSwapData().getToken(), this.getSwapData().getClaimHash());
683
+ const commitFee = await (swapContract.getRawCommitFee != null ?
684
+ swapContract.getRawCommitFee(this._getInitiator(), this.getSwapData(), feeRate) :
685
+ swapContract.getCommitFee(this._getInitiator(), this.getSwapData(), feeRate));
686
+ const claimFee = await (swapContract.getRawClaimFee != null ?
687
+ swapContract.getRawClaimFee(this._getInitiator(), this.getSwapData(), feeRate) :
688
+ swapContract.getClaimFee(this._getInitiator(), this.getSwapData(), feeRate));
689
+ return commitFee + claimFee;
690
+ }
691
+ canCommitAndClaimInOneShot() {
692
+ return this.wrapper.contract.initAndClaimWithSecret != null;
693
+ }
694
+ /**
695
+ * Returns transactions for both commit & claim operation together, such that they can be signed all at once by
696
+ * the wallet. CAUTION: transactions must be sent sequentially, such that the claim (2nd) transaction is only
697
+ * sent after the commit (1st) transaction confirms. Failure to do so can reveal the HTLC pre-image too soon,
698
+ * opening a possibility for the LP to steal funds.
699
+ *
700
+ * @param skipChecks Skip checks like making sure init signature is still valid and swap wasn't commited yet
701
+ * (this is handled when swap is created (quoted), if you commit right after quoting, you can use skipChecks=true)
702
+ *
703
+ * @throws {Error} If in invalid state (must be PR_PAID or CLAIM_COMMITED)
704
+ */
705
+ async txsCommitAndClaim(skipChecks) {
706
+ if (this.state === FromBTCLNSwapState.CLAIM_COMMITED)
707
+ return await this.txsClaim();
708
+ if (this.state !== FromBTCLNSwapState.PR_PAID &&
709
+ (this.state !== FromBTCLNSwapState.QUOTE_SOFT_EXPIRED || this.signatureData == null))
710
+ throw new Error("Must be in PR_PAID state!");
711
+ if (this.data == null)
712
+ throw new Error("Unknown data, wrong state?");
713
+ const initTxs = await this.txsCommit(skipChecks);
714
+ const claimTxs = await this.wrapper.contract.txsClaimWithSecret(this._getInitiator(), this.data, this.secret, true, true, undefined, true);
715
+ return initTxs.concat(claimTxs);
716
+ }
717
+ /**
718
+ * Commits and claims the swap, in a way that the transactions can be signed together by the underlying provider and
719
+ * then sent sequentially
720
+ *
721
+ * @param _signer Signer to sign the transactions with, must be the same as used in the initialization
722
+ * @param abortSignal Abort signal to stop waiting for the transaction confirmation and abort
723
+ * @param skipChecks Skip checks like making sure init signature is still valid and swap wasn't commited yet
724
+ * (this is handled when swap is created (quoted), if you commit right after quoting, you can use skipChecks=true)
725
+ * @param onBeforeCommitTxSent
726
+ * @param onBeforeClaimTxSent
727
+ * @throws {Error} If in invalid state (must be PR_PAID or CLAIM_COMMITED)
728
+ * @throws {Error} If invalid signer is provided that doesn't match the swap data
729
+ */
730
+ async commitAndClaim(_signer, abortSignal, skipChecks, onBeforeCommitTxSent, onBeforeClaimTxSent) {
731
+ const signer = (0, base_1.isAbstractSigner)(_signer) ? _signer : await this.wrapper.chain.wrapSigner(_signer);
732
+ if (!this.canCommitAndClaimInOneShot())
733
+ throw new Error("Cannot commitAndClaim in single action, please run commit and claim separately!");
734
+ this.checkSigner(signer);
735
+ if (this.state === FromBTCLNSwapState.CLAIM_COMMITED)
736
+ return [await this.claim(signer, abortSignal, onBeforeClaimTxSent)];
737
+ let txCount = 0;
738
+ const txs = await this.txsCommitAndClaim(skipChecks);
739
+ const result = await this.wrapper.chain.sendAndConfirm(signer, txs, true, abortSignal, undefined, (txId) => {
740
+ txCount++;
741
+ if (onBeforeCommitTxSent != null && txCount === 1)
742
+ onBeforeCommitTxSent(txId);
743
+ if (onBeforeClaimTxSent != null && txCount === txs.length)
744
+ onBeforeClaimTxSent(txId);
745
+ return Promise.resolve();
746
+ });
747
+ this.commitTxId = result[0] ?? this.commitTxId;
748
+ this.claimTxId = result[result.length - 1] ?? this.claimTxId;
749
+ if (this.state !== FromBTCLNSwapState.CLAIM_CLAIMED) {
750
+ await this._saveAndEmit(FromBTCLNSwapState.CLAIM_CLAIMED);
751
+ }
752
+ return result;
753
+ }
754
+ //////////////////////////////
755
+ //// LNURL
756
+ /**
757
+ * Is this an LNURL-withdraw swap?
758
+ */
759
+ isLNURL() {
760
+ return this.lnurl != null;
761
+ }
762
+ /**
763
+ * Gets the used LNURL or null if this is not an LNURL-withdraw swap
764
+ */
765
+ getLNURL() {
766
+ return this.lnurl ?? null;
767
+ }
768
+ /**
769
+ * Pay the generated lightning network invoice with LNURL-withdraw
770
+ */
771
+ async settleWithLNURLWithdraw(lnurl) {
772
+ if (this.lnurl != null)
773
+ throw new Error("Cannot settle LNURL-withdraw swap with different LNURL");
774
+ let lnurlParams;
775
+ if (typeof (lnurl) === "string") {
776
+ const parsedLNURL = await LNURL_1.LNURL.getLNURL(lnurl);
777
+ if (parsedLNURL == null || parsedLNURL.tag !== "withdrawRequest")
778
+ throw new UserError_1.UserError("Invalid LNURL-withdraw to settle the swap");
779
+ lnurlParams = parsedLNURL;
780
+ }
781
+ else {
782
+ lnurlParams = lnurl.params;
783
+ }
784
+ LNURL_1.LNURL.useLNURLWithdraw(lnurlParams, this.pr).catch(e => this.lnurlFailSignal.abort(e));
785
+ this.lnurl = lnurlParams.url;
786
+ this.lnurlCallback = lnurlParams.callback;
787
+ this.lnurlK1 = lnurlParams.k1;
788
+ this.prPosted = true;
789
+ await this._saveAndEmit();
790
+ }
791
+ //////////////////////////////
792
+ //// Storage
793
+ serialize() {
794
+ return {
795
+ ...super.serialize(),
796
+ pr: this.pr,
797
+ secret: this.secret,
798
+ lnurl: this.lnurl,
799
+ lnurlK1: this.lnurlK1,
800
+ lnurlCallback: this.lnurlCallback,
801
+ prPosted: this.prPosted,
802
+ initialSwapData: this.initialSwapData.serialize()
803
+ };
804
+ }
805
+ //////////////////////////////
806
+ //// Swap ticks & sync
807
+ /**
808
+ * Checks the swap's state on-chain and compares it to its internal state, updates/changes it according to on-chain
809
+ * data
810
+ *
811
+ * @private
812
+ */
813
+ async syncStateFromChain(quoteDefinitelyExpired, commitStatus) {
814
+ //Check for expiry before the getCommitStatus to prevent race conditions
815
+ let quoteExpired = false;
816
+ if (this.state === FromBTCLNSwapState.PR_PAID || (this.state === FromBTCLNSwapState.QUOTE_SOFT_EXPIRED && this.signatureData != null)) {
817
+ quoteExpired = quoteDefinitelyExpired ?? await this._verifyQuoteDefinitelyExpired();
818
+ }
819
+ if (this.state === FromBTCLNSwapState.CLAIM_COMMITED || this.state === FromBTCLNSwapState.EXPIRED) {
820
+ //Check if it's already successfully paid
821
+ commitStatus ??= await this.wrapper.contract.getCommitStatus(this._getInitiator(), this.data);
822
+ if (commitStatus?.type === base_1.SwapCommitStateType.PAID) {
823
+ if (this.claimTxId == null)
824
+ this.claimTxId = await commitStatus.getClaimTxId();
825
+ this.state = FromBTCLNSwapState.CLAIM_CLAIMED;
826
+ return true;
827
+ }
828
+ if (commitStatus?.type === base_1.SwapCommitStateType.NOT_COMMITED || commitStatus?.type === base_1.SwapCommitStateType.EXPIRED) {
829
+ if (this.refundTxId == null && commitStatus.getRefundTxId)
830
+ this.refundTxId = await commitStatus.getRefundTxId();
831
+ this.state = FromBTCLNSwapState.FAILED;
832
+ return true;
833
+ }
834
+ }
835
+ if (this.state === FromBTCLNSwapState.PR_PAID || (this.state === FromBTCLNSwapState.QUOTE_SOFT_EXPIRED && this.signatureData != null)) {
836
+ //Check if it's already committed
837
+ commitStatus ??= await this.wrapper.contract.getCommitStatus(this._getInitiator(), this.data);
838
+ switch (commitStatus?.type) {
839
+ case base_1.SwapCommitStateType.COMMITED:
840
+ this.state = FromBTCLNSwapState.CLAIM_COMMITED;
841
+ return true;
842
+ case base_1.SwapCommitStateType.EXPIRED:
843
+ if (this.refundTxId == null && commitStatus.getRefundTxId)
844
+ this.refundTxId = await commitStatus.getRefundTxId();
845
+ this.state = FromBTCLNSwapState.QUOTE_EXPIRED;
846
+ return true;
847
+ case base_1.SwapCommitStateType.PAID:
848
+ if (this.claimTxId == null && commitStatus.getClaimTxId)
849
+ this.claimTxId = await commitStatus.getClaimTxId();
850
+ this.state = FromBTCLNSwapState.CLAIM_CLAIMED;
851
+ return true;
852
+ }
853
+ }
854
+ //Set the state on expiry here
855
+ if (this.state === FromBTCLNSwapState.PR_PAID || (this.state === FromBTCLNSwapState.QUOTE_SOFT_EXPIRED && this.signatureData != null)) {
856
+ if (quoteExpired) {
857
+ this.state = FromBTCLNSwapState.QUOTE_EXPIRED;
858
+ return true;
859
+ }
860
+ }
861
+ return false;
862
+ }
863
+ _shouldFetchExpiryStatus() {
864
+ return this.state === FromBTCLNSwapState.PR_PAID || (this.state === FromBTCLNSwapState.QUOTE_SOFT_EXPIRED && this.signatureData != null);
865
+ }
866
+ _shouldFetchCommitStatus() {
867
+ return this.state === FromBTCLNSwapState.PR_PAID || (this.state === FromBTCLNSwapState.QUOTE_SOFT_EXPIRED && this.signatureData != null) ||
868
+ this.state === FromBTCLNSwapState.CLAIM_COMMITED || this.state === FromBTCLNSwapState.EXPIRED;
869
+ }
870
+ _shouldCheckIntermediary() {
871
+ return this.state === FromBTCLNSwapState.PR_CREATED || (this.state === FromBTCLNSwapState.QUOTE_SOFT_EXPIRED && this.signatureData == null);
872
+ }
873
+ async _sync(save, quoteDefinitelyExpired, commitStatus, skipLpCheck) {
874
+ let changed = false;
875
+ if (this.state === FromBTCLNSwapState.PR_CREATED || (this.state === FromBTCLNSwapState.QUOTE_SOFT_EXPIRED && this.signatureData == null)) {
876
+ if (this.state != FromBTCLNSwapState.QUOTE_SOFT_EXPIRED && this.getTimeoutTime() < Date.now()) {
877
+ this.state = FromBTCLNSwapState.QUOTE_SOFT_EXPIRED;
878
+ changed ||= true;
879
+ }
880
+ if (!skipLpCheck)
881
+ try {
882
+ const result = await this._checkIntermediaryPaymentReceived(false);
883
+ if (result !== null)
884
+ changed ||= true;
885
+ }
886
+ catch (e) {
887
+ this.logger.error("_sync(): Failed to synchronize swap, error: ", e);
888
+ }
889
+ if (this.state === FromBTCLNSwapState.PR_CREATED || (this.state === FromBTCLNSwapState.QUOTE_SOFT_EXPIRED && this.signatureData == null)) {
890
+ if (await this._verifyQuoteDefinitelyExpired()) {
891
+ this.state = FromBTCLNSwapState.QUOTE_EXPIRED;
892
+ changed ||= true;
893
+ }
894
+ }
895
+ }
896
+ if (await this.syncStateFromChain(quoteDefinitelyExpired, commitStatus))
897
+ changed = true;
898
+ if (save && changed)
899
+ await this._saveAndEmit();
900
+ return changed;
901
+ }
902
+ async _tick(save) {
903
+ switch (this.state) {
904
+ case FromBTCLNSwapState.PR_CREATED:
905
+ if (this.getTimeoutTime() < Date.now()) {
906
+ this.state = FromBTCLNSwapState.QUOTE_SOFT_EXPIRED;
907
+ if (save)
908
+ await this._saveAndEmit();
909
+ return true;
910
+ }
911
+ break;
912
+ case FromBTCLNSwapState.PR_PAID:
913
+ if (this.expiry < Date.now()) {
914
+ this.state = FromBTCLNSwapState.QUOTE_SOFT_EXPIRED;
915
+ if (save)
916
+ await this._saveAndEmit();
917
+ return true;
918
+ }
919
+ break;
920
+ case FromBTCLNSwapState.CLAIM_COMMITED:
921
+ const expired = await this.wrapper.contract.isExpired(this._getInitiator(), this.data);
922
+ if (expired) {
923
+ this.state = FromBTCLNSwapState.EXPIRED;
924
+ if (save)
925
+ await this._saveAndEmit();
926
+ return true;
927
+ }
928
+ break;
929
+ }
930
+ return false;
931
+ }
932
+ }
933
+ exports.FromBTCLNSwap = FromBTCLNSwap;