@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.
Files changed (226) hide show
  1. package/dist/SmartChainAssets.d.ts +181 -181
  2. package/dist/SmartChainAssets.js +181 -181
  3. package/dist/bitcoin/coinselect2/accumulative.d.ts +6 -6
  4. package/dist/bitcoin/coinselect2/accumulative.js +52 -51
  5. package/dist/bitcoin/coinselect2/blackjack.d.ts +6 -6
  6. package/dist/bitcoin/coinselect2/blackjack.js +38 -37
  7. package/dist/bitcoin/coinselect2/index.d.ts +19 -17
  8. package/dist/bitcoin/coinselect2/index.js +69 -69
  9. package/dist/bitcoin/coinselect2/utils.d.ts +77 -75
  10. package/dist/bitcoin/coinselect2/utils.js +123 -123
  11. package/dist/bitcoin/wallet/BitcoinWallet.d.ts +130 -128
  12. package/dist/bitcoin/wallet/BitcoinWallet.js +322 -322
  13. package/dist/bitcoin/wallet/IBitcoinWallet.d.ts +78 -78
  14. package/dist/bitcoin/wallet/IBitcoinWallet.js +21 -20
  15. package/dist/bitcoin/wallet/SingleAddressBitcoinWallet.d.ts +101 -99
  16. package/dist/bitcoin/wallet/SingleAddressBitcoinWallet.js +190 -176
  17. package/dist/enums/FeeType.d.ts +15 -15
  18. package/dist/enums/FeeType.js +19 -19
  19. package/dist/enums/SwapAmountType.d.ts +15 -15
  20. package/dist/enums/SwapAmountType.js +19 -19
  21. package/dist/enums/SwapDirection.d.ts +15 -15
  22. package/dist/enums/SwapDirection.js +19 -19
  23. package/dist/enums/SwapSide.d.ts +15 -15
  24. package/dist/enums/SwapSide.js +19 -19
  25. package/dist/enums/SwapType.d.ts +75 -75
  26. package/dist/enums/SwapType.js +79 -79
  27. package/dist/errors/IntermediaryError.d.ts +13 -13
  28. package/dist/errors/IntermediaryError.js +27 -27
  29. package/dist/errors/RequestError.d.ts +32 -32
  30. package/dist/errors/RequestError.js +54 -54
  31. package/dist/errors/UserError.d.ts +8 -8
  32. package/dist/errors/UserError.js +16 -16
  33. package/dist/events/UnifiedSwapEventListener.d.ts +23 -23
  34. package/dist/events/UnifiedSwapEventListener.js +130 -130
  35. package/dist/http/HttpUtils.d.ts +27 -27
  36. package/dist/http/HttpUtils.js +91 -90
  37. package/dist/http/paramcoders/IParamReader.d.ts +8 -8
  38. package/dist/http/paramcoders/IParamReader.js +2 -2
  39. package/dist/http/paramcoders/ParamDecoder.d.ts +44 -42
  40. package/dist/http/paramcoders/ParamDecoder.js +137 -137
  41. package/dist/http/paramcoders/ParamEncoder.d.ts +20 -18
  42. package/dist/http/paramcoders/ParamEncoder.js +36 -36
  43. package/dist/http/paramcoders/SchemaVerifier.d.ts +26 -26
  44. package/dist/http/paramcoders/SchemaVerifier.js +145 -145
  45. package/dist/http/paramcoders/client/ResponseParamDecoder.d.ts +11 -11
  46. package/dist/http/paramcoders/client/ResponseParamDecoder.js +57 -57
  47. package/dist/http/paramcoders/client/StreamParamEncoder.d.ts +13 -11
  48. package/dist/http/paramcoders/client/StreamParamEncoder.js +26 -26
  49. package/dist/http/paramcoders/client/StreamingFetchPromise.d.ts +16 -16
  50. package/dist/http/paramcoders/client/StreamingFetchPromise.js +174 -173
  51. package/dist/index.d.ts +85 -85
  52. package/dist/index.js +158 -158
  53. package/dist/intermediaries/Intermediary.d.ts +157 -157
  54. package/dist/intermediaries/Intermediary.js +142 -142
  55. package/dist/intermediaries/IntermediaryDiscovery.d.ts +199 -198
  56. package/dist/intermediaries/IntermediaryDiscovery.js +406 -406
  57. package/dist/intermediaries/apis/IntermediaryAPI.d.ts +439 -437
  58. package/dist/intermediaries/apis/IntermediaryAPI.js +603 -603
  59. package/dist/intermediaries/apis/TrustedIntermediaryAPI.d.ts +155 -155
  60. package/dist/intermediaries/apis/TrustedIntermediaryAPI.js +137 -137
  61. package/dist/lnurl/LNURL.d.ts +102 -102
  62. package/dist/lnurl/LNURL.js +321 -321
  63. package/dist/prices/RedundantSwapPrice.d.ts +110 -110
  64. package/dist/prices/RedundantSwapPrice.js +222 -222
  65. package/dist/prices/SingleSwapPrice.d.ts +34 -34
  66. package/dist/prices/SingleSwapPrice.js +44 -44
  67. package/dist/prices/SwapPriceWithChain.d.ts +107 -107
  68. package/dist/prices/SwapPriceWithChain.js +128 -128
  69. package/dist/prices/abstract/ICachedSwapPrice.d.ts +28 -28
  70. package/dist/prices/abstract/ICachedSwapPrice.js +62 -62
  71. package/dist/prices/abstract/IPriceProvider.d.ts +81 -81
  72. package/dist/prices/abstract/IPriceProvider.js +74 -74
  73. package/dist/prices/abstract/ISwapPrice.d.ts +168 -168
  74. package/dist/prices/abstract/ISwapPrice.js +279 -279
  75. package/dist/prices/providers/BinancePriceProvider.d.ts +23 -23
  76. package/dist/prices/providers/BinancePriceProvider.js +30 -30
  77. package/dist/prices/providers/CoinGeckoPriceProvider.d.ts +23 -23
  78. package/dist/prices/providers/CoinGeckoPriceProvider.js +29 -29
  79. package/dist/prices/providers/CoinPaprikaPriceProvider.d.ts +25 -25
  80. package/dist/prices/providers/CoinPaprikaPriceProvider.js +29 -29
  81. package/dist/prices/providers/CustomPriceProvider.d.ts +24 -24
  82. package/dist/prices/providers/CustomPriceProvider.js +35 -35
  83. package/dist/prices/providers/KrakenPriceProvider.d.ts +38 -38
  84. package/dist/prices/providers/KrakenPriceProvider.js +45 -45
  85. package/dist/prices/providers/OKXPriceProvider.d.ts +34 -34
  86. package/dist/prices/providers/OKXPriceProvider.js +29 -29
  87. package/dist/prices/providers/abstract/ExchangePriceProvider.d.ts +17 -17
  88. package/dist/prices/providers/abstract/ExchangePriceProvider.js +21 -21
  89. package/dist/prices/providers/abstract/HttpPriceProvider.d.ts +7 -7
  90. package/dist/prices/providers/abstract/HttpPriceProvider.js +12 -12
  91. package/dist/storage/IUnifiedStorage.d.ts +85 -85
  92. package/dist/storage/IUnifiedStorage.js +2 -2
  93. package/dist/storage/UnifiedSwapStorage.d.ts +114 -114
  94. package/dist/storage/UnifiedSwapStorage.js +116 -116
  95. package/dist/storage-browser/IndexedDBUnifiedStorage.d.ts +63 -63
  96. package/dist/storage-browser/IndexedDBUnifiedStorage.js +298 -298
  97. package/dist/storage-browser/LocalStorageManager.d.ts +49 -49
  98. package/dist/storage-browser/LocalStorageManager.js +93 -93
  99. package/dist/swapper/Swapper.d.ts +687 -686
  100. package/dist/swapper/Swapper.js +1603 -1603
  101. package/dist/swapper/SwapperFactory.d.ts +135 -135
  102. package/dist/swapper/SwapperFactory.js +162 -162
  103. package/dist/swapper/SwapperUtils.d.ts +200 -200
  104. package/dist/swapper/SwapperUtils.js +467 -467
  105. package/dist/swapper/SwapperWithChain.d.ts +404 -404
  106. package/dist/swapper/SwapperWithChain.js +469 -469
  107. package/dist/swapper/SwapperWithSigner.d.ts +322 -322
  108. package/dist/swapper/SwapperWithSigner.js +318 -318
  109. package/dist/swaps/IAddressSwap.d.ts +22 -22
  110. package/dist/swaps/IAddressSwap.js +14 -13
  111. package/dist/swaps/IBTCWalletSwap.d.ts +73 -73
  112. package/dist/swaps/IBTCWalletSwap.js +18 -17
  113. package/dist/swaps/IClaimableSwap.d.ts +49 -49
  114. package/dist/swaps/IClaimableSwap.js +15 -14
  115. package/dist/swaps/IClaimableSwapWrapper.d.ts +15 -15
  116. package/dist/swaps/IClaimableSwapWrapper.js +2 -2
  117. package/dist/swaps/IRefundableSwap.d.ts +43 -43
  118. package/dist/swaps/IRefundableSwap.js +14 -13
  119. package/dist/swaps/ISwap.d.ts +387 -386
  120. package/dist/swaps/ISwap.js +346 -346
  121. package/dist/swaps/ISwapWithGasDrop.d.ts +21 -21
  122. package/dist/swaps/ISwapWithGasDrop.js +12 -11
  123. package/dist/swaps/ISwapWrapper.d.ts +285 -283
  124. package/dist/swaps/ISwapWrapper.js +353 -353
  125. package/dist/swaps/escrow_swaps/IEscrowSelfInitSwap.d.ts +98 -98
  126. package/dist/swaps/escrow_swaps/IEscrowSelfInitSwap.js +126 -126
  127. package/dist/swaps/escrow_swaps/IEscrowSwap.d.ts +135 -133
  128. package/dist/swaps/escrow_swaps/IEscrowSwap.js +169 -169
  129. package/dist/swaps/escrow_swaps/IEscrowSwapWrapper.d.ts +115 -114
  130. package/dist/swaps/escrow_swaps/IEscrowSwapWrapper.js +134 -134
  131. package/dist/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.d.ts +101 -98
  132. package/dist/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.js +130 -130
  133. package/dist/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.d.ts +162 -162
  134. package/dist/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.js +190 -190
  135. package/dist/swaps/escrow_swaps/frombtc/IFromBTCWrapper.d.ts +58 -58
  136. package/dist/swaps/escrow_swaps/frombtc/IFromBTCWrapper.js +78 -78
  137. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.d.ts +531 -529
  138. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.js +1285 -1285
  139. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.d.ts +184 -181
  140. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.js +418 -418
  141. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.d.ts +583 -581
  142. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.js +1371 -1371
  143. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.d.ts +228 -225
  144. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.js +506 -506
  145. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.d.ts +458 -458
  146. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.js +1126 -1126
  147. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.d.ts +191 -190
  148. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.js +378 -378
  149. package/dist/swaps/escrow_swaps/tobtc/IToBTCSwap.d.ts +403 -403
  150. package/dist/swaps/escrow_swaps/tobtc/IToBTCSwap.js +924 -924
  151. package/dist/swaps/escrow_swaps/tobtc/IToBTCWrapper.d.ts +62 -62
  152. package/dist/swaps/escrow_swaps/tobtc/IToBTCWrapper.js +112 -112
  153. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.d.ts +127 -125
  154. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.js +256 -256
  155. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.d.ts +242 -241
  156. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.js +520 -520
  157. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.d.ts +73 -73
  158. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.js +155 -155
  159. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.d.ts +128 -127
  160. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.js +278 -278
  161. package/dist/swaps/spv_swaps/SpvFromBTCSwap.d.ts +630 -630
  162. package/dist/swaps/spv_swaps/SpvFromBTCSwap.js +1443 -1443
  163. package/dist/swaps/spv_swaps/SpvFromBTCWrapper.d.ts +214 -213
  164. package/dist/swaps/spv_swaps/SpvFromBTCWrapper.js +756 -756
  165. package/dist/swaps/trusted/ln/LnForGasSwap.d.ts +261 -261
  166. package/dist/swaps/trusted/ln/LnForGasSwap.js +511 -511
  167. package/dist/swaps/trusted/ln/LnForGasWrapper.d.ts +40 -40
  168. package/dist/swaps/trusted/ln/LnForGasWrapper.js +82 -82
  169. package/dist/swaps/trusted/onchain/OnchainForGasSwap.d.ts +342 -342
  170. package/dist/swaps/trusted/onchain/OnchainForGasSwap.js +715 -715
  171. package/dist/swaps/trusted/onchain/OnchainForGasWrapper.d.ts +69 -68
  172. package/dist/swaps/trusted/onchain/OnchainForGasWrapper.js +92 -92
  173. package/dist/types/AmountData.d.ts +10 -10
  174. package/dist/types/AmountData.js +2 -2
  175. package/dist/types/CustomPriceFunction.d.ts +11 -11
  176. package/dist/types/CustomPriceFunction.js +2 -2
  177. package/dist/types/PriceInfoType.d.ts +28 -28
  178. package/dist/types/PriceInfoType.js +57 -56
  179. package/dist/types/SwapExecutionAction.d.ts +88 -88
  180. package/dist/types/SwapExecutionAction.js +2 -2
  181. package/dist/types/SwapStateInfo.d.ts +5 -5
  182. package/dist/types/SwapStateInfo.js +2 -2
  183. package/dist/types/SwapWithSigner.d.ts +17 -17
  184. package/dist/types/SwapWithSigner.js +43 -42
  185. package/dist/types/Token.d.ts +99 -99
  186. package/dist/types/Token.js +76 -76
  187. package/dist/types/TokenAmount.d.ts +69 -69
  188. package/dist/types/TokenAmount.js +60 -59
  189. package/dist/types/fees/Fee.d.ts +50 -50
  190. package/dist/types/fees/Fee.js +2 -2
  191. package/dist/types/fees/FeeBreakdown.d.ts +11 -11
  192. package/dist/types/fees/FeeBreakdown.js +2 -2
  193. package/dist/types/fees/PercentagePPM.d.ts +17 -17
  194. package/dist/types/fees/PercentagePPM.js +18 -17
  195. package/dist/types/lnurl/LNURLPay.d.ts +61 -61
  196. package/dist/types/lnurl/LNURLPay.js +31 -30
  197. package/dist/types/lnurl/LNURLWithdraw.d.ts +48 -48
  198. package/dist/types/lnurl/LNURLWithdraw.js +27 -26
  199. package/dist/types/wallets/LightningInvoiceCreateService.d.ts +24 -24
  200. package/dist/types/wallets/LightningInvoiceCreateService.js +15 -14
  201. package/dist/types/wallets/MinimalBitcoinWalletInterface.d.ts +23 -23
  202. package/dist/types/wallets/MinimalBitcoinWalletInterface.js +2 -2
  203. package/dist/types/wallets/MinimalLightningNetworkWalletInterface.d.ts +9 -9
  204. package/dist/types/wallets/MinimalLightningNetworkWalletInterface.js +2 -2
  205. package/dist/utils/AutomaticClockDriftCorrection.d.ts +1 -1
  206. package/dist/utils/AutomaticClockDriftCorrection.js +70 -69
  207. package/dist/utils/BitcoinUtils.d.ts +14 -12
  208. package/dist/utils/BitcoinUtils.js +102 -101
  209. package/dist/utils/BitcoinWalletUtils.d.ts +7 -7
  210. package/dist/utils/BitcoinWalletUtils.js +14 -13
  211. package/dist/utils/Logger.d.ts +7 -7
  212. package/dist/utils/Logger.js +12 -11
  213. package/dist/utils/RetryUtils.d.ts +22 -22
  214. package/dist/utils/RetryUtils.js +67 -66
  215. package/dist/utils/SwapUtils.d.ts +88 -88
  216. package/dist/utils/SwapUtils.js +72 -72
  217. package/dist/utils/TimeoutUtils.d.ts +17 -17
  218. package/dist/utils/TimeoutUtils.js +55 -54
  219. package/dist/utils/TokenUtils.d.ts +19 -19
  220. package/dist/utils/TokenUtils.js +37 -36
  221. package/dist/utils/TypeUtils.d.ts +7 -7
  222. package/dist/utils/TypeUtils.js +2 -2
  223. package/dist/utils/Utils.d.ts +58 -56
  224. package/dist/utils/Utils.js +194 -193
  225. package/package.json +1 -1
  226. package/src/bitcoin/wallet/SingleAddressBitcoinWallet.ts +14 -2
