@atomiqlabs/sdk 8.6.6 → 8.6.8
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 +52 -51
- package/dist/bitcoin/coinselect2/blackjack.d.ts +6 -6
- package/dist/bitcoin/coinselect2/blackjack.js +38 -37
- package/dist/bitcoin/coinselect2/index.d.ts +19 -17
- package/dist/bitcoin/coinselect2/index.js +69 -69
- package/dist/bitcoin/coinselect2/utils.d.ts +77 -75
- package/dist/bitcoin/coinselect2/utils.js +123 -123
- package/dist/bitcoin/wallet/BitcoinWallet.d.ts +130 -128
- package/dist/bitcoin/wallet/BitcoinWallet.js +322 -322
- package/dist/bitcoin/wallet/IBitcoinWallet.d.ts +78 -78
- package/dist/bitcoin/wallet/IBitcoinWallet.js +21 -20
- package/dist/bitcoin/wallet/SingleAddressBitcoinWallet.d.ts +101 -99
- package/dist/bitcoin/wallet/SingleAddressBitcoinWallet.js +190 -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 +91 -90
- package/dist/http/paramcoders/IParamReader.d.ts +8 -8
- package/dist/http/paramcoders/IParamReader.js +2 -2
- package/dist/http/paramcoders/ParamDecoder.d.ts +44 -42
- package/dist/http/paramcoders/ParamDecoder.js +137 -137
- package/dist/http/paramcoders/ParamEncoder.d.ts +20 -18
- 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 +13 -11
- 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 +174 -173
- 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 +199 -198
- package/dist/intermediaries/IntermediaryDiscovery.js +406 -406
- package/dist/intermediaries/apis/IntermediaryAPI.d.ts +439 -437
- package/dist/intermediaries/apis/IntermediaryAPI.js +603 -603
- 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 -168
- package/dist/prices/abstract/ISwapPrice.js +279 -279
- 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 +687 -686
- 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 +14 -13
- package/dist/swaps/IBTCWalletSwap.d.ts +73 -73
- package/dist/swaps/IBTCWalletSwap.js +18 -17
- package/dist/swaps/IClaimableSwap.d.ts +49 -49
- package/dist/swaps/IClaimableSwap.js +15 -14
- 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 +14 -13
- package/dist/swaps/ISwap.d.ts +387 -386
- package/dist/swaps/ISwap.js +346 -346
- package/dist/swaps/ISwapWithGasDrop.d.ts +21 -21
- package/dist/swaps/ISwapWithGasDrop.js +12 -11
- package/dist/swaps/ISwapWrapper.d.ts +285 -283
- 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 +135 -133
- package/dist/swaps/escrow_swaps/IEscrowSwap.js +169 -169
- package/dist/swaps/escrow_swaps/IEscrowSwapWrapper.d.ts +115 -114
- package/dist/swaps/escrow_swaps/IEscrowSwapWrapper.js +134 -134
- package/dist/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.d.ts +101 -98
- 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 +531 -529
- package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.js +1285 -1285
- package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.d.ts +184 -181
- package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.js +418 -418
- package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.d.ts +583 -581
- package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.js +1371 -1371
- package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.d.ts +228 -225
- 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 +191 -190
- package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.js +378 -378
- 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 +127 -125
- package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.js +256 -256
- package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.d.ts +242 -241
- 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 +128 -127
- 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 +214 -213
- package/dist/swaps/spv_swaps/SpvFromBTCWrapper.js +756 -756
- 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 +69 -68
- 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 +57 -56
- 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 +43 -42
- 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 +60 -59
- 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 +18 -17
- package/dist/types/lnurl/LNURLPay.d.ts +61 -61
- package/dist/types/lnurl/LNURLPay.js +31 -30
- package/dist/types/lnurl/LNURLWithdraw.d.ts +48 -48
- package/dist/types/lnurl/LNURLWithdraw.js +27 -26
- package/dist/types/wallets/LightningInvoiceCreateService.d.ts +24 -24
- package/dist/types/wallets/LightningInvoiceCreateService.js +15 -14
- 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 +70 -69
- package/dist/utils/BitcoinUtils.d.ts +14 -12
- package/dist/utils/BitcoinUtils.js +102 -101
- package/dist/utils/BitcoinWalletUtils.d.ts +7 -7
- package/dist/utils/BitcoinWalletUtils.js +14 -13
- package/dist/utils/Logger.d.ts +7 -7
- package/dist/utils/Logger.js +12 -11
- package/dist/utils/RetryUtils.d.ts +22 -22
- package/dist/utils/RetryUtils.js +67 -66
- 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 +55 -54
- package/dist/utils/TokenUtils.d.ts +19 -19
- package/dist/utils/TokenUtils.js +37 -36
- package/dist/utils/TypeUtils.d.ts +7 -7
- package/dist/utils/TypeUtils.js +2 -2
- package/dist/utils/Utils.d.ts +58 -56
- package/dist/utils/Utils.js +194 -193
- package/package.json +1 -1
- package/src/bitcoin/wallet/SingleAddressBitcoinWallet.ts +14 -2
|
@@ -1,168 +1,168 @@
|
|
|
1
|
-
import { ChainIds, MultiChain } from "../../swapper/Swapper";
|
|
2
|
-
import { Token } from "../../types/Token";
|
|
3
|
-
import { PriceInfoType } from "../../types/PriceInfoType";
|
|
4
|
-
/**
|
|
5
|
-
* Abstract base class for swap pricing implementations
|
|
6
|
-
*
|
|
7
|
-
* @category Pricing
|
|
8
|
-
*/
|
|
9
|
-
export declare abstract class ISwapPrice<T extends MultiChain = MultiChain> {
|
|
10
|
-
maxAllowedFeeDifferencePPM: bigint;
|
|
11
|
-
protected constructor(maxAllowedFeeDifferencePPM: bigint);
|
|
12
|
-
/**
|
|
13
|
-
* Gets the decimal places for a given token, returns `-1` if token should be ignored & `null` if token is not found
|
|
14
|
-
*
|
|
15
|
-
* @param chainIdentifier Chain identifier of the smart chain
|
|
16
|
-
* @param tokenAddress Token address
|
|
17
|
-
* @protected
|
|
18
|
-
*/
|
|
19
|
-
protected abstract getDecimals<C extends ChainIds<T>>(chainIdentifier: C, tokenAddress: string): number | null;
|
|
20
|
-
/**
|
|
21
|
-
* Returns the price of the token in BTC uSats (microSats)
|
|
22
|
-
*
|
|
23
|
-
* @param chainIdentifier Chain identifier of the smart chain
|
|
24
|
-
* @param tokenAddress Token address
|
|
25
|
-
* @param abortSignal
|
|
26
|
-
* @protected
|
|
27
|
-
*/
|
|
28
|
-
protected abstract getPrice<C extends ChainIds<T>>(chainIdentifier: C, tokenAddress: string, abortSignal?: AbortSignal): Promise<bigint>;
|
|
29
|
-
/**
|
|
30
|
-
* Returns the price of bitcoin in USD (sats/USD)
|
|
31
|
-
*
|
|
32
|
-
* @param abortSignal
|
|
33
|
-
* @protected
|
|
34
|
-
*/
|
|
35
|
-
protected abstract getUsdPrice(abortSignal?: AbortSignal): Promise<number>;
|
|
36
|
-
/**
|
|
37
|
-
* Gets the decimal places for a given token, returns `-1` if token should be ignored & throws if token is not found
|
|
38
|
-
*
|
|
39
|
-
* @param chainIdentifier Chain identifier of the smart chain
|
|
40
|
-
* @param tokenAddress Token address
|
|
41
|
-
* @throws {Error} When token is not known
|
|
42
|
-
* @protected
|
|
43
|
-
*/
|
|
44
|
-
protected getDecimalsThrowing<C extends ChainIds<T>>(chainIdentifier: C, tokenAddress: string): number;
|
|
45
|
-
/**
|
|
46
|
-
* Recomputes pricing info without fetching the current price
|
|
47
|
-
*
|
|
48
|
-
* @param chainIdentifier Chain identifier of the smart chain
|
|
49
|
-
* @param amountSats Amount of sats (BTC) to be received from the swap
|
|
50
|
-
* @param satsBaseFee Base fee in sats (BTC) as reported by the intermediary
|
|
51
|
-
* @param feePPM PPM fee rate as reported by the intermediary
|
|
52
|
-
* @param paidToken Amount of token to be paid to the swap
|
|
53
|
-
* @param tokenAddress Token address to be paid
|
|
54
|
-
*/
|
|
55
|
-
recomputePriceInfoSend<C extends ChainIds<T>>(chainIdentifier: C, amountSats: bigint, satsBaseFee: bigint, feePPM: bigint, paidToken: bigint, tokenAddress: string): PriceInfoType;
|
|
56
|
-
/**
|
|
57
|
-
* Checks whether the swap amounts are valid given the current market rate for a given pair
|
|
58
|
-
*
|
|
59
|
-
* @param chainIdentifier Chain identifier of the smart chain
|
|
60
|
-
* @param amountSats Amount of sats (BTC) to be received from the swap
|
|
61
|
-
* @param satsBaseFee Base fee in sats (BTC) as reported by the intermediary
|
|
62
|
-
* @param feePPM PPM fee rate as reported by the intermediary
|
|
63
|
-
* @param paidToken Amount of token to be paid to the swap
|
|
64
|
-
* @param tokenAddress Token address to be paid
|
|
65
|
-
* @param abortSignal
|
|
66
|
-
* @param preFetchedPrice An optional price pre-fetched with {@link preFetchPrice}
|
|
67
|
-
* @param realSwapFeeSats
|
|
68
|
-
*/
|
|
69
|
-
isValidAmountSend<C extends ChainIds<T>>(chainIdentifier: C, amountSats: bigint, satsBaseFee: bigint, feePPM: bigint, paidToken: bigint, tokenAddress: string, abortSignal?: AbortSignal, preFetchedPrice?: bigint | null, realSwapFeeSats?: bigint): Promise<PriceInfoType>;
|
|
70
|
-
/**
|
|
71
|
-
* Recomputes pricing info without fetching the current price
|
|
72
|
-
*
|
|
73
|
-
* @param chainIdentifier Chain identifier of the smart chain
|
|
74
|
-
* @param amountSats Amount of sats (BTC) to be paid to the swap
|
|
75
|
-
* @param satsBaseFee Base fee in sats (BTC) as reported by the intermediary
|
|
76
|
-
* @param feePPM PPM fee rate as reported by the intermediary
|
|
77
|
-
* @param receiveToken Amount of token to be received from the swap
|
|
78
|
-
* @param tokenAddress Token address to be received
|
|
79
|
-
*/
|
|
80
|
-
recomputePriceInfoReceive<C extends ChainIds<T>>(chainIdentifier: C, amountSats: bigint, satsBaseFee: bigint, feePPM: bigint, receiveToken: bigint, tokenAddress: string): PriceInfoType;
|
|
81
|
-
/**
|
|
82
|
-
* Checks whether the swap amounts are valid given the current market rate for a given pair
|
|
83
|
-
*
|
|
84
|
-
* @param chainIdentifier Chain identifier of the smart chain
|
|
85
|
-
* @param amountSats Amount of sats (BTC) to be paid to the swap
|
|
86
|
-
* @param satsBaseFee Base fee in sats (BTC) as reported by the intermediary
|
|
87
|
-
* @param feePPM PPM fee rate as reported by the intermediary
|
|
88
|
-
* @param receiveToken Amount of token to be received from the swap
|
|
89
|
-
* @param tokenAddress Token address to be received
|
|
90
|
-
* @param abortSignal
|
|
91
|
-
* @param preFetchedPrice An optional price pre-fetched with {@link preFetchPrice}
|
|
92
|
-
* @param realSwapFeeSats
|
|
93
|
-
*/
|
|
94
|
-
isValidAmountReceive<C extends ChainIds<T>>(chainIdentifier: C, amountSats: bigint, satsBaseFee: bigint, feePPM: bigint, receiveToken: bigint, tokenAddress: string, abortSignal?: AbortSignal, preFetchedPrice?: bigint | null, realSwapFeeSats?: bigint): Promise<PriceInfoType>;
|
|
95
|
-
/**
|
|
96
|
-
* Pre-fetches the pricing data for a given token, such that further calls to {@link isValidAmountReceive} or
|
|
97
|
-
* {@link isValidAmountSend} are quicker and don't need to wait for the price fetch
|
|
98
|
-
*
|
|
99
|
-
* @param chainIdentifier Chain identifier of the smart chain
|
|
100
|
-
* @param tokenAddress Token address
|
|
101
|
-
* @param abortSignal
|
|
102
|
-
*/
|
|
103
|
-
preFetchPrice<C extends ChainIds<T>>(chainIdentifier: C, tokenAddress: string, abortSignal?: AbortSignal): Promise<bigint>;
|
|
104
|
-
/**
|
|
105
|
-
* Pre-fetches the Bitcoin USD price data, such that further calls to {@link getBtcUsdValue},
|
|
106
|
-
* {@link getTokenUsdValue} or {@link getUsdValue} are quicker and don't need to wait for the price fetch
|
|
107
|
-
*
|
|
108
|
-
* @param abortSignal
|
|
109
|
-
*/
|
|
110
|
-
preFetchUsdPrice(abortSignal?: AbortSignal): Promise<number>;
|
|
111
|
-
/**
|
|
112
|
-
* Returns amount of `toToken` that is equivalent to `fromAmount` satoshis
|
|
113
|
-
*
|
|
114
|
-
* @param chainIdentifier Chain identifier string for the smart chain
|
|
115
|
-
* @param fromAmount Amount of satoshis
|
|
116
|
-
* @param toToken Token address
|
|
117
|
-
* @param abortSignal
|
|
118
|
-
* @param preFetchedPrice An optional price pre-fetched with {@link preFetchPrice}
|
|
119
|
-
* @throws {Error} when token is not found
|
|
120
|
-
*/
|
|
121
|
-
getFromBtcSwapAmount<C extends ChainIds<T>>(chainIdentifier: C, fromAmount: bigint, toToken: string, abortSignal?: AbortSignal, preFetchedPrice?: bigint | null): Promise<bigint>;
|
|
122
|
-
/**
|
|
123
|
-
* Returns amount of satoshis that are equivalent to `fromAmount` of `fromToken`
|
|
124
|
-
*
|
|
125
|
-
* @param chainIdentifier Chain identifier string for the smart chain
|
|
126
|
-
* @param fromAmount Amount of the token
|
|
127
|
-
* @param fromToken Token address
|
|
128
|
-
* @param abortSignal
|
|
129
|
-
* @param preFetchedPrice An optional price pre-fetched with {@link preFetchPrice}
|
|
130
|
-
* @throws {Error} when token is not found
|
|
131
|
-
*/
|
|
132
|
-
getToBtcSwapAmount<C extends ChainIds<T>>(chainIdentifier: C, fromAmount: bigint, fromToken: string, abortSignal?: AbortSignal, preFetchedPrice?: bigint): Promise<bigint>;
|
|
133
|
-
/**
|
|
134
|
-
* Returns whether the token should be ignored and pricing for it not calculated
|
|
135
|
-
*
|
|
136
|
-
* @param chainIdentifier Chain identifier string for the smart chain
|
|
137
|
-
* @param tokenAddress Token address
|
|
138
|
-
* @throws {Error} if token is not found
|
|
139
|
-
*/
|
|
140
|
-
shouldIgnore<C extends ChainIds<T>>(chainIdentifier: C, tokenAddress: string): boolean;
|
|
141
|
-
/**
|
|
142
|
-
* Returns the USD value of the bitcoin amount
|
|
143
|
-
*
|
|
144
|
-
* @param btcSats Bitcoin amount in satoshis
|
|
145
|
-
* @param abortSignal
|
|
146
|
-
* @param preFetchedUsdPrice An optional price pre-fetched with {@link preFetchUsdPrice}
|
|
147
|
-
*/
|
|
148
|
-
getBtcUsdValue(btcSats: bigint, abortSignal?: AbortSignal, preFetchedUsdPrice?: number): Promise<number>;
|
|
149
|
-
/**
|
|
150
|
-
* Returns the USD value of the smart chain token amount
|
|
151
|
-
*
|
|
152
|
-
* @param chainIdentifier Chain identifier string for the smart chain
|
|
153
|
-
* @param tokenAmount Amount of the token in base units
|
|
154
|
-
* @param tokenAddress Token address
|
|
155
|
-
* @param abortSignal
|
|
156
|
-
* @param preFetchedUsdPrice An optional price pre-fetched with {@link preFetchUsdPrice}
|
|
157
|
-
*/
|
|
158
|
-
getTokenUsdValue<C extends ChainIds<T>>(chainIdentifier: C, tokenAmount: bigint, tokenAddress: string, abortSignal?: AbortSignal, preFetchedUsdPrice?: number): Promise<number>;
|
|
159
|
-
/**
|
|
160
|
-
* Returns the USD value of the token amount
|
|
161
|
-
*
|
|
162
|
-
* @param amount Amount in base units of the token
|
|
163
|
-
* @param token Token to fetch the usd price for
|
|
164
|
-
* @param abortSignal
|
|
165
|
-
* @param preFetchedUsdPrice An optional price pre-fetched with {@link preFetchUsdPrice}
|
|
166
|
-
*/
|
|
167
|
-
getUsdValue<C extends ChainIds<T>>(amount: bigint, token: Token<C>, abortSignal?: AbortSignal, preFetchedUsdPrice?: number): Promise<number>;
|
|
168
|
-
}
|
|
1
|
+
import { ChainIds, MultiChain } from "../../swapper/Swapper";
|
|
2
|
+
import { Token } from "../../types/Token";
|
|
3
|
+
import { PriceInfoType } from "../../types/PriceInfoType";
|
|
4
|
+
/**
|
|
5
|
+
* Abstract base class for swap pricing implementations
|
|
6
|
+
*
|
|
7
|
+
* @category Pricing
|
|
8
|
+
*/
|
|
9
|
+
export declare abstract class ISwapPrice<T extends MultiChain = MultiChain> {
|
|
10
|
+
maxAllowedFeeDifferencePPM: bigint;
|
|
11
|
+
protected constructor(maxAllowedFeeDifferencePPM: bigint);
|
|
12
|
+
/**
|
|
13
|
+
* Gets the decimal places for a given token, returns `-1` if token should be ignored & `null` if token is not found
|
|
14
|
+
*
|
|
15
|
+
* @param chainIdentifier Chain identifier of the smart chain
|
|
16
|
+
* @param tokenAddress Token address
|
|
17
|
+
* @protected
|
|
18
|
+
*/
|
|
19
|
+
protected abstract getDecimals<C extends ChainIds<T>>(chainIdentifier: C, tokenAddress: string): number | null;
|
|
20
|
+
/**
|
|
21
|
+
* Returns the price of the token in BTC uSats (microSats)
|
|
22
|
+
*
|
|
23
|
+
* @param chainIdentifier Chain identifier of the smart chain
|
|
24
|
+
* @param tokenAddress Token address
|
|
25
|
+
* @param abortSignal
|
|
26
|
+
* @protected
|
|
27
|
+
*/
|
|
28
|
+
protected abstract getPrice<C extends ChainIds<T>>(chainIdentifier: C, tokenAddress: string, abortSignal?: AbortSignal): Promise<bigint>;
|
|
29
|
+
/**
|
|
30
|
+
* Returns the price of bitcoin in USD (sats/USD)
|
|
31
|
+
*
|
|
32
|
+
* @param abortSignal
|
|
33
|
+
* @protected
|
|
34
|
+
*/
|
|
35
|
+
protected abstract getUsdPrice(abortSignal?: AbortSignal): Promise<number>;
|
|
36
|
+
/**
|
|
37
|
+
* Gets the decimal places for a given token, returns `-1` if token should be ignored & throws if token is not found
|
|
38
|
+
*
|
|
39
|
+
* @param chainIdentifier Chain identifier of the smart chain
|
|
40
|
+
* @param tokenAddress Token address
|
|
41
|
+
* @throws {Error} When token is not known
|
|
42
|
+
* @protected
|
|
43
|
+
*/
|
|
44
|
+
protected getDecimalsThrowing<C extends ChainIds<T>>(chainIdentifier: C, tokenAddress: string): number;
|
|
45
|
+
/**
|
|
46
|
+
* Recomputes pricing info without fetching the current price
|
|
47
|
+
*
|
|
48
|
+
* @param chainIdentifier Chain identifier of the smart chain
|
|
49
|
+
* @param amountSats Amount of sats (BTC) to be received from the swap
|
|
50
|
+
* @param satsBaseFee Base fee in sats (BTC) as reported by the intermediary
|
|
51
|
+
* @param feePPM PPM fee rate as reported by the intermediary
|
|
52
|
+
* @param paidToken Amount of token to be paid to the swap
|
|
53
|
+
* @param tokenAddress Token address to be paid
|
|
54
|
+
*/
|
|
55
|
+
recomputePriceInfoSend<C extends ChainIds<T>>(chainIdentifier: C, amountSats: bigint, satsBaseFee: bigint, feePPM: bigint, paidToken: bigint, tokenAddress: string): PriceInfoType;
|
|
56
|
+
/**
|
|
57
|
+
* Checks whether the swap amounts are valid given the current market rate for a given pair
|
|
58
|
+
*
|
|
59
|
+
* @param chainIdentifier Chain identifier of the smart chain
|
|
60
|
+
* @param amountSats Amount of sats (BTC) to be received from the swap
|
|
61
|
+
* @param satsBaseFee Base fee in sats (BTC) as reported by the intermediary
|
|
62
|
+
* @param feePPM PPM fee rate as reported by the intermediary
|
|
63
|
+
* @param paidToken Amount of token to be paid to the swap
|
|
64
|
+
* @param tokenAddress Token address to be paid
|
|
65
|
+
* @param abortSignal
|
|
66
|
+
* @param preFetchedPrice An optional price pre-fetched with {@link preFetchPrice}
|
|
67
|
+
* @param realSwapFeeSats
|
|
68
|
+
*/
|
|
69
|
+
isValidAmountSend<C extends ChainIds<T>>(chainIdentifier: C, amountSats: bigint, satsBaseFee: bigint, feePPM: bigint, paidToken: bigint, tokenAddress: string, abortSignal?: AbortSignal, preFetchedPrice?: bigint | null, realSwapFeeSats?: bigint): Promise<PriceInfoType>;
|
|
70
|
+
/**
|
|
71
|
+
* Recomputes pricing info without fetching the current price
|
|
72
|
+
*
|
|
73
|
+
* @param chainIdentifier Chain identifier of the smart chain
|
|
74
|
+
* @param amountSats Amount of sats (BTC) to be paid to the swap
|
|
75
|
+
* @param satsBaseFee Base fee in sats (BTC) as reported by the intermediary
|
|
76
|
+
* @param feePPM PPM fee rate as reported by the intermediary
|
|
77
|
+
* @param receiveToken Amount of token to be received from the swap
|
|
78
|
+
* @param tokenAddress Token address to be received
|
|
79
|
+
*/
|
|
80
|
+
recomputePriceInfoReceive<C extends ChainIds<T>>(chainIdentifier: C, amountSats: bigint, satsBaseFee: bigint, feePPM: bigint, receiveToken: bigint, tokenAddress: string): PriceInfoType;
|
|
81
|
+
/**
|
|
82
|
+
* Checks whether the swap amounts are valid given the current market rate for a given pair
|
|
83
|
+
*
|
|
84
|
+
* @param chainIdentifier Chain identifier of the smart chain
|
|
85
|
+
* @param amountSats Amount of sats (BTC) to be paid to the swap
|
|
86
|
+
* @param satsBaseFee Base fee in sats (BTC) as reported by the intermediary
|
|
87
|
+
* @param feePPM PPM fee rate as reported by the intermediary
|
|
88
|
+
* @param receiveToken Amount of token to be received from the swap
|
|
89
|
+
* @param tokenAddress Token address to be received
|
|
90
|
+
* @param abortSignal
|
|
91
|
+
* @param preFetchedPrice An optional price pre-fetched with {@link preFetchPrice}
|
|
92
|
+
* @param realSwapFeeSats
|
|
93
|
+
*/
|
|
94
|
+
isValidAmountReceive<C extends ChainIds<T>>(chainIdentifier: C, amountSats: bigint, satsBaseFee: bigint, feePPM: bigint, receiveToken: bigint, tokenAddress: string, abortSignal?: AbortSignal, preFetchedPrice?: bigint | null, realSwapFeeSats?: bigint): Promise<PriceInfoType>;
|
|
95
|
+
/**
|
|
96
|
+
* Pre-fetches the pricing data for a given token, such that further calls to {@link isValidAmountReceive} or
|
|
97
|
+
* {@link isValidAmountSend} are quicker and don't need to wait for the price fetch
|
|
98
|
+
*
|
|
99
|
+
* @param chainIdentifier Chain identifier of the smart chain
|
|
100
|
+
* @param tokenAddress Token address
|
|
101
|
+
* @param abortSignal
|
|
102
|
+
*/
|
|
103
|
+
preFetchPrice<C extends ChainIds<T>>(chainIdentifier: C, tokenAddress: string, abortSignal?: AbortSignal): Promise<bigint>;
|
|
104
|
+
/**
|
|
105
|
+
* Pre-fetches the Bitcoin USD price data, such that further calls to {@link getBtcUsdValue},
|
|
106
|
+
* {@link getTokenUsdValue} or {@link getUsdValue} are quicker and don't need to wait for the price fetch
|
|
107
|
+
*
|
|
108
|
+
* @param abortSignal
|
|
109
|
+
*/
|
|
110
|
+
preFetchUsdPrice(abortSignal?: AbortSignal): Promise<number>;
|
|
111
|
+
/**
|
|
112
|
+
* Returns amount of `toToken` that is equivalent to `fromAmount` satoshis
|
|
113
|
+
*
|
|
114
|
+
* @param chainIdentifier Chain identifier string for the smart chain
|
|
115
|
+
* @param fromAmount Amount of satoshis
|
|
116
|
+
* @param toToken Token address
|
|
117
|
+
* @param abortSignal
|
|
118
|
+
* @param preFetchedPrice An optional price pre-fetched with {@link preFetchPrice}
|
|
119
|
+
* @throws {Error} when token is not found
|
|
120
|
+
*/
|
|
121
|
+
getFromBtcSwapAmount<C extends ChainIds<T>>(chainIdentifier: C, fromAmount: bigint, toToken: string, abortSignal?: AbortSignal, preFetchedPrice?: bigint | null): Promise<bigint>;
|
|
122
|
+
/**
|
|
123
|
+
* Returns amount of satoshis that are equivalent to `fromAmount` of `fromToken`
|
|
124
|
+
*
|
|
125
|
+
* @param chainIdentifier Chain identifier string for the smart chain
|
|
126
|
+
* @param fromAmount Amount of the token
|
|
127
|
+
* @param fromToken Token address
|
|
128
|
+
* @param abortSignal
|
|
129
|
+
* @param preFetchedPrice An optional price pre-fetched with {@link preFetchPrice}
|
|
130
|
+
* @throws {Error} when token is not found
|
|
131
|
+
*/
|
|
132
|
+
getToBtcSwapAmount<C extends ChainIds<T>>(chainIdentifier: C, fromAmount: bigint, fromToken: string, abortSignal?: AbortSignal, preFetchedPrice?: bigint): Promise<bigint>;
|
|
133
|
+
/**
|
|
134
|
+
* Returns whether the token should be ignored and pricing for it not calculated
|
|
135
|
+
*
|
|
136
|
+
* @param chainIdentifier Chain identifier string for the smart chain
|
|
137
|
+
* @param tokenAddress Token address
|
|
138
|
+
* @throws {Error} if token is not found
|
|
139
|
+
*/
|
|
140
|
+
shouldIgnore<C extends ChainIds<T>>(chainIdentifier: C, tokenAddress: string): boolean;
|
|
141
|
+
/**
|
|
142
|
+
* Returns the USD value of the bitcoin amount
|
|
143
|
+
*
|
|
144
|
+
* @param btcSats Bitcoin amount in satoshis
|
|
145
|
+
* @param abortSignal
|
|
146
|
+
* @param preFetchedUsdPrice An optional price pre-fetched with {@link preFetchUsdPrice}
|
|
147
|
+
*/
|
|
148
|
+
getBtcUsdValue(btcSats: bigint, abortSignal?: AbortSignal, preFetchedUsdPrice?: number): Promise<number>;
|
|
149
|
+
/**
|
|
150
|
+
* Returns the USD value of the smart chain token amount
|
|
151
|
+
*
|
|
152
|
+
* @param chainIdentifier Chain identifier string for the smart chain
|
|
153
|
+
* @param tokenAmount Amount of the token in base units
|
|
154
|
+
* @param tokenAddress Token address
|
|
155
|
+
* @param abortSignal
|
|
156
|
+
* @param preFetchedUsdPrice An optional price pre-fetched with {@link preFetchUsdPrice}
|
|
157
|
+
*/
|
|
158
|
+
getTokenUsdValue<C extends ChainIds<T>>(chainIdentifier: C, tokenAmount: bigint, tokenAddress: string, abortSignal?: AbortSignal, preFetchedUsdPrice?: number): Promise<number>;
|
|
159
|
+
/**
|
|
160
|
+
* Returns the USD value of the token amount
|
|
161
|
+
*
|
|
162
|
+
* @param amount Amount in base units of the token
|
|
163
|
+
* @param token Token to fetch the usd price for
|
|
164
|
+
* @param abortSignal
|
|
165
|
+
* @param preFetchedUsdPrice An optional price pre-fetched with {@link preFetchUsdPrice}
|
|
166
|
+
*/
|
|
167
|
+
getUsdValue<C extends ChainIds<T>>(amount: bigint, token: Token<C>, abortSignal?: AbortSignal, preFetchedUsdPrice?: number): Promise<number>;
|
|
168
|
+
}
|