@atomiqlabs/chain-evm 1.0.0-dev.75 → 1.0.0-dev.77

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 (185) hide show
  1. package/LICENSE +201 -201
  2. package/dist/chains/botanix/BotanixChainType.d.ts +13 -13
  3. package/dist/chains/botanix/BotanixChainType.js +2 -2
  4. package/dist/chains/botanix/BotanixInitializer.d.ts +30 -30
  5. package/dist/chains/botanix/BotanixInitializer.js +122 -122
  6. package/dist/chains/citrea/CitreaBtcRelay.d.ts +21 -21
  7. package/dist/chains/citrea/CitreaBtcRelay.js +43 -43
  8. package/dist/chains/citrea/CitreaChainType.d.ts +13 -13
  9. package/dist/chains/citrea/CitreaChainType.js +2 -2
  10. package/dist/chains/citrea/CitreaFees.d.ts +29 -29
  11. package/dist/chains/citrea/CitreaFees.js +67 -67
  12. package/dist/chains/citrea/CitreaInitializer.d.ts +30 -30
  13. package/dist/chains/citrea/CitreaInitializer.js +129 -129
  14. package/dist/chains/citrea/CitreaSpvVaultContract.d.ts +15 -15
  15. package/dist/chains/citrea/CitreaSpvVaultContract.js +74 -74
  16. package/dist/chains/citrea/CitreaSwapContract.d.ts +22 -22
  17. package/dist/chains/citrea/CitreaSwapContract.js +96 -96
  18. package/dist/chains/citrea/CitreaTokens.d.ts +9 -9
  19. package/dist/chains/citrea/CitreaTokens.js +20 -20
  20. package/dist/evm/btcrelay/BtcRelayAbi.d.ts +198 -198
  21. package/dist/evm/btcrelay/BtcRelayAbi.js +261 -261
  22. package/dist/evm/btcrelay/BtcRelayTypechain.d.ts +172 -172
  23. package/dist/evm/btcrelay/BtcRelayTypechain.js +2 -2
  24. package/dist/evm/btcrelay/EVMBtcRelay.d.ts +197 -197
  25. package/dist/evm/btcrelay/EVMBtcRelay.js +435 -435
  26. package/dist/evm/btcrelay/headers/EVMBtcHeader.d.ts +33 -33
  27. package/dist/evm/btcrelay/headers/EVMBtcHeader.js +84 -84
  28. package/dist/evm/btcrelay/headers/EVMBtcStoredHeader.d.ts +56 -56
  29. package/dist/evm/btcrelay/headers/EVMBtcStoredHeader.js +123 -123
  30. package/dist/evm/chain/EVMChainInterface.d.ts +51 -51
  31. package/dist/evm/chain/EVMChainInterface.js +89 -89
  32. package/dist/evm/chain/EVMModule.d.ts +9 -9
  33. package/dist/evm/chain/EVMModule.js +13 -13
  34. package/dist/evm/chain/modules/ERC20Abi.d.ts +168 -168
  35. package/dist/evm/chain/modules/ERC20Abi.js +225 -225
  36. package/dist/evm/chain/modules/EVMAddresses.d.ts +10 -10
  37. package/dist/evm/chain/modules/EVMAddresses.js +30 -30
  38. package/dist/evm/chain/modules/EVMBlocks.d.ts +20 -20
  39. package/dist/evm/chain/modules/EVMBlocks.js +64 -64
  40. package/dist/evm/chain/modules/EVMEvents.d.ts +36 -36
  41. package/dist/evm/chain/modules/EVMEvents.js +122 -122
  42. package/dist/evm/chain/modules/EVMFees.d.ts +36 -36
  43. package/dist/evm/chain/modules/EVMFees.js +74 -74
  44. package/dist/evm/chain/modules/EVMSignatures.d.ts +29 -29
  45. package/dist/evm/chain/modules/EVMSignatures.js +68 -68
  46. package/dist/evm/chain/modules/EVMTokens.d.ts +70 -70
  47. package/dist/evm/chain/modules/EVMTokens.js +142 -142
  48. package/dist/evm/chain/modules/EVMTransactions.d.ts +94 -94
  49. package/dist/evm/chain/modules/EVMTransactions.js +286 -286
  50. package/dist/evm/contract/EVMContractBase.d.ts +22 -22
  51. package/dist/evm/contract/EVMContractBase.js +34 -34
  52. package/dist/evm/contract/EVMContractModule.d.ts +8 -8
  53. package/dist/evm/contract/EVMContractModule.js +11 -11
  54. package/dist/evm/contract/modules/EVMContractEvents.d.ts +42 -42
  55. package/dist/evm/contract/modules/EVMContractEvents.js +75 -75
  56. package/dist/evm/events/EVMChainEvents.d.ts +22 -22
  57. package/dist/evm/events/EVMChainEvents.js +69 -69
  58. package/dist/evm/events/EVMChainEventsBrowser.d.ts +102 -102
  59. package/dist/evm/events/EVMChainEventsBrowser.js +413 -404
  60. package/dist/evm/providers/JsonRpcProviderWithRetries.d.ts +15 -15
  61. package/dist/evm/providers/JsonRpcProviderWithRetries.js +19 -19
  62. package/dist/evm/providers/ReconnectingWebSocketProvider.d.ts +22 -22
  63. package/dist/evm/providers/ReconnectingWebSocketProvider.js +87 -87
  64. package/dist/evm/providers/SocketProvider.d.ts +111 -111
  65. package/dist/evm/providers/SocketProvider.js +334 -334
  66. package/dist/evm/providers/WebSocketProviderWithRetries.d.ts +17 -17
  67. package/dist/evm/providers/WebSocketProviderWithRetries.js +19 -19
  68. package/dist/evm/spv_swap/EVMSpvVaultContract.d.ts +79 -79
  69. package/dist/evm/spv_swap/EVMSpvVaultContract.js +482 -482
  70. package/dist/evm/spv_swap/EVMSpvVaultData.d.ts +39 -39
  71. package/dist/evm/spv_swap/EVMSpvVaultData.js +0 -180
  72. package/dist/evm/spv_swap/EVMSpvWithdrawalData.d.ts +19 -19
  73. package/dist/evm/spv_swap/EVMSpvWithdrawalData.js +55 -55
  74. package/dist/evm/spv_swap/SpvVaultContractAbi.d.ts +91 -91
  75. package/dist/evm/spv_swap/SpvVaultContractAbi.js +849 -849
  76. package/dist/evm/spv_swap/SpvVaultContractTypechain.d.ts +450 -450
  77. package/dist/evm/spv_swap/SpvVaultContractTypechain.js +2 -2
  78. package/dist/evm/swaps/EVMSwapContract.d.ts +193 -193
  79. package/dist/evm/swaps/EVMSwapContract.js +378 -378
  80. package/dist/evm/swaps/EVMSwapData.d.ts +66 -66
  81. package/dist/evm/swaps/EVMSwapData.js +260 -260
  82. package/dist/evm/swaps/EVMSwapModule.d.ts +9 -9
  83. package/dist/evm/swaps/EVMSwapModule.js +11 -11
  84. package/dist/evm/swaps/EscrowManagerAbi.d.ts +120 -120
  85. package/dist/evm/swaps/EscrowManagerAbi.js +985 -985
  86. package/dist/evm/swaps/EscrowManagerTypechain.d.ts +475 -475
  87. package/dist/evm/swaps/EscrowManagerTypechain.js +2 -2
  88. package/dist/evm/swaps/handlers/IHandler.d.ts +13 -13
  89. package/dist/evm/swaps/handlers/IHandler.js +2 -2
  90. package/dist/evm/swaps/handlers/claim/ClaimHandlers.d.ts +10 -10
  91. package/dist/evm/swaps/handlers/claim/ClaimHandlers.js +13 -13
  92. package/dist/evm/swaps/handlers/claim/HashlockClaimHandler.d.ts +20 -20
  93. package/dist/evm/swaps/handlers/claim/HashlockClaimHandler.js +39 -39
  94. package/dist/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.d.ts +24 -24
  95. package/dist/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.js +59 -59
  96. package/dist/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.d.ts +25 -25
  97. package/dist/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.js +51 -51
  98. package/dist/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.d.ts +21 -21
  99. package/dist/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.js +28 -28
  100. package/dist/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.d.ts +48 -48
  101. package/dist/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.js +63 -63
  102. package/dist/evm/swaps/handlers/refund/TimelockRefundHandler.d.ts +17 -17
  103. package/dist/evm/swaps/handlers/refund/TimelockRefundHandler.js +28 -28
  104. package/dist/evm/swaps/modules/EVMLpVault.d.ts +69 -69
  105. package/dist/evm/swaps/modules/EVMLpVault.js +134 -134
  106. package/dist/evm/swaps/modules/EVMSwapClaim.d.ts +54 -54
  107. package/dist/evm/swaps/modules/EVMSwapClaim.js +137 -137
  108. package/dist/evm/swaps/modules/EVMSwapInit.d.ts +88 -88
  109. package/dist/evm/swaps/modules/EVMSwapInit.js +274 -274
  110. package/dist/evm/swaps/modules/EVMSwapRefund.d.ts +62 -62
  111. package/dist/evm/swaps/modules/EVMSwapRefund.js +167 -167
  112. package/dist/evm/typechain/common.d.ts +50 -50
  113. package/dist/evm/typechain/common.js +2 -2
  114. package/dist/evm/wallet/EVMBrowserSigner.d.ts +5 -5
  115. package/dist/evm/wallet/EVMBrowserSigner.js +11 -11
  116. package/dist/evm/wallet/EVMPersistentSigner.d.ts +29 -29
  117. package/dist/evm/wallet/EVMPersistentSigner.js +222 -222
  118. package/dist/evm/wallet/EVMSigner.d.ts +11 -11
  119. package/dist/evm/wallet/EVMSigner.js +24 -24
  120. package/dist/index.d.ts +44 -44
  121. package/dist/index.js +60 -60
  122. package/dist/utils/Utils.d.ts +17 -17
  123. package/dist/utils/Utils.js +81 -81
  124. package/package.json +39 -39
  125. package/src/chains/botanix/BotanixChainType.ts +28 -28
  126. package/src/chains/botanix/BotanixInitializer.ts +171 -171
  127. package/src/chains/citrea/CitreaBtcRelay.ts +57 -57
  128. package/src/chains/citrea/CitreaChainType.ts +28 -28
  129. package/src/chains/citrea/CitreaFees.ts +77 -77
  130. package/src/chains/citrea/CitreaInitializer.ts +178 -178
  131. package/src/chains/citrea/CitreaSpvVaultContract.ts +75 -75
  132. package/src/chains/citrea/CitreaSwapContract.ts +102 -102
  133. package/src/chains/citrea/CitreaTokens.ts +21 -21
  134. package/src/evm/btcrelay/BtcRelayAbi.ts +258 -258
  135. package/src/evm/btcrelay/BtcRelayTypechain.ts +371 -371
  136. package/src/evm/btcrelay/EVMBtcRelay.ts +537 -537
  137. package/src/evm/btcrelay/headers/EVMBtcHeader.ts +109 -109
  138. package/src/evm/btcrelay/headers/EVMBtcStoredHeader.ts +152 -152
  139. package/src/evm/chain/EVMChainInterface.ts +155 -155
  140. package/src/evm/chain/EVMModule.ts +21 -21
  141. package/src/evm/chain/modules/ERC20Abi.ts +222 -222
  142. package/src/evm/chain/modules/EVMAddresses.ts +28 -28
  143. package/src/evm/chain/modules/EVMBlocks.ts +75 -75
  144. package/src/evm/chain/modules/EVMEvents.ts +139 -139
  145. package/src/evm/chain/modules/EVMFees.ts +104 -104
  146. package/src/evm/chain/modules/EVMSignatures.ts +76 -76
  147. package/src/evm/chain/modules/EVMTokens.ts +155 -155
  148. package/src/evm/chain/modules/EVMTransactions.ts +325 -325
  149. package/src/evm/contract/EVMContractBase.ts +63 -63
  150. package/src/evm/contract/EVMContractModule.ts +16 -16
  151. package/src/evm/contract/modules/EVMContractEvents.ts +102 -102
  152. package/src/evm/events/EVMChainEvents.ts +82 -82
  153. package/src/evm/events/EVMChainEventsBrowser.ts +534 -525
  154. package/src/evm/providers/JsonRpcProviderWithRetries.ts +24 -24
  155. package/src/evm/providers/ReconnectingWebSocketProvider.ts +101 -101
  156. package/src/evm/providers/SocketProvider.ts +368 -368
  157. package/src/evm/providers/WebSocketProviderWithRetries.ts +27 -27
  158. package/src/evm/spv_swap/EVMSpvVaultContract.ts +615 -615
  159. package/src/evm/spv_swap/EVMSpvVaultData.ts +224 -224
  160. package/src/evm/spv_swap/EVMSpvWithdrawalData.ts +70 -70
  161. package/src/evm/spv_swap/SpvVaultContractAbi.ts +846 -846
  162. package/src/evm/spv_swap/SpvVaultContractTypechain.ts +685 -685
  163. package/src/evm/swaps/EVMSwapContract.ts +600 -600
  164. package/src/evm/swaps/EVMSwapData.ts +378 -378
  165. package/src/evm/swaps/EVMSwapModule.ts +16 -16
  166. package/src/evm/swaps/EscrowManagerAbi.ts +982 -982
  167. package/src/evm/swaps/EscrowManagerTypechain.ts +723 -723
  168. package/src/evm/swaps/handlers/IHandler.ts +17 -17
  169. package/src/evm/swaps/handlers/claim/ClaimHandlers.ts +20 -20
  170. package/src/evm/swaps/handlers/claim/HashlockClaimHandler.ts +46 -46
  171. package/src/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.ts +82 -82
  172. package/src/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.ts +76 -76
  173. package/src/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.ts +46 -46
  174. package/src/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.ts +115 -115
  175. package/src/evm/swaps/handlers/refund/TimelockRefundHandler.ts +37 -37
  176. package/src/evm/swaps/modules/EVMLpVault.ts +154 -154
  177. package/src/evm/swaps/modules/EVMSwapClaim.ts +172 -172
  178. package/src/evm/swaps/modules/EVMSwapInit.ts +328 -328
  179. package/src/evm/swaps/modules/EVMSwapRefund.ts +229 -229
  180. package/src/evm/typechain/common.ts +131 -131
  181. package/src/evm/wallet/EVMBrowserSigner.ts +11 -11
  182. package/src/evm/wallet/EVMPersistentSigner.ts +298 -298
  183. package/src/evm/wallet/EVMSigner.ts +31 -31
  184. package/src/index.ts +53 -53
  185. package/src/utils/Utils.ts +92 -92
