@atomiqlabs/sdk 8.7.7 → 8.8.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (339) hide show
  1. package/LICENSE +201 -201
  2. package/README.md +1760 -1760
  3. package/dist/SmartChainAssets.d.ts +181 -181
  4. package/dist/SmartChainAssets.js +181 -181
  5. package/dist/bitcoin/coinselect2/accumulative.d.ts +7 -6
  6. package/dist/bitcoin/coinselect2/accumulative.js +52 -52
  7. package/dist/bitcoin/coinselect2/blackjack.d.ts +7 -6
  8. package/dist/bitcoin/coinselect2/blackjack.js +38 -38
  9. package/dist/bitcoin/coinselect2/index.d.ts +20 -19
  10. package/dist/bitcoin/coinselect2/index.js +69 -69
  11. package/dist/bitcoin/coinselect2/utils.d.ts +82 -77
  12. package/dist/bitcoin/coinselect2/utils.js +158 -123
  13. package/dist/bitcoin/wallet/BitcoinWallet.d.ts +113 -130
  14. package/dist/bitcoin/wallet/BitcoinWallet.js +335 -322
  15. package/dist/bitcoin/wallet/IBitcoinWallet.d.ts +116 -78
  16. package/dist/bitcoin/wallet/IBitcoinWallet.js +21 -21
  17. package/dist/bitcoin/wallet/SingleAddressBitcoinWallet.d.ts +106 -101
  18. package/dist/bitcoin/wallet/SingleAddressBitcoinWallet.js +196 -190
  19. package/dist/enums/FeeType.d.ts +15 -15
  20. package/dist/enums/FeeType.js +19 -19
  21. package/dist/enums/SwapAmountType.d.ts +15 -15
  22. package/dist/enums/SwapAmountType.js +19 -19
  23. package/dist/enums/SwapDirection.d.ts +15 -15
  24. package/dist/enums/SwapDirection.js +19 -19
  25. package/dist/enums/SwapSide.d.ts +15 -15
  26. package/dist/enums/SwapSide.js +19 -19
  27. package/dist/enums/SwapType.d.ts +75 -75
  28. package/dist/enums/SwapType.js +79 -79
  29. package/dist/errors/IntermediaryError.d.ts +13 -13
  30. package/dist/errors/IntermediaryError.js +27 -27
  31. package/dist/errors/RequestError.d.ts +32 -32
  32. package/dist/errors/RequestError.js +54 -54
  33. package/dist/errors/UserError.d.ts +8 -8
  34. package/dist/errors/UserError.js +16 -16
  35. package/dist/events/UnifiedSwapEventListener.d.ts +23 -23
  36. package/dist/events/UnifiedSwapEventListener.js +132 -132
  37. package/dist/http/HttpUtils.d.ts +27 -27
  38. package/dist/http/HttpUtils.js +91 -91
  39. package/dist/http/paramcoders/IParamReader.d.ts +8 -8
  40. package/dist/http/paramcoders/IParamReader.js +2 -2
  41. package/dist/http/paramcoders/ParamDecoder.d.ts +44 -44
  42. package/dist/http/paramcoders/ParamDecoder.js +137 -137
  43. package/dist/http/paramcoders/ParamEncoder.d.ts +20 -20
  44. package/dist/http/paramcoders/ParamEncoder.js +36 -36
  45. package/dist/http/paramcoders/SchemaVerifier.d.ts +26 -26
  46. package/dist/http/paramcoders/SchemaVerifier.js +145 -145
  47. package/dist/http/paramcoders/client/ResponseParamDecoder.d.ts +11 -11
  48. package/dist/http/paramcoders/client/ResponseParamDecoder.js +57 -57
  49. package/dist/http/paramcoders/client/StreamParamEncoder.d.ts +13 -13
  50. package/dist/http/paramcoders/client/StreamParamEncoder.js +26 -26
  51. package/dist/http/paramcoders/client/StreamingFetchPromise.d.ts +16 -16
  52. package/dist/http/paramcoders/client/StreamingFetchPromise.js +174 -174
  53. package/dist/index.d.ts +85 -85
  54. package/dist/index.js +158 -158
  55. package/dist/intermediaries/Intermediary.d.ts +178 -178
  56. package/dist/intermediaries/Intermediary.js +166 -166
  57. package/dist/intermediaries/IntermediaryDiscovery.d.ts +211 -211
  58. package/dist/intermediaries/IntermediaryDiscovery.js +424 -424
  59. package/dist/intermediaries/apis/IntermediaryAPI.d.ts +450 -440
  60. package/dist/intermediaries/apis/IntermediaryAPI.js +618 -603
  61. package/dist/intermediaries/apis/TrustedIntermediaryAPI.d.ts +155 -155
  62. package/dist/intermediaries/apis/TrustedIntermediaryAPI.js +137 -137
  63. package/dist/lnurl/LNURL.d.ts +102 -102
  64. package/dist/lnurl/LNURL.js +321 -321
  65. package/dist/prices/RedundantSwapPrice.d.ts +110 -110
  66. package/dist/prices/RedundantSwapPrice.js +222 -222
  67. package/dist/prices/SingleSwapPrice.d.ts +34 -34
  68. package/dist/prices/SingleSwapPrice.js +44 -44
  69. package/dist/prices/SwapPriceWithChain.d.ts +107 -107
  70. package/dist/prices/SwapPriceWithChain.js +128 -128
  71. package/dist/prices/abstract/ICachedSwapPrice.d.ts +28 -28
  72. package/dist/prices/abstract/ICachedSwapPrice.js +62 -62
  73. package/dist/prices/abstract/IPriceProvider.d.ts +81 -81
  74. package/dist/prices/abstract/IPriceProvider.js +74 -74
  75. package/dist/prices/abstract/ISwapPrice.d.ts +168 -168
  76. package/dist/prices/abstract/ISwapPrice.js +279 -279
  77. package/dist/prices/providers/BinancePriceProvider.d.ts +23 -23
  78. package/dist/prices/providers/BinancePriceProvider.js +30 -30
  79. package/dist/prices/providers/CoinGeckoPriceProvider.d.ts +23 -23
  80. package/dist/prices/providers/CoinGeckoPriceProvider.js +29 -29
  81. package/dist/prices/providers/CoinPaprikaPriceProvider.d.ts +25 -25
  82. package/dist/prices/providers/CoinPaprikaPriceProvider.js +29 -29
  83. package/dist/prices/providers/CustomPriceProvider.d.ts +24 -24
  84. package/dist/prices/providers/CustomPriceProvider.js +35 -35
  85. package/dist/prices/providers/KrakenPriceProvider.d.ts +38 -38
  86. package/dist/prices/providers/KrakenPriceProvider.js +45 -45
  87. package/dist/prices/providers/OKXPriceProvider.d.ts +34 -34
  88. package/dist/prices/providers/OKXPriceProvider.js +29 -29
  89. package/dist/prices/providers/abstract/ExchangePriceProvider.d.ts +17 -17
  90. package/dist/prices/providers/abstract/ExchangePriceProvider.js +21 -21
  91. package/dist/prices/providers/abstract/HttpPriceProvider.d.ts +7 -7
  92. package/dist/prices/providers/abstract/HttpPriceProvider.js +12 -12
  93. package/dist/storage/IUnifiedStorage.d.ts +85 -85
  94. package/dist/storage/IUnifiedStorage.js +2 -2
  95. package/dist/storage/UnifiedSwapStorage.d.ts +114 -114
  96. package/dist/storage/UnifiedSwapStorage.js +116 -116
  97. package/dist/storage-browser/IndexedDBUnifiedStorage.d.ts +63 -63
  98. package/dist/storage-browser/IndexedDBUnifiedStorage.js +298 -298
  99. package/dist/storage-browser/LocalStorageManager.d.ts +49 -49
  100. package/dist/storage-browser/LocalStorageManager.js +93 -93
  101. package/dist/swapper/Swapper.d.ts +732 -692
  102. package/dist/swapper/Swapper.js +1713 -1657
  103. package/dist/swapper/SwapperFactory.d.ts +135 -135
  104. package/dist/swapper/SwapperFactory.js +162 -162
  105. package/dist/swapper/SwapperUtils.d.ts +206 -206
  106. package/dist/swapper/SwapperUtils.js +481 -481
  107. package/dist/swapper/SwapperWithChain.d.ts +404 -404
  108. package/dist/swapper/SwapperWithChain.js +469 -469
  109. package/dist/swapper/SwapperWithSigner.d.ts +322 -322
  110. package/dist/swapper/SwapperWithSigner.js +318 -318
  111. package/dist/swaps/IAddressSwap.d.ts +22 -22
  112. package/dist/swaps/IAddressSwap.js +14 -14
  113. package/dist/swaps/IBTCWalletSwap.d.ts +73 -73
  114. package/dist/swaps/IBTCWalletSwap.js +18 -18
  115. package/dist/swaps/IClaimableSwap.d.ts +49 -49
  116. package/dist/swaps/IClaimableSwap.js +15 -15
  117. package/dist/swaps/IClaimableSwapWrapper.d.ts +15 -15
  118. package/dist/swaps/IClaimableSwapWrapper.js +2 -2
  119. package/dist/swaps/IRefundableSwap.d.ts +43 -43
  120. package/dist/swaps/IRefundableSwap.js +14 -14
  121. package/dist/swaps/ISwap.d.ts +392 -392
  122. package/dist/swaps/ISwap.js +349 -349
  123. package/dist/swaps/ISwapWithGasDrop.d.ts +21 -21
  124. package/dist/swaps/ISwapWithGasDrop.js +12 -12
  125. package/dist/swaps/ISwapWrapper.d.ts +285 -285
  126. package/dist/swaps/ISwapWrapper.js +353 -353
  127. package/dist/swaps/escrow_swaps/IEscrowSelfInitSwap.d.ts +98 -98
  128. package/dist/swaps/escrow_swaps/IEscrowSelfInitSwap.js +126 -126
  129. package/dist/swaps/escrow_swaps/IEscrowSwap.d.ts +139 -139
  130. package/dist/swaps/escrow_swaps/IEscrowSwap.js +170 -170
  131. package/dist/swaps/escrow_swaps/IEscrowSwapWrapper.d.ts +128 -128
  132. package/dist/swaps/escrow_swaps/IEscrowSwapWrapper.js +167 -167
  133. package/dist/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.d.ts +105 -105
  134. package/dist/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.js +129 -129
  135. package/dist/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.d.ts +162 -162
  136. package/dist/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.js +190 -190
  137. package/dist/swaps/escrow_swaps/frombtc/IFromBTCWrapper.d.ts +64 -64
  138. package/dist/swaps/escrow_swaps/frombtc/IFromBTCWrapper.js +82 -82
  139. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.d.ts +531 -531
  140. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.js +1285 -1285
  141. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.d.ts +190 -190
  142. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.js +432 -432
  143. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.d.ts +583 -583
  144. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.js +1371 -1371
  145. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.d.ts +235 -235
  146. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.js +525 -525
  147. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.d.ts +458 -458
  148. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.js +1126 -1126
  149. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.d.ts +202 -202
  150. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.js +406 -406
  151. package/dist/swaps/escrow_swaps/tobtc/IToBTCSwap.d.ts +403 -403
  152. package/dist/swaps/escrow_swaps/tobtc/IToBTCSwap.js +924 -924
  153. package/dist/swaps/escrow_swaps/tobtc/IToBTCWrapper.d.ts +68 -68
  154. package/dist/swaps/escrow_swaps/tobtc/IToBTCWrapper.js +117 -117
  155. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.d.ts +127 -127
  156. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.js +256 -256
  157. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.d.ts +251 -251
  158. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.js +536 -536
  159. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.d.ts +73 -73
  160. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.js +155 -155
  161. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.d.ts +132 -132
  162. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.js +286 -286
  163. package/dist/swaps/spv_swaps/SpvFromBTCSwap.d.ts +637 -631
  164. package/dist/swaps/spv_swaps/SpvFromBTCSwap.js +1448 -1444
  165. package/dist/swaps/spv_swaps/SpvFromBTCWrapper.d.ts +257 -225
  166. package/dist/swaps/spv_swaps/SpvFromBTCWrapper.js +947 -822
  167. package/dist/swaps/trusted/ln/LnForGasSwap.d.ts +261 -261
  168. package/dist/swaps/trusted/ln/LnForGasSwap.js +511 -511
  169. package/dist/swaps/trusted/ln/LnForGasWrapper.d.ts +40 -40
  170. package/dist/swaps/trusted/ln/LnForGasWrapper.js +83 -83
  171. package/dist/swaps/trusted/onchain/OnchainForGasSwap.d.ts +342 -342
  172. package/dist/swaps/trusted/onchain/OnchainForGasSwap.js +715 -715
  173. package/dist/swaps/trusted/onchain/OnchainForGasWrapper.d.ts +69 -69
  174. package/dist/swaps/trusted/onchain/OnchainForGasWrapper.js +93 -93
  175. package/dist/types/AmountData.d.ts +10 -10
  176. package/dist/types/AmountData.js +2 -2
  177. package/dist/types/CustomPriceFunction.d.ts +11 -11
  178. package/dist/types/CustomPriceFunction.js +2 -2
  179. package/dist/types/PriceInfoType.d.ts +28 -28
  180. package/dist/types/PriceInfoType.js +57 -57
  181. package/dist/types/SwapExecutionAction.d.ts +88 -88
  182. package/dist/types/SwapExecutionAction.js +2 -2
  183. package/dist/types/SwapStateInfo.d.ts +5 -5
  184. package/dist/types/SwapStateInfo.js +2 -2
  185. package/dist/types/SwapWithSigner.d.ts +17 -17
  186. package/dist/types/SwapWithSigner.js +43 -43
  187. package/dist/types/Token.d.ts +99 -99
  188. package/dist/types/Token.js +76 -76
  189. package/dist/types/TokenAmount.d.ts +69 -69
  190. package/dist/types/TokenAmount.js +60 -60
  191. package/dist/types/fees/Fee.d.ts +50 -50
  192. package/dist/types/fees/Fee.js +2 -2
  193. package/dist/types/fees/FeeBreakdown.d.ts +11 -11
  194. package/dist/types/fees/FeeBreakdown.js +2 -2
  195. package/dist/types/fees/PercentagePPM.d.ts +17 -17
  196. package/dist/types/fees/PercentagePPM.js +18 -18
  197. package/dist/types/lnurl/LNURLPay.d.ts +61 -61
  198. package/dist/types/lnurl/LNURLPay.js +31 -31
  199. package/dist/types/lnurl/LNURLWithdraw.d.ts +48 -48
  200. package/dist/types/lnurl/LNURLWithdraw.js +27 -27
  201. package/dist/types/wallets/LightningInvoiceCreateService.d.ts +24 -24
  202. package/dist/types/wallets/LightningInvoiceCreateService.js +15 -15
  203. package/dist/types/wallets/MinimalBitcoinWalletInterface.d.ts +23 -23
  204. package/dist/types/wallets/MinimalBitcoinWalletInterface.js +2 -2
  205. package/dist/types/wallets/MinimalLightningNetworkWalletInterface.d.ts +9 -9
  206. package/dist/types/wallets/MinimalLightningNetworkWalletInterface.js +2 -2
  207. package/dist/utils/AutomaticClockDriftCorrection.d.ts +1 -1
  208. package/dist/utils/AutomaticClockDriftCorrection.js +70 -70
  209. package/dist/utils/BitcoinUtils.d.ts +16 -14
  210. package/dist/utils/BitcoinUtils.js +141 -102
  211. package/dist/utils/BitcoinWalletUtils.d.ts +7 -7
  212. package/dist/utils/BitcoinWalletUtils.js +14 -14
  213. package/dist/utils/Logger.d.ts +7 -7
  214. package/dist/utils/Logger.js +12 -12
  215. package/dist/utils/RetryUtils.d.ts +22 -22
  216. package/dist/utils/RetryUtils.js +67 -67
  217. package/dist/utils/SwapUtils.d.ts +88 -88
  218. package/dist/utils/SwapUtils.js +72 -72
  219. package/dist/utils/TimeoutUtils.d.ts +17 -17
  220. package/dist/utils/TimeoutUtils.js +55 -55
  221. package/dist/utils/TokenUtils.d.ts +19 -19
  222. package/dist/utils/TokenUtils.js +37 -37
  223. package/dist/utils/TypeUtils.d.ts +7 -7
  224. package/dist/utils/TypeUtils.js +2 -2
  225. package/dist/utils/Utils.d.ts +67 -67
  226. package/dist/utils/Utils.js +208 -208
  227. package/package.json +43 -43
  228. package/src/SmartChainAssets.ts +186 -186
  229. package/src/bitcoin/coinselect2/accumulative.ts +69 -68
  230. package/src/bitcoin/coinselect2/blackjack.ts +50 -49
  231. package/src/bitcoin/coinselect2/index.ts +93 -92
  232. package/src/bitcoin/coinselect2/utils.ts +236 -195
  233. package/src/bitcoin/wallet/BitcoinWallet.ts +439 -427
  234. package/src/bitcoin/wallet/IBitcoinWallet.ts +140 -99
  235. package/src/bitcoin/wallet/SingleAddressBitcoinWallet.ts +225 -217
  236. package/src/enums/FeeType.ts +15 -15
  237. package/src/enums/SwapAmountType.ts +16 -16
  238. package/src/enums/SwapDirection.ts +15 -15
  239. package/src/enums/SwapSide.ts +16 -16
  240. package/src/enums/SwapType.ts +75 -75
  241. package/src/errors/IntermediaryError.ts +28 -28
  242. package/src/errors/RequestError.ts +64 -64
  243. package/src/errors/UserError.ts +15 -15
  244. package/src/events/UnifiedSwapEventListener.ts +173 -173
  245. package/src/http/HttpUtils.ts +91 -91
  246. package/src/http/paramcoders/IParamReader.ts +9 -9
  247. package/src/http/paramcoders/ParamDecoder.ts +145 -145
  248. package/src/http/paramcoders/ParamEncoder.ts +40 -40
  249. package/src/http/paramcoders/SchemaVerifier.ts +153 -153
  250. package/src/http/paramcoders/client/ResponseParamDecoder.ts +57 -57
  251. package/src/http/paramcoders/client/StreamParamEncoder.ts +28 -28
  252. package/src/http/paramcoders/client/StreamingFetchPromise.ts +192 -192
  253. package/src/index.ts +140 -140
  254. package/src/intermediaries/Intermediary.ts +280 -280
  255. package/src/intermediaries/IntermediaryDiscovery.ts +541 -541
  256. package/src/intermediaries/apis/IntermediaryAPI.ts +963 -947
  257. package/src/intermediaries/apis/TrustedIntermediaryAPI.ts +257 -257
  258. package/src/lnurl/LNURL.ts +402 -402
  259. package/src/prices/RedundantSwapPrice.ts +264 -264
  260. package/src/prices/SingleSwapPrice.ts +50 -50
  261. package/src/prices/SwapPriceWithChain.ts +194 -194
  262. package/src/prices/abstract/ICachedSwapPrice.ts +85 -85
  263. package/src/prices/abstract/IPriceProvider.ts +127 -127
  264. package/src/prices/abstract/ISwapPrice.ts +390 -390
  265. package/src/prices/providers/BinancePriceProvider.ts +48 -48
  266. package/src/prices/providers/CoinGeckoPriceProvider.ts +46 -46
  267. package/src/prices/providers/CoinPaprikaPriceProvider.ts +49 -49
  268. package/src/prices/providers/CustomPriceProvider.ts +40 -40
  269. package/src/prices/providers/KrakenPriceProvider.ts +83 -83
  270. package/src/prices/providers/OKXPriceProvider.ts +59 -59
  271. package/src/prices/providers/abstract/ExchangePriceProvider.ts +31 -31
  272. package/src/prices/providers/abstract/HttpPriceProvider.ts +14 -14
  273. package/src/storage/IUnifiedStorage.ts +95 -95
  274. package/src/storage/UnifiedSwapStorage.ts +141 -141
  275. package/src/storage-browser/IndexedDBUnifiedStorage.ts +350 -350
  276. package/src/storage-browser/LocalStorageManager.ts +106 -106
  277. package/src/swapper/Swapper.ts +2488 -2416
  278. package/src/swapper/SwapperFactory.ts +307 -307
  279. package/src/swapper/SwapperUtils.ts +570 -570
  280. package/src/swapper/SwapperWithChain.ts +707 -707
  281. package/src/swapper/SwapperWithSigner.ts +511 -511
  282. package/src/swaps/IAddressSwap.ts +30 -30
  283. package/src/swaps/IBTCWalletSwap.ts +92 -92
  284. package/src/swaps/IClaimableSwap.ts +65 -65
  285. package/src/swaps/IClaimableSwapWrapper.ts +17 -17
  286. package/src/swaps/IRefundableSwap.ts +58 -58
  287. package/src/swaps/ISwap.ts +703 -703
  288. package/src/swaps/ISwapWithGasDrop.ts +25 -25
  289. package/src/swaps/ISwapWrapper.ts +539 -539
  290. package/src/swaps/escrow_swaps/IEscrowSelfInitSwap.ts +217 -217
  291. package/src/swaps/escrow_swaps/IEscrowSwap.ts +269 -269
  292. package/src/swaps/escrow_swaps/IEscrowSwapWrapper.ts +282 -282
  293. package/src/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.ts +169 -169
  294. package/src/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.ts +300 -300
  295. package/src/swaps/escrow_swaps/frombtc/IFromBTCWrapper.ts +107 -107
  296. package/src/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.ts +1473 -1474
  297. package/src/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.ts +601 -601
  298. package/src/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.ts +1582 -1582
  299. package/src/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.ts +750 -750
  300. package/src/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.ts +1299 -1299
  301. package/src/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.ts +610 -610
  302. package/src/swaps/escrow_swaps/tobtc/IToBTCSwap.ts +1096 -1096
  303. package/src/swaps/escrow_swaps/tobtc/IToBTCWrapper.ts +138 -138
  304. package/src/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.ts +304 -304
  305. package/src/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.ts +786 -786
  306. package/src/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.ts +206 -206
  307. package/src/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.ts +401 -401
  308. package/src/swaps/spv_swaps/SpvFromBTCSwap.ts +1812 -1799
  309. package/src/swaps/spv_swaps/SpvFromBTCWrapper.ts +1236 -1060
  310. package/src/swaps/trusted/ln/LnForGasSwap.ts +589 -589
  311. package/src/swaps/trusted/ln/LnForGasWrapper.ts +91 -91
  312. package/src/swaps/trusted/onchain/OnchainForGasSwap.ts +862 -862
  313. package/src/swaps/trusted/onchain/OnchainForGasWrapper.ts +131 -131
  314. package/src/types/AmountData.ts +9 -9
  315. package/src/types/CustomPriceFunction.ts +11 -11
  316. package/src/types/PriceInfoType.ts +66 -66
  317. package/src/types/SwapExecutionAction.ts +99 -99
  318. package/src/types/SwapStateInfo.ts +6 -6
  319. package/src/types/SwapWithSigner.ts +61 -61
  320. package/src/types/Token.ts +163 -163
  321. package/src/types/TokenAmount.ts +132 -132
  322. package/src/types/fees/Fee.ts +56 -56
  323. package/src/types/fees/FeeBreakdown.ts +11 -11
  324. package/src/types/fees/PercentagePPM.ts +26 -26
  325. package/src/types/lnurl/LNURLPay.ts +79 -79
  326. package/src/types/lnurl/LNURLWithdraw.ts +61 -61
  327. package/src/types/wallets/LightningInvoiceCreateService.ts +30 -30
  328. package/src/types/wallets/MinimalBitcoinWalletInterface.ts +21 -21
  329. package/src/types/wallets/MinimalLightningNetworkWalletInterface.ts +9 -9
  330. package/src/utils/AutomaticClockDriftCorrection.ts +71 -71
  331. package/src/utils/BitcoinUtils.ts +132 -91
  332. package/src/utils/BitcoinWalletUtils.ts +15 -15
  333. package/src/utils/Logger.ts +14 -14
  334. package/src/utils/RetryUtils.ts +78 -78
  335. package/src/utils/SwapUtils.ts +99 -99
  336. package/src/utils/TimeoutUtils.ts +49 -49
  337. package/src/utils/TokenUtils.ts +33 -33
  338. package/src/utils/TypeUtils.ts +8 -8
  339. package/src/utils/Utils.ts +212 -212
