@atomiqlabs/sdk 8.6.4 → 8.6.6

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 (239) hide show
  1. package/dist/SmartChainAssets.d.ts +181 -181
  2. package/dist/SmartChainAssets.js +181 -181
  3. package/dist/bitcoin/coinselect2/accumulative.d.ts +6 -6
  4. package/dist/bitcoin/coinselect2/accumulative.js +51 -52
  5. package/dist/bitcoin/coinselect2/blackjack.d.ts +6 -6
  6. package/dist/bitcoin/coinselect2/blackjack.js +37 -38
  7. package/dist/bitcoin/coinselect2/index.d.ts +17 -19
  8. package/dist/bitcoin/coinselect2/index.js +69 -69
  9. package/dist/bitcoin/coinselect2/utils.d.ts +75 -77
  10. package/dist/bitcoin/coinselect2/utils.js +123 -123
  11. package/dist/bitcoin/wallet/BitcoinWallet.d.ts +128 -130
  12. package/dist/bitcoin/wallet/BitcoinWallet.js +322 -322
  13. package/dist/bitcoin/wallet/IBitcoinWallet.d.ts +78 -78
  14. package/dist/bitcoin/wallet/IBitcoinWallet.js +20 -21
  15. package/dist/bitcoin/wallet/SingleAddressBitcoinWallet.d.ts +99 -101
  16. package/dist/bitcoin/wallet/SingleAddressBitcoinWallet.js +176 -176
  17. package/dist/enums/FeeType.d.ts +15 -15
  18. package/dist/enums/FeeType.js +19 -19
  19. package/dist/enums/SwapAmountType.d.ts +15 -15
  20. package/dist/enums/SwapAmountType.js +19 -19
  21. package/dist/enums/SwapDirection.d.ts +15 -15
  22. package/dist/enums/SwapDirection.js +19 -19
  23. package/dist/enums/SwapSide.d.ts +15 -15
  24. package/dist/enums/SwapSide.js +19 -19
  25. package/dist/enums/SwapType.d.ts +75 -75
  26. package/dist/enums/SwapType.js +79 -79
  27. package/dist/errors/IntermediaryError.d.ts +13 -13
  28. package/dist/errors/IntermediaryError.js +27 -27
  29. package/dist/errors/RequestError.d.ts +32 -32
  30. package/dist/errors/RequestError.js +54 -54
  31. package/dist/errors/UserError.d.ts +8 -8
  32. package/dist/errors/UserError.js +16 -16
  33. package/dist/events/UnifiedSwapEventListener.d.ts +23 -23
  34. package/dist/events/UnifiedSwapEventListener.js +130 -130
  35. package/dist/http/HttpUtils.d.ts +27 -27
  36. package/dist/http/HttpUtils.js +90 -91
  37. package/dist/http/paramcoders/IParamReader.d.ts +8 -8
  38. package/dist/http/paramcoders/IParamReader.js +2 -2
  39. package/dist/http/paramcoders/ParamDecoder.d.ts +42 -44
  40. package/dist/http/paramcoders/ParamDecoder.js +137 -137
  41. package/dist/http/paramcoders/ParamEncoder.d.ts +18 -20
  42. package/dist/http/paramcoders/ParamEncoder.js +36 -36
  43. package/dist/http/paramcoders/SchemaVerifier.d.ts +26 -26
  44. package/dist/http/paramcoders/SchemaVerifier.js +145 -145
  45. package/dist/http/paramcoders/client/ResponseParamDecoder.d.ts +11 -11
  46. package/dist/http/paramcoders/client/ResponseParamDecoder.js +57 -57
  47. package/dist/http/paramcoders/client/StreamParamEncoder.d.ts +11 -13
  48. package/dist/http/paramcoders/client/StreamParamEncoder.js +26 -26
  49. package/dist/http/paramcoders/client/StreamingFetchPromise.d.ts +16 -16
  50. package/dist/http/paramcoders/client/StreamingFetchPromise.js +173 -174
  51. package/dist/index.d.ts +85 -85
  52. package/dist/index.js +158 -158
  53. package/dist/intermediaries/Intermediary.d.ts +157 -157
  54. package/dist/intermediaries/Intermediary.js +142 -142
  55. package/dist/intermediaries/IntermediaryDiscovery.d.ts +198 -199
  56. package/dist/intermediaries/IntermediaryDiscovery.js +406 -406
  57. package/dist/intermediaries/apis/IntermediaryAPI.d.ts +437 -438
  58. package/dist/intermediaries/apis/IntermediaryAPI.js +603 -602
  59. package/dist/intermediaries/apis/TrustedIntermediaryAPI.d.ts +155 -155
  60. package/dist/intermediaries/apis/TrustedIntermediaryAPI.js +137 -137
  61. package/dist/lnurl/LNURL.d.ts +102 -102
  62. package/dist/lnurl/LNURL.js +321 -321
  63. package/dist/prices/RedundantSwapPrice.d.ts +110 -110
  64. package/dist/prices/RedundantSwapPrice.js +222 -222
  65. package/dist/prices/SingleSwapPrice.d.ts +34 -34
  66. package/dist/prices/SingleSwapPrice.js +44 -44
  67. package/dist/prices/SwapPriceWithChain.d.ts +107 -107
  68. package/dist/prices/SwapPriceWithChain.js +128 -128
  69. package/dist/prices/abstract/ICachedSwapPrice.d.ts +28 -28
  70. package/dist/prices/abstract/ICachedSwapPrice.js +62 -62
  71. package/dist/prices/abstract/IPriceProvider.d.ts +81 -81
  72. package/dist/prices/abstract/IPriceProvider.js +74 -74
  73. package/dist/prices/abstract/ISwapPrice.d.ts +168 -166
  74. package/dist/prices/abstract/ISwapPrice.js +279 -267
  75. package/dist/prices/providers/BinancePriceProvider.d.ts +23 -23
  76. package/dist/prices/providers/BinancePriceProvider.js +30 -30
  77. package/dist/prices/providers/CoinGeckoPriceProvider.d.ts +23 -23
  78. package/dist/prices/providers/CoinGeckoPriceProvider.js +29 -29
  79. package/dist/prices/providers/CoinPaprikaPriceProvider.d.ts +25 -25
  80. package/dist/prices/providers/CoinPaprikaPriceProvider.js +29 -29
  81. package/dist/prices/providers/CustomPriceProvider.d.ts +24 -24
  82. package/dist/prices/providers/CustomPriceProvider.js +35 -35
  83. package/dist/prices/providers/KrakenPriceProvider.d.ts +38 -38
  84. package/dist/prices/providers/KrakenPriceProvider.js +45 -45
  85. package/dist/prices/providers/OKXPriceProvider.d.ts +34 -34
  86. package/dist/prices/providers/OKXPriceProvider.js +29 -29
  87. package/dist/prices/providers/abstract/ExchangePriceProvider.d.ts +17 -17
  88. package/dist/prices/providers/abstract/ExchangePriceProvider.js +21 -21
  89. package/dist/prices/providers/abstract/HttpPriceProvider.d.ts +7 -7
  90. package/dist/prices/providers/abstract/HttpPriceProvider.js +12 -12
  91. package/dist/storage/IUnifiedStorage.d.ts +85 -85
  92. package/dist/storage/IUnifiedStorage.js +2 -2
  93. package/dist/storage/UnifiedSwapStorage.d.ts +114 -114
  94. package/dist/storage/UnifiedSwapStorage.js +116 -116
  95. package/dist/storage-browser/IndexedDBUnifiedStorage.d.ts +63 -63
  96. package/dist/storage-browser/IndexedDBUnifiedStorage.js +298 -298
  97. package/dist/storage-browser/LocalStorageManager.d.ts +49 -49
  98. package/dist/storage-browser/LocalStorageManager.js +93 -93
  99. package/dist/swapper/Swapper.d.ts +686 -687
  100. package/dist/swapper/Swapper.js +1603 -1603
  101. package/dist/swapper/SwapperFactory.d.ts +135 -135
  102. package/dist/swapper/SwapperFactory.js +162 -162
  103. package/dist/swapper/SwapperUtils.d.ts +200 -200
  104. package/dist/swapper/SwapperUtils.js +467 -467
  105. package/dist/swapper/SwapperWithChain.d.ts +404 -404
  106. package/dist/swapper/SwapperWithChain.js +469 -469
  107. package/dist/swapper/SwapperWithSigner.d.ts +322 -322
  108. package/dist/swapper/SwapperWithSigner.js +318 -318
  109. package/dist/swaps/IAddressSwap.d.ts +22 -22
  110. package/dist/swaps/IAddressSwap.js +13 -14
  111. package/dist/swaps/IBTCWalletSwap.d.ts +73 -73
  112. package/dist/swaps/IBTCWalletSwap.js +17 -18
  113. package/dist/swaps/IClaimableSwap.d.ts +49 -49
  114. package/dist/swaps/IClaimableSwap.js +14 -15
  115. package/dist/swaps/IClaimableSwapWrapper.d.ts +15 -15
  116. package/dist/swaps/IClaimableSwapWrapper.js +2 -2
  117. package/dist/swaps/IRefundableSwap.d.ts +43 -43
  118. package/dist/swaps/IRefundableSwap.js +13 -14
  119. package/dist/swaps/ISwap.d.ts +386 -387
  120. package/dist/swaps/ISwap.js +346 -341
  121. package/dist/swaps/ISwapWithGasDrop.d.ts +21 -21
  122. package/dist/swaps/ISwapWithGasDrop.js +11 -12
  123. package/dist/swaps/ISwapWrapper.d.ts +283 -284
  124. package/dist/swaps/ISwapWrapper.js +353 -353
  125. package/dist/swaps/escrow_swaps/IEscrowSelfInitSwap.d.ts +98 -98
  126. package/dist/swaps/escrow_swaps/IEscrowSelfInitSwap.js +126 -126
  127. package/dist/swaps/escrow_swaps/IEscrowSwap.d.ts +133 -135
  128. package/dist/swaps/escrow_swaps/IEscrowSwap.js +169 -169
  129. package/dist/swaps/escrow_swaps/IEscrowSwapWrapper.d.ts +114 -115
  130. package/dist/swaps/escrow_swaps/IEscrowSwapWrapper.js +134 -134
  131. package/dist/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.d.ts +98 -101
  132. package/dist/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.js +130 -130
  133. package/dist/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.d.ts +162 -162
  134. package/dist/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.js +190 -190
  135. package/dist/swaps/escrow_swaps/frombtc/IFromBTCWrapper.d.ts +58 -58
  136. package/dist/swaps/escrow_swaps/frombtc/IFromBTCWrapper.js +78 -78
  137. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.d.ts +529 -531
  138. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.js +1285 -1285
  139. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.d.ts +181 -184
  140. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.js +418 -417
  141. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.d.ts +581 -583
  142. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.js +1371 -1371
  143. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.d.ts +225 -228
  144. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.js +506 -506
  145. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.d.ts +458 -458
  146. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.js +1126 -1126
  147. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.d.ts +190 -191
  148. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.js +378 -377
  149. package/dist/swaps/escrow_swaps/tobtc/IToBTCSwap.d.ts +403 -403
  150. package/dist/swaps/escrow_swaps/tobtc/IToBTCSwap.js +924 -924
  151. package/dist/swaps/escrow_swaps/tobtc/IToBTCWrapper.d.ts +62 -62
  152. package/dist/swaps/escrow_swaps/tobtc/IToBTCWrapper.js +112 -112
  153. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.d.ts +125 -127
  154. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.js +256 -256
  155. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.d.ts +241 -242
  156. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.js +520 -520
  157. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.d.ts +73 -73
  158. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.js +155 -155
  159. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.d.ts +127 -128
  160. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.js +278 -278
  161. package/dist/swaps/spv_swaps/SpvFromBTCSwap.d.ts +630 -630
  162. package/dist/swaps/spv_swaps/SpvFromBTCSwap.js +1443 -1443
  163. package/dist/swaps/spv_swaps/SpvFromBTCWrapper.d.ts +213 -207
  164. package/dist/swaps/spv_swaps/SpvFromBTCWrapper.js +756 -755
  165. package/dist/swaps/trusted/ln/LnForGasSwap.d.ts +261 -261
  166. package/dist/swaps/trusted/ln/LnForGasSwap.js +511 -511
  167. package/dist/swaps/trusted/ln/LnForGasWrapper.d.ts +40 -40
  168. package/dist/swaps/trusted/ln/LnForGasWrapper.js +82 -82
  169. package/dist/swaps/trusted/onchain/OnchainForGasSwap.d.ts +342 -342
  170. package/dist/swaps/trusted/onchain/OnchainForGasSwap.js +715 -715
  171. package/dist/swaps/trusted/onchain/OnchainForGasWrapper.d.ts +68 -69
  172. package/dist/swaps/trusted/onchain/OnchainForGasWrapper.js +92 -92
  173. package/dist/types/AmountData.d.ts +10 -10
  174. package/dist/types/AmountData.js +2 -2
  175. package/dist/types/CustomPriceFunction.d.ts +11 -11
  176. package/dist/types/CustomPriceFunction.js +2 -2
  177. package/dist/types/PriceInfoType.d.ts +28 -28
  178. package/dist/types/PriceInfoType.js +56 -57
  179. package/dist/types/SwapExecutionAction.d.ts +88 -88
  180. package/dist/types/SwapExecutionAction.js +2 -2
  181. package/dist/types/SwapStateInfo.d.ts +5 -5
  182. package/dist/types/SwapStateInfo.js +2 -2
  183. package/dist/types/SwapWithSigner.d.ts +17 -17
  184. package/dist/types/SwapWithSigner.js +42 -43
  185. package/dist/types/Token.d.ts +99 -99
  186. package/dist/types/Token.js +76 -76
  187. package/dist/types/TokenAmount.d.ts +69 -69
  188. package/dist/types/TokenAmount.js +59 -60
  189. package/dist/types/fees/Fee.d.ts +50 -50
  190. package/dist/types/fees/Fee.js +2 -2
  191. package/dist/types/fees/FeeBreakdown.d.ts +11 -11
  192. package/dist/types/fees/FeeBreakdown.js +2 -2
  193. package/dist/types/fees/PercentagePPM.d.ts +17 -17
  194. package/dist/types/fees/PercentagePPM.js +17 -18
  195. package/dist/types/lnurl/LNURLPay.d.ts +61 -61
  196. package/dist/types/lnurl/LNURLPay.js +30 -31
  197. package/dist/types/lnurl/LNURLWithdraw.d.ts +48 -48
  198. package/dist/types/lnurl/LNURLWithdraw.js +26 -27
  199. package/dist/types/wallets/LightningInvoiceCreateService.d.ts +24 -24
  200. package/dist/types/wallets/LightningInvoiceCreateService.js +14 -15
  201. package/dist/types/wallets/MinimalBitcoinWalletInterface.d.ts +23 -23
  202. package/dist/types/wallets/MinimalBitcoinWalletInterface.js +2 -2
  203. package/dist/types/wallets/MinimalLightningNetworkWalletInterface.d.ts +9 -9
  204. package/dist/types/wallets/MinimalLightningNetworkWalletInterface.js +2 -2
  205. package/dist/utils/AutomaticClockDriftCorrection.d.ts +1 -1
  206. package/dist/utils/AutomaticClockDriftCorrection.js +69 -70
  207. package/dist/utils/BitcoinUtils.d.ts +12 -14
  208. package/dist/utils/BitcoinUtils.js +101 -102
  209. package/dist/utils/BitcoinWalletUtils.d.ts +7 -7
  210. package/dist/utils/BitcoinWalletUtils.js +13 -14
  211. package/dist/utils/Logger.d.ts +7 -7
  212. package/dist/utils/Logger.js +11 -12
  213. package/dist/utils/RetryUtils.d.ts +22 -22
  214. package/dist/utils/RetryUtils.js +66 -67
  215. package/dist/utils/SwapUtils.d.ts +88 -88
  216. package/dist/utils/SwapUtils.js +72 -72
  217. package/dist/utils/TimeoutUtils.d.ts +17 -17
  218. package/dist/utils/TimeoutUtils.js +54 -55
  219. package/dist/utils/TokenUtils.d.ts +19 -19
  220. package/dist/utils/TokenUtils.js +36 -37
  221. package/dist/utils/TypeUtils.d.ts +7 -7
  222. package/dist/utils/TypeUtils.js +2 -2
  223. package/dist/utils/Utils.d.ts +56 -58
  224. package/dist/utils/Utils.js +193 -194
  225. package/package.json +1 -1
  226. package/src/intermediaries/apis/IntermediaryAPI.ts +4 -2
  227. package/src/prices/abstract/ISwapPrice.ts +19 -6
  228. package/src/swaps/ISwap.ts +17 -6
  229. package/src/swaps/ISwapWrapper.ts +4 -3
  230. package/src/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.ts +4 -2
  231. package/src/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.ts +4 -1
  232. package/src/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.ts +2 -2
  233. package/src/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.ts +4 -2
  234. package/src/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.ts +6 -6
  235. package/src/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.ts +5 -5
  236. package/src/swaps/spv_swaps/SpvFromBTCSwap.ts +4 -1
  237. package/src/swaps/spv_swaps/SpvFromBTCWrapper.ts +10 -2
  238. package/src/swaps/trusted/ln/LnForGasWrapper.ts +1 -1
  239. package/src/swaps/trusted/onchain/OnchainForGasWrapper.ts +1 -1
