@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
package/dist/swaps/ISwap.d.ts
CHANGED
|
@@ -1,387 +1,386 @@
|
|
|
1
|
-
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
9
|
-
import {
|
|
10
|
-
import {
|
|
11
|
-
import {
|
|
12
|
-
import {
|
|
13
|
-
import {
|
|
14
|
-
import {
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
*
|
|
18
|
-
*
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
*
|
|
31
|
-
*
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
*
|
|
37
|
-
*
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
*
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
*
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
*
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
*
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
*
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
*
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
*
|
|
77
|
-
*
|
|
78
|
-
*
|
|
79
|
-
*
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
*
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
*
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
*
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
*
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
*
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
*
|
|
110
|
-
*
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
*
|
|
116
|
-
*
|
|
117
|
-
*
|
|
118
|
-
*
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
protected constructor(wrapper: D["Wrapper"],
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
*
|
|
148
|
-
*
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
*
|
|
154
|
-
*
|
|
155
|
-
* @param
|
|
156
|
-
* @param
|
|
157
|
-
* @
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
*
|
|
163
|
-
*
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
*
|
|
169
|
-
*
|
|
170
|
-
*
|
|
171
|
-
*
|
|
172
|
-
*
|
|
173
|
-
*
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
*
|
|
179
|
-
*
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
*
|
|
201
|
-
*
|
|
202
|
-
* @
|
|
203
|
-
* @
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
*
|
|
209
|
-
*
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
*
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
*
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
*
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
*
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
*
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
*
|
|
284
|
-
*
|
|
285
|
-
*
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
*
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
*
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
*
|
|
345
|
-
*
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
*
|
|
351
|
-
*
|
|
352
|
-
*
|
|
353
|
-
*
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
*
|
|
363
|
-
*
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
*
|
|
369
|
-
*
|
|
370
|
-
*
|
|
371
|
-
*
|
|
372
|
-
*
|
|
373
|
-
*
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
*
|
|
379
|
-
*
|
|
380
|
-
*
|
|
381
|
-
*
|
|
382
|
-
*
|
|
383
|
-
*
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
}
|
|
1
|
+
import { SwapType } from "../enums/SwapType";
|
|
2
|
+
import { EventEmitter } from "events";
|
|
3
|
+
import { ISwapWrapper, SwapTypeDefinition } from "./ISwapWrapper";
|
|
4
|
+
import { ChainType } from "@atomiqlabs/base";
|
|
5
|
+
import { SwapDirection } from "../enums/SwapDirection";
|
|
6
|
+
import { Fee } from "../types/fees/Fee";
|
|
7
|
+
import { FeeBreakdown } from "../types/fees/FeeBreakdown";
|
|
8
|
+
import { PercentagePPM } from "../types/fees/PercentagePPM";
|
|
9
|
+
import { TokenAmount } from "../types/TokenAmount";
|
|
10
|
+
import { Token } from "../types/Token";
|
|
11
|
+
import { SwapExecutionAction } from "../types/SwapExecutionAction";
|
|
12
|
+
import { LoggerType } from "../utils/Logger";
|
|
13
|
+
import { PriceInfoType } from "../types/PriceInfoType";
|
|
14
|
+
import { SwapStateInfo } from "../types/SwapStateInfo";
|
|
15
|
+
/**
|
|
16
|
+
* Initialization data for creating a swap
|
|
17
|
+
*
|
|
18
|
+
* @category Swaps/Base
|
|
19
|
+
*/
|
|
20
|
+
export type ISwapInit = {
|
|
21
|
+
pricingInfo: PriceInfoType;
|
|
22
|
+
url?: string;
|
|
23
|
+
expiry: number;
|
|
24
|
+
swapFee: bigint;
|
|
25
|
+
swapFeeBtc: bigint;
|
|
26
|
+
exactIn: boolean;
|
|
27
|
+
};
|
|
28
|
+
/**
|
|
29
|
+
* Type guard to check if an object is an ISwapInit
|
|
30
|
+
*
|
|
31
|
+
* @category Swaps/Base
|
|
32
|
+
*/
|
|
33
|
+
export declare function isISwapInit(obj: any): obj is ISwapInit;
|
|
34
|
+
/**
|
|
35
|
+
* Base abstract class for all swap types
|
|
36
|
+
*
|
|
37
|
+
* @category Swaps/Base
|
|
38
|
+
*/
|
|
39
|
+
export declare abstract class ISwap<T extends ChainType = ChainType, D extends SwapTypeDefinition<T, ISwapWrapper<T, D>, ISwap<T, D, S>> = SwapTypeDefinition<T, ISwapWrapper<T, any>, ISwap<T, any, any>>, S extends number = number> {
|
|
40
|
+
/**
|
|
41
|
+
* Swap type
|
|
42
|
+
*/
|
|
43
|
+
protected readonly abstract TYPE: SwapType;
|
|
44
|
+
/**
|
|
45
|
+
* Description for the states
|
|
46
|
+
* @internal
|
|
47
|
+
*/
|
|
48
|
+
protected readonly abstract swapStateDescription: Record<S, string>;
|
|
49
|
+
/**
|
|
50
|
+
* Name of the states
|
|
51
|
+
* @internal
|
|
52
|
+
*/
|
|
53
|
+
protected readonly abstract swapStateName: (state: number) => string;
|
|
54
|
+
/**
|
|
55
|
+
* Swap logger
|
|
56
|
+
* @internal
|
|
57
|
+
*/
|
|
58
|
+
protected readonly abstract logger: LoggerType;
|
|
59
|
+
/**
|
|
60
|
+
* Current newest defined version of the swap
|
|
61
|
+
* @internal
|
|
62
|
+
*/
|
|
63
|
+
protected readonly currentVersion: number;
|
|
64
|
+
/**
|
|
65
|
+
* Wrapper instance holding this swap
|
|
66
|
+
* @internal
|
|
67
|
+
*/
|
|
68
|
+
protected readonly wrapper: D["Wrapper"];
|
|
69
|
+
/**
|
|
70
|
+
* The current version of the swap
|
|
71
|
+
* @internal
|
|
72
|
+
*/
|
|
73
|
+
protected version: number;
|
|
74
|
+
/**
|
|
75
|
+
* Whether a swap was initialized, a swap is considered initialize on first interaction with it, i.e.
|
|
76
|
+
* calling commit() on a Smart chain -> Bitcoin swaps, calling waitForPayment() or similar on the other
|
|
77
|
+
* direction. Not initiated swaps are not saved to the persistent storage by default (see
|
|
78
|
+
* {@link SwapperOptions.saveUninitializedSwaps})
|
|
79
|
+
* @internal
|
|
80
|
+
*/
|
|
81
|
+
protected initiated: boolean;
|
|
82
|
+
/**
|
|
83
|
+
* Expiration of the swap quote
|
|
84
|
+
* @internal
|
|
85
|
+
*/
|
|
86
|
+
protected expiry: number;
|
|
87
|
+
/**
|
|
88
|
+
* Pricing information of the swap
|
|
89
|
+
* @internal
|
|
90
|
+
*/
|
|
91
|
+
protected pricingInfo?: PriceInfoType;
|
|
92
|
+
/**
|
|
93
|
+
* Swap fee in the non-bitcoin token
|
|
94
|
+
* @internal
|
|
95
|
+
*/
|
|
96
|
+
protected swapFee: bigint;
|
|
97
|
+
/**
|
|
98
|
+
* Swap fee in bitcoin satoshis
|
|
99
|
+
* @internal
|
|
100
|
+
*/
|
|
101
|
+
protected swapFeeBtc: bigint;
|
|
102
|
+
/**
|
|
103
|
+
* Swap state
|
|
104
|
+
* @internal
|
|
105
|
+
*/
|
|
106
|
+
_state: S;
|
|
107
|
+
/**
|
|
108
|
+
* Random nonce to differentiate the swap from others with the same identifier hash (i.e. when quoting the same swap
|
|
109
|
+
* from multiple LPs)
|
|
110
|
+
* @internal
|
|
111
|
+
*/
|
|
112
|
+
_randomNonce: string;
|
|
113
|
+
/**
|
|
114
|
+
* Whether the swap is saved in the persistent storage or not.
|
|
115
|
+
*
|
|
116
|
+
* @remarks This field itself is not persisted but is instead derived during runtime
|
|
117
|
+
*
|
|
118
|
+
* @internal
|
|
119
|
+
*/
|
|
120
|
+
_persisted: boolean;
|
|
121
|
+
/**
|
|
122
|
+
* Event emitter emitting `"swapState"` event when swap's state changes
|
|
123
|
+
*/
|
|
124
|
+
readonly events: EventEmitter<{
|
|
125
|
+
swapState: [D["Swap"]];
|
|
126
|
+
}>;
|
|
127
|
+
/**
|
|
128
|
+
* URL of the intermediary (LP) used for this swap, already has the swap service specific path appended
|
|
129
|
+
*/
|
|
130
|
+
readonly url?: string;
|
|
131
|
+
/**
|
|
132
|
+
* Smart chain identifier string corresponding to this swap
|
|
133
|
+
*/
|
|
134
|
+
readonly chainIdentifier: T["ChainId"];
|
|
135
|
+
/**
|
|
136
|
+
* Whether a swap is an exact input swap
|
|
137
|
+
*/
|
|
138
|
+
readonly exactIn: boolean;
|
|
139
|
+
/**
|
|
140
|
+
* A UNIX milliseconds timestamps of when this swap was created
|
|
141
|
+
*/
|
|
142
|
+
createdAt: number;
|
|
143
|
+
protected constructor(wrapper: D["Wrapper"], obj: any);
|
|
144
|
+
protected constructor(wrapper: D["Wrapper"], swapInit: ISwapInit);
|
|
145
|
+
/**
|
|
146
|
+
* Called when swap is deserialized to potentially update the version of the data for the swap
|
|
147
|
+
*
|
|
148
|
+
* @internal
|
|
149
|
+
*/
|
|
150
|
+
protected abstract upgradeVersion(): void;
|
|
151
|
+
/**
|
|
152
|
+
* Waits till the swap reaches a specific state
|
|
153
|
+
*
|
|
154
|
+
* @param targetState The state to wait for
|
|
155
|
+
* @param type Whether to wait for the state exactly or also to a state with a higher number
|
|
156
|
+
* @param abortSignal Abort signal
|
|
157
|
+
* @internal
|
|
158
|
+
*/
|
|
159
|
+
protected waitTillState(targetState: S, type?: "eq" | "gte" | "neq", abortSignal?: AbortSignal): Promise<void>;
|
|
160
|
+
/**
|
|
161
|
+
* Returns a list of steps or transactions required to finish and settle the swap
|
|
162
|
+
*
|
|
163
|
+
* @param options Additional options for executing the swap
|
|
164
|
+
*/
|
|
165
|
+
abstract txsExecute(options?: any): Promise<SwapExecutionAction<T>[]>;
|
|
166
|
+
/**
|
|
167
|
+
* Executes the swap with the provided wallet, the exact arguments for this functions differ for various swap
|
|
168
|
+
* types. Check the `execute()` function signature in the respective swap class to see the required arguments.
|
|
169
|
+
*
|
|
170
|
+
* @param args Execution arguments, usually contains a source wallet object, callbacks and options, for exact
|
|
171
|
+
* syntax check the respective swap class.
|
|
172
|
+
*
|
|
173
|
+
* @returns Whether a swap was successfully executed or not, if it wasn't the user can refund or claim manually
|
|
174
|
+
*/
|
|
175
|
+
abstract execute(...args: any[]): Promise<boolean>;
|
|
176
|
+
/**
|
|
177
|
+
* This attempts to populate missing fields in the pricing info based on the swap amounts
|
|
178
|
+
*
|
|
179
|
+
* @internal
|
|
180
|
+
*/
|
|
181
|
+
protected tryRecomputeSwapPrice(): void;
|
|
182
|
+
/**
|
|
183
|
+
* Re-fetches & revalidates the price data based on the current market prices
|
|
184
|
+
*/
|
|
185
|
+
refreshPriceData(): Promise<void>;
|
|
186
|
+
/**
|
|
187
|
+
* Checks if the pricing for the swap is valid, according to max allowed price difference set in the ISwapPrice
|
|
188
|
+
*/
|
|
189
|
+
hasValidPrice(): boolean;
|
|
190
|
+
/**
|
|
191
|
+
* Returns pricing info about the swap
|
|
192
|
+
*/
|
|
193
|
+
getPriceInfo(): {
|
|
194
|
+
marketPrice?: number;
|
|
195
|
+
swapPrice: number;
|
|
196
|
+
difference: PercentagePPM;
|
|
197
|
+
};
|
|
198
|
+
/**
|
|
199
|
+
* Asserts a given signer is the initiator of this swap
|
|
200
|
+
*
|
|
201
|
+
* @param signer Signer to check with this swap's initiator
|
|
202
|
+
* @throws {Error} When signer's address doesn't match with the swap's initiator one
|
|
203
|
+
* @internal
|
|
204
|
+
*/
|
|
205
|
+
protected checkSigner(signer: T["Signer"] | string): void;
|
|
206
|
+
/**
|
|
207
|
+
* Returns an escrow hash of the swap
|
|
208
|
+
*
|
|
209
|
+
* @internal
|
|
210
|
+
*/
|
|
211
|
+
abstract _getEscrowHash(): string | null;
|
|
212
|
+
/**
|
|
213
|
+
* Checks if the swap's quote is expired for good (i.e. the swap strictly cannot be initiated anymore)
|
|
214
|
+
* @internal
|
|
215
|
+
*/
|
|
216
|
+
abstract _verifyQuoteDefinitelyExpired(): Promise<boolean>;
|
|
217
|
+
/**
|
|
218
|
+
* Checks if the swap's quote is still valid
|
|
219
|
+
* @internal
|
|
220
|
+
*/
|
|
221
|
+
abstract _verifyQuoteValid(): Promise<boolean>;
|
|
222
|
+
/**
|
|
223
|
+
* Returns the intiator address of the swap - address that created this swap
|
|
224
|
+
* @internal
|
|
225
|
+
*/
|
|
226
|
+
abstract _getInitiator(): string;
|
|
227
|
+
/**
|
|
228
|
+
* Sets this swap as initiated
|
|
229
|
+
* @internal
|
|
230
|
+
*/
|
|
231
|
+
_setInitiated(): void;
|
|
232
|
+
/**
|
|
233
|
+
* Returns source address of the swap
|
|
234
|
+
*/
|
|
235
|
+
abstract getInputAddress(): string | null;
|
|
236
|
+
/**
|
|
237
|
+
* Returns destination address of the swap
|
|
238
|
+
*/
|
|
239
|
+
abstract getOutputAddress(): string | null;
|
|
240
|
+
/**
|
|
241
|
+
* Returns swap input transaction ID on the source chain
|
|
242
|
+
*/
|
|
243
|
+
abstract getInputTxId(): string | null;
|
|
244
|
+
/**
|
|
245
|
+
* Returns swap output transaction ID on the destination chain
|
|
246
|
+
*/
|
|
247
|
+
abstract getOutputTxId(): string | null;
|
|
248
|
+
/**
|
|
249
|
+
* Returns the ID of the swap, as used in the storage
|
|
250
|
+
*/
|
|
251
|
+
abstract getId(): string;
|
|
252
|
+
/**
|
|
253
|
+
* Checks whether there is some action required from the user for this swap - can mean either refundable or claimable
|
|
254
|
+
*/
|
|
255
|
+
abstract requiresAction(): boolean;
|
|
256
|
+
/**
|
|
257
|
+
* Returns whether the swap is finished and in its terminal state (this can mean successful, refunded or failed)
|
|
258
|
+
*/
|
|
259
|
+
abstract isFinished(): boolean;
|
|
260
|
+
/**
|
|
261
|
+
* Checks whether the swap's quote has definitely expired and cannot be committed anymore, we can remove such swap
|
|
262
|
+
*/
|
|
263
|
+
abstract isQuoteExpired(): boolean;
|
|
264
|
+
/**
|
|
265
|
+
* Checks whether the swap's quote is soft expired (this means there is not enough time buffer for it to commit,
|
|
266
|
+
* but it still can happen)
|
|
267
|
+
*/
|
|
268
|
+
abstract isQuoteSoftExpired(): boolean;
|
|
269
|
+
/**
|
|
270
|
+
* Returns whether the swap finished successful
|
|
271
|
+
*/
|
|
272
|
+
abstract isSuccessful(): boolean;
|
|
273
|
+
/**
|
|
274
|
+
* Returns whether the swap failed (e.g. was refunded)
|
|
275
|
+
*/
|
|
276
|
+
abstract isFailed(): boolean;
|
|
277
|
+
/**
|
|
278
|
+
* Returns whether the swap is currently being processed
|
|
279
|
+
*/
|
|
280
|
+
abstract isInProgress(): boolean;
|
|
281
|
+
/**
|
|
282
|
+
* Whether a swap was initialized, a swap is considered initialized on first interaction with it, i.e.
|
|
283
|
+
* calling commit() on a Smart chain -> Bitcoin swaps, calling waitForPayment() or similar on the other
|
|
284
|
+
* direction. Not initiated swaps are not saved to the persistent storage by default (see
|
|
285
|
+
* {@link SwapperOptions.saveUninitializedSwaps})
|
|
286
|
+
*/
|
|
287
|
+
isInitiated(): boolean;
|
|
288
|
+
/**
|
|
289
|
+
* Returns quote expiry in UNIX millis
|
|
290
|
+
*/
|
|
291
|
+
getQuoteExpiry(): number;
|
|
292
|
+
/**
|
|
293
|
+
* Returns the type of the swap
|
|
294
|
+
*/
|
|
295
|
+
getType(): SwapType;
|
|
296
|
+
/**
|
|
297
|
+
* Returns the direction of the swap
|
|
298
|
+
*/
|
|
299
|
+
getDirection(): SwapDirection;
|
|
300
|
+
/**
|
|
301
|
+
* Returns the current state of the swap
|
|
302
|
+
*/
|
|
303
|
+
getState(): S;
|
|
304
|
+
/**
|
|
305
|
+
* Returns the current state of the swap along with the human-readable description of the state
|
|
306
|
+
*/
|
|
307
|
+
getStateInfo(): SwapStateInfo<S>;
|
|
308
|
+
/**
|
|
309
|
+
* Returns a state-dependent set of actions for the user to execute, or empty array if there is currently
|
|
310
|
+
* no action required from the user to execute.
|
|
311
|
+
*/
|
|
312
|
+
abstract getCurrentActions(): Promise<SwapExecutionAction<T>[]>;
|
|
313
|
+
/**
|
|
314
|
+
* Returns output amount of the swap, user receives this much
|
|
315
|
+
*/
|
|
316
|
+
abstract getOutput(): TokenAmount;
|
|
317
|
+
/**
|
|
318
|
+
* Returns the output token of the swap
|
|
319
|
+
*/
|
|
320
|
+
abstract getOutputToken(): Token<T["ChainId"]>;
|
|
321
|
+
/**
|
|
322
|
+
* Returns input amount of the swap, user needs to pay this much
|
|
323
|
+
*/
|
|
324
|
+
abstract getInput(): TokenAmount;
|
|
325
|
+
/**
|
|
326
|
+
* Returns the input token of the swap
|
|
327
|
+
*/
|
|
328
|
+
abstract getInputToken(): Token<T["ChainId"]>;
|
|
329
|
+
/**
|
|
330
|
+
* Returns input amount of the swap without the fees (swap fee, network fee)
|
|
331
|
+
*/
|
|
332
|
+
abstract getInputWithoutFee(): TokenAmount;
|
|
333
|
+
/**
|
|
334
|
+
* Returns total fee for the swap, the fee is represented in source currency & destination currency, but is
|
|
335
|
+
* paid only once
|
|
336
|
+
*/
|
|
337
|
+
abstract getFee(): Fee;
|
|
338
|
+
/**
|
|
339
|
+
* Returns the breakdown of all the fees paid
|
|
340
|
+
*/
|
|
341
|
+
abstract getFeeBreakdown(): FeeBreakdown<T["ChainId"]>;
|
|
342
|
+
/**
|
|
343
|
+
* Saves the swap data to the underlying storage, or removes it if it is in a quote expired state
|
|
344
|
+
*
|
|
345
|
+
* @internal
|
|
346
|
+
*/
|
|
347
|
+
_save(): Promise<void>;
|
|
348
|
+
/**
|
|
349
|
+
* Saves the swap data and also emits a swap state change
|
|
350
|
+
*
|
|
351
|
+
* @param state Optional state to set before the swap is saved an event emitted
|
|
352
|
+
*
|
|
353
|
+
* @internal
|
|
354
|
+
*/
|
|
355
|
+
_saveAndEmit(state?: S): Promise<void>;
|
|
356
|
+
/**
|
|
357
|
+
* Serializes the swap to a JSON stringifiable representation (i.e. no bigints, buffers etc.)
|
|
358
|
+
*/
|
|
359
|
+
serialize(): any;
|
|
360
|
+
/**
|
|
361
|
+
* Emits a `swapState` event with the current swap
|
|
362
|
+
*
|
|
363
|
+
* @internal
|
|
364
|
+
*/
|
|
365
|
+
_emitEvent(): void;
|
|
366
|
+
/**
|
|
367
|
+
* Synchronizes swap state from chain and/or LP node, usually ran on startup
|
|
368
|
+
*
|
|
369
|
+
* @param save whether to save the new swap state or not
|
|
370
|
+
*
|
|
371
|
+
* @returns {boolean} true if the swap changed, false if the swap hasn't changed
|
|
372
|
+
*
|
|
373
|
+
* @internal
|
|
374
|
+
*/
|
|
375
|
+
abstract _sync(save?: boolean): Promise<boolean>;
|
|
376
|
+
/**
|
|
377
|
+
* Runs quick checks on the swap, such as checking the expiry, usually ran periodically every few seconds
|
|
378
|
+
*
|
|
379
|
+
* @param save whether to save the new swap state or not
|
|
380
|
+
*
|
|
381
|
+
* @returns {boolean} true if the swap changed, false if the swap hasn't changed
|
|
382
|
+
*
|
|
383
|
+
* @internal
|
|
384
|
+
*/
|
|
385
|
+
abstract _tick(save?: boolean): Promise<boolean>;
|
|
386
|
+
}
|