@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
@@ -6,13 +6,19 @@ const IEscrowSelfInitSwap_1 = require("../IEscrowSelfInitSwap");
6
6
  const FeeType_1 = require("../../../enums/FeeType");
7
7
  const PercentagePPM_1 = require("../../../types/fees/PercentagePPM");
8
8
  const TokenAmount_1 = require("../../../types/TokenAmount");
9
+ /**
10
+ * Base class for legacy escrow-based Bitcoin (on-chain & lightning) -> Smart chain swaps,
11
+ * which require the user to manually initiate the escrow on the destination smart chain
12
+ *
13
+ * @category Swaps
14
+ */
9
15
  class IFromBTCSelfInitSwap extends IEscrowSelfInitSwap_1.IEscrowSelfInitSwap {
10
16
  constructor(wrapper, initOrObj) {
11
17
  super(wrapper, initOrObj);
12
18
  }
13
19
  /**
14
- * In case swapFee in BTC is not supplied it recalculates it based on swap price
15
- * @protected
20
+ * @inheritDoc
21
+ * @internal
16
22
  */
17
23
  tryRecomputeSwapPrice() {
18
24
  const input = this.getInput();
@@ -21,106 +27,163 @@ class IFromBTCSelfInitSwap extends IEscrowSelfInitSwap_1.IEscrowSelfInitSwap {
21
27
  }
22
28
  super.tryRecomputeSwapPrice();
23
29
  }
30
+ /**
31
+ * @inheritDoc
32
+ * @internal
33
+ */
24
34
  _getInitiator() {
25
35
  return this.getSwapData().getClaimer();
26
36
  }
37
+ /**
38
+ * @inheritDoc
39
+ */
27
40
  getOutputTxId() {
28
- return this.claimTxId ?? null;
41
+ return this._claimTxId ?? null;
29
42
  }
43
+ /**
44
+ * @inheritDoc
45
+ */
30
46
  getOutputAddress() {
31
47
  return this._getInitiator();
32
48
  }
49
+ /**
50
+ * @inheritDoc
51
+ */
33
52
  requiresAction() {
34
53
  return this.isClaimable();
35
54
  }
36
55
  //////////////////////////////
37
56
  //// Amounts & fees
57
+ /**
58
+ * Returns the swap output amount in destination token based units without any fees, this
59
+ * value is therefore always higher than the actual received output.
60
+ *
61
+ * @internal
62
+ */
38
63
  getOutAmountWithoutFee() {
39
64
  return this.getSwapData().getAmount() + this.swapFee;
40
65
  }
66
+ /**
67
+ * Returns the swap fee charged by the intermediary (LP) on this swap
68
+ *
69
+ * @internal
70
+ */
41
71
  getSwapFee() {
42
72
  if (this.pricingInfo == null)
43
73
  throw new Error("No pricing info known, cannot estimate fee!");
44
74
  const feeWithoutBaseFee = this.swapFeeBtc - this.pricingInfo.satsBaseFee;
45
75
  const inputWithoutFee = this.getInputWithoutFee();
46
76
  const swapFeePPM = inputWithoutFee.rawAmount == null ? 0n : feeWithoutBaseFee * 1000000n / inputWithoutFee.rawAmount;
47
- const amountInSrcToken = (0, TokenAmount_1.toTokenAmount)(this.swapFeeBtc, this.inputToken, this.wrapper.prices, this.pricingInfo);
77
+ const amountInSrcToken = (0, TokenAmount_1.toTokenAmount)(this.swapFeeBtc, this.inputToken, this.wrapper._prices, this.pricingInfo);
48
78
  return {
49
79
  amountInSrcToken,
50
- amountInDstToken: (0, TokenAmount_1.toTokenAmount)(this.swapFee, this.wrapper.tokens[this.getSwapData().getToken()], this.wrapper.prices, this.pricingInfo),
80
+ amountInDstToken: (0, TokenAmount_1.toTokenAmount)(this.swapFee, this.wrapper._tokens[this.getSwapData().getToken()], this.wrapper._prices, this.pricingInfo),
51
81
  currentUsdValue: amountInSrcToken.currentUsdValue,
52
82
  usdValue: amountInSrcToken.usdValue,
53
83
  pastUsdValue: amountInSrcToken.pastUsdValue,
54
84
  composition: {
55
- base: (0, TokenAmount_1.toTokenAmount)(this.pricingInfo.satsBaseFee, this.inputToken, this.wrapper.prices, this.pricingInfo),
85
+ base: (0, TokenAmount_1.toTokenAmount)(this.pricingInfo.satsBaseFee, this.inputToken, this.wrapper._prices, this.pricingInfo),
56
86
  percentage: (0, PercentagePPM_1.ppmToPercentage)(swapFeePPM)
57
87
  }
58
88
  };
59
89
  }
90
+ /**
91
+ * @inheritDoc
92
+ */
60
93
  getFee() {
61
94
  return this.getSwapFee();
62
95
  }
96
+ /**
97
+ * @inheritDoc
98
+ */
63
99
  getFeeBreakdown() {
64
100
  return [{
65
101
  type: FeeType_1.FeeType.SWAP,
66
102
  fee: this.getSwapFee()
67
103
  }];
68
104
  }
105
+ /**
106
+ * @inheritDoc
107
+ */
69
108
  getOutputToken() {
70
- return this.wrapper.tokens[this.getSwapData().getToken()];
109
+ return this.wrapper._tokens[this.getSwapData().getToken()];
71
110
  }
111
+ /**
112
+ * @inheritDoc
113
+ */
72
114
  getOutput() {
73
- return (0, TokenAmount_1.toTokenAmount)(this.getSwapData().getAmount(), this.wrapper.tokens[this.getSwapData().getToken()], this.wrapper.prices, this.pricingInfo);
115
+ return (0, TokenAmount_1.toTokenAmount)(this.getSwapData().getAmount(), this.wrapper._tokens[this.getSwapData().getToken()], this.wrapper._prices, this.pricingInfo);
74
116
  }
117
+ /**
118
+ * @inheritDoc
119
+ */
75
120
  getInputWithoutFee() {
76
121
  const input = this.getInput();
77
122
  if (input.rawAmount == null)
78
- return (0, TokenAmount_1.toTokenAmount)(null, this.inputToken, this.wrapper.prices, this.pricingInfo);
79
- return (0, TokenAmount_1.toTokenAmount)(input.rawAmount - this.swapFeeBtc, this.inputToken, this.wrapper.prices, this.pricingInfo);
80
- }
81
- getSecurityDeposit() {
82
- return (0, TokenAmount_1.toTokenAmount)(this.getSwapData().getSecurityDeposit(), this.wrapper.getNativeToken(), this.wrapper.prices, this.pricingInfo);
83
- }
84
- getTotalDeposit() {
85
- return (0, TokenAmount_1.toTokenAmount)(this.getSwapData().getTotalDeposit(), this.wrapper.getNativeToken(), this.wrapper.prices, this.pricingInfo);
123
+ return (0, TokenAmount_1.toTokenAmount)(null, this.inputToken, this.wrapper._prices, this.pricingInfo);
124
+ return (0, TokenAmount_1.toTokenAmount)(input.rawAmount - this.swapFeeBtc, this.inputToken, this.wrapper._prices, this.pricingInfo);
86
125
  }
126
+ /**
127
+ * @inheritDoc
128
+ */
87
129
  async hasEnoughForTxFees() {
88
130
  const [balance, commitFee] = await Promise.all([
89
- this.wrapper.contract.getBalance(this._getInitiator(), this.wrapper.chain.getNativeCurrencyAddress(), false),
131
+ this.wrapper._contract.getBalance(this._getInitiator(), this.wrapper._chain.getNativeCurrencyAddress(), false),
90
132
  this.getCommitFee()
91
133
  ]);
92
134
  const totalFee = commitFee + this.getSwapData().getTotalDeposit();
93
135
  return {
94
136
  enoughBalance: balance >= totalFee,
95
- balance: (0, TokenAmount_1.toTokenAmount)(balance, this.wrapper.getNativeToken(), this.wrapper.prices, this.pricingInfo),
96
- required: (0, TokenAmount_1.toTokenAmount)(totalFee, this.wrapper.getNativeToken(), this.wrapper.prices, this.pricingInfo)
137
+ balance: (0, TokenAmount_1.toTokenAmount)(balance, this.wrapper._getNativeToken(), this.wrapper._prices, this.pricingInfo),
138
+ required: (0, TokenAmount_1.toTokenAmount)(totalFee, this.wrapper._getNativeToken(), this.wrapper._prices, this.pricingInfo)
97
139
  };
98
140
  }
141
+ /**
142
+ * Returns the amount of native token of the destination chain locked up during initialization of the escrow
143
+ * to act as a security deposit that can be taken by the intermediary (LP) if the user doesn't go through
144
+ * with the swap
145
+ */
146
+ getSecurityDeposit() {
147
+ return (0, TokenAmount_1.toTokenAmount)(this.getSwapData().getSecurityDeposit(), this.wrapper._getNativeToken(), this.wrapper._prices, this.pricingInfo);
148
+ }
149
+ /**
150
+ * Returns the total amount of native token of the destination chain locked up during initialization of the escrow.
151
+ * This covers the security deposit and the watchtower fee (if applicable), it is calculated a maximum of those
152
+ * two values.
153
+ */
154
+ getTotalDeposit() {
155
+ return (0, TokenAmount_1.toTokenAmount)(this.getSwapData().getTotalDeposit(), this.wrapper._getNativeToken(), this.wrapper._prices, this.pricingInfo);
156
+ }
99
157
  //////////////////////////////
100
158
  //// Commit
101
159
  /**
102
- * Returns the transactions required for committing the swap on-chain, locking the tokens from the intermediary
103
- * in an HTLC or PTLC
160
+ * Creates the escrow on the destination smart chain side, pre-locking the tokens from the intermediary (LP)
161
+ * into an escrow.
162
+ *
163
+ * @inheritDoc
104
164
  *
105
- * @param skipChecks Skip checks like making sure init signature is still valid and swap wasn't commited yet
106
- * (this is handled when swap is created (quoted), if you commit right after quoting, you can use skipChecks=true)
107
165
  * @throws {Error} When in invalid state to commit the swap
108
166
  */
109
167
  async txsCommit(skipChecks) {
110
168
  if (!this.canCommit())
111
169
  throw new Error("Must be in CREATED state!");
112
- if (this.data == null || this.signatureData == null)
170
+ if (this._data == null || this.signatureData == null)
113
171
  throw new Error("data or signature data is null, invalid state?");
114
172
  if (!this.initiated) {
115
173
  this.initiated = true;
116
174
  await this._saveAndEmit();
117
175
  }
118
- return await this.wrapper.contract.txsInit(this._getInitiator(), this.data, this.signatureData, skipChecks, this.feeRate).catch(e => Promise.reject(e instanceof base_1.SignatureVerificationError ? new Error("Request timed out") : e));
176
+ return await this.wrapper._contract.txsInit(this._getInitiator(), this._data, this.signatureData, skipChecks, this.feeRate).catch(e => Promise.reject(e instanceof base_1.SignatureVerificationError ? new Error("Request timed out") : e));
119
177
  }
120
178
  //////////////////////////////
121
179
  //// Claim
122
- getClaimFee() {
123
- return this.wrapper.contract.getClaimFee(this._getInitiator(), this.getSwapData());
180
+ /**
181
+ * Returns the transaction fee required for the claim transaction to settle the escrow on the destination
182
+ * smart chain
183
+ */
184
+ async getClaimNetworkFee() {
185
+ const swapContract = this.wrapper._contract;
186
+ return (0, TokenAmount_1.toTokenAmount)(await swapContract.getClaimFee(this._getInitiator(), this.getSwapData()), this.wrapper._getNativeToken(), this.wrapper._prices);
124
187
  }
125
188
  }
126
189
  exports.IFromBTCSelfInitSwap = IFromBTCSelfInitSwap;
@@ -5,41 +5,54 @@ import { IEscrowSwapDefinition, IEscrowSwapWrapper } from "../IEscrowSwapWrapper
5
5
  import { IEscrowSwap } from "../IEscrowSwap";
6
6
  import { AmountData } from "../../../types/AmountData";
7
7
  export type IFromBTCDefinition<T extends ChainType, W extends IFromBTCWrapper<T, any>, S extends IEscrowSwap<T>> = IEscrowSwapDefinition<T, W, S>;
8
+ /**
9
+ * Base class for wrappers of escrow-based Bitcoin (on-chain & lightning) -> Smart chain swaps
10
+ *
11
+ * @category Swaps
12
+ */
8
13
  export declare abstract class IFromBTCWrapper<T extends ChainType, D extends IFromBTCDefinition<T, IFromBTCWrapper<T, D>, IEscrowSwap<T, D>>, O extends ISwapWrapperOptions = ISwapWrapperOptions> extends IEscrowSwapWrapper<T, D, O> {
9
14
  /**
10
15
  * Returns a random sequence to be used for swaps
11
16
  *
12
- * @protected
13
17
  * @returns Random 64-bit sequence number
18
+ *
19
+ * @internal
14
20
  */
15
21
  protected getRandomSequence(): bigint;
16
22
  /**
17
- * Pre-fetches feeRate for a given swap
23
+ * Pre-fetches smart chain fee rate for initiating a swap escrow on the smart chain side
18
24
  *
19
25
  * @param signer Address initiating the swap
20
26
  * @param amountData
21
27
  * @param claimHash optional claim hash of the swap or null
22
28
  * @param abortController
23
- * @protected
29
+ *
24
30
  * @returns Fee rate
31
+ *
32
+ * @internal
25
33
  */
26
34
  protected preFetchFeeRate(signer: string, amountData: AmountData, claimHash: string | undefined, abortController: AbortController): Promise<string | undefined>;
27
35
  /**
28
- * Pre-fetches intermediary's available SC on-chain liquidity
36
+ * Pre-fetches intermediary (LP) available smart chain liquidity
37
+ *
29
38
  * @param amountData
30
39
  * @param lp Intermediary
31
40
  * @param abortController
32
- * @protected
41
+ *
33
42
  * @returns Intermediary's liquidity balance
43
+ *
44
+ * @internal
34
45
  */
35
46
  protected preFetchIntermediaryLiquidity(amountData: AmountData, lp: Intermediary, abortController: AbortController): Promise<bigint | undefined>;
36
47
  /**
37
- * Verifies whether the intermediary has enough available liquidity such that we can initiate the swap
48
+ * Verifies whether the intermediary (LP) has enough available liquidity such that we can initiate the swap
49
+ *
50
+ * @param amount Swap amount that the recipient should receive
51
+ * @param liquidityPromise pre-fetched liquidity promise as obtained from {@link preFetchIntermediaryLiquidity}
38
52
  *
39
- * @param amount Swap amount that we should receive
40
- * @param liquidityPromise pre-fetched liquidity promise as obtained from preFetchIntermediaryLiquidity()
41
- * @protected
42
53
  * @throws {IntermediaryError} if intermediary's liquidity is lower than what's required for the swap
54
+ *
55
+ * @internal
43
56
  */
44
57
  protected verifyIntermediaryLiquidity(amount: bigint, liquidityPromise: Promise<bigint>): Promise<void>;
45
58
  }
@@ -5,28 +5,36 @@ const IntermediaryError_1 = require("../../../errors/IntermediaryError");
5
5
  const Utils_1 = require("../../../utils/Utils");
6
6
  const base_1 = require("@atomiqlabs/base");
7
7
  const IEscrowSwapWrapper_1 = require("../IEscrowSwapWrapper");
8
+ /**
9
+ * Base class for wrappers of escrow-based Bitcoin (on-chain & lightning) -> Smart chain swaps
10
+ *
11
+ * @category Swaps
12
+ */
8
13
  class IFromBTCWrapper extends IEscrowSwapWrapper_1.IEscrowSwapWrapper {
9
14
  /**
10
15
  * Returns a random sequence to be used for swaps
11
16
  *
12
- * @protected
13
17
  * @returns Random 64-bit sequence number
18
+ *
19
+ * @internal
14
20
  */
15
21
  getRandomSequence() {
16
22
  return base_1.BigIntBufferUtils.fromBuffer((0, Utils_1.randomBytes)(8));
17
23
  }
18
24
  /**
19
- * Pre-fetches feeRate for a given swap
25
+ * Pre-fetches smart chain fee rate for initiating a swap escrow on the smart chain side
20
26
  *
21
27
  * @param signer Address initiating the swap
22
28
  * @param amountData
23
29
  * @param claimHash optional claim hash of the swap or null
24
30
  * @param abortController
25
- * @protected
31
+ *
26
32
  * @returns Fee rate
33
+ *
34
+ * @internal
27
35
  */
28
36
  preFetchFeeRate(signer, amountData, claimHash, abortController) {
29
- return this.contract.getInitFeeRate(this.chain.randomAddress(), signer, amountData.token, claimHash)
37
+ return this._contract.getInitFeeRate(this._chain.randomAddress(), signer, amountData.token, claimHash)
30
38
  .catch(e => {
31
39
  this.logger.warn("preFetchFeeRate(): Error: ", e);
32
40
  abortController.abort(e);
@@ -34,27 +42,32 @@ class IFromBTCWrapper extends IEscrowSwapWrapper_1.IEscrowSwapWrapper {
34
42
  });
35
43
  }
36
44
  /**
37
- * Pre-fetches intermediary's available SC on-chain liquidity
45
+ * Pre-fetches intermediary (LP) available smart chain liquidity
46
+ *
38
47
  * @param amountData
39
48
  * @param lp Intermediary
40
49
  * @param abortController
41
- * @protected
50
+ *
42
51
  * @returns Intermediary's liquidity balance
52
+ *
53
+ * @internal
43
54
  */
44
55
  preFetchIntermediaryLiquidity(amountData, lp, abortController) {
45
- return lp.getLiquidity(this.chainIdentifier, this.contract, amountData.token.toString(), abortController.signal).catch(e => {
56
+ return lp.getLiquidity(this.chainIdentifier, this._contract, amountData.token.toString(), abortController.signal).catch(e => {
46
57
  this.logger.warn("preFetchIntermediaryLiquidity(): Error: ", e);
47
58
  abortController.abort(e);
48
59
  return undefined;
49
60
  });
50
61
  }
51
62
  /**
52
- * Verifies whether the intermediary has enough available liquidity such that we can initiate the swap
63
+ * Verifies whether the intermediary (LP) has enough available liquidity such that we can initiate the swap
64
+ *
65
+ * @param amount Swap amount that the recipient should receive
66
+ * @param liquidityPromise pre-fetched liquidity promise as obtained from {@link preFetchIntermediaryLiquidity}
53
67
  *
54
- * @param amount Swap amount that we should receive
55
- * @param liquidityPromise pre-fetched liquidity promise as obtained from preFetchIntermediaryLiquidity()
56
- * @protected
57
68
  * @throws {IntermediaryError} if intermediary's liquidity is lower than what's required for the swap
69
+ *
70
+ * @internal
58
71
  */
59
72
  async verifyIntermediaryLiquidity(amount, liquidityPromise) {
60
73
  const liquidity = await liquidityPromise;