@@ -1,469 +1,469 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.SwapperWithChain = void 0;
4
- const SwapType_1 = require("../enums/SwapType");
5
- const SwapPriceWithChain_1 = require("../prices/SwapPriceWithChain");
6
- const SwapperWithSigner_1 = require("./SwapperWithSigner");
7
- const UserError_1 = require("../errors/UserError");
8
- const Token_1 = require("../types/Token");
9
- /**
10
- * Chain-specific wrapper around Swapper for a particular blockchain
11
- *
12
- * @category Core
13
- */
14
- class SwapperWithChain {
15
- /**
16
- * Intermediary discovery instance
17
- */
18
- get intermediaryDiscovery() {
19
- return this.swapper.intermediaryDiscovery;
20
- }
21
- /**
22
- * Miscellaneous utility functions
23
- */
24
- get Utils() {
25
- return this.swapper.Utils;
26
- }
27
- /**
28
- * Helper information about various swap protocol and their features:
29
- * - `requiresInputWallet`: Whether a swap requires a connected wallet on the input chain able to sign
30
- * arbitrary transaction
31
- * - `requiresOutputWallet`: Whether a swap requires a connected wallet on the output chain able to sign
32
- * arbitrary transactions
33
- * - `supportsGasDrop`: Whether a swap supports the "gas drop" feature, allowing to user to receive a small
34
- * amount of native token as part of the swap when swapping to smart chains
35
- *
36
- * Uses a `Record` type here, use the {@link SwapProtocolInfo} import for a literal readonly type, with
37
- * pre-filled exact values in the type.
38
- */
39
- get SwapTypeInfo() {
40
- return this.swapper.SwapTypeInfo;
41
- }
42
- constructor(swapper, chainIdentifier) {
43
- this.swapper = swapper;
44
- this.chainIdentifier = chainIdentifier;
45
- this.prices = new SwapPriceWithChain_1.SwapPriceWithChain(swapper.prices, chainIdentifier);
46
- }
47
- /**
48
- * Creates Smart chain -> Bitcoin ({@link SwapType.TO_BTC}) swap
49
- *
50
- * @param signer Signer's address on the source chain
51
- * @param tokenAddress Token address to pay with
52
- * @param address Recipient's bitcoin address
53
- * @param amount Amount to send in token based units (if `exactIn=true`) or receive in satoshis (if `exactIn=false`)
54
- * @param exactIn Whether to use exact in instead of exact out
55
- * @param additionalParams Additional parameters sent to the LP when creating the swap
56
- * @param options Additional options for the swap
57
- */
58
- createToBTCSwap(signer, tokenAddress, address, amount, exactIn, additionalParams, options) {
59
- return this.swapper.createToBTCSwap(this.chainIdentifier, signer, tokenAddress, address, amount, exactIn, additionalParams, options);
60
- }
61
- /**
62
- * Creates Smart chain -> Bitcoin Lightning ({@link SwapType.TO_BTCLN}) swap
63
- *
64
- * @param signer Signer's address on the source chain
65
- * @param tokenAddress Token address to pay with
66
- * @param paymentRequest BOLT11 lightning network invoice to be paid (needs to have a fixed amount), and the swap
67
- * amount is taken from this fixed amount, hence only exact output swaps are supported
68
- * @param additionalParams Additional parameters sent to the LP when creating the swap
69
- * @param options Additional options for the swap
70
- */
71
- createToBTCLNSwap(signer, tokenAddress, paymentRequest, additionalParams, options) {
72
- return this.swapper.createToBTCLNSwap(this.chainIdentifier, signer, tokenAddress, paymentRequest, additionalParams, options);
73
- }
74
- /**
75
- * Creates Smart chain -> Bitcoin Lightning ({@link SwapType.TO_BTCLN}) swap via LNURL-pay link
76
- *
77
- * @param signer Signer's address on the source chain
78
- * @param tokenAddress Token address to pay with
79
- * @param lnurlPay LNURL-pay link to use for the payment
80
- * @param amount Amount to send in token based units (if `exactIn=true`) or receive in satoshis (if `exactIn=false`)
81
- * @param exactIn Whether to do an exact in swap instead of exact out
82
- * @param additionalParams Additional parameters sent to the LP when creating the swap
83
- * @param options Additional options for the swap
84
- */
85
- createToBTCLNSwapViaLNURL(signer, tokenAddress, lnurlPay, amount, exactIn, additionalParams, options) {
86
- return this.swapper.createToBTCLNSwapViaLNURL(this.chainIdentifier, signer, tokenAddress, lnurlPay, amount, exactIn, additionalParams, options);
87
- }
88
- /**
89
- * Creates Smart chain -> Bitcoin Lightning ({@link SwapType.TO_BTCLN}) swap via {@link LightningInvoiceCreateService}
90
- *
91
- * @param signer Signer's address on the source chain
92
- * @param tokenAddress Token address to pay with
93
- * @param service Invoice create service object which facilitates the creation of fixed amount LN invoices
94
- * @param amount Amount to send in token based units (if `exactIn=true`) or receive in satoshis (if `exactIn=false`)
95
- * @param exactIn Whether to do an exact in swap instead of exact out
96
- * @param additionalParams Additional parameters sent to the LP when creating the swap
97
- * @param options Additional options for the swap
98
- */
99
- createToBTCLNSwapViaInvoiceCreateService(signer, tokenAddress, service, amount, exactIn, additionalParams, options) {
100
- return this.swapper.createToBTCLNSwapViaInvoiceCreateService(this.chainIdentifier, signer, tokenAddress, service, amount, exactIn, additionalParams, options);
101
- }
102
- /**
103
- * Creates Bitcoin -> Smart chain ({@link SwapType.SPV_VAULT_FROM_BTC}) swap
104
- *
105
- * @param recipient Recipient address on the destination chain
106
- * @param tokenAddress Token address to receive
107
- * @param amount Amount to send in satoshis (if `exactOut=false`) or receive in token based units (if `exactOut=true`)
108
- * @param exactOut Whether to use a exact out instead of exact in
109
- * @param additionalParams Additional parameters sent to the LP when creating the swap
110
- * @param options Additional options for the swap
111
- */
112
- async createFromBTCSwapNew(recipient, tokenAddress, amount, exactOut = false, additionalParams, options) {
113
- return this.swapper.createFromBTCSwapNew(this.chainIdentifier, recipient, tokenAddress, amount, exactOut, additionalParams, options);
114
- }
115
- /**
116
- * Creates LEGACY Bitcoin -> Smart chain ({@link SwapType.FROM_BTC}) swap
117
- *
118
- * @param recipient Recipient address on the destination chain
119
- * @param tokenAddress Token address to receive
120
- * @param amount Amount to send in satoshis (if `exactOut=false`) or receive in token based units (if `exactOut=true`)
121
- * @param exactOut Whether to use a exact out instead of exact in
122
- * @param additionalParams Additional parameters sent to the LP when creating the swap
123
- * @param options Additional options for the swap
124
- */
125
- createFromBTCSwap(recipient, tokenAddress, amount, exactOut, additionalParams, options) {
126
- return this.swapper.createFromBTCSwap(this.chainIdentifier, recipient, tokenAddress, amount, exactOut, additionalParams, options);
127
- }
128
- /**
129
- * Creates LEGACY Bitcoin Lightning -> Smart chain ({@link SwapType.FROM_BTCLN}) swap
130
- *
131
- * @param recipient Recipient address on the destination chain
132
- * @param tokenAddress Token address to receive
133
- * @param amount Amount to send in satoshis (if `exactOut=false`) or receive in token based units (if `exactOut=true`)
134
- * @param exactOut Whether to use a exact out instead of exact in
135
- * @param additionalParams Additional parameters sent to the LP when creating the swap
136
- * @param options Additional options for the swap
137
- */
138
- createFromBTCLNSwap(recipient, tokenAddress, amount, exactOut, additionalParams, options) {
139
- return this.swapper.createFromBTCLNSwap(this.chainIdentifier, recipient, tokenAddress, amount, exactOut, additionalParams, options);
140
- }
141
- /**
142
- * Creates LEGACY Bitcoin Lightning -> Smart chain ({@link SwapType.FROM_BTCLN}) swap, withdrawing from
143
- * an LNURL-withdraw link
144
- *
145
- * @param recipient Recipient address on the destination chain
146
- * @param tokenAddress Token address to receive
147
- * @param lnurl LNURL-withdraw link to pull the funds from
148
- * @param amount Amount to send in satoshis (if `exactOut=false`) or receive in token based units (if `exactOut=true`)
149
- * @param exactOut Whether to use a exact out instead of exact in
150
- * @param additionalParams Additional parameters sent to the LP when creating the swap
151
- */
152
- createFromBTCLNSwapViaLNURL(recipient, tokenAddress, lnurl, amount, exactOut, additionalParams) {
153
- return this.swapper.createFromBTCLNSwapViaLNURL(this.chainIdentifier, recipient, tokenAddress, lnurl, amount, exactOut, additionalParams);
154
- }
155
- /**
156
- * Creates Bitcoin Lightning -> Smart chain ({@link SwapType.FROM_BTCLN_AUTO}) swap
157
- *
158
- * @param recipient Recipient address on the destination chain
159
- * @param tokenAddress Token address to receive
160
- * @param amount Amount to send in satoshis (if `exactOut=false`) or receive in token based units (if `exactOut=true`)
161
- * @param exactOut Whether to use a exact out instead of exact in
162
- * @param additionalParams Additional parameters sent to the LP when creating the swap
163
- * @param options Additional options for the swap
164
- */
165
- createFromBTCLNSwapNew(recipient, tokenAddress, amount, exactOut, additionalParams, options) {
166
- return this.swapper.createFromBTCLNSwapNew(this.chainIdentifier, recipient, tokenAddress, amount, exactOut, additionalParams, options);
167
- }
168
- /**
169
- * Creates Bitcoin Lightning -> Smart chain ({@link SwapType.FROM_BTCLN_AUTO}) swap, withdrawing from
170
- * an LNURL-withdraw link
171
- *
172
- * @param recipient Recipient address on the destination chain
173
- * @param tokenAddress Token address to receive
174
- * @param lnurl LNURL-withdraw link to pull the funds from
175
- * @param amount Amount to send in satoshis (if `exactOut=false`) or receive in token based units (if `exactOut=true`)
176
- * @param exactOut Whether to use a exact out instead of exact in
177
- * @param additionalParams Additional parameters sent to the LP when creating the swap
178
- * @param options Additional options for the swap
179
- */
180
- createFromBTCLNSwapNewViaLNURL(recipient, tokenAddress, lnurl, amount, exactOut, additionalParams, options) {
181
- return this.swapper.createFromBTCLNSwapNewViaLNURL(this.chainIdentifier, recipient, tokenAddress, lnurl, amount, exactOut, additionalParams, options);
182
- }
183
- /**
184
- * Creates a trusted Bitcoin Lightning -> Smart chain ({@link SwapType.TRUSTED_FROM_BTCLN}) gas swap
185
- *
186
- * @param recipient Recipient address on the destination chain
187
- * @param amount Amount of native token to receive, in base units
188
- * @param trustedIntermediaryOrUrl URL or Intermediary object of the trusted intermediary to use, otherwise uses default
189
- * @throws {Error} If no trusted intermediary specified
190
- */
191
- createTrustedLNForGasSwap(recipient, amount, trustedIntermediaryOrUrl) {
192
- return this.swapper.createTrustedLNForGasSwap(this.chainIdentifier, recipient, amount, trustedIntermediaryOrUrl);
193
- }
194
- /**
195
- * Creates a trusted Bitcoin -> Smart chain ({@link SwapType.TRUSTED_FROM_BTC}) gas swap
196
- *
197
- * @param recipient Recipient address on the destination chain
198
- * @param amount Amount of native token to receive, in base units
199
- * @param refundAddress Bitcoin refund address, in case the swap fails the funds are refunded here
200
- * @param trustedIntermediaryOrUrl URL or Intermediary object of the trusted intermediary to use, otherwise uses default
201
- * @throws {Error} If no trusted intermediary specified
202
- */
203
- createTrustedOnchainForGasSwap(recipient, amount, refundAddress, trustedIntermediaryOrUrl) {
204
- return this.swapper.createTrustedOnchainForGasSwap(this.chainIdentifier, recipient, amount, refundAddress, trustedIntermediaryOrUrl);
205
- }
206
- /**
207
- * Creates a swap from srcToken to dstToken, of a specific token amount, either specifying input amount (exactIn=true)
208
- * or output amount (exactIn=false), NOTE: For regular -> BTC-LN (lightning) swaps the passed amount is ignored and
209
- * invoice's pre-set amount is used instead.
210
- * @deprecated Use swap() instead
211
- *
212
- * @param signer Smartchain (Solana, Starknet, etc.) address of the user
213
- * @param srcToken Source token of the swap, user pays this token
214
- * @param dstToken Destination token of the swap, user receives this token
215
- * @param amount Amount of the swap
216
- * @param exactIn Whether the amount specified is an input amount (exactIn=true) or an output amount (exactIn=false)
217
- * @param addressLnurlLightningInvoice Bitcoin on-chain address, lightning invoice, LNURL-pay to pay or
218
- * LNURL-withdrawal to withdraw money from
219
- */
220
- create(signer, srcToken, dstToken, amount, exactIn, addressLnurlLightningInvoice) {
221
- return this.swapper.create(signer, srcToken, dstToken, amount, exactIn, addressLnurlLightningInvoice);
222
- }
223
- /**
224
- * Creates a swap from srcToken to dstToken, of a specific token amount, either specifying input amount (exactIn=true)
225
- * or output amount (exactIn=false), NOTE: For regular SmartChain -> BTC-LN (lightning) swaps the passed amount is ignored and
226
- * invoice's pre-set amount is used instead, use LNURL-pay for dynamic amounts
227
- *
228
- * @param srcToken Source token of the swap, user pays this token
229
- * @param dstToken Destination token of the swap, user receives this token
230
- * @param amount Amount of the swap
231
- * @param exactIn Whether the amount specified is an input amount (exactIn=true) or an output amount (exactIn=false)
232
- * @param src Source wallet/lnurl-withdraw of the swap
233
- * @param dst Destination smart chain address, bitcoin on-chain address, lightning invoice, LNURL-pay
234
- * @param options Options for the swap
235
- */
236
- swap(srcToken, dstToken, amount, exactIn, src, dst, options) {
237
- if (typeof (srcToken) === "string")
238
- srcToken = this.getToken(srcToken);
239
- if (typeof (dstToken) === "string")
240
- dstToken = this.getToken(dstToken);
241
- return this.swapper.swap(srcToken, dstToken, amount, exactIn, src, dst, options);
242
- }
243
- /**
244
- * Returns swaps that are in-progress and are claimable for the specific chain, optionally also for a specific signer's address
245
- */
246
- getAllSwaps(signer) {
247
- return this.swapper.getAllSwaps(this.chainIdentifier, signer);
248
- }
249
- /**
250
- * Returns swaps that are in-progress and are claimable for the specific chain, optionally also for a specific signer's address
251
- */
252
- getActionableSwaps(signer) {
253
- return this.swapper.getActionableSwaps(this.chainIdentifier, signer);
254
- }
255
- /**
256
- * Returns swaps that are refundable for the specific chain, optionally also for a specific signer's address
257
- */
258
- getRefundableSwaps(signer) {
259
- return this.swapper.getRefundableSwaps(this.chainIdentifier, signer);
260
- }
261
- /**
262
- * Returns swaps that are due to be claimed/settled manually for the specific chain,
263
- * optionally also for a specific signer's address
264
- */
265
- getClaimableSwaps(signer) {
266
- return this.swapper.getClaimableSwaps(this.chainIdentifier, signer);
267
- }
268
- /**
269
- * Returns swap with a specific id (identifier) on a specific chain and optionally with a signer
270
- */
271
- getSwapById(id, signer) {
272
- return this.swapper.getSwapById(id, this.chainIdentifier, signer);
273
- }
274
- /**
275
- * Returns the swap with a proper return type, or `undefined` if not found or has wrong type
276
- *
277
- * @param id An ID of the swap ({@link ISwap.getId})
278
- * @param swapType Type of the swap
279
- * @param signer An optional required smart chain signer address to fetch the swap for
280
- */
281
- async getTypedSwapById(id, swapType, signer) {
282
- return this.swapper.getTypedSwapById(id, this.chainIdentifier, swapType, signer);
283
- }
284
- /**
285
- * Synchronizes swaps from on-chain, this is ran automatically when SDK is initialized, hence
286
- * should only be ran manually when `dontCheckPastSwaps=true` is passed in the swapper options,
287
- * also deletes expired quotes
288
- *
289
- * @param signer Optional signer to only run swap sync for swaps initiated by this signer
290
- */
291
- async _syncSwaps(signer) {
292
- return this.swapper._syncSwaps(this.chainIdentifier, signer);
293
- }
294
- /**
295
- * Recovers swaps from on-chain historical data.
296
- *
297
- * Please note that the recovered swaps might not be complete (i.e. missing amounts or addresses), as some
298
- * of the swap data is purely off-chain and can never be recovered purely from on-chain data. This
299
- * functions tries to recover as much swap data as possible.
300
- *
301
- * @param signer Signer address to recover the swaps for
302
- * @param startBlockheight Optional starting blockheight for swap data recovery, will only check swaps
303
- * initiated after this blockheight
304
- */
305
- async recoverSwaps(signer, startBlockheight) {
306
- return this.swapper.recoverSwaps(this.chainIdentifier, signer, startBlockheight);
307
- }
308
- /**
309
- * Returns the {@link Token} object for a given token
310
- *
311
- * @param tickerOrAddress Token to return the object for, can use multiple formats:
312
- * - a) token ticker, such as `"BTC"`, `"SOL"`, etc.
313
- * - b) token ticker prefixed with smart chain identifier, such as `"SOLANA-SOL"`, `"SOLANA-USDC"`, etc.
314
- * - c) token address
315
- */
316
- getToken(tickerOrAddress) {
317
- //Btc tokens - BTC, BTCLN, BTC-LN
318
- if (tickerOrAddress === "BTC" || tickerOrAddress === "BITCOIN-BTC")
319
- return Token_1.BitcoinTokens.BTC;
320
- if (tickerOrAddress === "BTCLN" || tickerOrAddress === "BTC-LN" || tickerOrAddress === "LIGHTNING-BTC")
321
- return Token_1.BitcoinTokens.BTCLN;
322
- //Check if the ticker is in format <chainId>-<ticker>, i.e. SOLANA-USDC, STARKNET-WBTC
323
- if (tickerOrAddress.includes("-")) {
324
- const [chainId, ticker] = tickerOrAddress.split("-");
325
- if (chainId !== this.chainIdentifier)
326
- throw new UserError_1.UserError(`Invalid chainId specified in ticker: ${chainId}, swapper chainId: ${this.chainIdentifier}`);
327
- const token = this.swapper._tokensByTicker[this.chainIdentifier]?.[ticker];
328
- if (token == null)
329
- throw new UserError_1.UserError(`Not found ticker: ${ticker} for chainId: ${chainId}`);
330
- return token;
331
- }
332
- const chain = this.swapper._chains[this.chainIdentifier];
333
- if (chain.chainInterface.isValidToken(tickerOrAddress)) {
334
- //Try to find in known token addresses
335
- const token = this.swapper._tokens[this.chainIdentifier]?.[tickerOrAddress];
336
- if (token != null)
337
- return token;
338
- }
339
- else {
340
- //Check in known tickers
341
- const token = this.swapper._tokensByTicker[this.chainIdentifier]?.[tickerOrAddress];
342
- if (token != null)
343
- return token;
344
- }
345
- throw new UserError_1.UserError(`Specified token address or ticker ${tickerOrAddress} not found for chainId: ${this.chainIdentifier}!`);
346
- }
347
- /**
348
- * Returns whether the SDK supports a given swap type on this chain based on currently known LPs
349
- *
350
- * @param swapType Swap protocol type
351
- */
352
- supportsSwapType(swapType) {
353
- return this.swapper.supportsSwapType(this.chainIdentifier, swapType);
354
- }
355
- /**
356
- * Returns type of the swap based on input and output tokens specified
357
- *
358
- * @param srcToken Source token
359
- * @param dstToken Destination token
360
- */
361
- getSwapType(srcToken, dstToken) {
362
- return this.swapper.getSwapType(srcToken, dstToken);
363
- }
364
- /**
365
- * Returns minimum/maximum limits for inputs and outputs for a swap between given tokens
366
- *
367
- * @param srcToken Source token
368
- * @param dstToken Destination token
369
- */
370
- getSwapLimits(srcToken, dstToken) {
371
- return this.swapper.getSwapLimits(srcToken, dstToken);
372
- }
373
- /**
374
- * Returns a set of supported tokens by all the intermediaries offering a specific swap service
375
- *
376
- * @param _swapType Swap service type to check supported tokens for
377
- */
378
- getSupportedTokens(_swapType) {
379
- const tokens = [];
380
- this.intermediaryDiscovery.intermediaries.forEach(lp => {
381
- let swapType = _swapType;
382
- if (swapType === SwapType_1.SwapType.FROM_BTCLN && this.supportsSwapType(SwapType_1.SwapType.FROM_BTCLN_AUTO))
383
- swapType = SwapType_1.SwapType.FROM_BTCLN_AUTO;
384
- if (swapType === SwapType_1.SwapType.FROM_BTC && this.supportsSwapType(SwapType_1.SwapType.SPV_VAULT_FROM_BTC))
385
- swapType = SwapType_1.SwapType.SPV_VAULT_FROM_BTC;
386
- const chainTokens = lp.services[swapType]?.chainTokens?.[this.chainIdentifier];
387
- if (chainTokens == null)
388
- return;
389
- for (let tokenAddress of chainTokens) {
390
- const token = this.swapper._tokens?.[this.chainIdentifier]?.[tokenAddress];
391
- if (token != null)
392
- tokens.push(token);
393
- }
394
- });
395
- return tokens;
396
- }
397
- /**
398
- * Returns the set of supported tokens by all the intermediaries we know of offering a specific swapType service
399
- *
400
- * @param swapType Specific swap type for which to obtain supported tokens
401
- */
402
- getSupportedTokenAddresses(swapType) {
403
- const set = new Set();
404
- this.intermediaryDiscovery.intermediaries.forEach(lp => {
405
- const chainTokens = lp.services[swapType]?.chainTokens?.[this.chainIdentifier];
406
- if (chainTokens == null)
407
- return;
408
- chainTokens.forEach(token => set.add(token));
409
- });
410
- return set;
411
- }
412
- /**
413
- * Returns tokens that you can swap to (if input=true) from a given token,
414
- * or tokens that you can swap from (if input=false) to a given token
415
- */
416
- getSwapCounterTokens(token, input) {
417
- if ((0, Token_1.isSCToken)(token)) {
418
- const result = [];
419
- if (input) {
420
- //TO_BTC or TO_BTCLN
421
- if (this.getSupportedTokenAddresses(SwapType_1.SwapType.TO_BTCLN).has(token.address)) {
422
- result.push(Token_1.BitcoinTokens.BTCLN);
423
- }
424
- if (this.getSupportedTokenAddresses(SwapType_1.SwapType.TO_BTC).has(token.address)) {
425
- result.push(Token_1.BitcoinTokens.BTC);
426
- }
427
- }
428
- else {
429
- //FROM_BTC or FROM_BTCLN
430
- const fromLightningSwapType = this.supportsSwapType(SwapType_1.SwapType.FROM_BTCLN_AUTO) ? SwapType_1.SwapType.FROM_BTCLN_AUTO : SwapType_1.SwapType.FROM_BTCLN;
431
- if (this.getSupportedTokenAddresses(fromLightningSwapType).has(token.address)) {
432
- result.push(Token_1.BitcoinTokens.BTCLN);
433
- }
434
- const fromOnchainSwapType = this.supportsSwapType(SwapType_1.SwapType.SPV_VAULT_FROM_BTC) ? SwapType_1.SwapType.SPV_VAULT_FROM_BTC : SwapType_1.SwapType.FROM_BTC;
435
- if (this.getSupportedTokenAddresses(fromOnchainSwapType).has(token.address)) {
436
- result.push(Token_1.BitcoinTokens.BTC);
437
- }
438
- }
439
- return result;
440
- }
441
- else {
442
- if (input) {
443
- if (token.lightning) {
444
- return this.getSupportedTokens(SwapType_1.SwapType.FROM_BTCLN);
445
- }
446
- else {
447
- return this.getSupportedTokens(SwapType_1.SwapType.FROM_BTC);
448
- }
449
- }
450
- else {
451
- if (token.lightning) {
452
- return this.getSupportedTokens(SwapType_1.SwapType.TO_BTCLN);
453
- }
454
- else {
455
- return this.getSupportedTokens(SwapType_1.SwapType.TO_BTC);
456
- }
457
- }
458
- }
459
- }
460
- /**
461
- * Creates a child swapper instance with a signer
462
- *
463
- * @param signer Signer to use for the new swapper instance
464
- */
465
- withSigner(signer) {
466
- return new SwapperWithSigner_1.SwapperWithSigner(this, signer);
467
- }
468
- }
469
- exports.SwapperWithChain = SwapperWithChain;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.SwapperWithChain = void 0;
4
+ const SwapType_1 = require("../enums/SwapType");
5
+ const SwapPriceWithChain_1 = require("../prices/SwapPriceWithChain");
6
+ const SwapperWithSigner_1 = require("./SwapperWithSigner");
7
+ const UserError_1 = require("../errors/UserError");
8
+ const Token_1 = require("../types/Token");
9
+ /**
10
+ * Chain-specific wrapper around Swapper for a particular blockchain
11
+ *
12
+ * @category Core
13
+ */
14
+ class SwapperWithChain {
15
+ /**
16
+ * Intermediary discovery instance
17
+ */
18
+ get intermediaryDiscovery() {
19
+ return this.swapper.intermediaryDiscovery;
20
+ }
21
+ /**
22
+ * Miscellaneous utility functions
23
+ */
24
+ get Utils() {
25
+ return this.swapper.Utils;
26
+ }
27
+ /**
28
+ * Helper information about various swap protocol and their features:
29
+ * - `requiresInputWallet`: Whether a swap requires a connected wallet on the input chain able to sign
30
+ * arbitrary transaction
31
+ * - `requiresOutputWallet`: Whether a swap requires a connected wallet on the output chain able to sign
32
+ * arbitrary transactions
33
+ * - `supportsGasDrop`: Whether a swap supports the "gas drop" feature, allowing to user to receive a small
34
+ * amount of native token as part of the swap when swapping to smart chains
35
+ *
36
+ * Uses a `Record` type here, use the {@link SwapProtocolInfo} import for a literal readonly type, with
37
+ * pre-filled exact values in the type.
38
+ */
39
+ get SwapTypeInfo() {
40
+ return this.swapper.SwapTypeInfo;
41
+ }
42
+ constructor(swapper, chainIdentifier) {
43
+ this.swapper = swapper;
44
+ this.chainIdentifier = chainIdentifier;
45
+ this.prices = new SwapPriceWithChain_1.SwapPriceWithChain(swapper.prices, chainIdentifier);
46
+ }
47
+ /**
48
+ * Creates Smart chain -> Bitcoin ({@link SwapType.TO_BTC}) swap
49
+ *
50
+ * @param signer Signer's address on the source chain
51
+ * @param tokenAddress Token address to pay with
52
+ * @param address Recipient's bitcoin address
53
+ * @param amount Amount to send in token based units (if `exactIn=true`) or receive in satoshis (if `exactIn=false`)
54
+ * @param exactIn Whether to use exact in instead of exact out
55
+ * @param additionalParams Additional parameters sent to the LP when creating the swap
56
+ * @param options Additional options for the swap
57
+ */
58
+ createToBTCSwap(signer, tokenAddress, address, amount, exactIn, additionalParams, options) {
59
+ return this.swapper.createToBTCSwap(this.chainIdentifier, signer, tokenAddress, address, amount, exactIn, additionalParams, options);
60
+ }
61
+ /**
62
+ * Creates Smart chain -> Bitcoin Lightning ({@link SwapType.TO_BTCLN}) swap
63
+ *
64
+ * @param signer Signer's address on the source chain
65
+ * @param tokenAddress Token address to pay with
66
+ * @param paymentRequest BOLT11 lightning network invoice to be paid (needs to have a fixed amount), and the swap
67
+ * amount is taken from this fixed amount, hence only exact output swaps are supported
68
+ * @param additionalParams Additional parameters sent to the LP when creating the swap
69
+ * @param options Additional options for the swap
70
+ */
71
+ createToBTCLNSwap(signer, tokenAddress, paymentRequest, additionalParams, options) {
72
+ return this.swapper.createToBTCLNSwap(this.chainIdentifier, signer, tokenAddress, paymentRequest, additionalParams, options);
73
+ }
74
+ /**
75
+ * Creates Smart chain -> Bitcoin Lightning ({@link SwapType.TO_BTCLN}) swap via LNURL-pay link
76
+ *
77
+ * @param signer Signer's address on the source chain
78
+ * @param tokenAddress Token address to pay with
79
+ * @param lnurlPay LNURL-pay link to use for the payment
80
+ * @param amount Amount to send in token based units (if `exactIn=true`) or receive in satoshis (if `exactIn=false`)
81
+ * @param exactIn Whether to do an exact in swap instead of exact out
82
+ * @param additionalParams Additional parameters sent to the LP when creating the swap
83
+ * @param options Additional options for the swap
84
+ */
85
+ createToBTCLNSwapViaLNURL(signer, tokenAddress, lnurlPay, amount, exactIn, additionalParams, options) {
86
+ return this.swapper.createToBTCLNSwapViaLNURL(this.chainIdentifier, signer, tokenAddress, lnurlPay, amount, exactIn, additionalParams, options);
87
+ }
88
+ /**
89
+ * Creates Smart chain -> Bitcoin Lightning ({@link SwapType.TO_BTCLN}) swap via {@link LightningInvoiceCreateService}
90
+ *
91
+ * @param signer Signer's address on the source chain
92
+ * @param tokenAddress Token address to pay with
93
+ * @param service Invoice create service object which facilitates the creation of fixed amount LN invoices
94
+ * @param amount Amount to send in token based units (if `exactIn=true`) or receive in satoshis (if `exactIn=false`)
95
+ * @param exactIn Whether to do an exact in swap instead of exact out
96
+ * @param additionalParams Additional parameters sent to the LP when creating the swap
97
+ * @param options Additional options for the swap
98
+ */
99
+ createToBTCLNSwapViaInvoiceCreateService(signer, tokenAddress, service, amount, exactIn, additionalParams, options) {
100
+ return this.swapper.createToBTCLNSwapViaInvoiceCreateService(this.chainIdentifier, signer, tokenAddress, service, amount, exactIn, additionalParams, options);
101
+ }
102
+ /**
103
+ * Creates Bitcoin -> Smart chain ({@link SwapType.SPV_VAULT_FROM_BTC}) swap
104
+ *
105
+ * @param recipient Recipient address on the destination chain
106
+ * @param tokenAddress Token address to receive
107
+ * @param amount Amount to send in satoshis (if `exactOut=false`) or receive in token based units (if `exactOut=true`)
108
+ * @param exactOut Whether to use a exact out instead of exact in
109
+ * @param additionalParams Additional parameters sent to the LP when creating the swap
110
+ * @param options Additional options for the swap
111
+ */
112
+ async createFromBTCSwapNew(recipient, tokenAddress, amount, exactOut = false, additionalParams, options) {
113
+ return this.swapper.createFromBTCSwapNew(this.chainIdentifier, recipient, tokenAddress, amount, exactOut, additionalParams, options);
114
+ }
115
+ /**
116
+ * Creates LEGACY Bitcoin -> Smart chain ({@link SwapType.FROM_BTC}) swap
117
+ *
118
+ * @param recipient Recipient address on the destination chain
119
+ * @param tokenAddress Token address to receive
120
+ * @param amount Amount to send in satoshis (if `exactOut=false`) or receive in token based units (if `exactOut=true`)
121
+ * @param exactOut Whether to use a exact out instead of exact in
122
+ * @param additionalParams Additional parameters sent to the LP when creating the swap
123
+ * @param options Additional options for the swap
124
+ */
125
+ createFromBTCSwap(recipient, tokenAddress, amount, exactOut, additionalParams, options) {
126
+ return this.swapper.createFromBTCSwap(this.chainIdentifier, recipient, tokenAddress, amount, exactOut, additionalParams, options);
127
+ }
128
+ /**
129
+ * Creates LEGACY Bitcoin Lightning -> Smart chain ({@link SwapType.FROM_BTCLN}) swap
130
+ *
131
+ * @param recipient Recipient address on the destination chain
132
+ * @param tokenAddress Token address to receive
133
+ * @param amount Amount to send in satoshis (if `exactOut=false`) or receive in token based units (if `exactOut=true`)
134
+ * @param exactOut Whether to use a exact out instead of exact in
135
+ * @param additionalParams Additional parameters sent to the LP when creating the swap
136
+ * @param options Additional options for the swap
137
+ */
138
+ createFromBTCLNSwap(recipient, tokenAddress, amount, exactOut, additionalParams, options) {
139
+ return this.swapper.createFromBTCLNSwap(this.chainIdentifier, recipient, tokenAddress, amount, exactOut, additionalParams, options);
140
+ }
141
+ /**
142
+ * Creates LEGACY Bitcoin Lightning -> Smart chain ({@link SwapType.FROM_BTCLN}) swap, withdrawing from
143
+ * an LNURL-withdraw link
144
+ *
145
+ * @param recipient Recipient address on the destination chain
146
+ * @param tokenAddress Token address to receive
147
+ * @param lnurl LNURL-withdraw link to pull the funds from
148
+ * @param amount Amount to send in satoshis (if `exactOut=false`) or receive in token based units (if `exactOut=true`)
149
+ * @param exactOut Whether to use a exact out instead of exact in
150
+ * @param additionalParams Additional parameters sent to the LP when creating the swap
151
+ */
152
+ createFromBTCLNSwapViaLNURL(recipient, tokenAddress, lnurl, amount, exactOut, additionalParams) {
153
+ return this.swapper.createFromBTCLNSwapViaLNURL(this.chainIdentifier, recipient, tokenAddress, lnurl, amount, exactOut, additionalParams);
154
+ }
155
+ /**
156
+ * Creates Bitcoin Lightning -> Smart chain ({@link SwapType.FROM_BTCLN_AUTO}) swap
157
+ *
158
+ * @param recipient Recipient address on the destination chain
159
+ * @param tokenAddress Token address to receive
160
+ * @param amount Amount to send in satoshis (if `exactOut=false`) or receive in token based units (if `exactOut=true`)
161
+ * @param exactOut Whether to use a exact out instead of exact in
162
+ * @param additionalParams Additional parameters sent to the LP when creating the swap
163
+ * @param options Additional options for the swap
164
+ */
165
+ createFromBTCLNSwapNew(recipient, tokenAddress, amount, exactOut, additionalParams, options) {
166
+ return this.swapper.createFromBTCLNSwapNew(this.chainIdentifier, recipient, tokenAddress, amount, exactOut, additionalParams, options);
167
+ }
168
+ /**
169
+ * Creates Bitcoin Lightning -> Smart chain ({@link SwapType.FROM_BTCLN_AUTO}) swap, withdrawing from
170
+ * an LNURL-withdraw link
171
+ *
172
+ * @param recipient Recipient address on the destination chain
173
+ * @param tokenAddress Token address to receive
174
+ * @param lnurl LNURL-withdraw link to pull the funds from
175
+ * @param amount Amount to send in satoshis (if `exactOut=false`) or receive in token based units (if `exactOut=true`)
176
+ * @param exactOut Whether to use a exact out instead of exact in
177
+ * @param additionalParams Additional parameters sent to the LP when creating the swap
178
+ * @param options Additional options for the swap
179
+ */
180
+ createFromBTCLNSwapNewViaLNURL(recipient, tokenAddress, lnurl, amount, exactOut, additionalParams, options) {
181
+ return this.swapper.createFromBTCLNSwapNewViaLNURL(this.chainIdentifier, recipient, tokenAddress, lnurl, amount, exactOut, additionalParams, options);
182
+ }
183
+ /**
184
+ * Creates a trusted Bitcoin Lightning -> Smart chain ({@link SwapType.TRUSTED_FROM_BTCLN}) gas swap
185
+ *
186
+ * @param recipient Recipient address on the destination chain
187
+ * @param amount Amount of native token to receive, in base units
188
+ * @param trustedIntermediaryOrUrl URL or Intermediary object of the trusted intermediary to use, otherwise uses default
189
+ * @throws {Error} If no trusted intermediary specified
190
+ */
191
+ createTrustedLNForGasSwap(recipient, amount, trustedIntermediaryOrUrl) {
192
+ return this.swapper.createTrustedLNForGasSwap(this.chainIdentifier, recipient, amount, trustedIntermediaryOrUrl);
193
+ }
194
+ /**
195
+ * Creates a trusted Bitcoin -> Smart chain ({@link SwapType.TRUSTED_FROM_BTC}) gas swap
196
+ *
197
+ * @param recipient Recipient address on the destination chain
198
+ * @param amount Amount of native token to receive, in base units
199
+ * @param refundAddress Bitcoin refund address, in case the swap fails the funds are refunded here
200
+ * @param trustedIntermediaryOrUrl URL or Intermediary object of the trusted intermediary to use, otherwise uses default
201
+ * @throws {Error} If no trusted intermediary specified
202
+ */
203
+ createTrustedOnchainForGasSwap(recipient, amount, refundAddress, trustedIntermediaryOrUrl) {
204
+ return this.swapper.createTrustedOnchainForGasSwap(this.chainIdentifier, recipient, amount, refundAddress, trustedIntermediaryOrUrl);
205
+ }
206
+ /**
207
+ * Creates a swap from srcToken to dstToken, of a specific token amount, either specifying input amount (exactIn=true)
208
+ * or output amount (exactIn=false), NOTE: For regular -> BTC-LN (lightning) swaps the passed amount is ignored and
209
+ * invoice's pre-set amount is used instead.
210
+ * @deprecated Use swap() instead
211
+ *
212
+ * @param signer Smartchain (Solana, Starknet, etc.) address of the user
213
+ * @param srcToken Source token of the swap, user pays this token
214
+ * @param dstToken Destination token of the swap, user receives this token
215
+ * @param amount Amount of the swap
216
+ * @param exactIn Whether the amount specified is an input amount (exactIn=true) or an output amount (exactIn=false)
217
+ * @param addressLnurlLightningInvoice Bitcoin on-chain address, lightning invoice, LNURL-pay to pay or
218
+ * LNURL-withdrawal to withdraw money from
219
+ */
220
+ create(signer, srcToken, dstToken, amount, exactIn, addressLnurlLightningInvoice) {
221
+ return this.swapper.create(signer, srcToken, dstToken, amount, exactIn, addressLnurlLightningInvoice);
222
+ }
223
+ /**
224
+ * Creates a swap from srcToken to dstToken, of a specific token amount, either specifying input amount (exactIn=true)
225
+ * or output amount (exactIn=false), NOTE: For regular SmartChain -> BTC-LN (lightning) swaps the passed amount is ignored and
226
+ * invoice's pre-set amount is used instead, use LNURL-pay for dynamic amounts
227
+ *
228
+ * @param srcToken Source token of the swap, user pays this token
229
+ * @param dstToken Destination token of the swap, user receives this token
230
+ * @param amount Amount of the swap
231
+ * @param exactIn Whether the amount specified is an input amount (exactIn=true) or an output amount (exactIn=false)
232
+ * @param src Source wallet/lnurl-withdraw of the swap
233
+ * @param dst Destination smart chain address, bitcoin on-chain address, lightning invoice, LNURL-pay
234
+ * @param options Options for the swap
235
+ */
236
+ swap(srcToken, dstToken, amount, exactIn, src, dst, options) {
237
+ if (typeof (srcToken) === "string")
238
+ srcToken = this.getToken(srcToken);
239
+ if (typeof (dstToken) === "string")
240
+ dstToken = this.getToken(dstToken);
241
+ return this.swapper.swap(srcToken, dstToken, amount, exactIn, src, dst, options);
242
+ }
243
+ /**
244
+ * Returns swaps that are in-progress and are claimable for the specific chain, optionally also for a specific signer's address
245
+ */
246
+ getAllSwaps(signer) {
247
+ return this.swapper.getAllSwaps(this.chainIdentifier, signer);
248
+ }
249
+ /**
250
+ * Returns swaps that are in-progress and are claimable for the specific chain, optionally also for a specific signer's address
251
+ */
252
+ getActionableSwaps(signer) {
253
+ return this.swapper.getActionableSwaps(this.chainIdentifier, signer);
254
+ }
255
+ /**
256
+ * Returns swaps that are refundable for the specific chain, optionally also for a specific signer's address
257
+ */
258
+ getRefundableSwaps(signer) {
259
+ return this.swapper.getRefundableSwaps(this.chainIdentifier, signer);
260
+ }
261
+ /**
262
+ * Returns swaps that are due to be claimed/settled manually for the specific chain,
263
+ * optionally also for a specific signer's address
264
+ */
265
+ getClaimableSwaps(signer) {
266
+ return this.swapper.getClaimableSwaps(this.chainIdentifier, signer);
267
+ }
268
+ /**
269
+ * Returns swap with a specific id (identifier) on a specific chain and optionally with a signer
270
+ */
271
+ getSwapById(id, signer) {
272
+ return this.swapper.getSwapById(id, this.chainIdentifier, signer);
273
+ }
274
+ /**
275
+ * Returns the swap with a proper return type, or `undefined` if not found or has wrong type
276
+ *
277
+ * @param id An ID of the swap ({@link ISwap.getId})
278
+ * @param swapType Type of the swap
279
+ * @param signer An optional required smart chain signer address to fetch the swap for
280
+ */
281
+ async getTypedSwapById(id, swapType, signer) {
282
+ return this.swapper.getTypedSwapById(id, this.chainIdentifier, swapType, signer);
283
+ }
284
+ /**
285
+ * Synchronizes swaps from on-chain, this is ran automatically when SDK is initialized, hence
286
+ * should only be ran manually when `dontCheckPastSwaps=true` is passed in the swapper options,
287
+ * also deletes expired quotes
288
+ *
289
+ * @param signer Optional signer to only run swap sync for swaps initiated by this signer
290
+ */
291
+ async _syncSwaps(signer) {
292
+ return this.swapper._syncSwaps(this.chainIdentifier, signer);
293
+ }
294
+ /**
295
+ * Recovers swaps from on-chain historical data.
296
+ *
297
+ * Please note that the recovered swaps might not be complete (i.e. missing amounts or addresses), as some
298
+ * of the swap data is purely off-chain and can never be recovered purely from on-chain data. This
299
+ * functions tries to recover as much swap data as possible.
300
+ *
301
+ * @param signer Signer address to recover the swaps for
302
+ * @param startBlockheight Optional starting blockheight for swap data recovery, will only check swaps
303
+ * initiated after this blockheight
304
+ */
305
+ async recoverSwaps(signer, startBlockheight) {
306
+ return this.swapper.recoverSwaps(this.chainIdentifier, signer, startBlockheight);
307
+ }
308
+ /**
309
+ * Returns the {@link Token} object for a given token
310
+ *
311
+ * @param tickerOrAddress Token to return the object for, can use multiple formats:
312
+ * - a) token ticker, such as `"BTC"`, `"SOL"`, etc.
313
+ * - b) token ticker prefixed with smart chain identifier, such as `"SOLANA-SOL"`, `"SOLANA-USDC"`, etc.
314
+ * - c) token address
315
+ */
316
+ getToken(tickerOrAddress) {
317
+ //Btc tokens - BTC, BTCLN, BTC-LN
318
+ if (tickerOrAddress === "BTC" || tickerOrAddress === "BITCOIN-BTC")
319
+ return Token_1.BitcoinTokens.BTC;
320
+ if (tickerOrAddress === "BTCLN" || tickerOrAddress === "BTC-LN" || tickerOrAddress === "LIGHTNING-BTC")
321
+ return Token_1.BitcoinTokens.BTCLN;
322
+ //Check if the ticker is in format <chainId>-<ticker>, i.e. SOLANA-USDC, STARKNET-WBTC
323
+ if (tickerOrAddress.includes("-")) {
324
+ const [chainId, ticker] = tickerOrAddress.split("-");
325
+ if (chainId !== this.chainIdentifier)
326
+ throw new UserError_1.UserError(`Invalid chainId specified in ticker: ${chainId}, swapper chainId: ${this.chainIdentifier}`);
327
+ const token = this.swapper._tokensByTicker[this.chainIdentifier]?.[ticker];
328
+ if (token == null)
329
+ throw new UserError_1.UserError(`Not found ticker: ${ticker} for chainId: ${chainId}`);
330
+ return token;
331
+ }
332
+ const chain = this.swapper._chains[this.chainIdentifier];
333
+ if (chain.chainInterface.isValidToken(tickerOrAddress)) {
334
+ //Try to find in known token addresses
335
+ const token = this.swapper._tokens[this.chainIdentifier]?.[tickerOrAddress];
336
+ if (token != null)
337
+ return token;
338
+ }
339
+ else {
340
+ //Check in known tickers
341
+ const token = this.swapper._tokensByTicker[this.chainIdentifier]?.[tickerOrAddress];
342
+ if (token != null)
343
+ return token;
344
+ }
345
+ throw new UserError_1.UserError(`Specified token address or ticker ${tickerOrAddress} not found for chainId: ${this.chainIdentifier}!`);
346
+ }
347
+ /**
348
+ * Returns whether the SDK supports a given swap type on this chain based on currently known LPs
349
+ *
350
+ * @param swapType Swap protocol type
351
+ */
352
+ supportsSwapType(swapType) {
353
+ return this.swapper.supportsSwapType(this.chainIdentifier, swapType);
354
+ }
355
+ /**
356
+ * Returns type of the swap based on input and output tokens specified
357
+ *
358
+ * @param srcToken Source token
359
+ * @param dstToken Destination token
360
+ */
361
+ getSwapType(srcToken, dstToken) {
362
+ return this.swapper.getSwapType(srcToken, dstToken);
363
+ }
364
+ /**
365
+ * Returns minimum/maximum limits for inputs and outputs for a swap between given tokens
366
+ *
367
+ * @param srcToken Source token
368
+ * @param dstToken Destination token
369
+ */
370
+ getSwapLimits(srcToken, dstToken) {
371
+ return this.swapper.getSwapLimits(srcToken, dstToken);
372
+ }
373
+ /**
374
+ * Returns a set of supported tokens by all the intermediaries offering a specific swap service
375
+ *
376
+ * @param _swapType Swap service type to check supported tokens for
377
+ */
378
+ getSupportedTokens(_swapType) {
379
+ const tokens = [];
380
+ this.intermediaryDiscovery.intermediaries.forEach(lp => {
381
+ let swapType = _swapType;
382
+ if (swapType === SwapType_1.SwapType.FROM_BTCLN && this.supportsSwapType(SwapType_1.SwapType.FROM_BTCLN_AUTO))
383
+ swapType = SwapType_1.SwapType.FROM_BTCLN_AUTO;
384
+ if (swapType === SwapType_1.SwapType.FROM_BTC && this.supportsSwapType(SwapType_1.SwapType.SPV_VAULT_FROM_BTC))
385
+ swapType = SwapType_1.SwapType.SPV_VAULT_FROM_BTC;
386
+ const chainTokens = lp.services[swapType]?.chainTokens?.[this.chainIdentifier];
387
+ if (chainTokens == null)
388
+ return;
389
+ for (let tokenAddress of chainTokens) {
390
+ const token = this.swapper._tokens?.[this.chainIdentifier]?.[tokenAddress];
391
+ if (token != null)
392
+ tokens.push(token);
393
+ }
394
+ });
395
+ return tokens;
396
+ }
397
+ /**
398
+ * Returns the set of supported tokens by all the intermediaries we know of offering a specific swapType service
399
+ *
400
+ * @param swapType Specific swap type for which to obtain supported tokens
401
+ */
402
+ getSupportedTokenAddresses(swapType) {
403
+ const set = new Set();
404
+ this.intermediaryDiscovery.intermediaries.forEach(lp => {
405
+ const chainTokens = lp.services[swapType]?.chainTokens?.[this.chainIdentifier];
406
+ if (chainTokens == null)
407
+ return;
408
+ chainTokens.forEach(token => set.add(token));
409
+ });
410
+ return set;
411
+ }
412
+ /**
413
+ * Returns tokens that you can swap to (if input=true) from a given token,
414
+ * or tokens that you can swap from (if input=false) to a given token
415
+ */
416
+ getSwapCounterTokens(token, input) {
417
+ if ((0, Token_1.isSCToken)(token)) {
418
+ const result = [];
419
+ if (input) {
420
+ //TO_BTC or TO_BTCLN
421
+ if (this.getSupportedTokenAddresses(SwapType_1.SwapType.TO_BTCLN).has(token.address)) {
422
+ result.push(Token_1.BitcoinTokens.BTCLN);
423
+ }
424
+ if (this.getSupportedTokenAddresses(SwapType_1.SwapType.TO_BTC).has(token.address)) {
425
+ result.push(Token_1.BitcoinTokens.BTC);
426
+ }
427
+ }
428
+ else {
429
+ //FROM_BTC or FROM_BTCLN
430
+ const fromLightningSwapType = this.supportsSwapType(SwapType_1.SwapType.FROM_BTCLN_AUTO) ? SwapType_1.SwapType.FROM_BTCLN_AUTO : SwapType_1.SwapType.FROM_BTCLN;
431
+ if (this.getSupportedTokenAddresses(fromLightningSwapType).has(token.address)) {
432
+ result.push(Token_1.BitcoinTokens.BTCLN);
433
+ }
434
+ const fromOnchainSwapType = this.supportsSwapType(SwapType_1.SwapType.SPV_VAULT_FROM_BTC) ? SwapType_1.SwapType.SPV_VAULT_FROM_BTC : SwapType_1.SwapType.FROM_BTC;
435
+ if (this.getSupportedTokenAddresses(fromOnchainSwapType).has(token.address)) {
436
+ result.push(Token_1.BitcoinTokens.BTC);
437
+ }
438
+ }
439
+ return result;
440
+ }
441
+ else {
442
+ if (input) {
443
+ if (token.lightning) {
444
+ return this.getSupportedTokens(SwapType_1.SwapType.FROM_BTCLN);
445
+ }
446
+ else {
447
+ return this.getSupportedTokens(SwapType_1.SwapType.FROM_BTC);
448
+ }
449
+ }
450
+ else {
451
+ if (token.lightning) {
452
+ return this.getSupportedTokens(SwapType_1.SwapType.TO_BTCLN);
453
+ }
454
+ else {
455
+ return this.getSupportedTokens(SwapType_1.SwapType.TO_BTC);
456
+ }
457
+ }
458
+ }
459
+ }
460
+ /**
461
+ * Creates a child swapper instance with a signer
462
+ *
463
+ * @param signer Signer to use for the new swapper instance
464
+ */
465
+ withSigner(signer) {
466
+ return new SwapperWithSigner_1.SwapperWithSigner(this, signer);
467
+ }
468
+ }
469
+ exports.SwapperWithChain = SwapperWithChain;