@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,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;
|