@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.
- package/dist/SmartChainAssets.d.ts +181 -181
- package/dist/SmartChainAssets.js +181 -181
- package/dist/bitcoin/coinselect2/accumulative.d.ts +6 -6
- package/dist/bitcoin/coinselect2/accumulative.js +51 -52
- package/dist/bitcoin/coinselect2/blackjack.d.ts +6 -6
- package/dist/bitcoin/coinselect2/blackjack.js +37 -38
- package/dist/bitcoin/coinselect2/index.d.ts +17 -19
- package/dist/bitcoin/coinselect2/index.js +69 -69
- package/dist/bitcoin/coinselect2/utils.d.ts +75 -77
- package/dist/bitcoin/coinselect2/utils.js +123 -123
- package/dist/bitcoin/wallet/BitcoinWallet.d.ts +128 -130
- package/dist/bitcoin/wallet/BitcoinWallet.js +322 -322
- package/dist/bitcoin/wallet/IBitcoinWallet.d.ts +78 -78
- package/dist/bitcoin/wallet/IBitcoinWallet.js +20 -21
- package/dist/bitcoin/wallet/SingleAddressBitcoinWallet.d.ts +99 -101
- package/dist/bitcoin/wallet/SingleAddressBitcoinWallet.js +176 -176
- package/dist/enums/FeeType.d.ts +15 -15
- package/dist/enums/FeeType.js +19 -19
- package/dist/enums/SwapAmountType.d.ts +15 -15
- package/dist/enums/SwapAmountType.js +19 -19
- package/dist/enums/SwapDirection.d.ts +15 -15
- package/dist/enums/SwapDirection.js +19 -19
- package/dist/enums/SwapSide.d.ts +15 -15
- package/dist/enums/SwapSide.js +19 -19
- package/dist/enums/SwapType.d.ts +75 -75
- package/dist/enums/SwapType.js +79 -79
- package/dist/errors/IntermediaryError.d.ts +13 -13
- package/dist/errors/IntermediaryError.js +27 -27
- package/dist/errors/RequestError.d.ts +32 -32
- package/dist/errors/RequestError.js +54 -54
- package/dist/errors/UserError.d.ts +8 -8
- package/dist/errors/UserError.js +16 -16
- package/dist/events/UnifiedSwapEventListener.d.ts +23 -23
- package/dist/events/UnifiedSwapEventListener.js +130 -130
- package/dist/http/HttpUtils.d.ts +27 -27
- package/dist/http/HttpUtils.js +90 -91
- package/dist/http/paramcoders/IParamReader.d.ts +8 -8
- package/dist/http/paramcoders/IParamReader.js +2 -2
- package/dist/http/paramcoders/ParamDecoder.d.ts +42 -44
- package/dist/http/paramcoders/ParamDecoder.js +137 -137
- package/dist/http/paramcoders/ParamEncoder.d.ts +18 -20
- package/dist/http/paramcoders/ParamEncoder.js +36 -36
- package/dist/http/paramcoders/SchemaVerifier.d.ts +26 -26
- package/dist/http/paramcoders/SchemaVerifier.js +145 -145
- package/dist/http/paramcoders/client/ResponseParamDecoder.d.ts +11 -11
- package/dist/http/paramcoders/client/ResponseParamDecoder.js +57 -57
- package/dist/http/paramcoders/client/StreamParamEncoder.d.ts +11 -13
- package/dist/http/paramcoders/client/StreamParamEncoder.js +26 -26
- package/dist/http/paramcoders/client/StreamingFetchPromise.d.ts +16 -16
- package/dist/http/paramcoders/client/StreamingFetchPromise.js +173 -174
- package/dist/index.d.ts +85 -85
- package/dist/index.js +158 -158
- package/dist/intermediaries/Intermediary.d.ts +157 -157
- package/dist/intermediaries/Intermediary.js +142 -142
- package/dist/intermediaries/IntermediaryDiscovery.d.ts +198 -199
- package/dist/intermediaries/IntermediaryDiscovery.js +406 -406
- package/dist/intermediaries/apis/IntermediaryAPI.d.ts +437 -438
- package/dist/intermediaries/apis/IntermediaryAPI.js +603 -602
- package/dist/intermediaries/apis/TrustedIntermediaryAPI.d.ts +155 -155
- package/dist/intermediaries/apis/TrustedIntermediaryAPI.js +137 -137
- package/dist/lnurl/LNURL.d.ts +102 -102
- package/dist/lnurl/LNURL.js +321 -321
- package/dist/prices/RedundantSwapPrice.d.ts +110 -110
- package/dist/prices/RedundantSwapPrice.js +222 -222
- package/dist/prices/SingleSwapPrice.d.ts +34 -34
- package/dist/prices/SingleSwapPrice.js +44 -44
- package/dist/prices/SwapPriceWithChain.d.ts +107 -107
- package/dist/prices/SwapPriceWithChain.js +128 -128
- package/dist/prices/abstract/ICachedSwapPrice.d.ts +28 -28
- package/dist/prices/abstract/ICachedSwapPrice.js +62 -62
- package/dist/prices/abstract/IPriceProvider.d.ts +81 -81
- package/dist/prices/abstract/IPriceProvider.js +74 -74
- package/dist/prices/abstract/ISwapPrice.d.ts +168 -166
- package/dist/prices/abstract/ISwapPrice.js +279 -267
- package/dist/prices/providers/BinancePriceProvider.d.ts +23 -23
- package/dist/prices/providers/BinancePriceProvider.js +30 -30
- package/dist/prices/providers/CoinGeckoPriceProvider.d.ts +23 -23
- package/dist/prices/providers/CoinGeckoPriceProvider.js +29 -29
- package/dist/prices/providers/CoinPaprikaPriceProvider.d.ts +25 -25
- package/dist/prices/providers/CoinPaprikaPriceProvider.js +29 -29
- package/dist/prices/providers/CustomPriceProvider.d.ts +24 -24
- package/dist/prices/providers/CustomPriceProvider.js +35 -35
- package/dist/prices/providers/KrakenPriceProvider.d.ts +38 -38
- package/dist/prices/providers/KrakenPriceProvider.js +45 -45
- package/dist/prices/providers/OKXPriceProvider.d.ts +34 -34
- package/dist/prices/providers/OKXPriceProvider.js +29 -29
- package/dist/prices/providers/abstract/ExchangePriceProvider.d.ts +17 -17
- package/dist/prices/providers/abstract/ExchangePriceProvider.js +21 -21
- package/dist/prices/providers/abstract/HttpPriceProvider.d.ts +7 -7
- package/dist/prices/providers/abstract/HttpPriceProvider.js +12 -12
- package/dist/storage/IUnifiedStorage.d.ts +85 -85
- package/dist/storage/IUnifiedStorage.js +2 -2
- package/dist/storage/UnifiedSwapStorage.d.ts +114 -114
- package/dist/storage/UnifiedSwapStorage.js +116 -116
- package/dist/storage-browser/IndexedDBUnifiedStorage.d.ts +63 -63
- package/dist/storage-browser/IndexedDBUnifiedStorage.js +298 -298
- package/dist/storage-browser/LocalStorageManager.d.ts +49 -49
- package/dist/storage-browser/LocalStorageManager.js +93 -93
- package/dist/swapper/Swapper.d.ts +686 -687
- package/dist/swapper/Swapper.js +1603 -1603
- package/dist/swapper/SwapperFactory.d.ts +135 -135
- package/dist/swapper/SwapperFactory.js +162 -162
- package/dist/swapper/SwapperUtils.d.ts +200 -200
- package/dist/swapper/SwapperUtils.js +467 -467
- package/dist/swapper/SwapperWithChain.d.ts +404 -404
- package/dist/swapper/SwapperWithChain.js +469 -469
- package/dist/swapper/SwapperWithSigner.d.ts +322 -322
- package/dist/swapper/SwapperWithSigner.js +318 -318
- package/dist/swaps/IAddressSwap.d.ts +22 -22
- package/dist/swaps/IAddressSwap.js +13 -14
- package/dist/swaps/IBTCWalletSwap.d.ts +73 -73
- package/dist/swaps/IBTCWalletSwap.js +17 -18
- package/dist/swaps/IClaimableSwap.d.ts +49 -49
- package/dist/swaps/IClaimableSwap.js +14 -15
- package/dist/swaps/IClaimableSwapWrapper.d.ts +15 -15
- package/dist/swaps/IClaimableSwapWrapper.js +2 -2
- package/dist/swaps/IRefundableSwap.d.ts +43 -43
- package/dist/swaps/IRefundableSwap.js +13 -14
- package/dist/swaps/ISwap.d.ts +386 -387
- package/dist/swaps/ISwap.js +346 -341
- package/dist/swaps/ISwapWithGasDrop.d.ts +21 -21
- package/dist/swaps/ISwapWithGasDrop.js +11 -12
- package/dist/swaps/ISwapWrapper.d.ts +283 -284
- package/dist/swaps/ISwapWrapper.js +353 -353
- package/dist/swaps/escrow_swaps/IEscrowSelfInitSwap.d.ts +98 -98
- package/dist/swaps/escrow_swaps/IEscrowSelfInitSwap.js +126 -126
- package/dist/swaps/escrow_swaps/IEscrowSwap.d.ts +133 -135
- package/dist/swaps/escrow_swaps/IEscrowSwap.js +169 -169
- package/dist/swaps/escrow_swaps/IEscrowSwapWrapper.d.ts +114 -115
- package/dist/swaps/escrow_swaps/IEscrowSwapWrapper.js +134 -134
- package/dist/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.d.ts +98 -101
- package/dist/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.js +130 -130
- package/dist/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.d.ts +162 -162
- package/dist/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.js +190 -190
- package/dist/swaps/escrow_swaps/frombtc/IFromBTCWrapper.d.ts +58 -58
- package/dist/swaps/escrow_swaps/frombtc/IFromBTCWrapper.js +78 -78
- package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.d.ts +529 -531
- package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.js +1285 -1285
- package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.d.ts +181 -184
- package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.js +418 -417
- package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.d.ts +581 -583
- package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.js +1371 -1371
- package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.d.ts +225 -228
- package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.js +506 -506
- package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.d.ts +458 -458
- package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.js +1126 -1126
- package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.d.ts +190 -191
- package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.js +378 -377
- package/dist/swaps/escrow_swaps/tobtc/IToBTCSwap.d.ts +403 -403
- package/dist/swaps/escrow_swaps/tobtc/IToBTCSwap.js +924 -924
- package/dist/swaps/escrow_swaps/tobtc/IToBTCWrapper.d.ts +62 -62
- package/dist/swaps/escrow_swaps/tobtc/IToBTCWrapper.js +112 -112
- package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.d.ts +125 -127
- package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.js +256 -256
- package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.d.ts +241 -242
- package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.js +520 -520
- package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.d.ts +73 -73
- package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.js +155 -155
- package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.d.ts +127 -128
- package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.js +278 -278
- package/dist/swaps/spv_swaps/SpvFromBTCSwap.d.ts +630 -630
- package/dist/swaps/spv_swaps/SpvFromBTCSwap.js +1443 -1443
- package/dist/swaps/spv_swaps/SpvFromBTCWrapper.d.ts +213 -207
- package/dist/swaps/spv_swaps/SpvFromBTCWrapper.js +756 -755
- package/dist/swaps/trusted/ln/LnForGasSwap.d.ts +261 -261
- package/dist/swaps/trusted/ln/LnForGasSwap.js +511 -511
- package/dist/swaps/trusted/ln/LnForGasWrapper.d.ts +40 -40
- package/dist/swaps/trusted/ln/LnForGasWrapper.js +82 -82
- package/dist/swaps/trusted/onchain/OnchainForGasSwap.d.ts +342 -342
- package/dist/swaps/trusted/onchain/OnchainForGasSwap.js +715 -715
- package/dist/swaps/trusted/onchain/OnchainForGasWrapper.d.ts +68 -69
- package/dist/swaps/trusted/onchain/OnchainForGasWrapper.js +92 -92
- package/dist/types/AmountData.d.ts +10 -10
- package/dist/types/AmountData.js +2 -2
- package/dist/types/CustomPriceFunction.d.ts +11 -11
- package/dist/types/CustomPriceFunction.js +2 -2
- package/dist/types/PriceInfoType.d.ts +28 -28
- package/dist/types/PriceInfoType.js +56 -57
- package/dist/types/SwapExecutionAction.d.ts +88 -88
- package/dist/types/SwapExecutionAction.js +2 -2
- package/dist/types/SwapStateInfo.d.ts +5 -5
- package/dist/types/SwapStateInfo.js +2 -2
- package/dist/types/SwapWithSigner.d.ts +17 -17
- package/dist/types/SwapWithSigner.js +42 -43
- package/dist/types/Token.d.ts +99 -99
- package/dist/types/Token.js +76 -76
- package/dist/types/TokenAmount.d.ts +69 -69
- package/dist/types/TokenAmount.js +59 -60
- package/dist/types/fees/Fee.d.ts +50 -50
- package/dist/types/fees/Fee.js +2 -2
- package/dist/types/fees/FeeBreakdown.d.ts +11 -11
- package/dist/types/fees/FeeBreakdown.js +2 -2
- package/dist/types/fees/PercentagePPM.d.ts +17 -17
- package/dist/types/fees/PercentagePPM.js +17 -18
- package/dist/types/lnurl/LNURLPay.d.ts +61 -61
- package/dist/types/lnurl/LNURLPay.js +30 -31
- package/dist/types/lnurl/LNURLWithdraw.d.ts +48 -48
- package/dist/types/lnurl/LNURLWithdraw.js +26 -27
- package/dist/types/wallets/LightningInvoiceCreateService.d.ts +24 -24
- package/dist/types/wallets/LightningInvoiceCreateService.js +14 -15
- package/dist/types/wallets/MinimalBitcoinWalletInterface.d.ts +23 -23
- package/dist/types/wallets/MinimalBitcoinWalletInterface.js +2 -2
- package/dist/types/wallets/MinimalLightningNetworkWalletInterface.d.ts +9 -9
- package/dist/types/wallets/MinimalLightningNetworkWalletInterface.js +2 -2
- package/dist/utils/AutomaticClockDriftCorrection.d.ts +1 -1
- package/dist/utils/AutomaticClockDriftCorrection.js +69 -70
- package/dist/utils/BitcoinUtils.d.ts +12 -14
- package/dist/utils/BitcoinUtils.js +101 -102
- package/dist/utils/BitcoinWalletUtils.d.ts +7 -7
- package/dist/utils/BitcoinWalletUtils.js +13 -14
- package/dist/utils/Logger.d.ts +7 -7
- package/dist/utils/Logger.js +11 -12
- package/dist/utils/RetryUtils.d.ts +22 -22
- package/dist/utils/RetryUtils.js +66 -67
- package/dist/utils/SwapUtils.d.ts +88 -88
- package/dist/utils/SwapUtils.js +72 -72
- package/dist/utils/TimeoutUtils.d.ts +17 -17
- package/dist/utils/TimeoutUtils.js +54 -55
- package/dist/utils/TokenUtils.d.ts +19 -19
- package/dist/utils/TokenUtils.js +36 -37
- package/dist/utils/TypeUtils.d.ts +7 -7
- package/dist/utils/TypeUtils.js +2 -2
- package/dist/utils/Utils.d.ts +56 -58
- package/dist/utils/Utils.js +193 -194
- package/package.json +1 -1
- package/src/intermediaries/apis/IntermediaryAPI.ts +4 -2
- package/src/prices/abstract/ISwapPrice.ts +19 -6
- package/src/swaps/ISwap.ts +17 -6
- package/src/swaps/ISwapWrapper.ts +4 -3
- package/src/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.ts +4 -2
- package/src/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.ts +4 -1
- package/src/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.ts +2 -2
- package/src/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.ts +4 -2
- package/src/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.ts +6 -6
- package/src/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.ts +5 -5
- package/src/swaps/spv_swaps/SpvFromBTCSwap.ts +4 -1
- package/src/swaps/spv_swaps/SpvFromBTCWrapper.ts +10 -2
- package/src/swaps/trusted/ln/LnForGasWrapper.ts +1 -1
- package/src/swaps/trusted/onchain/OnchainForGasWrapper.ts +1 -1
|
@@ -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;
|