@@ -1,21 +1,21 @@
1
- import { ChainType } from "@atomiqlabs/base";
2
- import { TokenAmount } from "../types/TokenAmount";
3
- import { SCToken } from "../types/Token";
4
- /**
5
- * Type guard to check if a swap has gas drop functionality
6
- *
7
- * @category Swaps/Types
8
- */
9
- export declare function isSwapWithGasDrop(swap: any): swap is ISwapWithGasDrop<any>;
10
- /**
11
- * Interface for swaps with gas drop functionality
12
- *
13
- * @category Swaps/Types
14
- */
15
- export interface ISwapWithGasDrop<T extends ChainType> {
16
- /**
17
- * Returns the output of the "gas drop", additional native token received by the user on
18
- * the destination chain
19
- */
20
- getGasDropOutput(): TokenAmount<SCToken<T["ChainId"]>>;
21
- }
1
+ import { ChainType } from "@atomiqlabs/base";
2
+ import { TokenAmount } from "../types/TokenAmount";
3
+ import { SCToken } from "../types/Token";
4
+ /**
5
+ * Type guard to check if a swap has gas drop functionality
6
+ *
7
+ * @category Swaps/Types
8
+ */
9
+ export declare function isSwapWithGasDrop(swap: any): swap is ISwapWithGasDrop<any>;
10
+ /**
11
+ * Interface for swaps with gas drop functionality
12
+ *
13
+ * @category Swaps/Types
14
+ */
15
+ export interface ISwapWithGasDrop<T extends ChainType> {
16
+ /**
17
+ * Returns the output of the "gas drop", additional native token received by the user on
18
+ * the destination chain
19
+ */
20
+ getGasDropOutput(): TokenAmount<SCToken<T["ChainId"]>>;
21
+ }
@@ -1,11 +1,12 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.isSwapWithGasDrop = isSwapWithGasDrop;
4
- /**
5
- * Type guard to check if a swap has gas drop functionality
6
- *
7
- * @category Swaps/Types
8
- */
9
- function isSwapWithGasDrop(swap) {
10
- return swap != null && typeof (swap.getGasDropOutput) === "function";
11
- }
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.isSwapWithGasDrop = void 0;
4
+ /**
5
+ * Type guard to check if a swap has gas drop functionality
6
+ *
7
+ * @category Swaps/Types
8
+ */
9
+ function isSwapWithGasDrop(swap) {
10
+ return swap != null && typeof (swap.getGasDropOutput) === "function";
11
+ }
12
+ exports.isSwapWithGasDrop = isSwapWithGasDrop;
@@ -1,283 +1,285 @@
1
- import { ChainEvent, ChainType } from "@atomiqlabs/base";
2
- import { EventEmitter } from "events";
3
- import { ISwap } from "./ISwap";
4
- import { ISwapPrice } from "../prices/abstract/ISwapPrice";
5
- import { UnifiedSwapEventListener } from "../events/UnifiedSwapEventListener";
6
- import { SwapType } from "../enums/SwapType";
7
- import { UnifiedSwapStorage } from "../storage/UnifiedSwapStorage";
8
- import { SCToken } from "../types/Token";
9
- import { PriceInfoType } from "../types/PriceInfoType";
10
- export declare const DEFAULT_MAX_PARALLEL_SWAP_TICKS = 50;
11
- export declare const DEFAULT_MAX_PARALLEL_SWAP_SYNCS = 50;
12
- /**
13
- * Options for swap wrapper configuration
14
- *
15
- * @category Swaps/Base
16
- */
17
- export type ISwapWrapperOptions = {
18
- getRequestTimeout?: number;
19
- postRequestTimeout?: number;
20
- /**
21
- * How many swaps to call `_tick()` for in parallel
22
- */
23
- maxParallelSwapTicks?: number;
24
- /**
25
- * How many swaps to call `_sync()` for in parallel
26
- */
27
- maxParallelSwapSyncs?: number;
28
- /**
29
- * Whether to save swaps that are not initialized into the persistent storage
30
- */
31
- saveUninitializedSwaps?: boolean;
32
- };
33
- /**
34
- * Token configuration for wrapper constructors
35
- *
36
- * @category Swaps/Base
37
- */
38
- export type WrapperCtorTokens<T extends ChainType = ChainType> = {
39
- [tokenAddress: string]: SCToken<T["ChainId"]>;
40
- };
41
- /**
42
- * Type definition linking wrapper and swap types
43
- *
44
- * @category Swaps/Base
45
- */
46
- export type SwapTypeDefinition<T extends ChainType, W extends ISwapWrapper<T, any>, S extends ISwap<T>> = {
47
- Wrapper: W;
48
- Swap: S;
49
- };
50
- /**
51
- * Base abstract class for swap handler implementations
52
- *
53
- * @category Swaps/Base
54
- */
55
- export declare abstract class ISwapWrapper<T extends ChainType, D extends SwapTypeDefinition<T, ISwapWrapper<T, D>, ISwap<T, D>>, O extends ISwapWrapperOptions = ISwapWrapperOptions> {
56
- /**
57
- * Swap type
58
- */
59
- abstract readonly TYPE: SwapType;
60
- /**
61
- * Function for deserializing swaps
62
- * @internal
63
- */
64
- abstract readonly _swapDeserializer: new (wrapper: D["Wrapper"], data: any) => D["Swap"];
65
- /**
66
- * Logger instance
67
- * @internal
68
- */
69
- protected readonly logger: import("../utils/Logger").LoggerType;
70
- /**
71
- * Persistent storage backend for the swaps
72
- * @internal
73
- */
74
- protected readonly unifiedStorage: UnifiedSwapStorage<T>;
75
- /**
76
- * Smart chain events listener for listening to and parsing of on-chain events
77
- * @internal
78
- */
79
- protected readonly unifiedChainEvents: UnifiedSwapEventListener<T>;
80
- /**
81
- * States of the swaps where {@link ISwap._tick} should be called every second
82
- * @internal
83
- */
84
- protected readonly tickSwapState?: Array<D["Swap"]["_state"]>;
85
- /**
86
- * In-memory mapping of pending (not initiated) swaps, utilizing weak references to automatically
87
- * free memory when swaps are dereferenced in not initiated state
88
- * @internal
89
- */
90
- protected readonly pendingSwaps: Map<string, WeakRef<D["Swap"]>>;
91
- /**
92
- * Whether this wrapper is initialized (have to call {@link init} to initialize a wrapper)
93
- * @internal
94
- */
95
- protected isInitialized: boolean;
96
- /**
97
- * An interval for calling tick functions on the underlying swaps
98
- * @internal
99
- */
100
- protected tickInterval?: NodeJS.Timeout;
101
- /**
102
- * An internal abort controller for the running tick handler
103
- * @internal
104
- */
105
- protected tickAbortController?: AbortController;
106
- /**
107
- * States of the swaps in pending (non-final state), these are checked automatically on initial swap synchronization
108
- * @internal
109
- */
110
- abstract readonly _pendingSwapStates: Array<D["Swap"]["_state"]>;
111
- /**
112
- * Chain interface of the underlying smart chain
113
- * @internal
114
- */
115
- readonly _chain: T["ChainInterface"];
116
- /**
117
- * Pricing API
118
- * @internal
119
- */
120
- readonly _prices: ISwapPrice;
121
- /**
122
- * Wrapper options
123
- * @internal
124
- */
125
- readonly _options: O;
126
- /**
127
- * Tokens indexed by their token address
128
- * @internal
129
- */
130
- readonly _tokens: {
131
- [tokenAddress: string]: SCToken<T["ChainId"]>;
132
- };
133
- /**
134
- * Chain identifier string of this wrapper
135
- */
136
- readonly chainIdentifier: T["ChainId"];
137
- /**
138
- * Event emitter emitting `"swapState"` event when swap's state changes
139
- */
140
- readonly events: EventEmitter<{
141
- swapState: [D["Swap"]];
142
- }>;
143
- constructor(chainIdentifier: T["ChainId"], unifiedStorage: UnifiedSwapStorage<T>, unifiedChainEvents: UnifiedSwapEventListener<T>, chain: T["ChainInterface"], prices: ISwapPrice, tokens: WrapperCtorTokens, options: O, events?: EventEmitter<{
144
- swapState: [ISwap];
145
- }>);
146
- /**
147
- * Parses the provided gas amount from its `string` or `bigint` representation to `bigint` base units.
148
- *
149
- * Defaults to `0n` if no gasAmount is provided
150
- *
151
- * @param gasAmount
152
- * @internal
153
- */
154
- protected parseGasAmount(gasAmount?: string | bigint): bigint;
155
- /**
156
- * Pre-fetches swap price for a given swap
157
- *
158
- * @param amountData Amount data
159
- * @param abortSignal Abort signal
160
- * @returns Price of the token in uSats (micro sats)
161
- * @internal
162
- */
163
- protected preFetchPrice(amountData: {
164
- token: string;
165
- }, abortSignal?: AbortSignal): Promise<bigint | undefined>;
166
- /**
167
- * Pre-fetches bitcoin's USD price
168
- *
169
- * @param abortSignal Abort signal
170
- * @internal
171
- */
172
- protected preFetchUsdPrice(abortSignal?: AbortSignal): Promise<number | undefined>;
173
- /**
174
- * Verifies returned price for swaps
175
- *
176
- * @param lpServiceData Service data for the service in question (TO_BTCLN, TO_BTC, etc.) of the given intermediary
177
- * @param send Whether this is a send (Smart chain -> Bitcoin) or receive (Bitcoin -> Smart chain) swap
178
- * @param amountSats Amount in BTC
179
- * @param amountToken Amount in token
180
- * @param token Token used in the swap
181
- * @param feeData Fee data as returned by the intermediary
182
- * @param pricePrefetchPromise Optional price pre-fetch promise
183
- * @param usdPricePrefetchPromise Optiona USD price pre-fetch promise
184
- * @param abortSignal Abort signal
185
- * @returns Price info object
186
- * @throws {IntermediaryError} if the calculated fee is too high
187
- *
188
- * @internal
189
- */
190
- protected verifyReturnedPrice(lpServiceData: {
191
- swapBaseFee: number;
192
- swapFeePPM: number;
193
- }, send: boolean, amountSats: bigint, amountToken: bigint, token: string, feeData: {
194
- networkFee?: bigint;
195
- swapFeeBtc?: bigint;
196
- }, pricePrefetchPromise?: Promise<bigint | undefined>, usdPricePrefetchPromise?: Promise<number | undefined>, abortSignal?: AbortSignal): Promise<PriceInfoType>;
197
- /**
198
- * Processes a single smart chain on-chain event
199
- *
200
- * @param event Smart chain event to process
201
- * @param swap A swap related to the event
202
- * @internal
203
- */
204
- protected abstract processEvent?(event: ChainEvent<T["Data"]>, swap: D["Swap"]): Promise<void>;
205
- /**
206
- * Starts the interval calling the {@link ISwap._tick} on all the known swaps in tick-enabled states
207
- * @internal
208
- */
209
- protected startTickInterval(): void;
210
- /**
211
- * Runs checks on passed swaps, syncing their state from on-chain data
212
- *
213
- * @param pastSwaps Swaps to check
214
- * @internal
215
- */
216
- protected _checkPastSwaps(pastSwaps: D["Swap"][]): Promise<{
217
- changedSwaps: D["Swap"][];
218
- removeSwaps: D["Swap"][];
219
- }>;
220
- /**
221
- * Initializes the swap wrapper, needs to be called before any other action can be taken
222
- *
223
- * @param noTimers Whether to skip scheduling a tick timer for the swaps, if the tick timer is not initiated
224
- * the swap states depending on e.g. expiry can be out of sync with the actual expiration of the swap
225
- * @param noCheckPastSwaps Whether to skip checking past swaps on initialization (by default all pending swaps
226
- * are re-checked on init, and their state is synchronized from the on-chain data)
227
- */
228
- init(noTimers?: boolean, noCheckPastSwaps?: boolean): Promise<void>;
229
- /**
230
- * Un-subscribes from event listeners on the smart chain, terminates the tick interval and stops this wrapper
231
- */
232
- stop(): Promise<void>;
233
- /**
234
- * Runs checks on all the known pending swaps, syncing their state from on-chain data
235
- *
236
- * @remarks Doesn't work properly if you pass non-persisted swaps
237
- *
238
- * @param pastSwaps Optional array of past swaps to check, otherwise all relevant swaps will be fetched
239
- * from the persistent storage
240
- * @param noSave Whether to skip saving the swap changes in the persistent storage
241
- */
242
- checkPastSwaps(pastSwaps?: D["Swap"][], noSave?: boolean): Promise<{
243
- removeSwaps: D["Swap"][];
244
- changedSwaps: D["Swap"][];
245
- }>;
246
- /**
247
- * Invokes {@link ISwap._tick} on all the known swaps
248
- *
249
- * @param swaps Optional array of swaps to invoke `_tick()` on, otherwise all relevant swaps will be fetched
250
- * from the persistent storage
251
- * @param abortSignal Abort signal
252
- */
253
- tick(swaps?: D["Swap"][], abortSignal?: AbortSignal): Promise<void>;
254
- /**
255
- * Returns the smart chain's native token used to pay for fees
256
- * @internal
257
- */
258
- _getNativeToken(): SCToken<T["ChainId"]>;
259
- /**
260
- * Saves the swap, if it is not initiated it is only saved to pending swaps
261
- *
262
- * @param swap Swap to save
263
- *
264
- * @internal
265
- */
266
- _saveSwapData(swap: D["Swap"]): Promise<void>;
267
- /**
268
- * Removes the swap from the persistent storage and pending swaps
269
- *
270
- * @param swap Swap to remove
271
- *
272
- * @internal
273
- */
274
- _removeSwapData(swap: D["Swap"]): Promise<void>;
275
- /**
276
- * Retrieves a swap by its ID from the pending swap mapping
277
- *
278
- * @param id
279
- *
280
- * @internal
281
- */
282
- _getPendingSwap(id: string): D["Swap"] | null;
283
- }
1
+ /// <reference types="node" />
2
+ /// <reference types="node" />
3
+ import { ChainEvent, ChainType } from "@atomiqlabs/base";
4
+ import { EventEmitter } from "events";
5
+ import { ISwap } from "./ISwap";
6
+ import { ISwapPrice } from "../prices/abstract/ISwapPrice";
7
+ import { UnifiedSwapEventListener } from "../events/UnifiedSwapEventListener";
8
+ import { SwapType } from "../enums/SwapType";
9
+ import { UnifiedSwapStorage } from "../storage/UnifiedSwapStorage";
10
+ import { SCToken } from "../types/Token";
11
+ import { PriceInfoType } from "../types/PriceInfoType";
12
+ export declare const DEFAULT_MAX_PARALLEL_SWAP_TICKS = 50;
13
+ export declare const DEFAULT_MAX_PARALLEL_SWAP_SYNCS = 50;
14
+ /**
15
+ * Options for swap wrapper configuration
16
+ *
17
+ * @category Swaps/Base
18
+ */
19
+ export type ISwapWrapperOptions = {
20
+ getRequestTimeout?: number;
21
+ postRequestTimeout?: number;
22
+ /**
23
+ * How many swaps to call `_tick()` for in parallel
24
+ */
25
+ maxParallelSwapTicks?: number;
26
+ /**
27
+ * How many swaps to call `_sync()` for in parallel
28
+ */
29
+ maxParallelSwapSyncs?: number;
30
+ /**
31
+ * Whether to save swaps that are not initialized into the persistent storage
32
+ */
33
+ saveUninitializedSwaps?: boolean;
34
+ };
35
+ /**
36
+ * Token configuration for wrapper constructors
37
+ *
38
+ * @category Swaps/Base
39
+ */
40
+ export type WrapperCtorTokens<T extends ChainType = ChainType> = {
41
+ [tokenAddress: string]: SCToken<T["ChainId"]>;
42
+ };
43
+ /**
44
+ * Type definition linking wrapper and swap types
45
+ *
46
+ * @category Swaps/Base
47
+ */
48
+ export type SwapTypeDefinition<T extends ChainType, W extends ISwapWrapper<T, any>, S extends ISwap<T>> = {
49
+ Wrapper: W;
50
+ Swap: S;
51
+ };
52
+ /**
53
+ * Base abstract class for swap handler implementations
54
+ *
55
+ * @category Swaps/Base
56
+ */
57
+ export declare abstract class ISwapWrapper<T extends ChainType, D extends SwapTypeDefinition<T, ISwapWrapper<T, D>, ISwap<T, D>>, O extends ISwapWrapperOptions = ISwapWrapperOptions> {
58
+ /**
59
+ * Swap type
60
+ */
61
+ abstract readonly TYPE: SwapType;
62
+ /**
63
+ * Function for deserializing swaps
64
+ * @internal
65
+ */
66
+ abstract readonly _swapDeserializer: new (wrapper: D["Wrapper"], data: any) => D["Swap"];
67
+ /**
68
+ * Logger instance
69
+ * @internal
70
+ */
71
+ protected readonly logger: import("../utils/Logger").LoggerType;
72
+ /**
73
+ * Persistent storage backend for the swaps
74
+ * @internal
75
+ */
76
+ protected readonly unifiedStorage: UnifiedSwapStorage<T>;
77
+ /**
78
+ * Smart chain events listener for listening to and parsing of on-chain events
79
+ * @internal
80
+ */
81
+ protected readonly unifiedChainEvents: UnifiedSwapEventListener<T>;
82
+ /**
83
+ * States of the swaps where {@link ISwap._tick} should be called every second
84
+ * @internal
85
+ */
86
+ protected readonly tickSwapState?: Array<D["Swap"]["_state"]>;
87
+ /**
88
+ * In-memory mapping of pending (not initiated) swaps, utilizing weak references to automatically
89
+ * free memory when swaps are dereferenced in not initiated state
90
+ * @internal
91
+ */
92
+ protected readonly pendingSwaps: Map<string, WeakRef<D["Swap"]>>;
93
+ /**
94
+ * Whether this wrapper is initialized (have to call {@link init} to initialize a wrapper)
95
+ * @internal
96
+ */
97
+ protected isInitialized: boolean;
98
+ /**
99
+ * An interval for calling tick functions on the underlying swaps
100
+ * @internal
101
+ */
102
+ protected tickInterval?: NodeJS.Timeout;
103
+ /**
104
+ * An internal abort controller for the running tick handler
105
+ * @internal
106
+ */
107
+ protected tickAbortController?: AbortController;
108
+ /**
109
+ * States of the swaps in pending (non-final state), these are checked automatically on initial swap synchronization
110
+ * @internal
111
+ */
112
+ abstract readonly _pendingSwapStates: Array<D["Swap"]["_state"]>;
113
+ /**
114
+ * Chain interface of the underlying smart chain
115
+ * @internal
116
+ */
117
+ readonly _chain: T["ChainInterface"];
118
+ /**
119
+ * Pricing API
120
+ * @internal
121
+ */
122
+ readonly _prices: ISwapPrice;
123
+ /**
124
+ * Wrapper options
125
+ * @internal
126
+ */
127
+ readonly _options: O;
128
+ /**
129
+ * Tokens indexed by their token address
130
+ * @internal
131
+ */
132
+ readonly _tokens: {
133
+ [tokenAddress: string]: SCToken<T["ChainId"]>;
134
+ };
135
+ /**
136
+ * Chain identifier string of this wrapper
137
+ */
138
+ readonly chainIdentifier: T["ChainId"];
139
+ /**
140
+ * Event emitter emitting `"swapState"` event when swap's state changes
141
+ */
142
+ readonly events: EventEmitter<{
143
+ swapState: [D["Swap"]];
144
+ }>;
145
+ constructor(chainIdentifier: T["ChainId"], unifiedStorage: UnifiedSwapStorage<T>, unifiedChainEvents: UnifiedSwapEventListener<T>, chain: T["ChainInterface"], prices: ISwapPrice, tokens: WrapperCtorTokens, options: O, events?: EventEmitter<{
146
+ swapState: [ISwap];
147
+ }>);
148
+ /**
149
+ * Parses the provided gas amount from its `string` or `bigint` representation to `bigint` base units.
150
+ *
151
+ * Defaults to `0n` if no gasAmount is provided
152
+ *
153
+ * @param gasAmount
154
+ * @internal
155
+ */
156
+ protected parseGasAmount(gasAmount?: string | bigint): bigint;
157
+ /**
158
+ * Pre-fetches swap price for a given swap
159
+ *
160
+ * @param amountData Amount data
161
+ * @param abortSignal Abort signal
162
+ * @returns Price of the token in uSats (micro sats)
163
+ * @internal
164
+ */
165
+ protected preFetchPrice(amountData: {
166
+ token: string;
167
+ }, abortSignal?: AbortSignal): Promise<bigint | undefined>;
168
+ /**
169
+ * Pre-fetches bitcoin's USD price
170
+ *
171
+ * @param abortSignal Abort signal
172
+ * @internal
173
+ */
174
+ protected preFetchUsdPrice(abortSignal?: AbortSignal): Promise<number | undefined>;
175
+ /**
176
+ * Verifies returned price for swaps
177
+ *
178
+ * @param lpServiceData Service data for the service in question (TO_BTCLN, TO_BTC, etc.) of the given intermediary
179
+ * @param send Whether this is a send (Smart chain -> Bitcoin) or receive (Bitcoin -> Smart chain) swap
180
+ * @param amountSats Amount in BTC
181
+ * @param amountToken Amount in token
182
+ * @param token Token used in the swap
183
+ * @param feeData Fee data as returned by the intermediary
184
+ * @param pricePrefetchPromise Optional price pre-fetch promise
185
+ * @param usdPricePrefetchPromise Optiona USD price pre-fetch promise
186
+ * @param abortSignal Abort signal
187
+ * @returns Price info object
188
+ * @throws {IntermediaryError} if the calculated fee is too high
189
+ *
190
+ * @internal
191
+ */
192
+ protected verifyReturnedPrice(lpServiceData: {
193
+ swapBaseFee: number;
194
+ swapFeePPM: number;
195
+ }, send: boolean, amountSats: bigint, amountToken: bigint, token: string, feeData: {
196
+ networkFee?: bigint;
197
+ swapFeeBtc?: bigint;
198
+ }, pricePrefetchPromise?: Promise<bigint | undefined>, usdPricePrefetchPromise?: Promise<number | undefined>, abortSignal?: AbortSignal): Promise<PriceInfoType>;
199
+ /**
200
+ * Processes a single smart chain on-chain event
201
+ *
202
+ * @param event Smart chain event to process
203
+ * @param swap A swap related to the event
204
+ * @internal
205
+ */
206
+ protected abstract processEvent?(event: ChainEvent<T["Data"]>, swap: D["Swap"]): Promise<void>;
207
+ /**
208
+ * Starts the interval calling the {@link ISwap._tick} on all the known swaps in tick-enabled states
209
+ * @internal
210
+ */
211
+ protected startTickInterval(): void;
212
+ /**
213
+ * Runs checks on passed swaps, syncing their state from on-chain data
214
+ *
215
+ * @param pastSwaps Swaps to check
216
+ * @internal
217
+ */
218
+ protected _checkPastSwaps(pastSwaps: D["Swap"][]): Promise<{
219
+ changedSwaps: D["Swap"][];
220
+ removeSwaps: D["Swap"][];
221
+ }>;
222
+ /**
223
+ * Initializes the swap wrapper, needs to be called before any other action can be taken
224
+ *
225
+ * @param noTimers Whether to skip scheduling a tick timer for the swaps, if the tick timer is not initiated
226
+ * the swap states depending on e.g. expiry can be out of sync with the actual expiration of the swap
227
+ * @param noCheckPastSwaps Whether to skip checking past swaps on initialization (by default all pending swaps
228
+ * are re-checked on init, and their state is synchronized from the on-chain data)
229
+ */
230
+ init(noTimers?: boolean, noCheckPastSwaps?: boolean): Promise<void>;
231
+ /**
232
+ * Un-subscribes from event listeners on the smart chain, terminates the tick interval and stops this wrapper
233
+ */
234
+ stop(): Promise<void>;
235
+ /**
236
+ * Runs checks on all the known pending swaps, syncing their state from on-chain data
237
+ *
238
+ * @remarks Doesn't work properly if you pass non-persisted swaps
239
+ *
240
+ * @param pastSwaps Optional array of past swaps to check, otherwise all relevant swaps will be fetched
241
+ * from the persistent storage
242
+ * @param noSave Whether to skip saving the swap changes in the persistent storage
243
+ */
244
+ checkPastSwaps(pastSwaps?: D["Swap"][], noSave?: boolean): Promise<{
245
+ removeSwaps: D["Swap"][];
246
+ changedSwaps: D["Swap"][];
247
+ }>;
248
+ /**
249
+ * Invokes {@link ISwap._tick} on all the known swaps
250
+ *
251
+ * @param swaps Optional array of swaps to invoke `_tick()` on, otherwise all relevant swaps will be fetched
252
+ * from the persistent storage
253
+ * @param abortSignal Abort signal
254
+ */
255
+ tick(swaps?: D["Swap"][], abortSignal?: AbortSignal): Promise<void>;
256
+ /**
257
+ * Returns the smart chain's native token used to pay for fees
258
+ * @internal
259
+ */
260
+ _getNativeToken(): SCToken<T["ChainId"]>;
261
+ /**
262
+ * Saves the swap, if it is not initiated it is only saved to pending swaps
263
+ *
264
+ * @param swap Swap to save
265
+ *
266
+ * @internal
267
+ */
268
+ _saveSwapData(swap: D["Swap"]): Promise<void>;
269
+ /**
270
+ * Removes the swap from the persistent storage and pending swaps
271
+ *
272
+ * @param swap Swap to remove
273
+ *
274
+ * @internal
275
+ */
276
+ _removeSwapData(swap: D["Swap"]): Promise<void>;
277
+ /**
278
+ * Retrieves a swap by its ID from the pending swap mapping
279
+ *
280
+ * @param id
281
+ *
282
+ * @internal
283
+ */
284
+ _getPendingSwap(id: string): D["Swap"] | null;
285
+ }