@@ -1,318 +1,318 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.SwapperWithSigner = void 0;
4
- const SwapWithSigner_1 = require("../types/SwapWithSigner");
5
- /**
6
- * Chain and signer-specific wrapper for automatic signer injection into swap methods
7
- * @category Core
8
- */
9
- class SwapperWithSigner {
10
- /**
11
- * Pricing API used by the SDK
12
- */
13
- get prices() {
14
- return this.swapper.prices;
15
- }
16
- /**
17
- * Intermediary discovery instance
18
- */
19
- get intermediaryDiscovery() {
20
- return this.swapper.intermediaryDiscovery;
21
- }
22
- /**
23
- * Miscellaneous utility functions
24
- */
25
- get Utils() {
26
- return this.swapper.Utils;
27
- }
28
- /**
29
- * Helper information about various swap protocol and their features:
30
- * - `requiresInputWallet`: Whether a swap requires a connected wallet on the input chain able to sign
31
- * arbitrary transaction
32
- * - `requiresOutputWallet`: Whether a swap requires a connected wallet on the output chain able to sign
33
- * arbitrary transactions
34
- * - `supportsGasDrop`: Whether a swap supports the "gas drop" feature, allowing to user to receive a small
35
- * amount of native token as part of the swap when swapping to smart chains
36
- *
37
- * Uses a `Record` type here, use the {@link SwapProtocolInfo} import for a literal readonly type, with
38
- * pre-filled exact values in the type.
39
- */
40
- get SwapTypeInfo() {
41
- return this.swapper.SwapTypeInfo;
42
- }
43
- constructor(swapper, signer) {
44
- this.swapper = swapper;
45
- this.signer = signer;
46
- this.chainIdentifier = swapper.chainIdentifier;
47
- }
48
- /**
49
- * Creates Smart chain -> Bitcoin ({@link SwapType.TO_BTC}) swap
50
- *
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(tokenAddress, address, amount, exactIn, additionalParams, options) {
59
- return this.swapper.createToBTCSwap(this.signer.getAddress(), tokenAddress, address, amount, exactIn, additionalParams, options)
60
- .then(swap => (0, SwapWithSigner_1.wrapSwapWithSigner)(swap, this.signer));
61
- }
62
- /**
63
- * Creates Smart chain -> Bitcoin Lightning ({@link SwapType.TO_BTCLN}) swap
64
- *
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(tokenAddress, paymentRequest, additionalParams, options) {
72
- return this.swapper.createToBTCLNSwap(this.signer.getAddress(), tokenAddress, paymentRequest, additionalParams, options)
73
- .then(swap => (0, SwapWithSigner_1.wrapSwapWithSigner)(swap, this.signer));
74
- }
75
- /**
76
- * Creates Smart chain -> Bitcoin Lightning ({@link SwapType.TO_BTCLN}) swap via LNURL-pay link
77
- *
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(tokenAddress, lnurlPay, amount, exactIn, additionalParams, options) {
86
- return this.swapper.createToBTCLNSwapViaLNURL(this.signer.getAddress(), tokenAddress, lnurlPay, amount, exactIn, additionalParams, options)
87
- .then(swap => (0, SwapWithSigner_1.wrapSwapWithSigner)(swap, this.signer));
88
- }
89
- /**
90
- * Creates Smart chain -> Bitcoin Lightning ({@link SwapType.TO_BTCLN}) swap via {@link LightningInvoiceCreateService}
91
- *
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(tokenAddress, service, amount, exactIn, additionalParams, options) {
100
- return this.swapper.createToBTCLNSwapViaInvoiceCreateService(this.signer.getAddress(), tokenAddress, service, amount, exactIn, additionalParams, options)
101
- .then(swap => (0, SwapWithSigner_1.wrapSwapWithSigner)(swap, this.signer));
102
- }
103
- /**
104
- * Creates Bitcoin -> Smart chain ({@link SwapType.SPV_VAULT_FROM_BTC}) swap
105
- *
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
- createFromBTCSwapNew(tokenAddress, amount, exactOut, additionalParams, options) {
113
- return this.swapper.createFromBTCSwapNew(this.signer.getAddress(), tokenAddress, amount, exactOut, additionalParams, options)
114
- .then(swap => (0, SwapWithSigner_1.wrapSwapWithSigner)(swap, this.signer));
115
- }
116
- /**
117
- * Creates LEGACY Bitcoin -> Smart chain ({@link SwapType.FROM_BTC}) swap
118
- *
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(tokenAddress, amount, exactOut, additionalParams, options) {
126
- return this.swapper.createFromBTCSwap(this.signer.getAddress(), tokenAddress, amount, exactOut, additionalParams, options)
127
- .then(swap => (0, SwapWithSigner_1.wrapSwapWithSigner)(swap, this.signer));
128
- }
129
- /**
130
- * Creates LEGACY Bitcoin Lightning -> Smart chain ({@link SwapType.FROM_BTCLN}) swap
131
- *
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(tokenAddress, amount, exactOut, additionalParams, options) {
139
- return this.swapper.createFromBTCLNSwap(this.signer.getAddress(), tokenAddress, amount, exactOut, additionalParams, options)
140
- .then(swap => (0, SwapWithSigner_1.wrapSwapWithSigner)(swap, this.signer));
141
- }
142
- /**
143
- * Creates LEGACY Bitcoin Lightning -> Smart chain ({@link SwapType.FROM_BTCLN}) swap, withdrawing from
144
- * an LNURL-withdraw link
145
- *
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(tokenAddress, lnurl, amount, exactOut, additionalParams) {
153
- return this.swapper.createFromBTCLNSwapViaLNURL(this.signer.getAddress(), tokenAddress, lnurl, amount, exactOut, additionalParams)
154
- .then(swap => (0, SwapWithSigner_1.wrapSwapWithSigner)(swap, this.signer));
155
- }
156
- /**
157
- * Creates Bitcoin Lightning -> Smart chain ({@link SwapType.FROM_BTCLN_AUTO}) swap
158
- *
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(tokenAddress, amount, exactOut, additionalParams, options) {
166
- return this.swapper.createFromBTCLNSwapNew(this.signer.getAddress(), tokenAddress, amount, exactOut, additionalParams, options)
167
- .then(swap => (0, SwapWithSigner_1.wrapSwapWithSigner)(swap, this.signer));
168
- }
169
- /**
170
- * Creates Bitcoin Lightning -> Smart chain ({@link SwapType.FROM_BTCLN_AUTO}) swap, withdrawing from
171
- * an LNURL-withdraw link
172
- *
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(tokenAddress, lnurl, amount, exactOut, additionalParams, options) {
181
- return this.swapper.createFromBTCLNSwapNewViaLNURL(this.signer.getAddress(), tokenAddress, lnurl, amount, exactOut, additionalParams, options)
182
- .then(swap => (0, SwapWithSigner_1.wrapSwapWithSigner)(swap, this.signer));
183
- }
184
- /**
185
- * Creates a trusted Bitcoin Lightning -> Smart chain ({@link SwapType.TRUSTED_FROM_BTCLN}) gas swap
186
- *
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(amount, trustedIntermediaryOrUrl) {
192
- return this.swapper.createTrustedLNForGasSwap(this.signer.getAddress(), amount, trustedIntermediaryOrUrl);
193
- }
194
- /**
195
- * Creates a trusted Bitcoin -> Smart chain ({@link SwapType.TRUSTED_FROM_BTC}) gas swap
196
- *
197
- * @param amount Amount of native token to receive, in base units
198
- * @param refundAddress Bitcoin refund address, in case the swap fails the funds are refunded here
199
- * @param trustedIntermediaryOrUrl URL or Intermediary object of the trusted intermediary to use, otherwise uses default
200
- * @throws {Error} If no trusted intermediary specified
201
- */
202
- createTrustedOnchainForGasSwap(amount, refundAddress, trustedIntermediaryOrUrl) {
203
- return this.swapper.createTrustedOnchainForGasSwap(this.signer.getAddress(), amount, refundAddress, trustedIntermediaryOrUrl);
204
- }
205
- /**
206
- * Creates a swap from srcToken to dstToken, of a specific token amount, either specifying input amount (exactIn=true)
207
- * or output amount (exactIn=false), NOTE: For regular -> BTC-LN (lightning) swaps the passed amount is ignored and
208
- * invoice's pre-set amount is used instead.
209
- *
210
- * @param srcToken Source token of the swap, user pays this token
211
- * @param dstToken Destination token of the swap, user receives this token
212
- * @param amount Amount of the swap
213
- * @param exactIn Whether the amount specified is an input amount (exactIn=true) or an output amount (exactIn=false)
214
- * @param addressLnurlLightningInvoice Bitcoin on-chain address, lightning invoice, LNURL-pay to pay or
215
- * LNURL-withdrawal to withdraw money from
216
- */
217
- create(srcToken, dstToken, amount, exactIn, addressLnurlLightningInvoice) {
218
- return this.swapper.create(this.signer.getAddress(), srcToken, dstToken, amount, exactIn, addressLnurlLightningInvoice)
219
- .then(swap => (0, SwapWithSigner_1.wrapSwapWithSigner)(swap, this.signer));
220
- }
221
- /**
222
- * Returns swaps that are in-progress and are claimable for the specific chain, optionally also for a specific signer's address
223
- */
224
- getAllSwaps() {
225
- return this.swapper.getAllSwaps(this.signer.getAddress());
226
- }
227
- /**
228
- * Returns swaps that are in-progress and are claimable for the specific chain, optionally also for a specific signer's address
229
- */
230
- getActionableSwaps() {
231
- return this.swapper.getActionableSwaps(this.signer.getAddress());
232
- }
233
- /**
234
- * Returns swaps that are refundable for the specific chain, optionally also for a specific signer's address
235
- */
236
- getRefundableSwaps() {
237
- return this.swapper.getRefundableSwaps(this.signer.getAddress());
238
- }
239
- /**
240
- * Returns swap with a specific id (identifier) on a specific chain and optionally with a signer
241
- */
242
- getSwapById(id) {
243
- return this.swapper.getSwapById(id, this.signer.getAddress());
244
- }
245
- /**
246
- * Returns the swap with a proper return type, or `undefined` if not found or has wrong type
247
- *
248
- * @param id An ID of the swap ({@link ISwap.getId})
249
- * @param swapType Type of the swap
250
- */
251
- async getTypedSwapById(id, swapType) {
252
- return this.swapper.getTypedSwapById(id, swapType, this.signer.getAddress());
253
- }
254
- /**
255
- * Synchronizes swaps from chain, this is usually ran when SDK is initialized, deletes expired quotes
256
- */
257
- async _syncSwaps() {
258
- return this.swapper._syncSwaps(this.signer.getAddress());
259
- }
260
- /**
261
- * Recovers swaps from on-chain historical data.
262
- *
263
- * Please note that the recovered swaps might not be complete (i.e. missing amounts or addresses), as some
264
- * of the swap data is purely off-chain and can never be recovered purely from on-chain data. This
265
- * functions tries to recover as much swap data as possible.
266
- *
267
- * @param startBlockheight Optional starting blockheight for swap data recovery, will only check swaps
268
- * initiated after this blockheight
269
- */
270
- async recoverSwaps(startBlockheight) {
271
- return this.swapper.recoverSwaps(this.signer.getAddress(), startBlockheight);
272
- }
273
- /**
274
- * Returns the {@link Token} object for a given token
275
- *
276
- * @param tickerOrAddress Token to return the object for, can use multiple formats:
277
- * - a) token ticker, such as `"BTC"`, `"SOL"`, etc.
278
- * - b) token ticker prefixed with smart chain identifier, such as `"SOLANA-SOL"`, `"SOLANA-USDC"`, etc.
279
- * - c) token address
280
- */
281
- getToken(tickerOrAddress) {
282
- return this.swapper.getToken(tickerOrAddress);
283
- }
284
- /**
285
- * Returns whether the SDK supports a given swap type on this chain based on currently known LPs
286
- *
287
- * @param swapType Swap protocol type
288
- */
289
- supportsSwapType(swapType) {
290
- return this.swapper.supportsSwapType(swapType);
291
- }
292
- /**
293
- * Returns type of the swap based on input and output tokens specified
294
- *
295
- * @param srcToken Source token
296
- * @param dstToken Destination token
297
- */
298
- getSwapType(srcToken, dstToken) {
299
- return this.swapper.getSwapType(srcToken, dstToken);
300
- }
301
- /**
302
- * Returns minimum/maximum limits for inputs and outputs for a swap between given tokens
303
- *
304
- * @param srcToken Source token
305
- * @param dstToken Destination token
306
- */
307
- getSwapLimits(srcToken, dstToken) {
308
- return this.swapper.getSwapLimits(srcToken, dstToken);
309
- }
310
- /**
311
- * Returns tokens that you can swap to (if input=true) from a given token,
312
- * or tokens that you can swap from (if input=false) to a given token
313
- */
314
- getSwapCounterTokens(token, input) {
315
- return this.swapper.getSwapCounterTokens(token, input);
316
- }
317
- }
318
- exports.SwapperWithSigner = SwapperWithSigner;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.SwapperWithSigner = void 0;
4
+ const SwapWithSigner_1 = require("../types/SwapWithSigner");
5
+ /**
6
+ * Chain and signer-specific wrapper for automatic signer injection into swap methods
7
+ * @category Core
8
+ */
9
+ class SwapperWithSigner {
10
+ /**
11
+ * Pricing API used by the SDK
12
+ */
13
+ get prices() {
14
+ return this.swapper.prices;
15
+ }
16
+ /**
17
+ * Intermediary discovery instance
18
+ */
19
+ get intermediaryDiscovery() {
20
+ return this.swapper.intermediaryDiscovery;
21
+ }
22
+ /**
23
+ * Miscellaneous utility functions
24
+ */
25
+ get Utils() {
26
+ return this.swapper.Utils;
27
+ }
28
+ /**
29
+ * Helper information about various swap protocol and their features:
30
+ * - `requiresInputWallet`: Whether a swap requires a connected wallet on the input chain able to sign
31
+ * arbitrary transaction
32
+ * - `requiresOutputWallet`: Whether a swap requires a connected wallet on the output chain able to sign
33
+ * arbitrary transactions
34
+ * - `supportsGasDrop`: Whether a swap supports the "gas drop" feature, allowing to user to receive a small
35
+ * amount of native token as part of the swap when swapping to smart chains
36
+ *
37
+ * Uses a `Record` type here, use the {@link SwapProtocolInfo} import for a literal readonly type, with
38
+ * pre-filled exact values in the type.
39
+ */
40
+ get SwapTypeInfo() {
41
+ return this.swapper.SwapTypeInfo;
42
+ }
43
+ constructor(swapper, signer) {
44
+ this.swapper = swapper;
45
+ this.signer = signer;
46
+ this.chainIdentifier = swapper.chainIdentifier;
47
+ }
48
+ /**
49
+ * Creates Smart chain -> Bitcoin ({@link SwapType.TO_BTC}) swap
50
+ *
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(tokenAddress, address, amount, exactIn, additionalParams, options) {
59
+ return this.swapper.createToBTCSwap(this.signer.getAddress(), tokenAddress, address, amount, exactIn, additionalParams, options)
60
+ .then(swap => (0, SwapWithSigner_1.wrapSwapWithSigner)(swap, this.signer));
61
+ }
62
+ /**
63
+ * Creates Smart chain -> Bitcoin Lightning ({@link SwapType.TO_BTCLN}) swap
64
+ *
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(tokenAddress, paymentRequest, additionalParams, options) {
72
+ return this.swapper.createToBTCLNSwap(this.signer.getAddress(), tokenAddress, paymentRequest, additionalParams, options)
73
+ .then(swap => (0, SwapWithSigner_1.wrapSwapWithSigner)(swap, this.signer));
74
+ }
75
+ /**
76
+ * Creates Smart chain -> Bitcoin Lightning ({@link SwapType.TO_BTCLN}) swap via LNURL-pay link
77
+ *
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(tokenAddress, lnurlPay, amount, exactIn, additionalParams, options) {
86
+ return this.swapper.createToBTCLNSwapViaLNURL(this.signer.getAddress(), tokenAddress, lnurlPay, amount, exactIn, additionalParams, options)
87
+ .then(swap => (0, SwapWithSigner_1.wrapSwapWithSigner)(swap, this.signer));
88
+ }
89
+ /**
90
+ * Creates Smart chain -> Bitcoin Lightning ({@link SwapType.TO_BTCLN}) swap via {@link LightningInvoiceCreateService}
91
+ *
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(tokenAddress, service, amount, exactIn, additionalParams, options) {
100
+ return this.swapper.createToBTCLNSwapViaInvoiceCreateService(this.signer.getAddress(), tokenAddress, service, amount, exactIn, additionalParams, options)
101
+ .then(swap => (0, SwapWithSigner_1.wrapSwapWithSigner)(swap, this.signer));
102
+ }
103
+ /**
104
+ * Creates Bitcoin -> Smart chain ({@link SwapType.SPV_VAULT_FROM_BTC}) swap
105
+ *
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
+ createFromBTCSwapNew(tokenAddress, amount, exactOut, additionalParams, options) {
113
+ return this.swapper.createFromBTCSwapNew(this.signer.getAddress(), tokenAddress, amount, exactOut, additionalParams, options)
114
+ .then(swap => (0, SwapWithSigner_1.wrapSwapWithSigner)(swap, this.signer));
115
+ }
116
+ /**
117
+ * Creates LEGACY Bitcoin -> Smart chain ({@link SwapType.FROM_BTC}) swap
118
+ *
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(tokenAddress, amount, exactOut, additionalParams, options) {
126
+ return this.swapper.createFromBTCSwap(this.signer.getAddress(), tokenAddress, amount, exactOut, additionalParams, options)
127
+ .then(swap => (0, SwapWithSigner_1.wrapSwapWithSigner)(swap, this.signer));
128
+ }
129
+ /**
130
+ * Creates LEGACY Bitcoin Lightning -> Smart chain ({@link SwapType.FROM_BTCLN}) swap
131
+ *
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(tokenAddress, amount, exactOut, additionalParams, options) {
139
+ return this.swapper.createFromBTCLNSwap(this.signer.getAddress(), tokenAddress, amount, exactOut, additionalParams, options)
140
+ .then(swap => (0, SwapWithSigner_1.wrapSwapWithSigner)(swap, this.signer));
141
+ }
142
+ /**
143
+ * Creates LEGACY Bitcoin Lightning -> Smart chain ({@link SwapType.FROM_BTCLN}) swap, withdrawing from
144
+ * an LNURL-withdraw link
145
+ *
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(tokenAddress, lnurl, amount, exactOut, additionalParams) {
153
+ return this.swapper.createFromBTCLNSwapViaLNURL(this.signer.getAddress(), tokenAddress, lnurl, amount, exactOut, additionalParams)
154
+ .then(swap => (0, SwapWithSigner_1.wrapSwapWithSigner)(swap, this.signer));
155
+ }
156
+ /**
157
+ * Creates Bitcoin Lightning -> Smart chain ({@link SwapType.FROM_BTCLN_AUTO}) swap
158
+ *
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(tokenAddress, amount, exactOut, additionalParams, options) {
166
+ return this.swapper.createFromBTCLNSwapNew(this.signer.getAddress(), tokenAddress, amount, exactOut, additionalParams, options)
167
+ .then(swap => (0, SwapWithSigner_1.wrapSwapWithSigner)(swap, this.signer));
168
+ }
169
+ /**
170
+ * Creates Bitcoin Lightning -> Smart chain ({@link SwapType.FROM_BTCLN_AUTO}) swap, withdrawing from
171
+ * an LNURL-withdraw link
172
+ *
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(tokenAddress, lnurl, amount, exactOut, additionalParams, options) {
181
+ return this.swapper.createFromBTCLNSwapNewViaLNURL(this.signer.getAddress(), tokenAddress, lnurl, amount, exactOut, additionalParams, options)
182
+ .then(swap => (0, SwapWithSigner_1.wrapSwapWithSigner)(swap, this.signer));
183
+ }
184
+ /**
185
+ * Creates a trusted Bitcoin Lightning -> Smart chain ({@link SwapType.TRUSTED_FROM_BTCLN}) gas swap
186
+ *
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(amount, trustedIntermediaryOrUrl) {
192
+ return this.swapper.createTrustedLNForGasSwap(this.signer.getAddress(), amount, trustedIntermediaryOrUrl);
193
+ }
194
+ /**
195
+ * Creates a trusted Bitcoin -> Smart chain ({@link SwapType.TRUSTED_FROM_BTC}) gas swap
196
+ *
197
+ * @param amount Amount of native token to receive, in base units
198
+ * @param refundAddress Bitcoin refund address, in case the swap fails the funds are refunded here
199
+ * @param trustedIntermediaryOrUrl URL or Intermediary object of the trusted intermediary to use, otherwise uses default
200
+ * @throws {Error} If no trusted intermediary specified
201
+ */
202
+ createTrustedOnchainForGasSwap(amount, refundAddress, trustedIntermediaryOrUrl) {
203
+ return this.swapper.createTrustedOnchainForGasSwap(this.signer.getAddress(), amount, refundAddress, trustedIntermediaryOrUrl);
204
+ }
205
+ /**
206
+ * Creates a swap from srcToken to dstToken, of a specific token amount, either specifying input amount (exactIn=true)
207
+ * or output amount (exactIn=false), NOTE: For regular -> BTC-LN (lightning) swaps the passed amount is ignored and
208
+ * invoice's pre-set amount is used instead.
209
+ *
210
+ * @param srcToken Source token of the swap, user pays this token
211
+ * @param dstToken Destination token of the swap, user receives this token
212
+ * @param amount Amount of the swap
213
+ * @param exactIn Whether the amount specified is an input amount (exactIn=true) or an output amount (exactIn=false)
214
+ * @param addressLnurlLightningInvoice Bitcoin on-chain address, lightning invoice, LNURL-pay to pay or
215
+ * LNURL-withdrawal to withdraw money from
216
+ */
217
+ create(srcToken, dstToken, amount, exactIn, addressLnurlLightningInvoice) {
218
+ return this.swapper.create(this.signer.getAddress(), srcToken, dstToken, amount, exactIn, addressLnurlLightningInvoice)
219
+ .then(swap => (0, SwapWithSigner_1.wrapSwapWithSigner)(swap, this.signer));
220
+ }
221
+ /**
222
+ * Returns swaps that are in-progress and are claimable for the specific chain, optionally also for a specific signer's address
223
+ */
224
+ getAllSwaps() {
225
+ return this.swapper.getAllSwaps(this.signer.getAddress());
226
+ }
227
+ /**
228
+ * Returns swaps that are in-progress and are claimable for the specific chain, optionally also for a specific signer's address
229
+ */
230
+ getActionableSwaps() {
231
+ return this.swapper.getActionableSwaps(this.signer.getAddress());
232
+ }
233
+ /**
234
+ * Returns swaps that are refundable for the specific chain, optionally also for a specific signer's address
235
+ */
236
+ getRefundableSwaps() {
237
+ return this.swapper.getRefundableSwaps(this.signer.getAddress());
238
+ }
239
+ /**
240
+ * Returns swap with a specific id (identifier) on a specific chain and optionally with a signer
241
+ */
242
+ getSwapById(id) {
243
+ return this.swapper.getSwapById(id, this.signer.getAddress());
244
+ }
245
+ /**
246
+ * Returns the swap with a proper return type, or `undefined` if not found or has wrong type
247
+ *
248
+ * @param id An ID of the swap ({@link ISwap.getId})
249
+ * @param swapType Type of the swap
250
+ */
251
+ async getTypedSwapById(id, swapType) {
252
+ return this.swapper.getTypedSwapById(id, swapType, this.signer.getAddress());
253
+ }
254
+ /**
255
+ * Synchronizes swaps from chain, this is usually ran when SDK is initialized, deletes expired quotes
256
+ */
257
+ async _syncSwaps() {
258
+ return this.swapper._syncSwaps(this.signer.getAddress());
259
+ }
260
+ /**
261
+ * Recovers swaps from on-chain historical data.
262
+ *
263
+ * Please note that the recovered swaps might not be complete (i.e. missing amounts or addresses), as some
264
+ * of the swap data is purely off-chain and can never be recovered purely from on-chain data. This
265
+ * functions tries to recover as much swap data as possible.
266
+ *
267
+ * @param startBlockheight Optional starting blockheight for swap data recovery, will only check swaps
268
+ * initiated after this blockheight
269
+ */
270
+ async recoverSwaps(startBlockheight) {
271
+ return this.swapper.recoverSwaps(this.signer.getAddress(), startBlockheight);
272
+ }
273
+ /**
274
+ * Returns the {@link Token} object for a given token
275
+ *
276
+ * @param tickerOrAddress Token to return the object for, can use multiple formats:
277
+ * - a) token ticker, such as `"BTC"`, `"SOL"`, etc.
278
+ * - b) token ticker prefixed with smart chain identifier, such as `"SOLANA-SOL"`, `"SOLANA-USDC"`, etc.
279
+ * - c) token address
280
+ */
281
+ getToken(tickerOrAddress) {
282
+ return this.swapper.getToken(tickerOrAddress);
283
+ }
284
+ /**
285
+ * Returns whether the SDK supports a given swap type on this chain based on currently known LPs
286
+ *
287
+ * @param swapType Swap protocol type
288
+ */
289
+ supportsSwapType(swapType) {
290
+ return this.swapper.supportsSwapType(swapType);
291
+ }
292
+ /**
293
+ * Returns type of the swap based on input and output tokens specified
294
+ *
295
+ * @param srcToken Source token
296
+ * @param dstToken Destination token
297
+ */
298
+ getSwapType(srcToken, dstToken) {
299
+ return this.swapper.getSwapType(srcToken, dstToken);
300
+ }
301
+ /**
302
+ * Returns minimum/maximum limits for inputs and outputs for a swap between given tokens
303
+ *
304
+ * @param srcToken Source token
305
+ * @param dstToken Destination token
306
+ */
307
+ getSwapLimits(srcToken, dstToken) {
308
+ return this.swapper.getSwapLimits(srcToken, dstToken);
309
+ }
310
+ /**
311
+ * Returns tokens that you can swap to (if input=true) from a given token,
312
+ * or tokens that you can swap from (if input=false) to a given token
313
+ */
314
+ getSwapCounterTokens(token, input) {
315
+ return this.swapper.getSwapCounterTokens(token, input);
316
+ }
317
+ }
318
+ exports.SwapperWithSigner = SwapperWithSigner;