@@ -1,173 +1,173 @@
1
- import {ChainSwapType, RelaySynchronizer, SwapDataVerificationError} from "@atomiqlabs/base";
2
- import {IClaimHandler} from "../handlers/claim/ClaimHandlers";
3
- import {BitcoinOutputWitnessData} from "../handlers/claim/btc/BitcoinOutputClaimHandler";
4
- import {BitcoinWitnessData} from "../handlers/claim/btc/IBitcoinClaimHandler";
5
- import {Buffer} from "buffer";
6
- import {EVMSwapModule} from "../EVMSwapModule";
7
- import { EVMSwapData } from "../EVMSwapData";
8
- import {TransactionRequest} from "ethers";
9
- import {EVMFees} from "../../chain/modules/EVMFees";
10
- import {EVMTx} from "../../chain/modules/EVMTransactions";
11
- import {EVMBtcStoredHeader} from "../../btcrelay/headers/EVMBtcStoredHeader";
12
-
13
- export class EVMSwapClaim extends EVMSwapModule {
14
-
15
- private static readonly GasCosts = {
16
- BASE: 30_000 + 21_000,
17
- ERC20_TRANSFER: 40_000,
18
- NATIVE_TRANSFER: 35_500,
19
- LP_VAULT_TRANSFER: 10_000,
20
- REPUTATION: 25_000
21
- };
22
-
23
- /**
24
- * Claim action which uses the provided witness for claiming the swap
25
- *
26
- * @param signer
27
- * @param swapData
28
- * @param witness
29
- * @param feeRate
30
- * @param claimHandlerGas
31
- * @private
32
- */
33
- private async Claim(
34
- signer: string,
35
- swapData: EVMSwapData,
36
- witness: Buffer,
37
- feeRate: string,
38
- claimHandlerGas?: number
39
- ): Promise<TransactionRequest> {
40
- //TODO: Claim with success action not supported yet!
41
- const tx = await this.swapContract.claim.populateTransaction(swapData.toEscrowStruct(), witness);
42
- tx.from = signer;
43
- EVMFees.applyFeeRate(tx, this.getClaimGas(swapData) + (claimHandlerGas ?? 0), feeRate);
44
- return tx;
45
- }
46
-
47
- /**
48
- * Creates transactions claiming the swap using a secret (for HTLC swaps)
49
- *
50
- * @param signer
51
- * @param swapData swap to claim
52
- * @param secret hex encoded secret pre-image to the HTLC hash
53
- * @param checkExpiry whether to check if the swap is already expired (trying to claim an expired swap with a secret
54
- * is dangerous because we might end up revealing the secret to the counterparty without being able to claim the swap)
55
- * @param feeRate fee rate to use for the transaction
56
- */
57
- async txsClaimWithSecret(
58
- signer: string,
59
- swapData: EVMSwapData,
60
- secret: string,
61
- checkExpiry?: boolean,
62
- feeRate?: string
63
- ): Promise<EVMTx[]> {
64
- //We need to be sure that this transaction confirms in time, otherwise we reveal the secret to the counterparty
65
- // and won't claim the funds
66
- if(checkExpiry && await this.contract.isExpired(swapData.claimer.toString(), swapData)) {
67
- throw new SwapDataVerificationError("Not enough time to reliably pay the invoice");
68
- }
69
-
70
- const claimHandler: IClaimHandler<Buffer, string> = this.contract.claimHandlersByAddress[swapData.claimHandler.toLowerCase()];
71
- if(claimHandler==null) throw new SwapDataVerificationError("Unknown claim handler!");
72
- if(claimHandler.getType()!==ChainSwapType.HTLC) throw new SwapDataVerificationError("Invalid claim handler!");
73
-
74
- feeRate ??= await this.root.Fees.getFeeRate();
75
-
76
- const {initialTxns, witness} = await claimHandler.getWitness(signer, swapData, secret, feeRate);
77
- const tx = await this.Claim(signer, swapData, witness, feeRate, claimHandler.getGas(swapData));
78
-
79
- this.logger.debug("txsClaimWithSecret(): creating claim transaction, swap: "+swapData.getClaimHash()+" witness: ", witness.toString("hex"));
80
-
81
- return [...initialTxns, tx];
82
- }
83
-
84
- /**
85
- * Creates transaction claiming the swap using a confirmed transaction data (for BTC on-chain swaps)
86
- *
87
- * @param signer
88
- * @param swapData swap to claim
89
- * @param tx bitcoin transaction that satisfies the swap condition
90
- * @param requiredConfirmations
91
- * @param vout vout of the bitcoin transaction that satisfies the swap condition
92
- * @param commitedHeader commited header data from btc relay (fetched internally if null)
93
- * @param synchronizer optional synchronizer to use in case we need to sync up the btc relay ourselves
94
- * @param feeRate fee rate to be used for the transactions
95
- */
96
- async txsClaimWithTxData(
97
- signer: string,
98
- swapData: EVMSwapData,
99
- tx: { blockhash: string, confirmations: number, txid: string, hex: string, height: number },
100
- requiredConfirmations: number,
101
- vout: number,
102
- commitedHeader?: EVMBtcStoredHeader,
103
- synchronizer?: RelaySynchronizer<EVMBtcStoredHeader, EVMTx, any>,
104
- feeRate?: string
105
- ): Promise<EVMTx[] | null> {
106
- const claimHandler: IClaimHandler<any, BitcoinOutputWitnessData | BitcoinWitnessData> = this.contract.claimHandlersByAddress[swapData.claimHandler.toLowerCase()];
107
- if(claimHandler==null) throw new SwapDataVerificationError("Unknown claim handler!");
108
- if(
109
- claimHandler.getType()!==ChainSwapType.CHAIN_NONCED &&
110
- claimHandler.getType()!==ChainSwapType.CHAIN_TXID &&
111
- claimHandler.getType()!==ChainSwapType.CHAIN
112
- ) throw new SwapDataVerificationError("Invalid claim handler!");
113
-
114
- feeRate ??= await this.root.Fees.getFeeRate();
115
-
116
- const {initialTxns, witness} = await claimHandler.getWitness(signer, swapData, {
117
- tx,
118
- vout,
119
- requiredConfirmations,
120
- commitedHeader,
121
- btcRelay: this.contract.btcRelay,
122
- synchronizer,
123
- }, feeRate);
124
- const claimTx = await this.Claim(signer, swapData, witness, feeRate, claimHandler.getGas(swapData));
125
-
126
- return [...initialTxns, claimTx];
127
- }
128
-
129
- getClaimGas(swapData: EVMSwapData): number {
130
- let totalGas = EVMSwapClaim.GasCosts.BASE;
131
- if(swapData.reputation) totalGas += EVMSwapClaim.GasCosts.REPUTATION;
132
- if(swapData.isPayOut()) {
133
- if(swapData.isToken(this.root.getNativeCurrencyAddress())) {
134
- totalGas += EVMSwapClaim.GasCosts.NATIVE_TRANSFER;
135
- } else {
136
- totalGas += EVMSwapClaim.GasCosts.ERC20_TRANSFER;
137
- }
138
- } else {
139
- totalGas += EVMSwapClaim.GasCosts.LP_VAULT_TRANSFER;
140
- }
141
- if(swapData.getClaimerBounty() > 0n) {
142
- if(swapData.isDepositToken(this.root.getNativeCurrencyAddress())) {
143
- totalGas += EVMSwapClaim.GasCosts.NATIVE_TRANSFER;
144
- } else {
145
- totalGas += EVMSwapClaim.GasCosts.ERC20_TRANSFER;
146
- }
147
- }
148
- if(swapData.getSecurityDeposit() > swapData.getClaimerBounty()) {
149
- if(swapData.isDepositToken(this.root.getNativeCurrencyAddress())) {
150
- totalGas += EVMSwapClaim.GasCosts.NATIVE_TRANSFER;
151
- } else {
152
- totalGas += EVMSwapClaim.GasCosts.ERC20_TRANSFER;
153
- }
154
- }
155
- return totalGas;
156
- }
157
-
158
- /**
159
- * Get the estimated starknet transaction fee of the claim transaction
160
- */
161
- public async getClaimFee(swapData: EVMSwapData, feeRate?: string): Promise<bigint> {
162
- feeRate ??= await this.root.Fees.getFeeRate();
163
-
164
- //TODO: Claim with success action not supported yet!
165
- let gasRequired = this.getClaimGas(swapData);
166
-
167
- const claimHandler: IClaimHandler<any, any> = this.contract.claimHandlersByAddress[swapData.claimHandler.toLowerCase()];
168
- if(claimHandler!=null) gasRequired += claimHandler.getGas(swapData);
169
-
170
- return EVMFees.getGasFee(gasRequired, feeRate);
171
- }
172
-
1
+ import {ChainSwapType, RelaySynchronizer, SwapDataVerificationError} from "@atomiqlabs/base";
2
+ import {IClaimHandler} from "../handlers/claim/ClaimHandlers";
3
+ import {BitcoinOutputWitnessData} from "../handlers/claim/btc/BitcoinOutputClaimHandler";
4
+ import {BitcoinWitnessData} from "../handlers/claim/btc/IBitcoinClaimHandler";
5
+ import {Buffer} from "buffer";
6
+ import {EVMSwapModule} from "../EVMSwapModule";
7
+ import { EVMSwapData } from "../EVMSwapData";
8
+ import {TransactionRequest} from "ethers";
9
+ import {EVMFees} from "../../chain/modules/EVMFees";
10
+ import {EVMTx} from "../../chain/modules/EVMTransactions";
11
+ import {EVMBtcStoredHeader} from "../../btcrelay/headers/EVMBtcStoredHeader";
12
+
13
+ export class EVMSwapClaim extends EVMSwapModule {
14
+
15
+ private static readonly GasCosts = {
16
+ BASE: 30_000 + 21_000,
17
+ ERC20_TRANSFER: 40_000,
18
+ NATIVE_TRANSFER: 35_500,
19
+ LP_VAULT_TRANSFER: 10_000,
20
+ REPUTATION: 25_000
21
+ };
22
+
23
+ /**
24
+ * Claim action which uses the provided witness for claiming the swap
25
+ *
26
+ * @param signer
27
+ * @param swapData
28
+ * @param witness
29
+ * @param feeRate
30
+ * @param claimHandlerGas
31
+ * @private
32
+ */
33
+ private async Claim(
34
+ signer: string,
35
+ swapData: EVMSwapData,
36
+ witness: Buffer,
37
+ feeRate: string,
38
+ claimHandlerGas?: number
39
+ ): Promise<TransactionRequest> {
40
+ //TODO: Claim with success action not supported yet!
41
+ const tx = await this.swapContract.claim.populateTransaction(swapData.toEscrowStruct(), witness);
42
+ tx.from = signer;
43
+ EVMFees.applyFeeRate(tx, this.getClaimGas(swapData) + (claimHandlerGas ?? 0), feeRate);
44
+ return tx;
45
+ }
46
+
47
+ /**
48
+ * Creates transactions claiming the swap using a secret (for HTLC swaps)
49
+ *
50
+ * @param signer
51
+ * @param swapData swap to claim
52
+ * @param secret hex encoded secret pre-image to the HTLC hash
53
+ * @param checkExpiry whether to check if the swap is already expired (trying to claim an expired swap with a secret
54
+ * is dangerous because we might end up revealing the secret to the counterparty without being able to claim the swap)
55
+ * @param feeRate fee rate to use for the transaction
56
+ */
57
+ async txsClaimWithSecret(
58
+ signer: string,
59
+ swapData: EVMSwapData,
60
+ secret: string,
61
+ checkExpiry?: boolean,
62
+ feeRate?: string
63
+ ): Promise<EVMTx[]> {
64
+ //We need to be sure that this transaction confirms in time, otherwise we reveal the secret to the counterparty
65
+ // and won't claim the funds
66
+ if(checkExpiry && await this.contract.isExpired(swapData.claimer.toString(), swapData)) {
67
+ throw new SwapDataVerificationError("Not enough time to reliably pay the invoice");
68
+ }
69
+
70
+ const claimHandler: IClaimHandler<Buffer, string> = this.contract.claimHandlersByAddress[swapData.claimHandler.toLowerCase()];
71
+ if(claimHandler==null) throw new SwapDataVerificationError("Unknown claim handler!");
72
+ if(claimHandler.getType()!==ChainSwapType.HTLC) throw new SwapDataVerificationError("Invalid claim handler!");
73
+
74
+ feeRate ??= await this.root.Fees.getFeeRate();
75
+
76
+ const {initialTxns, witness} = await claimHandler.getWitness(signer, swapData, secret, feeRate);
77
+ const tx = await this.Claim(signer, swapData, witness, feeRate, claimHandler.getGas(swapData));
78
+
79
+ this.logger.debug("txsClaimWithSecret(): creating claim transaction, swap: "+swapData.getClaimHash()+" witness: ", witness.toString("hex"));
80
+
81
+ return [...initialTxns, tx];
82
+ }
83
+
84
+ /**
85
+ * Creates transaction claiming the swap using a confirmed transaction data (for BTC on-chain swaps)
86
+ *
87
+ * @param signer
88
+ * @param swapData swap to claim
89
+ * @param tx bitcoin transaction that satisfies the swap condition
90
+ * @param requiredConfirmations
91
+ * @param vout vout of the bitcoin transaction that satisfies the swap condition
92
+ * @param commitedHeader commited header data from btc relay (fetched internally if null)
93
+ * @param synchronizer optional synchronizer to use in case we need to sync up the btc relay ourselves
94
+ * @param feeRate fee rate to be used for the transactions
95
+ */
96
+ async txsClaimWithTxData(
97
+ signer: string,
98
+ swapData: EVMSwapData,
99
+ tx: { blockhash: string, confirmations: number, txid: string, hex: string, height: number },
100
+ requiredConfirmations: number,
101
+ vout: number,
102
+ commitedHeader?: EVMBtcStoredHeader,
103
+ synchronizer?: RelaySynchronizer<EVMBtcStoredHeader, EVMTx, any>,
104
+ feeRate?: string
105
+ ): Promise<EVMTx[] | null> {
106
+ const claimHandler: IClaimHandler<any, BitcoinOutputWitnessData | BitcoinWitnessData> = this.contract.claimHandlersByAddress[swapData.claimHandler.toLowerCase()];
107
+ if(claimHandler==null) throw new SwapDataVerificationError("Unknown claim handler!");
108
+ if(
109
+ claimHandler.getType()!==ChainSwapType.CHAIN_NONCED &&
110
+ claimHandler.getType()!==ChainSwapType.CHAIN_TXID &&
111
+ claimHandler.getType()!==ChainSwapType.CHAIN
112
+ ) throw new SwapDataVerificationError("Invalid claim handler!");
113
+
114
+ feeRate ??= await this.root.Fees.getFeeRate();
115
+
116
+ const {initialTxns, witness} = await claimHandler.getWitness(signer, swapData, {
117
+ tx,
118
+ vout,
119
+ requiredConfirmations,
120
+ commitedHeader,
121
+ btcRelay: this.contract.btcRelay,
122
+ synchronizer,
123
+ }, feeRate);
124
+ const claimTx = await this.Claim(signer, swapData, witness, feeRate, claimHandler.getGas(swapData));
125
+
126
+ return [...initialTxns, claimTx];
127
+ }
128
+
129
+ getClaimGas(swapData: EVMSwapData): number {
130
+ let totalGas = EVMSwapClaim.GasCosts.BASE;
131
+ if(swapData.reputation) totalGas += EVMSwapClaim.GasCosts.REPUTATION;
132
+ if(swapData.isPayOut()) {
133
+ if(swapData.isToken(this.root.getNativeCurrencyAddress())) {
134
+ totalGas += EVMSwapClaim.GasCosts.NATIVE_TRANSFER;
135
+ } else {
136
+ totalGas += EVMSwapClaim.GasCosts.ERC20_TRANSFER;
137
+ }
138
+ } else {
139
+ totalGas += EVMSwapClaim.GasCosts.LP_VAULT_TRANSFER;
140
+ }
141
+ if(swapData.getClaimerBounty() > 0n) {
142
+ if(swapData.isDepositToken(this.root.getNativeCurrencyAddress())) {
143
+ totalGas += EVMSwapClaim.GasCosts.NATIVE_TRANSFER;
144
+ } else {
145
+ totalGas += EVMSwapClaim.GasCosts.ERC20_TRANSFER;
146
+ }
147
+ }
148
+ if(swapData.getSecurityDeposit() > swapData.getClaimerBounty()) {
149
+ if(swapData.isDepositToken(this.root.getNativeCurrencyAddress())) {
150
+ totalGas += EVMSwapClaim.GasCosts.NATIVE_TRANSFER;
151
+ } else {
152
+ totalGas += EVMSwapClaim.GasCosts.ERC20_TRANSFER;
153
+ }
154
+ }
155
+ return totalGas;
156
+ }
157
+
158
+ /**
159
+ * Get the estimated starknet transaction fee of the claim transaction
160
+ */
161
+ public async getClaimFee(swapData: EVMSwapData, feeRate?: string): Promise<bigint> {
162
+ feeRate ??= await this.root.Fees.getFeeRate();
163
+
164
+ //TODO: Claim with success action not supported yet!
165
+ let gasRequired = this.getClaimGas(swapData);
166
+
167
+ const claimHandler: IClaimHandler<any, any> = this.contract.claimHandlersByAddress[swapData.claimHandler.toLowerCase()];
168
+ if(claimHandler!=null) gasRequired += claimHandler.getGas(swapData);
169
+
170
+ return EVMFees.getGasFee(gasRequired, feeRate);
171
+ }
172
+
173
173
  }