@atomiqlabs/sdk 8.6.6 → 8.6.7

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 (225) 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 +176 -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
@@ -1,278 +1,278 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.ToBTCWrapper = void 0;
4
- const ToBTCSwap_1 = require("./ToBTCSwap");
5
- const IToBTCWrapper_1 = require("../IToBTCWrapper");
6
- const base_1 = require("@atomiqlabs/base");
7
- const UserError_1 = require("../../../../errors/UserError");
8
- const IntermediaryError_1 = require("../../../../errors/IntermediaryError");
9
- const SwapType_1 = require("../../../../enums/SwapType");
10
- const Utils_1 = require("../../../../utils/Utils");
11
- const BitcoinUtils_1 = require("../../../../utils/BitcoinUtils");
12
- const IntermediaryAPI_1 = require("../../../../intermediaries/apis/IntermediaryAPI");
13
- const RequestError_1 = require("../../../../errors/RequestError");
14
- const utils_1 = require("@scure/btc-signer/utils");
15
- const RetryUtils_1 = require("../../../../utils/RetryUtils");
16
- const IToBTCSwap_1 = require("../IToBTCSwap");
17
- /**
18
- * Escrow based (PrTLC) swap for Smart chains -> Bitcoin
19
- *
20
- * @category Swaps/Smart chain → Bitcoin
21
- */
22
- class ToBTCWrapper extends IToBTCWrapper_1.IToBTCWrapper {
23
- /**
24
- * @param chainIdentifier
25
- * @param unifiedStorage Storage interface for the current environment
26
- * @param unifiedChainEvents Smart chain on-chain event listener
27
- * @param chain
28
- * @param contract Chain specific swap contract
29
- * @param prices Swap pricing handler
30
- * @param tokens
31
- * @param swapDataDeserializer Deserializer for chain specific SwapData
32
- * @param btcRpc Bitcoin RPC api
33
- * @param options
34
- * @param events Instance to use for emitting events
35
- */
36
- constructor(chainIdentifier, unifiedStorage, unifiedChainEvents, chain, contract, prices, tokens, swapDataDeserializer, btcRpc, options, events) {
37
- super(chainIdentifier, unifiedStorage, unifiedChainEvents, chain, contract, prices, tokens, swapDataDeserializer, {
38
- ...options,
39
- bitcoinNetwork: options?.bitcoinNetwork ?? utils_1.TEST_NETWORK,
40
- safetyFactor: options?.safetyFactor ?? 2,
41
- maxConfirmations: options?.maxConfirmations ?? 6,
42
- bitcoinBlocktime: options?.bitcoinBlocktime ?? (60 * 10),
43
- maxExpectedOnchainSendSafetyFactor: options?.maxExpectedOnchainSendSafetyFactor ?? 4,
44
- maxExpectedOnchainSendGracePeriodBlocks: options?.maxExpectedOnchainSendGracePeriodBlocks ?? 12,
45
- }, events);
46
- this.TYPE = SwapType_1.SwapType.TO_BTC;
47
- /**
48
- * @internal
49
- */
50
- this._swapDeserializer = ToBTCSwap_1.ToBTCSwap;
51
- this._btcRpc = btcRpc;
52
- }
53
- /**
54
- * Returns randomly generated random bitcoin transaction nonce to be used for BTC on-chain swaps
55
- *
56
- * @returns Escrow nonce
57
- *
58
- * @private
59
- */
60
- getRandomNonce() {
61
- const firstPart = BigInt(Math.floor((Date.now() / 1000)) - 700000000);
62
- return (firstPart << 24n) | base_1.BigIntBufferUtils.fromBuffer((0, Utils_1.randomBytes)(3));
63
- }
64
- /**
65
- * Converts bitcoin address to its corresponding output script
66
- *
67
- * @param addr Bitcoin address to get the output script for
68
- *
69
- * @returns Output script as Buffer
70
- * @throws {UserError} if invalid address is specified
71
- *
72
- * @private
73
- */
74
- btcAddressToOutputScript(addr) {
75
- try {
76
- return (0, BitcoinUtils_1.toOutputScript)(this._options.bitcoinNetwork, addr);
77
- }
78
- catch (e) {
79
- throw new UserError_1.UserError("Invalid address specified");
80
- }
81
- }
82
- /**
83
- * Verifies returned LP data
84
- *
85
- * @param signer
86
- * @param resp LP's response
87
- * @param amountData
88
- * @param lp
89
- * @param options Options as passed to the swap create function
90
- * @param data LP's returned parsed swap data
91
- * @param hash Payment hash of the swap
92
- *
93
- * @throws {IntermediaryError} if returned data are not correct
94
- *
95
- * @private
96
- */
97
- verifyReturnedData(signer, resp, amountData, lp, options, data, hash) {
98
- if (resp.totalFee !== (resp.swapFee + resp.networkFee))
99
- throw new IntermediaryError_1.IntermediaryError("Invalid totalFee returned");
100
- if (amountData.exactIn) {
101
- if (resp.total !== amountData.amount)
102
- throw new IntermediaryError_1.IntermediaryError("Invalid total returned");
103
- }
104
- else {
105
- if (resp.amount !== amountData.amount)
106
- throw new IntermediaryError_1.IntermediaryError("Invalid amount returned");
107
- }
108
- const maxAllowedBlockDelta = BigInt(options.confirmations +
109
- options.confirmationTarget +
110
- this._options.maxExpectedOnchainSendGracePeriodBlocks);
111
- const maxAllowedExpiryDelta = maxAllowedBlockDelta
112
- * BigInt(this._options.maxExpectedOnchainSendSafetyFactor)
113
- * BigInt(this._options.bitcoinBlocktime);
114
- const currentTimestamp = BigInt(Math.floor(Date.now() / 1000));
115
- const maxAllowedExpiryTimestamp = currentTimestamp + maxAllowedExpiryDelta;
116
- if (data.getExpiry() > maxAllowedExpiryTimestamp) {
117
- throw new IntermediaryError_1.IntermediaryError("Expiry time returned too high!");
118
- }
119
- if (data.getAmount() !== resp.total ||
120
- data.getClaimHash() !== hash ||
121
- data.getType() !== base_1.ChainSwapType.CHAIN_NONCED ||
122
- !data.isPayIn() ||
123
- !data.isToken(amountData.token) ||
124
- !data.isClaimer(lp.getAddress(this.chainIdentifier)) ||
125
- !data.isOfferer(signer) ||
126
- data.getTotalDeposit() !== 0n) {
127
- throw new IntermediaryError_1.IntermediaryError("Invalid data returned");
128
- }
129
- }
130
- /**
131
- * Returns a newly created Smart chain -> Bitcoin swap using the PrTLC based escrow swap protocol,
132
- * with the passed amount.
133
- *
134
- * @param signer Source chain signer address initiating the swap
135
- * @param recipient Recipient bitcoin on-chain address
136
- * @param amountData Amount, token and exact input/output data for to swap
137
- * @param lps An array of intermediaries (LPs) to get the quotes from
138
- * @param options Optional additional quote options
139
- * @param additionalParams Optional additional parameters sent to the LP when creating the swap
140
- * @param abortSignal Abort signal
141
- */
142
- create(signer, recipient, amountData, lps, options, additionalParams, abortSignal) {
143
- if (!this.isInitialized)
144
- throw new Error("Not initialized, call init() first!");
145
- const _options = {
146
- confirmationTarget: options?.confirmationTarget ?? 3,
147
- confirmations: options?.confirmations ?? 2
148
- };
149
- const nonce = this.getRandomNonce();
150
- const outputScript = this.btcAddressToOutputScript(recipient);
151
- const _hash = !amountData.exactIn ?
152
- this._contract.getHashForOnchain(outputScript, amountData.amount, _options.confirmations, nonce).toString("hex") :
153
- undefined;
154
- const _abortController = (0, Utils_1.extendAbortController)(abortSignal);
155
- const pricePreFetchPromise = this.preFetchPrice(amountData, _abortController.signal);
156
- const usdPricePrefetchPromise = this.preFetchUsdPrice(_abortController.signal);
157
- const feeRatePromise = this.preFetchFeeRate(signer, amountData, _hash, _abortController);
158
- const _signDataPromise = this._contract.preFetchBlockDataForSignatures == null ?
159
- this.preFetchSignData(Promise.resolve(true)) :
160
- undefined;
161
- return lps.map(lp => {
162
- return {
163
- intermediary: lp,
164
- quote: (async () => {
165
- if (lp.services[SwapType_1.SwapType.TO_BTC] == null)
166
- throw new Error("LP service for processing to btc swaps not found!");
167
- const abortController = (0, Utils_1.extendAbortController)(_abortController.signal);
168
- const reputationPromise = this.preFetchIntermediaryReputation(amountData, lp, abortController);
169
- try {
170
- const { signDataPromise, resp } = await (0, RetryUtils_1.tryWithRetries)(async (retryCount) => {
171
- const { signDataPrefetch, response } = IntermediaryAPI_1.IntermediaryAPI.initToBTC(this.chainIdentifier, lp.url, {
172
- btcAddress: recipient,
173
- amount: amountData.amount,
174
- confirmationTarget: _options.confirmationTarget,
175
- confirmations: _options.confirmations,
176
- nonce: nonce,
177
- token: amountData.token,
178
- offerer: signer,
179
- exactIn: amountData.exactIn,
180
- feeRate: (0, Utils_1.throwIfUndefined)(feeRatePromise),
181
- additionalParams
182
- }, this._options.postRequestTimeout, abortController.signal, retryCount > 0 ? false : undefined);
183
- let signDataPromise = _signDataPromise;
184
- if (signDataPromise == null) {
185
- signDataPromise = this.preFetchSignData(signDataPrefetch);
186
- }
187
- else
188
- signDataPrefetch.catch(() => { });
189
- return {
190
- signDataPromise,
191
- resp: await response
192
- };
193
- }, undefined, RequestError_1.RequestError, abortController.signal);
194
- let hash = _hash ?? this._contract.getHashForOnchain(outputScript, resp.amount, _options.confirmations, nonce).toString("hex");
195
- const data = new this._swapDataDeserializer(resp.data);
196
- data.setOfferer(signer);
197
- const inputWithoutFees = data.getAmount() - resp.swapFee - resp.networkFee;
198
- const swapFeeBtc = resp.swapFee * resp.amount / inputWithoutFees;
199
- const networkFeeBtc = resp.networkFee * resp.amount / inputWithoutFees;
200
- this.verifyReturnedData(signer, resp, amountData, lp, _options, data, hash);
201
- const [pricingInfo, signatureExpiry, reputation] = await Promise.all([
202
- this.verifyReturnedPrice(lp.services[SwapType_1.SwapType.TO_BTC], true, resp.amount, data.getAmount(), amountData.token, { networkFee: resp.networkFee, swapFeeBtc }, pricePreFetchPromise, usdPricePrefetchPromise, abortController.signal),
203
- this.verifyReturnedSignature(signer, data, resp, feeRatePromise, signDataPromise, abortController.signal),
204
- reputationPromise
205
- ]);
206
- abortController.signal.throwIfAborted();
207
- if (reputation != null)
208
- lp.reputation[amountData.token.toString()] = reputation;
209
- const quote = new ToBTCSwap_1.ToBTCSwap(this, {
210
- pricingInfo,
211
- url: lp.url,
212
- expiry: signatureExpiry,
213
- swapFee: resp.swapFee,
214
- swapFeeBtc,
215
- feeRate: (await feeRatePromise),
216
- signatureData: resp,
217
- data,
218
- networkFee: resp.networkFee,
219
- networkFeeBtc,
220
- address: recipient,
221
- amount: resp.amount,
222
- confirmationTarget: _options.confirmationTarget,
223
- satsPerVByte: Number(resp.satsPervByte),
224
- exactIn: amountData.exactIn,
225
- requiredConfirmations: _options.confirmations,
226
- nonce
227
- });
228
- return quote;
229
- }
230
- catch (e) {
231
- abortController.abort(e);
232
- throw e;
233
- }
234
- })()
235
- };
236
- });
237
- }
238
- /**
239
- * @inheritDoc
240
- */
241
- async recoverFromSwapDataAndState(init, state, lp) {
242
- const data = init.data;
243
- const swapInit = {
244
- pricingInfo: {
245
- isValid: true,
246
- satsBaseFee: 0n,
247
- swapPriceUSatPerToken: 100000000000000n,
248
- realPriceUSatPerToken: 100000000000000n,
249
- differencePPM: 0n,
250
- feePPM: 0n,
251
- },
252
- url: lp?.url,
253
- expiry: 0,
254
- swapFee: 0n,
255
- swapFeeBtc: 0n,
256
- confirmationTarget: 1,
257
- satsPerVByte: 0,
258
- feeRate: "",
259
- signatureData: undefined,
260
- nonce: data.getNonceHint() ?? undefined,
261
- requiredConfirmations: data.getConfirmationsHint() ?? undefined,
262
- data,
263
- networkFee: 0n,
264
- networkFeeBtc: 0n,
265
- exactIn: true
266
- };
267
- const swap = new ToBTCSwap_1.ToBTCSwap(this, swapInit);
268
- swap._commitTxId = await init.getInitTxId();
269
- const blockData = await init.getTxBlock();
270
- swap.createdAt = blockData.blockTime * 1000;
271
- swap._setInitiated();
272
- swap._state = IToBTCSwap_1.ToBTCSwapState.COMMITED;
273
- await swap._sync(false, false, state);
274
- await swap._save();
275
- return swap;
276
- }
277
- }
278
- exports.ToBTCWrapper = ToBTCWrapper;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ToBTCWrapper = void 0;
4
+ const ToBTCSwap_1 = require("./ToBTCSwap");
5
+ const IToBTCWrapper_1 = require("../IToBTCWrapper");
6
+ const base_1 = require("@atomiqlabs/base");
7
+ const UserError_1 = require("../../../../errors/UserError");
8
+ const IntermediaryError_1 = require("../../../../errors/IntermediaryError");
9
+ const SwapType_1 = require("../../../../enums/SwapType");
10
+ const Utils_1 = require("../../../../utils/Utils");
11
+ const BitcoinUtils_1 = require("../../../../utils/BitcoinUtils");
12
+ const IntermediaryAPI_1 = require("../../../../intermediaries/apis/IntermediaryAPI");
13
+ const RequestError_1 = require("../../../../errors/RequestError");
14
+ const utils_1 = require("@scure/btc-signer/utils");
15
+ const RetryUtils_1 = require("../../../../utils/RetryUtils");
16
+ const IToBTCSwap_1 = require("../IToBTCSwap");
17
+ /**
18
+ * Escrow based (PrTLC) swap for Smart chains -> Bitcoin
19
+ *
20
+ * @category Swaps/Smart chain → Bitcoin
21
+ */
22
+ class ToBTCWrapper extends IToBTCWrapper_1.IToBTCWrapper {
23
+ /**
24
+ * @param chainIdentifier
25
+ * @param unifiedStorage Storage interface for the current environment
26
+ * @param unifiedChainEvents Smart chain on-chain event listener
27
+ * @param chain
28
+ * @param contract Chain specific swap contract
29
+ * @param prices Swap pricing handler
30
+ * @param tokens
31
+ * @param swapDataDeserializer Deserializer for chain specific SwapData
32
+ * @param btcRpc Bitcoin RPC api
33
+ * @param options
34
+ * @param events Instance to use for emitting events
35
+ */
36
+ constructor(chainIdentifier, unifiedStorage, unifiedChainEvents, chain, contract, prices, tokens, swapDataDeserializer, btcRpc, options, events) {
37
+ super(chainIdentifier, unifiedStorage, unifiedChainEvents, chain, contract, prices, tokens, swapDataDeserializer, {
38
+ ...options,
39
+ bitcoinNetwork: options?.bitcoinNetwork ?? utils_1.TEST_NETWORK,
40
+ safetyFactor: options?.safetyFactor ?? 2,
41
+ maxConfirmations: options?.maxConfirmations ?? 6,
42
+ bitcoinBlocktime: options?.bitcoinBlocktime ?? (60 * 10),
43
+ maxExpectedOnchainSendSafetyFactor: options?.maxExpectedOnchainSendSafetyFactor ?? 4,
44
+ maxExpectedOnchainSendGracePeriodBlocks: options?.maxExpectedOnchainSendGracePeriodBlocks ?? 12,
45
+ }, events);
46
+ this.TYPE = SwapType_1.SwapType.TO_BTC;
47
+ /**
48
+ * @internal
49
+ */
50
+ this._swapDeserializer = ToBTCSwap_1.ToBTCSwap;
51
+ this._btcRpc = btcRpc;
52
+ }
53
+ /**
54
+ * Returns randomly generated random bitcoin transaction nonce to be used for BTC on-chain swaps
55
+ *
56
+ * @returns Escrow nonce
57
+ *
58
+ * @private
59
+ */
60
+ getRandomNonce() {
61
+ const firstPart = BigInt(Math.floor((Date.now() / 1000)) - 700000000);
62
+ return (firstPart << 24n) | base_1.BigIntBufferUtils.fromBuffer((0, Utils_1.randomBytes)(3));
63
+ }
64
+ /**
65
+ * Converts bitcoin address to its corresponding output script
66
+ *
67
+ * @param addr Bitcoin address to get the output script for
68
+ *
69
+ * @returns Output script as Buffer
70
+ * @throws {UserError} if invalid address is specified
71
+ *
72
+ * @private
73
+ */
74
+ btcAddressToOutputScript(addr) {
75
+ try {
76
+ return (0, BitcoinUtils_1.toOutputScript)(this._options.bitcoinNetwork, addr);
77
+ }
78
+ catch (e) {
79
+ throw new UserError_1.UserError("Invalid address specified");
80
+ }
81
+ }
82
+ /**
83
+ * Verifies returned LP data
84
+ *
85
+ * @param signer
86
+ * @param resp LP's response
87
+ * @param amountData
88
+ * @param lp
89
+ * @param options Options as passed to the swap create function
90
+ * @param data LP's returned parsed swap data
91
+ * @param hash Payment hash of the swap
92
+ *
93
+ * @throws {IntermediaryError} if returned data are not correct
94
+ *
95
+ * @private
96
+ */
97
+ verifyReturnedData(signer, resp, amountData, lp, options, data, hash) {
98
+ if (resp.totalFee !== (resp.swapFee + resp.networkFee))
99
+ throw new IntermediaryError_1.IntermediaryError("Invalid totalFee returned");
100
+ if (amountData.exactIn) {
101
+ if (resp.total !== amountData.amount)
102
+ throw new IntermediaryError_1.IntermediaryError("Invalid total returned");
103
+ }
104
+ else {
105
+ if (resp.amount !== amountData.amount)
106
+ throw new IntermediaryError_1.IntermediaryError("Invalid amount returned");
107
+ }
108
+ const maxAllowedBlockDelta = BigInt(options.confirmations +
109
+ options.confirmationTarget +
110
+ this._options.maxExpectedOnchainSendGracePeriodBlocks);
111
+ const maxAllowedExpiryDelta = maxAllowedBlockDelta
112
+ * BigInt(this._options.maxExpectedOnchainSendSafetyFactor)
113
+ * BigInt(this._options.bitcoinBlocktime);
114
+ const currentTimestamp = BigInt(Math.floor(Date.now() / 1000));
115
+ const maxAllowedExpiryTimestamp = currentTimestamp + maxAllowedExpiryDelta;
116
+ if (data.getExpiry() > maxAllowedExpiryTimestamp) {
117
+ throw new IntermediaryError_1.IntermediaryError("Expiry time returned too high!");
118
+ }
119
+ if (data.getAmount() !== resp.total ||
120
+ data.getClaimHash() !== hash ||
121
+ data.getType() !== base_1.ChainSwapType.CHAIN_NONCED ||
122
+ !data.isPayIn() ||
123
+ !data.isToken(amountData.token) ||
124
+ !data.isClaimer(lp.getAddress(this.chainIdentifier)) ||
125
+ !data.isOfferer(signer) ||
126
+ data.getTotalDeposit() !== 0n) {
127
+ throw new IntermediaryError_1.IntermediaryError("Invalid data returned");
128
+ }
129
+ }
130
+ /**
131
+ * Returns a newly created Smart chain -> Bitcoin swap using the PrTLC based escrow swap protocol,
132
+ * with the passed amount.
133
+ *
134
+ * @param signer Source chain signer address initiating the swap
135
+ * @param recipient Recipient bitcoin on-chain address
136
+ * @param amountData Amount, token and exact input/output data for to swap
137
+ * @param lps An array of intermediaries (LPs) to get the quotes from
138
+ * @param options Optional additional quote options
139
+ * @param additionalParams Optional additional parameters sent to the LP when creating the swap
140
+ * @param abortSignal Abort signal
141
+ */
142
+ create(signer, recipient, amountData, lps, options, additionalParams, abortSignal) {
143
+ if (!this.isInitialized)
144
+ throw new Error("Not initialized, call init() first!");
145
+ const _options = {
146
+ confirmationTarget: options?.confirmationTarget ?? 3,
147
+ confirmations: options?.confirmations ?? 2
148
+ };
149
+ const nonce = this.getRandomNonce();
150
+ const outputScript = this.btcAddressToOutputScript(recipient);
151
+ const _hash = !amountData.exactIn ?
152
+ this._contract.getHashForOnchain(outputScript, amountData.amount, _options.confirmations, nonce).toString("hex") :
153
+ undefined;
154
+ const _abortController = (0, Utils_1.extendAbortController)(abortSignal);
155
+ const pricePreFetchPromise = this.preFetchPrice(amountData, _abortController.signal);
156
+ const usdPricePrefetchPromise = this.preFetchUsdPrice(_abortController.signal);
157
+ const feeRatePromise = this.preFetchFeeRate(signer, amountData, _hash, _abortController);
158
+ const _signDataPromise = this._contract.preFetchBlockDataForSignatures == null ?
159
+ this.preFetchSignData(Promise.resolve(true)) :
160
+ undefined;
161
+ return lps.map(lp => {
162
+ return {
163
+ intermediary: lp,
164
+ quote: (async () => {
165
+ if (lp.services[SwapType_1.SwapType.TO_BTC] == null)
166
+ throw new Error("LP service for processing to btc swaps not found!");
167
+ const abortController = (0, Utils_1.extendAbortController)(_abortController.signal);
168
+ const reputationPromise = this.preFetchIntermediaryReputation(amountData, lp, abortController);
169
+ try {
170
+ const { signDataPromise, resp } = await (0, RetryUtils_1.tryWithRetries)(async (retryCount) => {
171
+ const { signDataPrefetch, response } = IntermediaryAPI_1.IntermediaryAPI.initToBTC(this.chainIdentifier, lp.url, {
172
+ btcAddress: recipient,
173
+ amount: amountData.amount,
174
+ confirmationTarget: _options.confirmationTarget,
175
+ confirmations: _options.confirmations,
176
+ nonce: nonce,
177
+ token: amountData.token,
178
+ offerer: signer,
179
+ exactIn: amountData.exactIn,
180
+ feeRate: (0, Utils_1.throwIfUndefined)(feeRatePromise),
181
+ additionalParams
182
+ }, this._options.postRequestTimeout, abortController.signal, retryCount > 0 ? false : undefined);
183
+ let signDataPromise = _signDataPromise;
184
+ if (signDataPromise == null) {
185
+ signDataPromise = this.preFetchSignData(signDataPrefetch);
186
+ }
187
+ else
188
+ signDataPrefetch.catch(() => { });
189
+ return {
190
+ signDataPromise,
191
+ resp: await response
192
+ };
193
+ }, undefined, RequestError_1.RequestError, abortController.signal);
194
+ let hash = _hash ?? this._contract.getHashForOnchain(outputScript, resp.amount, _options.confirmations, nonce).toString("hex");
195
+ const data = new this._swapDataDeserializer(resp.data);
196
+ data.setOfferer(signer);
197
+ const inputWithoutFees = data.getAmount() - resp.swapFee - resp.networkFee;
198
+ const swapFeeBtc = resp.swapFee * resp.amount / inputWithoutFees;
199
+ const networkFeeBtc = resp.networkFee * resp.amount / inputWithoutFees;
200
+ this.verifyReturnedData(signer, resp, amountData, lp, _options, data, hash);
201
+ const [pricingInfo, signatureExpiry, reputation] = await Promise.all([
202
+ this.verifyReturnedPrice(lp.services[SwapType_1.SwapType.TO_BTC], true, resp.amount, data.getAmount(), amountData.token, { networkFee: resp.networkFee, swapFeeBtc }, pricePreFetchPromise, usdPricePrefetchPromise, abortController.signal),
203
+ this.verifyReturnedSignature(signer, data, resp, feeRatePromise, signDataPromise, abortController.signal),
204
+ reputationPromise
205
+ ]);
206
+ abortController.signal.throwIfAborted();
207
+ if (reputation != null)
208
+ lp.reputation[amountData.token.toString()] = reputation;
209
+ const quote = new ToBTCSwap_1.ToBTCSwap(this, {
210
+ pricingInfo,
211
+ url: lp.url,
212
+ expiry: signatureExpiry,
213
+ swapFee: resp.swapFee,
214
+ swapFeeBtc,
215
+ feeRate: (await feeRatePromise),
216
+ signatureData: resp,
217
+ data,
218
+ networkFee: resp.networkFee,
219
+ networkFeeBtc,
220
+ address: recipient,
221
+ amount: resp.amount,
222
+ confirmationTarget: _options.confirmationTarget,
223
+ satsPerVByte: Number(resp.satsPervByte),
224
+ exactIn: amountData.exactIn,
225
+ requiredConfirmations: _options.confirmations,
226
+ nonce
227
+ });
228
+ return quote;
229
+ }
230
+ catch (e) {
231
+ abortController.abort(e);
232
+ throw e;
233
+ }
234
+ })()
235
+ };
236
+ });
237
+ }
238
+ /**
239
+ * @inheritDoc
240
+ */
241
+ async recoverFromSwapDataAndState(init, state, lp) {
242
+ const data = init.data;
243
+ const swapInit = {
244
+ pricingInfo: {
245
+ isValid: true,
246
+ satsBaseFee: 0n,
247
+ swapPriceUSatPerToken: 100000000000000n,
248
+ realPriceUSatPerToken: 100000000000000n,
249
+ differencePPM: 0n,
250
+ feePPM: 0n,
251
+ },
252
+ url: lp?.url,
253
+ expiry: 0,
254
+ swapFee: 0n,
255
+ swapFeeBtc: 0n,
256
+ confirmationTarget: 1,
257
+ satsPerVByte: 0,
258
+ feeRate: "",
259
+ signatureData: undefined,
260
+ nonce: data.getNonceHint() ?? undefined,
261
+ requiredConfirmations: data.getConfirmationsHint() ?? undefined,
262
+ data,
263
+ networkFee: 0n,
264
+ networkFeeBtc: 0n,
265
+ exactIn: true
266
+ };
267
+ const swap = new ToBTCSwap_1.ToBTCSwap(this, swapInit);
268
+ swap._commitTxId = await init.getInitTxId();
269
+ const blockData = await init.getTxBlock();
270
+ swap.createdAt = blockData.blockTime * 1000;
271
+ swap._setInitiated();
272
+ swap._state = IToBTCSwap_1.ToBTCSwapState.COMMITED;
273
+ await swap._sync(false, false, state);
274
+ await swap._save();
275
+ return swap;
276
+ }
277
+ }
278
+ exports.ToBTCWrapper = ToBTCWrapper;