@atomiqlabs/sdk 8.1.8 → 8.3.1

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 (253) hide show
  1. package/dist/bitcoin/wallet/BitcoinWallet.d.ts +41 -5
  2. package/dist/bitcoin/wallet/BitcoinWallet.js +36 -1
  3. package/dist/bitcoin/wallet/IBitcoinWallet.d.ts +52 -2
  4. package/dist/bitcoin/wallet/IBitcoinWallet.js +2 -1
  5. package/dist/bitcoin/wallet/SingleAddressBitcoinWallet.d.ts +42 -7
  6. package/dist/bitcoin/wallet/SingleAddressBitcoinWallet.js +36 -1
  7. package/dist/enums/FeeType.d.ts +7 -0
  8. package/dist/enums/FeeType.js +7 -0
  9. package/dist/enums/SwapAmountType.d.ts +7 -0
  10. package/dist/enums/SwapAmountType.js +7 -0
  11. package/dist/enums/SwapDirection.d.ts +7 -0
  12. package/dist/enums/SwapDirection.js +7 -0
  13. package/dist/enums/SwapType.d.ts +62 -1
  14. package/dist/enums/SwapType.js +62 -1
  15. package/dist/errors/IntermediaryError.d.ts +4 -0
  16. package/dist/errors/IntermediaryError.js +1 -0
  17. package/dist/errors/RequestError.d.ts +15 -1
  18. package/dist/errors/RequestError.js +8 -0
  19. package/dist/errors/UserError.d.ts +1 -0
  20. package/dist/errors/UserError.js +1 -0
  21. package/dist/index.d.ts +4 -5
  22. package/dist/index.js +3 -4
  23. package/dist/intermediaries/Intermediary.d.ts +57 -10
  24. package/dist/intermediaries/Intermediary.js +37 -10
  25. package/dist/intermediaries/IntermediaryDiscovery.d.ts +55 -22
  26. package/dist/intermediaries/IntermediaryDiscovery.js +35 -22
  27. package/dist/prices/RedundantSwapPrice.d.ts +24 -3
  28. package/dist/prices/RedundantSwapPrice.js +21 -1
  29. package/dist/prices/SingleSwapPrice.d.ts +9 -6
  30. package/dist/prices/SingleSwapPrice.js +10 -7
  31. package/dist/prices/SwapPriceWithChain.d.ts +54 -16
  32. package/dist/prices/SwapPriceWithChain.js +58 -20
  33. package/dist/prices/abstract/ISwapPrice.d.ts +94 -45
  34. package/dist/prices/abstract/ISwapPrice.js +103 -55
  35. package/dist/prices/providers/BinancePriceProvider.d.ts +7 -0
  36. package/dist/prices/providers/BinancePriceProvider.js +7 -0
  37. package/dist/prices/providers/CoinGeckoPriceProvider.d.ts +6 -0
  38. package/dist/prices/providers/CoinGeckoPriceProvider.js +6 -0
  39. package/dist/prices/providers/CoinPaprikaPriceProvider.d.ts +6 -0
  40. package/dist/prices/providers/CoinPaprikaPriceProvider.js +6 -0
  41. package/dist/prices/providers/CustomPriceProvider.d.ts +11 -0
  42. package/dist/prices/providers/CustomPriceProvider.js +11 -0
  43. package/dist/prices/providers/KrakenPriceProvider.d.ts +9 -0
  44. package/dist/prices/providers/KrakenPriceProvider.js +9 -0
  45. package/dist/prices/providers/OKXPriceProvider.d.ts +6 -0
  46. package/dist/prices/providers/OKXPriceProvider.js +6 -0
  47. package/dist/prices/providers/abstract/ExchangePriceProvider.d.ts +3 -0
  48. package/dist/prices/providers/abstract/ExchangePriceProvider.js +3 -0
  49. package/dist/storage/IUnifiedStorage.d.ts +19 -7
  50. package/dist/storage/UnifiedSwapStorage.d.ts +33 -3
  51. package/dist/storage/UnifiedSwapStorage.js +29 -1
  52. package/dist/storage-browser/IndexedDBUnifiedStorage.d.ts +31 -7
  53. package/dist/storage-browser/IndexedDBUnifiedStorage.js +29 -6
  54. package/dist/storage-browser/LocalStorageManager.d.ts +25 -1
  55. package/dist/storage-browser/LocalStorageManager.js +25 -1
  56. package/dist/swapper/Swapper.d.ts +302 -221
  57. package/dist/swapper/Swapper.js +376 -344
  58. package/dist/swapper/SwapperFactory.d.ts +41 -17
  59. package/dist/swapper/SwapperFactory.js +23 -2
  60. package/dist/swapper/SwapperUtils.d.ts +75 -28
  61. package/dist/swapper/SwapperUtils.js +107 -60
  62. package/dist/swapper/SwapperWithChain.d.ts +286 -91
  63. package/dist/swapper/SwapperWithChain.js +218 -64
  64. package/dist/swapper/SwapperWithSigner.d.ts +229 -80
  65. package/dist/swapper/SwapperWithSigner.js +190 -44
  66. package/dist/swaps/IAddressSwap.d.ts +10 -1
  67. package/dist/swaps/IAddressSwap.js +2 -1
  68. package/dist/swaps/IBTCWalletSwap.d.ts +24 -6
  69. package/dist/swaps/IBTCWalletSwap.js +2 -1
  70. package/dist/swaps/IClaimableSwap.d.ts +36 -4
  71. package/dist/swaps/IClaimableSwap.js +2 -1
  72. package/dist/swaps/IClaimableSwapWrapper.d.ts +11 -1
  73. package/dist/swaps/IRefundableSwap.d.ts +29 -3
  74. package/dist/swaps/IRefundableSwap.js +2 -1
  75. package/dist/swaps/ISwap.d.ts +159 -21
  76. package/dist/swaps/ISwap.js +90 -33
  77. package/dist/swaps/ISwapWithGasDrop.d.ts +6 -0
  78. package/dist/swaps/ISwapWithGasDrop.js +1 -0
  79. package/dist/swaps/ISwapWrapper.d.ts +157 -48
  80. package/dist/swaps/ISwapWrapper.js +130 -72
  81. package/dist/swaps/escrow_swaps/IEscrowSelfInitSwap.d.ts +49 -6
  82. package/dist/swaps/escrow_swaps/IEscrowSelfInitSwap.js +22 -12
  83. package/dist/swaps/escrow_swaps/IEscrowSwap.d.ts +65 -12
  84. package/dist/swaps/escrow_swaps/IEscrowSwap.js +38 -19
  85. package/dist/swaps/escrow_swaps/IEscrowSwapWrapper.d.ts +39 -9
  86. package/dist/swaps/escrow_swaps/IEscrowSwapWrapper.js +30 -21
  87. package/dist/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.d.ts +31 -15
  88. package/dist/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.js +33 -18
  89. package/dist/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.d.ts +94 -29
  90. package/dist/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.js +90 -27
  91. package/dist/swaps/escrow_swaps/frombtc/IFromBTCWrapper.d.ts +22 -9
  92. package/dist/swaps/escrow_swaps/frombtc/IFromBTCWrapper.js +24 -11
  93. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.d.ts +275 -58
  94. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.js +516 -239
  95. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.d.ts +76 -25
  96. package/dist/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.js +131 -49
  97. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.d.ts +311 -51
  98. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.js +542 -193
  99. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.d.ts +87 -26
  100. package/dist/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.js +147 -58
  101. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.d.ts +209 -53
  102. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.js +449 -242
  103. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.d.ts +77 -23
  104. package/dist/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.js +116 -46
  105. package/dist/swaps/escrow_swaps/tobtc/IToBTCSwap.d.ts +197 -56
  106. package/dist/swaps/escrow_swaps/tobtc/IToBTCSwap.js +326 -189
  107. package/dist/swaps/escrow_swaps/tobtc/IToBTCWrapper.d.ts +30 -5
  108. package/dist/swaps/escrow_swaps/tobtc/IToBTCWrapper.js +44 -19
  109. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.d.ts +60 -19
  110. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.js +74 -31
  111. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.d.ts +76 -50
  112. package/dist/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.js +106 -101
  113. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.d.ts +36 -13
  114. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.js +65 -19
  115. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.d.ts +46 -17
  116. package/dist/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.js +82 -27
  117. package/dist/swaps/spv_swaps/SpvFromBTCSwap.d.ts +328 -92
  118. package/dist/swaps/spv_swaps/SpvFromBTCSwap.js +460 -219
  119. package/dist/swaps/spv_swaps/SpvFromBTCWrapper.d.ts +76 -24
  120. package/dist/swaps/spv_swaps/SpvFromBTCWrapper.js +244 -124
  121. package/dist/swaps/trusted/ln/LnForGasSwap.d.ts +146 -18
  122. package/dist/swaps/trusted/ln/LnForGasSwap.js +173 -43
  123. package/dist/swaps/trusted/ln/LnForGasWrapper.d.ts +29 -10
  124. package/dist/swaps/trusted/ln/LnForGasWrapper.js +30 -11
  125. package/dist/swaps/trusted/onchain/OnchainForGasSwap.d.ts +200 -47
  126. package/dist/swaps/trusted/onchain/OnchainForGasSwap.js +230 -78
  127. package/dist/swaps/trusted/onchain/OnchainForGasWrapper.d.ts +34 -12
  128. package/dist/swaps/trusted/onchain/OnchainForGasWrapper.js +33 -14
  129. package/dist/types/AmountData.d.ts +2 -1
  130. package/dist/types/CustomPriceFunction.d.ts +7 -1
  131. package/dist/types/SwapExecutionAction.d.ts +74 -4
  132. package/dist/types/SwapWithSigner.d.ts +4 -1
  133. package/dist/types/SwapWithSigner.js +5 -2
  134. package/dist/types/Token.d.ts +11 -5
  135. package/dist/types/Token.js +6 -3
  136. package/dist/types/TokenAmount.d.ts +3 -0
  137. package/dist/types/TokenAmount.js +2 -0
  138. package/dist/types/fees/Fee.d.ts +2 -1
  139. package/dist/types/fees/FeeBreakdown.d.ts +2 -1
  140. package/dist/types/fees/PercentagePPM.d.ts +2 -0
  141. package/dist/types/fees/PercentagePPM.js +1 -0
  142. package/dist/types/lnurl/LNURLPay.d.ts +14 -6
  143. package/dist/types/lnurl/LNURLPay.js +6 -2
  144. package/dist/types/lnurl/LNURLWithdraw.d.ts +12 -5
  145. package/dist/types/lnurl/LNURLWithdraw.js +6 -2
  146. package/dist/types/wallets/LightningInvoiceCreateService.d.ts +20 -0
  147. package/dist/types/wallets/LightningInvoiceCreateService.js +15 -0
  148. package/dist/types/wallets/MinimalBitcoinWalletInterface.d.ts +3 -1
  149. package/dist/types/wallets/MinimalLightningNetworkWalletInterface.d.ts +3 -1
  150. package/dist/utils/BitcoinUtils.d.ts +1 -0
  151. package/dist/utils/BitcoinUtils.js +5 -1
  152. package/dist/utils/SwapUtils.d.ts +56 -1
  153. package/dist/utils/SwapUtils.js +53 -1
  154. package/dist/utils/TokenUtils.d.ts +10 -2
  155. package/dist/utils/TokenUtils.js +12 -4
  156. package/package.json +3 -3
  157. package/src/bitcoin/wallet/BitcoinWallet.ts +41 -5
  158. package/src/bitcoin/wallet/IBitcoinWallet.ts +57 -2
  159. package/src/bitcoin/wallet/SingleAddressBitcoinWallet.ts +42 -6
  160. package/src/enums/FeeType.ts +7 -0
  161. package/src/enums/SwapAmountType.ts +7 -0
  162. package/src/enums/SwapDirection.ts +7 -0
  163. package/src/enums/SwapType.ts +62 -2
  164. package/src/errors/IntermediaryError.ts +4 -0
  165. package/src/errors/RequestError.ts +15 -1
  166. package/src/errors/UserError.ts +1 -0
  167. package/src/index.ts +6 -5
  168. package/src/intermediaries/Intermediary.ts +57 -10
  169. package/src/intermediaries/IntermediaryDiscovery.ts +60 -27
  170. package/src/prices/RedundantSwapPrice.ts +24 -4
  171. package/src/prices/SingleSwapPrice.ts +10 -7
  172. package/src/prices/SwapPriceWithChain.ts +59 -21
  173. package/src/prices/abstract/ISwapPrice.ts +114 -65
  174. package/src/prices/providers/BinancePriceProvider.ts +7 -0
  175. package/src/prices/providers/CoinGeckoPriceProvider.ts +6 -0
  176. package/src/prices/providers/CoinPaprikaPriceProvider.ts +6 -0
  177. package/src/prices/providers/CustomPriceProvider.ts +11 -0
  178. package/src/prices/providers/KrakenPriceProvider.ts +9 -0
  179. package/src/prices/providers/OKXPriceProvider.ts +6 -0
  180. package/src/prices/providers/abstract/ExchangePriceProvider.ts +3 -0
  181. package/src/storage/IUnifiedStorage.ts +19 -7
  182. package/src/storage/UnifiedSwapStorage.ts +33 -3
  183. package/src/storage-browser/IndexedDBUnifiedStorage.ts +31 -8
  184. package/src/storage-browser/LocalStorageManager.ts +25 -1
  185. package/src/swapper/Swapper.ts +512 -378
  186. package/src/swapper/SwapperFactory.ts +44 -21
  187. package/src/swapper/SwapperUtils.ts +107 -60
  188. package/src/swapper/SwapperWithChain.ts +320 -81
  189. package/src/swapper/SwapperWithSigner.ts +263 -56
  190. package/src/swaps/IAddressSwap.ts +11 -1
  191. package/src/swaps/IBTCWalletSwap.ts +24 -8
  192. package/src/swaps/IClaimableSwap.ts +39 -4
  193. package/src/swaps/IClaimableSwapWrapper.ts +11 -2
  194. package/src/swaps/IRefundableSwap.ts +32 -3
  195. package/src/swaps/ISwap.ts +221 -82
  196. package/src/swaps/ISwapWithGasDrop.ts +6 -0
  197. package/src/swaps/ISwapWrapper.ts +212 -94
  198. package/src/swaps/escrow_swaps/IEscrowSelfInitSwap.ts +62 -18
  199. package/src/swaps/escrow_swaps/IEscrowSwap.ts +83 -37
  200. package/src/swaps/escrow_swaps/IEscrowSwapWrapper.ts +61 -30
  201. package/src/swaps/escrow_swaps/frombtc/IFromBTCLNWrapper.ts +37 -19
  202. package/src/swaps/escrow_swaps/frombtc/IFromBTCSelfInitSwap.ts +120 -51
  203. package/src/swaps/escrow_swaps/frombtc/IFromBTCWrapper.ts +24 -11
  204. package/src/swaps/escrow_swaps/frombtc/ln/FromBTCLNSwap.ts +559 -256
  205. package/src/swaps/escrow_swaps/frombtc/ln/FromBTCLNWrapper.ts +155 -61
  206. package/src/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoSwap.ts +590 -226
  207. package/src/swaps/escrow_swaps/frombtc/ln_auto/FromBTCLNAutoWrapper.ts +177 -74
  208. package/src/swaps/escrow_swaps/frombtc/onchain/FromBTCSwap.ts +470 -243
  209. package/src/swaps/escrow_swaps/frombtc/onchain/FromBTCWrapper.ts +141 -59
  210. package/src/swaps/escrow_swaps/tobtc/IToBTCSwap.ts +352 -193
  211. package/src/swaps/escrow_swaps/tobtc/IToBTCWrapper.ts +48 -23
  212. package/src/swaps/escrow_swaps/tobtc/ln/ToBTCLNSwap.ts +86 -39
  213. package/src/swaps/escrow_swaps/tobtc/ln/ToBTCLNWrapper.ts +110 -110
  214. package/src/swaps/escrow_swaps/tobtc/onchain/ToBTCSwap.ts +88 -33
  215. package/src/swaps/escrow_swaps/tobtc/onchain/ToBTCWrapper.ts +101 -31
  216. package/src/swaps/spv_swaps/SpvFromBTCSwap.ts +534 -263
  217. package/src/swaps/spv_swaps/SpvFromBTCWrapper.ts +289 -148
  218. package/src/swaps/trusted/ln/LnForGasSwap.ts +184 -45
  219. package/src/swaps/trusted/ln/LnForGasWrapper.ts +34 -15
  220. package/src/swaps/trusted/onchain/OnchainForGasSwap.ts +260 -86
  221. package/src/swaps/trusted/onchain/OnchainForGasWrapper.ts +41 -19
  222. package/src/types/AmountData.ts +2 -1
  223. package/src/types/CustomPriceFunction.ts +7 -1
  224. package/src/types/SwapExecutionAction.ts +84 -5
  225. package/src/types/SwapWithSigner.ts +7 -3
  226. package/src/types/Token.ts +12 -5
  227. package/src/types/TokenAmount.ts +3 -0
  228. package/src/types/fees/Fee.ts +2 -1
  229. package/src/types/fees/FeeBreakdown.ts +2 -1
  230. package/src/types/fees/PercentagePPM.ts +2 -0
  231. package/src/types/lnurl/LNURLPay.ts +14 -6
  232. package/src/types/lnurl/LNURLWithdraw.ts +12 -5
  233. package/src/types/wallets/LightningInvoiceCreateService.ts +26 -0
  234. package/src/types/wallets/MinimalBitcoinWalletInterface.ts +3 -1
  235. package/src/types/wallets/MinimalLightningNetworkWalletInterface.ts +3 -1
  236. package/src/utils/BitcoinUtils.ts +5 -0
  237. package/src/utils/SwapUtils.ts +61 -1
  238. package/src/utils/TokenUtils.ts +12 -4
  239. package/dist/bitcoin/BitcoinRpcWithAddressIndex.d.ts +0 -68
  240. package/dist/bitcoin/BitcoinRpcWithAddressIndex.js +0 -2
  241. package/dist/bitcoin/LightningNetworkApi.d.ts +0 -12
  242. package/dist/bitcoin/LightningNetworkApi.js +0 -2
  243. package/dist/bitcoin/mempool/MempoolApi.d.ts +0 -350
  244. package/dist/bitcoin/mempool/MempoolApi.js +0 -311
  245. package/dist/bitcoin/mempool/MempoolBitcoinBlock.d.ts +0 -44
  246. package/dist/bitcoin/mempool/MempoolBitcoinBlock.js +0 -48
  247. package/dist/bitcoin/mempool/MempoolBitcoinRpc.d.ts +0 -119
  248. package/dist/bitcoin/mempool/MempoolBitcoinRpc.js +0 -361
  249. package/dist/bitcoin/mempool/synchronizer/MempoolBtcRelaySynchronizer.d.ts +0 -22
  250. package/dist/bitcoin/mempool/synchronizer/MempoolBtcRelaySynchronizer.js +0 -105
  251. package/dist/errors/PaymentAuthError.d.ts +0 -11
  252. package/dist/errors/PaymentAuthError.js +0 -23
  253. package/src/errors/PaymentAuthError.ts +0 -26
@@ -1,361 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.MempoolBitcoinRpc = void 0;
4
- const MempoolBitcoinBlock_1 = require("./MempoolBitcoinBlock");
5
- const MempoolApi_1 = require("./MempoolApi");
6
- const buffer_1 = require("buffer");
7
- const Utils_1 = require("../../utils/Utils");
8
- const btc_signer_1 = require("@scure/btc-signer");
9
- const sha2_1 = require("@noble/hashes/sha2");
10
- const TimeoutUtils_1 = require("../../utils/TimeoutUtils");
11
- const BITCOIN_BLOCKTIME = 600 * 1000;
12
- const BITCOIN_BLOCKSIZE = 1024 * 1024;
13
- function bitcoinTxToBtcTx(btcTx) {
14
- return {
15
- locktime: btcTx.lockTime,
16
- version: btcTx.version,
17
- confirmations: 0,
18
- txid: buffer_1.Buffer.from((0, sha2_1.sha256)((0, sha2_1.sha256)(btcTx.toBytes(true, false)))).reverse().toString("hex"),
19
- hex: buffer_1.Buffer.from(btcTx.toBytes(true, false)).toString("hex"),
20
- raw: buffer_1.Buffer.from(btcTx.toBytes(true, true)).toString("hex"),
21
- vsize: btcTx.isFinal ? btcTx.vsize : NaN,
22
- outs: Array.from({ length: btcTx.outputsLength }, (_, i) => i).map((index) => {
23
- const output = btcTx.getOutput(index);
24
- return {
25
- value: Number(output.amount),
26
- n: index,
27
- scriptPubKey: {
28
- asm: btc_signer_1.Script.decode(output.script).map(val => typeof (val) === "object" ? buffer_1.Buffer.from(val).toString("hex") : val.toString()).join(" "),
29
- hex: buffer_1.Buffer.from(output.script).toString("hex")
30
- }
31
- };
32
- }),
33
- ins: Array.from({ length: btcTx.inputsLength }, (_, i) => i).map(index => {
34
- const input = btcTx.getInput(index);
35
- return {
36
- txid: buffer_1.Buffer.from(input.txid).toString("hex"),
37
- vout: input.index,
38
- scriptSig: {
39
- asm: btc_signer_1.Script.decode(input.finalScriptSig).map(val => typeof (val) === "object" ? buffer_1.Buffer.from(val).toString("hex") : val.toString()).join(" "),
40
- hex: buffer_1.Buffer.from(input.finalScriptSig).toString("hex")
41
- },
42
- sequence: input.sequence,
43
- txinwitness: input.finalScriptWitness == null ? [] : input.finalScriptWitness.map(witness => buffer_1.Buffer.from(witness).toString("hex"))
44
- };
45
- })
46
- };
47
- }
48
- /**
49
- * Bitcoin RPC implementation via Mempool.space API
50
- * @category Bitcoin
51
- */
52
- class MempoolBitcoinRpc {
53
- constructor(urlOrMempoolApi) {
54
- this.api = urlOrMempoolApi instanceof MempoolApi_1.MempoolApi ? urlOrMempoolApi : new MempoolApi_1.MempoolApi(urlOrMempoolApi);
55
- }
56
- /**
57
- * Returns a txo hash for a specific transaction vout
58
- *
59
- * @param vout
60
- * @private
61
- */
62
- static getTxoHash(vout) {
63
- return (0, Utils_1.getTxoHash)(vout.scriptpubkey, vout.value);
64
- }
65
- /**
66
- * Returns delay in milliseconds till an unconfirmed transaction is expected to confirm, returns -1
67
- * if the transaction won't confirm any time soon
68
- *
69
- * @param feeRate
70
- * @private
71
- */
72
- async getTimeTillConfirmation(feeRate) {
73
- const mempoolBlocks = await this.api.getPendingBlocks();
74
- const mempoolBlockIndex = mempoolBlocks.findIndex(block => block.feeRange[0] <= feeRate);
75
- if (mempoolBlockIndex === -1)
76
- return -1;
77
- //Last returned block is usually an aggregate (or a stack) of multiple btc blocks, if tx falls in this block
78
- // and the last returned block really is an aggregate one (size bigger than BITCOIN_BLOCKSIZE) we return -1
79
- if (mempoolBlockIndex + 1 === mempoolBlocks.length &&
80
- mempoolBlocks[mempoolBlocks.length - 1].blockVSize > BITCOIN_BLOCKSIZE)
81
- return -1;
82
- return (mempoolBlockIndex + 1) * BITCOIN_BLOCKTIME;
83
- }
84
- /**
85
- * Returns an estimate after which time the tx will confirm with the required amount of confirmations,
86
- * confirmationDelay of -1 means the transaction won't confirm in the near future
87
- *
88
- * @param tx
89
- * @param requiredConfirmations
90
- * @private
91
- *
92
- * @returns estimated confirmation delay, -1 if the transaction won't confirm in the near future, null if the
93
- * transaction was replaced or was confirmed in the meantime
94
- */
95
- async getConfirmationDelay(tx, requiredConfirmations) {
96
- if (tx.confirmations == null || tx.confirmations === 0) {
97
- //Get CPFP data
98
- const cpfpData = await this.api.getCPFPData(tx.txid);
99
- if (cpfpData.effectiveFeePerVsize == null) {
100
- //Transaction is either confirmed in the meantime, or replaced
101
- return null;
102
- }
103
- let confirmationDelay = (await this.getTimeTillConfirmation(cpfpData.effectiveFeePerVsize));
104
- if (confirmationDelay !== -1)
105
- confirmationDelay += (requiredConfirmations - 1) * BITCOIN_BLOCKTIME;
106
- return confirmationDelay;
107
- }
108
- if (tx.confirmations > requiredConfirmations)
109
- return 0;
110
- return ((requiredConfirmations - tx.confirmations) * BITCOIN_BLOCKTIME);
111
- }
112
- /**
113
- * Converts mempool API's transaction to BtcTx object while fetching the raw tx separately
114
- * @param tx Transaction to convert
115
- * @private
116
- */
117
- async toBtcTx(tx) {
118
- const base = await this.toBtcTxWithoutRawData(tx);
119
- if (base == null)
120
- return null;
121
- const rawTx = await this.api.getRawTransaction(tx.txid);
122
- if (rawTx == null)
123
- return null;
124
- //Strip witness data
125
- const btcTx = btc_signer_1.Transaction.fromRaw(rawTx, {
126
- allowLegacyWitnessUtxo: true,
127
- allowUnknownInputs: true,
128
- allowUnknownOutputs: true,
129
- disableScriptCheck: true
130
- });
131
- const strippedRawTx = buffer_1.Buffer.from(btcTx.toBytes(true, false)).toString("hex");
132
- return {
133
- ...base,
134
- hex: strippedRawTx,
135
- raw: rawTx.toString("hex")
136
- };
137
- }
138
- /**
139
- * Converts mempool API's transaction to BtcTx object, doesn't populate raw and hex fields
140
- * @param tx Transaction to convert
141
- * @private
142
- */
143
- async toBtcTxWithoutRawData(tx) {
144
- let confirmations = 0;
145
- if (tx.status != null && tx.status.confirmed) {
146
- const blockheight = await this.api.getTipBlockHeight();
147
- confirmations = blockheight - tx.status.block_height + 1;
148
- }
149
- return {
150
- locktime: tx.locktime,
151
- version: tx.version,
152
- blockheight: tx.status?.block_height,
153
- blockhash: tx.status?.block_hash,
154
- confirmations,
155
- txid: tx.txid,
156
- vsize: tx.weight / 4,
157
- outs: tx.vout.map((e, index) => {
158
- return {
159
- value: e.value,
160
- n: index,
161
- scriptPubKey: {
162
- hex: e.scriptpubkey,
163
- asm: e.scriptpubkey_asm
164
- }
165
- };
166
- }),
167
- ins: tx.vin.map(e => {
168
- return {
169
- txid: e.txid,
170
- vout: e.vout,
171
- scriptSig: {
172
- hex: e.scriptsig,
173
- asm: e.scriptsig_asm
174
- },
175
- sequence: e.sequence,
176
- txinwitness: e.witness
177
- };
178
- }),
179
- inputAddresses: tx.vin.map(e => e.prevout.scriptpubkey_address)
180
- };
181
- }
182
- getTipHeight() {
183
- return this.api.getTipBlockHeight();
184
- }
185
- async getBlockHeader(blockhash) {
186
- return new MempoolBitcoinBlock_1.MempoolBitcoinBlock(await this.api.getBlockHeader(blockhash));
187
- }
188
- async getMerkleProof(txId, blockhash) {
189
- const proof = await this.api.getTransactionProof(txId);
190
- return {
191
- reversedTxId: buffer_1.Buffer.from(txId, "hex").reverse(),
192
- pos: proof.pos,
193
- merkle: proof.merkle.map(e => buffer_1.Buffer.from(e, "hex").reverse()),
194
- blockheight: proof.block_height
195
- };
196
- }
197
- async getTransaction(txId) {
198
- const tx = await this.api.getTransaction(txId);
199
- if (tx == null)
200
- return null;
201
- return await this.toBtcTx(tx);
202
- }
203
- async isInMainChain(blockhash) {
204
- const blockStatus = await this.api.getBlockStatus(blockhash);
205
- return blockStatus.in_best_chain;
206
- }
207
- getBlockhash(height) {
208
- return this.api.getBlockHash(height);
209
- }
210
- getBlockWithTransactions(blockhash) {
211
- throw new Error("Unsupported.");
212
- }
213
- async getSyncInfo() {
214
- const tipHeight = await this.api.getTipBlockHeight();
215
- return {
216
- verificationProgress: 1,
217
- blocks: tipHeight,
218
- headers: tipHeight,
219
- ibd: false
220
- };
221
- }
222
- async getPast15Blocks(height) {
223
- return (await this.api.getPast15BlockHeaders(height)).map(blockHeader => new MempoolBitcoinBlock_1.MempoolBitcoinBlock(blockHeader));
224
- }
225
- async checkAddressTxos(address, txoHash) {
226
- const allTxs = await this.api.getAddressTransactions(address);
227
- const relevantTxs = allTxs
228
- .map(tx => {
229
- return {
230
- tx,
231
- vout: tx.vout.findIndex(vout => MempoolBitcoinRpc.getTxoHash(vout).equals(txoHash))
232
- };
233
- })
234
- .filter(obj => obj.vout >= 0)
235
- .sort((a, b) => {
236
- if (a.tx.status.confirmed && !b.tx.status.confirmed)
237
- return -1;
238
- if (!a.tx.status.confirmed && b.tx.status.confirmed)
239
- return 1;
240
- if (a.tx.status.confirmed && b.tx.status.confirmed)
241
- return a.tx.status.block_height - b.tx.status.block_height;
242
- return 0;
243
- });
244
- if (relevantTxs.length === 0)
245
- return null;
246
- return {
247
- tx: await this.toBtcTxWithoutRawData(relevantTxs[0].tx),
248
- vout: relevantTxs[0].vout
249
- };
250
- }
251
- /**
252
- * Waits till the address receives a transaction containing a specific txoHash
253
- *
254
- * @param address
255
- * @param txoHash
256
- * @param requiredConfirmations
257
- * @param stateUpdateCbk
258
- * @param abortSignal
259
- * @param intervalSeconds
260
- */
261
- async waitForAddressTxo(address, txoHash, requiredConfirmations, stateUpdateCbk, abortSignal, intervalSeconds) {
262
- if (abortSignal != null)
263
- abortSignal.throwIfAborted();
264
- while (abortSignal == null || !abortSignal.aborted) {
265
- await (0, TimeoutUtils_1.timeoutPromise)((intervalSeconds || 5) * 1000, abortSignal);
266
- const result = await this.checkAddressTxos(address, txoHash);
267
- if (result == null) {
268
- stateUpdateCbk();
269
- continue;
270
- }
271
- const confirmationDelay = await this.getConfirmationDelay(result.tx, requiredConfirmations);
272
- if (confirmationDelay == null)
273
- continue;
274
- if (stateUpdateCbk != null)
275
- stateUpdateCbk(result.tx, result.vout, confirmationDelay);
276
- if (confirmationDelay === 0)
277
- return result;
278
- }
279
- throw abortSignal.reason;
280
- }
281
- async waitForTransaction(txId, requiredConfirmations, stateUpdateCbk, abortSignal, intervalSeconds) {
282
- if (abortSignal != null)
283
- abortSignal.throwIfAborted();
284
- while (abortSignal == null || !abortSignal.aborted) {
285
- await (0, TimeoutUtils_1.timeoutPromise)((intervalSeconds || 5) * 1000, abortSignal);
286
- const result = await this.getTransaction(txId);
287
- if (result == null) {
288
- stateUpdateCbk();
289
- continue;
290
- }
291
- const confirmationDelay = await this.getConfirmationDelay(result, requiredConfirmations);
292
- if (confirmationDelay == null)
293
- continue;
294
- if (stateUpdateCbk != null)
295
- stateUpdateCbk(result, confirmationDelay);
296
- if (confirmationDelay === 0)
297
- return result;
298
- }
299
- throw abortSignal.reason;
300
- }
301
- async getLNNodeLiquidity(pubkey) {
302
- const nodeInfo = await this.api.getLNNodeInfo(pubkey);
303
- if (nodeInfo == null)
304
- return null;
305
- return {
306
- publicKey: nodeInfo.public_key,
307
- capacity: BigInt(nodeInfo.capacity),
308
- numChannels: nodeInfo.active_channel_count
309
- };
310
- }
311
- sendRawTransaction(rawTx) {
312
- return this.api.sendTransaction(rawTx);
313
- }
314
- sendRawPackage(rawTx) {
315
- throw new Error("Unsupported");
316
- }
317
- async isSpent(utxo, confirmed) {
318
- const [txId, voutStr] = utxo.split(":");
319
- const vout = parseInt(voutStr);
320
- const outspends = await this.api.getOutspends(txId);
321
- if (outspends[vout] == null)
322
- return true;
323
- if (confirmed) {
324
- return outspends[vout].spent && outspends[vout].status.confirmed;
325
- }
326
- return outspends[vout].spent;
327
- }
328
- parseTransaction(rawTx) {
329
- const btcTx = btc_signer_1.Transaction.fromRaw(buffer_1.Buffer.from(rawTx, "hex"), {
330
- allowLegacyWitnessUtxo: true,
331
- allowUnknownInputs: true,
332
- allowUnknownOutputs: true,
333
- disableScriptCheck: true
334
- });
335
- return Promise.resolve(bitcoinTxToBtcTx(btcTx));
336
- }
337
- getEffectiveFeeRate(btcTx) {
338
- throw new Error("Unsupported.");
339
- }
340
- async getFeeRate() {
341
- return (await this.api.getFees()).fastestFee;
342
- }
343
- getAddressBalances(address) {
344
- return this.api.getAddressBalances(address);
345
- }
346
- async getAddressUTXOs(address) {
347
- return (await this.api.getAddressUTXOs(address)).map(val => ({
348
- txid: val.txid,
349
- vout: val.vout,
350
- confirmed: val.status.confirmed,
351
- block_height: val.status.block_height,
352
- block_hash: val.status.block_hash,
353
- block_time: val.status.block_time,
354
- value: val.value
355
- }));
356
- }
357
- getCPFPData(txId) {
358
- return this.api.getCPFPData(txId);
359
- }
360
- }
361
- exports.MempoolBitcoinRpc = MempoolBitcoinRpc;
@@ -1,22 +0,0 @@
1
- import { BtcRelay, BtcStoredHeader, RelaySynchronizer } from "@atomiqlabs/base";
2
- import { MempoolBitcoinBlock } from "../MempoolBitcoinBlock";
3
- import { MempoolBitcoinRpc } from "../MempoolBitcoinRpc";
4
- export declare class MempoolBtcRelaySynchronizer<B extends BtcStoredHeader<any>, TX> implements RelaySynchronizer<B, TX, MempoolBitcoinBlock> {
5
- bitcoinRpc: MempoolBitcoinRpc;
6
- btcRelay: BtcRelay<B, TX, MempoolBitcoinBlock>;
7
- constructor(btcRelay: BtcRelay<B, TX, MempoolBitcoinBlock>, bitcoinRpc: MempoolBitcoinRpc);
8
- syncToLatestTxs(signer: string, feeRate?: string): Promise<{
9
- txs: TX[];
10
- targetCommitedHeader: B;
11
- computedHeaderMap: {
12
- [blockheight: number]: B;
13
- };
14
- blockHeaderMap: {
15
- [blockheight: number]: MempoolBitcoinBlock;
16
- };
17
- btcRelayTipCommitedHeader: B;
18
- btcRelayTipBlockHeader: MempoolBitcoinBlock;
19
- latestBlockHeader: MempoolBitcoinBlock;
20
- startForkId?: number;
21
- }>;
22
- }
@@ -1,105 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.MempoolBtcRelaySynchronizer = void 0;
4
- const Logger_1 = require("../../../utils/Logger");
5
- const TimeoutUtils_1 = require("../../../utils/TimeoutUtils");
6
- const logger = (0, Logger_1.getLogger)("MempoolBtcRelaySynchronizer: ");
7
- class MempoolBtcRelaySynchronizer {
8
- constructor(btcRelay, bitcoinRpc) {
9
- this.btcRelay = btcRelay;
10
- this.bitcoinRpc = bitcoinRpc;
11
- }
12
- async syncToLatestTxs(signer, feeRate) {
13
- const tipData = await this.btcRelay.getTipData();
14
- if (tipData == null)
15
- throw new Error("BtcRelay tip data not found - probably not initialized?");
16
- const latestKnownBlockLogData = await this.btcRelay.retrieveLatestKnownBlockLog();
17
- if (latestKnownBlockLogData == null)
18
- throw new Error("Failed to get latest known block log");
19
- const { resultStoredHeader, resultBitcoinHeader } = latestKnownBlockLogData;
20
- let cacheData = {
21
- forkId: resultStoredHeader.getBlockheight() < tipData.blockheight ? -1 : 0,
22
- lastStoredHeader: resultStoredHeader,
23
- computedCommitedHeaders: []
24
- };
25
- let spvTipBlockHeader = latestKnownBlockLogData.resultBitcoinHeader;
26
- logger.debug("Retrieved stored header with commitment: ", cacheData.lastStoredHeader);
27
- logger.debug("SPV tip bitcoin RPC block header: ", spvTipBlockHeader);
28
- let spvTipBlockHeight = spvTipBlockHeader.height;
29
- const txsList = [];
30
- const blockHeaderMap = {
31
- [resultBitcoinHeader.getHeight()]: resultBitcoinHeader
32
- };
33
- const computedHeaderMap = {
34
- [resultStoredHeader.getBlockheight()]: resultStoredHeader
35
- };
36
- let startForkId = undefined;
37
- let forkFee = feeRate;
38
- let mainFee = feeRate;
39
- const saveHeaders = async (headerCache) => {
40
- if (cacheData.forkId === -1) {
41
- if (mainFee == null)
42
- mainFee = await this.btcRelay.getMainFeeRate(signer);
43
- cacheData = await this.btcRelay.saveNewForkHeaders(signer, headerCache, cacheData.lastStoredHeader, tipData.chainWork, mainFee);
44
- }
45
- else if (cacheData.forkId === 0) {
46
- if (mainFee == null)
47
- mainFee = await this.btcRelay.getMainFeeRate(signer);
48
- cacheData = await this.btcRelay.saveMainHeaders(signer, headerCache, cacheData.lastStoredHeader, mainFee);
49
- }
50
- else {
51
- if (forkFee == null)
52
- forkFee = await this.btcRelay.getForkFeeRate(signer, cacheData.forkId);
53
- cacheData = await this.btcRelay.saveForkHeaders(signer, headerCache, cacheData.lastStoredHeader, cacheData.forkId, tipData.chainWork, forkFee);
54
- }
55
- if (cacheData.forkId !== -1 && cacheData.forkId !== 0)
56
- startForkId = cacheData.forkId;
57
- txsList.push(cacheData.tx);
58
- for (let storedHeader of cacheData.computedCommitedHeaders) {
59
- computedHeaderMap[storedHeader.getBlockheight()] = storedHeader;
60
- }
61
- };
62
- let headerCache = [];
63
- while (true) {
64
- const retrievedHeaders = await this.bitcoinRpc.getPast15Blocks(spvTipBlockHeight + 15);
65
- let startIndex = retrievedHeaders.findIndex(val => val.height === spvTipBlockHeight);
66
- if (startIndex === -1)
67
- startIndex = retrievedHeaders.length; //Start from the last block
68
- for (let i = startIndex - 1; i >= 0; i--) {
69
- const header = retrievedHeaders[i];
70
- blockHeaderMap[header.height] = header;
71
- headerCache.push(header);
72
- if (cacheData.forkId === 0 ?
73
- headerCache.length >= this.btcRelay.maxHeadersPerTx :
74
- headerCache.length >= this.btcRelay.maxForkHeadersPerTx) {
75
- await saveHeaders(headerCache);
76
- headerCache = [];
77
- }
78
- }
79
- if (retrievedHeaders.length > 0) {
80
- if (spvTipBlockHeight === retrievedHeaders[0].height)
81
- break; //Already at the tip
82
- spvTipBlockHeight = retrievedHeaders[0].height;
83
- await (0, TimeoutUtils_1.timeoutPromise)(1000);
84
- }
85
- else
86
- break;
87
- }
88
- if (headerCache.length > 0)
89
- await saveHeaders(headerCache);
90
- if (cacheData.forkId !== 0) {
91
- throw new Error("Unable to synchronize on-chain bitcoin light client! Not enough chainwork at connected RPC.");
92
- }
93
- return {
94
- txs: txsList,
95
- targetCommitedHeader: cacheData.lastStoredHeader,
96
- blockHeaderMap,
97
- computedHeaderMap,
98
- btcRelayTipCommitedHeader: resultStoredHeader,
99
- btcRelayTipBlockHeader: resultBitcoinHeader,
100
- latestBlockHeader: spvTipBlockHeader,
101
- startForkId
102
- };
103
- }
104
- }
105
- exports.MempoolBtcRelaySynchronizer = MempoolBtcRelaySynchronizer;
@@ -1,11 +0,0 @@
1
- /**
2
- * An error when the payment authorization returned by the intermediary is invalid
3
- * @category Errors
4
- */
5
- export declare class PaymentAuthError extends Error {
6
- code?: number;
7
- data: any;
8
- constructor(msg: string, code?: number, data?: any);
9
- getCode(): number | undefined;
10
- getData(): any;
11
- }
@@ -1,23 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.PaymentAuthError = void 0;
4
- /**
5
- * An error when the payment authorization returned by the intermediary is invalid
6
- * @category Errors
7
- */
8
- class PaymentAuthError extends Error {
9
- constructor(msg, code, data) {
10
- super(msg);
11
- this.data = data;
12
- this.code = code;
13
- // Set the prototype explicitly.
14
- Object.setPrototypeOf(this, PaymentAuthError.prototype);
15
- }
16
- getCode() {
17
- return this.code;
18
- }
19
- getData() {
20
- return this.data;
21
- }
22
- }
23
- exports.PaymentAuthError = PaymentAuthError;
@@ -1,26 +0,0 @@
1
- /**
2
- * An error when the payment authorization returned by the intermediary is invalid
3
- * @category Errors
4
- */
5
- export class PaymentAuthError extends Error {
6
-
7
- code?: number;
8
- data: any;
9
-
10
- constructor(msg: string, code?: number, data?: any) {
11
- super(msg);
12
- this.data = data;
13
- this.code = code;
14
- // Set the prototype explicitly.
15
- Object.setPrototypeOf(this, PaymentAuthError.prototype);
16
- }
17
-
18
- getCode(): number | undefined {
19
- return this.code;
20
- }
21
-
22
- getData(): any {
23
- return this.data;
24
- }
25
-
26
- }