@atomiqlabs/chain-evm 1.0.0-dev.38 → 1.0.0-dev.40

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 (167) hide show
  1. package/LICENSE +201 -201
  2. package/dist/chains/botanix/BotanixChainType.d.ts +13 -0
  3. package/dist/chains/botanix/BotanixChainType.js +2 -0
  4. package/dist/chains/botanix/BotanixInitializer.d.ts +30 -0
  5. package/dist/chains/botanix/BotanixInitializer.js +117 -0
  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 +127 -127
  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 +195 -195
  25. package/dist/evm/btcrelay/EVMBtcRelay.js +423 -423
  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 +73 -73
  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 +89 -89
  49. package/dist/evm/chain/modules/EVMTransactions.js +230 -230
  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 +67 -67
  58. package/dist/evm/events/EVMChainEventsBrowser.d.ts +86 -86
  59. package/dist/evm/events/EVMChainEventsBrowser.js +294 -294
  60. package/dist/evm/spv_swap/EVMSpvVaultContract.d.ts +78 -78
  61. package/dist/evm/spv_swap/EVMSpvVaultContract.js +478 -478
  62. package/dist/evm/spv_swap/EVMSpvVaultData.d.ts +39 -39
  63. package/dist/evm/spv_swap/EVMSpvVaultData.js +180 -180
  64. package/dist/evm/spv_swap/EVMSpvWithdrawalData.d.ts +19 -19
  65. package/dist/evm/spv_swap/EVMSpvWithdrawalData.js +55 -55
  66. package/dist/evm/spv_swap/SpvVaultContractAbi.d.ts +91 -91
  67. package/dist/evm/spv_swap/SpvVaultContractAbi.js +849 -849
  68. package/dist/evm/spv_swap/SpvVaultContractTypechain.d.ts +450 -450
  69. package/dist/evm/spv_swap/SpvVaultContractTypechain.js +2 -2
  70. package/dist/evm/swaps/EVMSwapContract.d.ts +193 -193
  71. package/dist/evm/swaps/EVMSwapContract.js +378 -378
  72. package/dist/evm/swaps/EVMSwapData.d.ts +66 -66
  73. package/dist/evm/swaps/EVMSwapData.js +260 -260
  74. package/dist/evm/swaps/EVMSwapModule.d.ts +9 -9
  75. package/dist/evm/swaps/EVMSwapModule.js +11 -11
  76. package/dist/evm/swaps/EscrowManagerAbi.d.ts +120 -120
  77. package/dist/evm/swaps/EscrowManagerAbi.js +985 -985
  78. package/dist/evm/swaps/EscrowManagerTypechain.d.ts +475 -475
  79. package/dist/evm/swaps/EscrowManagerTypechain.js +2 -2
  80. package/dist/evm/swaps/handlers/IHandler.d.ts +13 -13
  81. package/dist/evm/swaps/handlers/IHandler.js +2 -2
  82. package/dist/evm/swaps/handlers/claim/ClaimHandlers.d.ts +10 -10
  83. package/dist/evm/swaps/handlers/claim/ClaimHandlers.js +13 -13
  84. package/dist/evm/swaps/handlers/claim/HashlockClaimHandler.d.ts +20 -20
  85. package/dist/evm/swaps/handlers/claim/HashlockClaimHandler.js +39 -39
  86. package/dist/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.d.ts +24 -24
  87. package/dist/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.js +59 -59
  88. package/dist/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.d.ts +25 -25
  89. package/dist/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.js +51 -51
  90. package/dist/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.d.ts +21 -21
  91. package/dist/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.js +28 -28
  92. package/dist/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.d.ts +48 -48
  93. package/dist/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.js +63 -63
  94. package/dist/evm/swaps/handlers/refund/TimelockRefundHandler.d.ts +17 -17
  95. package/dist/evm/swaps/handlers/refund/TimelockRefundHandler.js +28 -28
  96. package/dist/evm/swaps/modules/EVMLpVault.d.ts +69 -69
  97. package/dist/evm/swaps/modules/EVMLpVault.js +134 -134
  98. package/dist/evm/swaps/modules/EVMSwapClaim.d.ts +54 -54
  99. package/dist/evm/swaps/modules/EVMSwapClaim.js +137 -137
  100. package/dist/evm/swaps/modules/EVMSwapInit.d.ts +88 -88
  101. package/dist/evm/swaps/modules/EVMSwapInit.js +274 -274
  102. package/dist/evm/swaps/modules/EVMSwapRefund.d.ts +62 -62
  103. package/dist/evm/swaps/modules/EVMSwapRefund.js +167 -167
  104. package/dist/evm/typechain/common.d.ts +50 -50
  105. package/dist/evm/typechain/common.js +2 -2
  106. package/dist/evm/wallet/EVMSigner.d.ts +10 -10
  107. package/dist/evm/wallet/EVMSigner.js +17 -17
  108. package/dist/index.d.ts +40 -38
  109. package/dist/index.js +56 -54
  110. package/dist/utils/Utils.d.ts +15 -15
  111. package/dist/utils/Utils.js +71 -71
  112. package/package.json +37 -37
  113. package/src/chains/botanix/BotanixChainType.ts +28 -0
  114. package/src/chains/botanix/BotanixInitializer.ts +164 -0
  115. package/src/chains/citrea/CitreaBtcRelay.ts +57 -57
  116. package/src/chains/citrea/CitreaChainType.ts +28 -28
  117. package/src/chains/citrea/CitreaFees.ts +77 -77
  118. package/src/chains/citrea/CitreaInitializer.ts +178 -178
  119. package/src/chains/citrea/CitreaSpvVaultContract.ts +75 -75
  120. package/src/chains/citrea/CitreaSwapContract.ts +102 -102
  121. package/src/chains/citrea/CitreaTokens.ts +21 -21
  122. package/src/evm/btcrelay/BtcRelayAbi.ts +258 -258
  123. package/src/evm/btcrelay/BtcRelayTypechain.ts +371 -371
  124. package/src/evm/btcrelay/EVMBtcRelay.ts +522 -522
  125. package/src/evm/btcrelay/headers/EVMBtcHeader.ts +109 -109
  126. package/src/evm/btcrelay/headers/EVMBtcStoredHeader.ts +152 -152
  127. package/src/evm/chain/EVMChainInterface.ts +155 -155
  128. package/src/evm/chain/EVMModule.ts +21 -21
  129. package/src/evm/chain/modules/ERC20Abi.ts +222 -222
  130. package/src/evm/chain/modules/EVMAddresses.ts +28 -28
  131. package/src/evm/chain/modules/EVMBlocks.ts +75 -75
  132. package/src/evm/chain/modules/EVMEvents.ts +139 -139
  133. package/src/evm/chain/modules/EVMFees.ts +104 -104
  134. package/src/evm/chain/modules/EVMSignatures.ts +76 -76
  135. package/src/evm/chain/modules/EVMTokens.ts +155 -155
  136. package/src/evm/chain/modules/EVMTransactions.ts +257 -257
  137. package/src/evm/contract/EVMContractBase.ts +63 -63
  138. package/src/evm/contract/EVMContractModule.ts +16 -16
  139. package/src/evm/contract/modules/EVMContractEvents.ts +102 -102
  140. package/src/evm/events/EVMChainEvents.ts +81 -81
  141. package/src/evm/events/EVMChainEventsBrowser.ts +390 -390
  142. package/src/evm/spv_swap/EVMSpvVaultContract.ts +608 -608
  143. package/src/evm/spv_swap/EVMSpvVaultData.ts +224 -224
  144. package/src/evm/spv_swap/EVMSpvWithdrawalData.ts +70 -70
  145. package/src/evm/spv_swap/SpvVaultContractAbi.ts +846 -846
  146. package/src/evm/spv_swap/SpvVaultContractTypechain.ts +685 -685
  147. package/src/evm/swaps/EVMSwapContract.ts +600 -600
  148. package/src/evm/swaps/EVMSwapData.ts +378 -378
  149. package/src/evm/swaps/EVMSwapModule.ts +16 -16
  150. package/src/evm/swaps/EscrowManagerAbi.ts +982 -982
  151. package/src/evm/swaps/EscrowManagerTypechain.ts +723 -723
  152. package/src/evm/swaps/handlers/IHandler.ts +17 -17
  153. package/src/evm/swaps/handlers/claim/ClaimHandlers.ts +20 -20
  154. package/src/evm/swaps/handlers/claim/HashlockClaimHandler.ts +46 -46
  155. package/src/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.ts +82 -82
  156. package/src/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.ts +76 -76
  157. package/src/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.ts +46 -46
  158. package/src/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.ts +115 -115
  159. package/src/evm/swaps/handlers/refund/TimelockRefundHandler.ts +37 -37
  160. package/src/evm/swaps/modules/EVMLpVault.ts +154 -154
  161. package/src/evm/swaps/modules/EVMSwapClaim.ts +172 -172
  162. package/src/evm/swaps/modules/EVMSwapInit.ts +328 -328
  163. package/src/evm/swaps/modules/EVMSwapRefund.ts +229 -229
  164. package/src/evm/typechain/common.ts +131 -131
  165. package/src/evm/wallet/EVMSigner.ts +25 -25
  166. package/src/index.ts +48 -45
  167. package/src/utils/Utils.ts +81 -81
@@ -1,274 +1,274 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.EVMSwapInit = void 0;
4
- const base_1 = require("@atomiqlabs/base");
5
- const EVMSwapModule_1 = require("../EVMSwapModule");
6
- const ethers_1 = require("ethers");
7
- const EVMFees_1 = require("../../chain/modules/EVMFees");
8
- const Utils_1 = require("../../../utils/Utils");
9
- const Initialize = [
10
- { name: "swapHash", type: "bytes32" },
11
- { name: "offerer", type: "address" },
12
- { name: "claimer", type: "address" },
13
- { name: "amount", type: "uint256" },
14
- { name: "token", type: "address" },
15
- { name: "payIn", type: "bool" },
16
- { name: "payOut", type: "bool" },
17
- { name: "trackingReputation", type: "bool" },
18
- { name: "claimHandler", type: "address" },
19
- { name: "claimData", type: "bytes32" },
20
- { name: "refundHandler", type: "address" },
21
- { name: "refundData", type: "bytes32" },
22
- { name: "securityDeposit", type: "uint256" },
23
- { name: "claimerBounty", type: "uint256" },
24
- { name: "depositToken", type: "address" },
25
- { name: "claimActionHash", type: "bytes32" },
26
- { name: "deadline", type: "uint256" },
27
- { name: "extraDataHash", type: "bytes32" }
28
- ];
29
- class EVMSwapInit extends EVMSwapModule_1.EVMSwapModule {
30
- /**
31
- * bare Init action based on the data passed in swapData
32
- *
33
- * @param sender
34
- * @param swapData
35
- * @param timeout
36
- * @param signature
37
- * @param feeRate
38
- * @private
39
- */
40
- async Init(sender, swapData, timeout, signature, feeRate) {
41
- let value = 0n;
42
- if (swapData.isPayIn()) {
43
- if (swapData.isOfferer(sender) && swapData.isToken(this.root.getNativeCurrencyAddress()))
44
- value += swapData.getAmount();
45
- }
46
- if (swapData.isDepositToken(this.root.getNativeCurrencyAddress()))
47
- value += swapData.getTotalDeposit();
48
- const tx = await this.swapContract.initialize.populateTransaction(swapData.toEscrowStruct(), signature, timeout, "0x" + (swapData.extraData ?? ""), {
49
- value
50
- });
51
- tx.from = sender;
52
- EVMFees_1.EVMFees.applyFeeRate(tx, this.getInitGas(swapData), feeRate);
53
- return tx;
54
- }
55
- /**
56
- * Returns auth prefix to be used with a specific swap, payIn=true & payIn=false use different prefixes (these
57
- * actually have no meaning for the smart contract in the EVM case)
58
- *
59
- * @param swapData
60
- * @private
61
- */
62
- getAuthPrefix(swapData) {
63
- return swapData.isPayIn() ? "claim_initialize" : "initialize";
64
- }
65
- async preFetchForInitSignatureVerification() {
66
- return {
67
- safeBlockTime: await this.root.Blocks.getBlockTime(this.root.config.safeBlockTag)
68
- };
69
- }
70
- /**
71
- * Signs swap initialization authorization, using data from preFetchedBlockData if provided & still valid (subject
72
- * to SIGNATURE_PREFETCH_DATA_VALIDITY)
73
- *
74
- * @param signer
75
- * @param swapData
76
- * @param authorizationTimeout
77
- * @public
78
- */
79
- async signSwapInitialization(signer, swapData, authorizationTimeout) {
80
- const authExpiry = Math.floor(Date.now() / 1000) + authorizationTimeout;
81
- const signature = await this.root.Signatures.signTypedMessage(this.contract.contractAddress, signer, Initialize, "Initialize", {
82
- "swapHash": "0x" + swapData.getEscrowHash(),
83
- "offerer": swapData.offerer,
84
- "claimer": swapData.claimer,
85
- "amount": swapData.amount,
86
- "token": swapData.token,
87
- "payIn": swapData.isPayIn(),
88
- "payOut": swapData.isPayOut(),
89
- "trackingReputation": swapData.reputation,
90
- "claimHandler": swapData.claimHandler,
91
- "claimData": "0x" + swapData.getClaimHash(),
92
- "refundHandler": swapData.refundHandler,
93
- "refundData": swapData.refundData.startsWith("0x") ? swapData.refundData : "0x" + swapData.refundData,
94
- "securityDeposit": swapData.securityDeposit,
95
- "claimerBounty": swapData.claimerBounty,
96
- "depositToken": swapData.depositToken,
97
- "claimActionHash": ethers_1.ZeroHash,
98
- "deadline": authExpiry,
99
- "extraDataHash": (0, ethers_1.keccak256)("0x" + (swapData.extraData ?? ""))
100
- });
101
- return {
102
- prefix: this.getAuthPrefix(swapData),
103
- timeout: authExpiry.toString(10),
104
- signature
105
- };
106
- }
107
- /**
108
- * Checks whether the provided signature data is valid, using preFetchedData if provided and still valid
109
- *
110
- * @param sender
111
- * @param swapData
112
- * @param timeout
113
- * @param prefix
114
- * @param signature
115
- * @param preFetchData
116
- * @public
117
- */
118
- async isSignatureValid(sender, swapData, timeout, prefix, signature, preFetchData) {
119
- if (!swapData.isOfferer(sender) && !swapData.isClaimer(sender))
120
- throw new base_1.SignatureVerificationError("TX sender not offerer nor claimer");
121
- const signer = swapData.isOfferer(sender) ? swapData.claimer : swapData.offerer;
122
- if (await this.contract.isExpired(sender, swapData)) {
123
- throw new base_1.SignatureVerificationError("Swap will expire too soon!");
124
- }
125
- if (prefix !== this.getAuthPrefix(swapData))
126
- throw new base_1.SignatureVerificationError("Invalid prefix");
127
- const currentTimestamp = BigInt(Math.floor(Date.now() / 1000));
128
- const timeoutBN = BigInt(timeout);
129
- const isExpired = (timeoutBN - currentTimestamp) < BigInt(this.contract.authGracePeriod);
130
- if (isExpired)
131
- throw new base_1.SignatureVerificationError("Authorization expired!");
132
- if (await this.isSignatureExpired(timeout, preFetchData))
133
- throw new base_1.SignatureVerificationError("Authorization expired!");
134
- const valid = await this.root.Signatures.isValidSignature(this.contract.contractAddress, signature, signer, Initialize, "Initialize", {
135
- "swapHash": "0x" + swapData.getEscrowHash(),
136
- "offerer": swapData.offerer,
137
- "claimer": swapData.claimer,
138
- "amount": swapData.amount,
139
- "token": swapData.token,
140
- "payIn": swapData.isPayIn(),
141
- "payOut": swapData.isPayOut(),
142
- "trackingReputation": swapData.reputation,
143
- "claimHandler": swapData.claimHandler,
144
- "claimData": "0x" + swapData.getClaimHash(),
145
- "refundHandler": swapData.refundHandler,
146
- "refundData": swapData.refundData.startsWith("0x") ? swapData.refundData : "0x" + swapData.refundData,
147
- "securityDeposit": swapData.securityDeposit,
148
- "claimerBounty": swapData.claimerBounty,
149
- "depositToken": swapData.depositToken,
150
- "claimActionHash": ethers_1.ZeroHash,
151
- "deadline": timeoutBN,
152
- "extraDataHash": (0, ethers_1.keccak256)("0x" + (swapData.extraData ?? ""))
153
- });
154
- if (!valid)
155
- throw new base_1.SignatureVerificationError("Invalid signature!");
156
- return null;
157
- }
158
- /**
159
- * Gets expiry of the provided signature data, this is a minimum of slot expiry & swap signature expiry
160
- *
161
- * @param timeout
162
- * @public
163
- */
164
- async getSignatureExpiry(timeout) {
165
- const now = Date.now();
166
- const timeoutExpiryTime = (parseInt(timeout) - this.contract.authGracePeriod) * 1000;
167
- if (timeoutExpiryTime < now)
168
- return 0;
169
- return timeoutExpiryTime;
170
- }
171
- /**
172
- * Checks whether signature is expired for good, compares the timestamp to the current "pending" block timestamp
173
- *
174
- * @param timeout
175
- * @param preFetchData
176
- * @public
177
- */
178
- async isSignatureExpired(timeout, preFetchData) {
179
- if (preFetchData == null || preFetchData.safeBlockTime == null) {
180
- preFetchData = await this.preFetchForInitSignatureVerification();
181
- }
182
- return preFetchData.safeBlockTime > parseInt(timeout);
183
- }
184
- /**
185
- * Creates init transaction with a valid signature from an LP
186
- *
187
- * @param sender
188
- * @param swapData swap to initialize
189
- * @param timeout init signature timeout
190
- * @param prefix init signature prefix
191
- * @param signature init signature
192
- * @param skipChecks whether to skip signature validity checks
193
- * @param feeRate fee rate to use for the transaction
194
- */
195
- async txsInit(sender, swapData, timeout, prefix, signature, skipChecks, feeRate) {
196
- var _a;
197
- if (swapData.isClaimer(sender) && swapData.isPayIn() &&
198
- swapData.isToken(this.root.getNativeCurrencyAddress()))
199
- throw new Error("Cannot initialize as claimer for payIn=true and native currency!");
200
- if (!skipChecks) {
201
- const [_, payStatus] = await Promise.all([
202
- swapData.isOfferer(sender) && !swapData.reputation ? Promise.resolve() : (0, Utils_1.tryWithRetries)(() => this.isSignatureValid(sender, swapData, timeout, prefix, signature), this.retryPolicy, (e) => e instanceof base_1.SignatureVerificationError),
203
- (0, Utils_1.tryWithRetries)(() => this.contract.getCommitStatus(sender, swapData), this.retryPolicy)
204
- ]);
205
- if (payStatus.type !== base_1.SwapCommitStateType.NOT_COMMITED)
206
- throw new base_1.SwapDataVerificationError("Invoice already being paid for or paid");
207
- }
208
- feeRate ?? (feeRate = await this.root.Fees.getFeeRate());
209
- const txs = [];
210
- const requiredApprovals = {};
211
- if (swapData.isPayIn() && swapData.isOfferer(sender)) {
212
- if (!swapData.isToken(this.root.getNativeCurrencyAddress())) {
213
- requiredApprovals[swapData.token.toLowerCase()] = swapData.amount;
214
- }
215
- }
216
- if (swapData.getTotalDeposit() !== 0n) {
217
- if (!swapData.isDepositToken(this.root.getNativeCurrencyAddress())) {
218
- requiredApprovals[_a = swapData.depositToken.toLowerCase()] ?? (requiredApprovals[_a] = 0n);
219
- requiredApprovals[swapData.depositToken.toLowerCase()] += swapData.getTotalDeposit();
220
- }
221
- }
222
- const requiredApprovalTxns = await Promise.all(Object.keys(requiredApprovals).map(token => this.root.Tokens.checkAndGetApproveTx(sender, token, requiredApprovals[token], this.contract.contractAddress, feeRate)));
223
- requiredApprovalTxns.forEach(tx => tx != null && txs.push(tx));
224
- txs.push(await this.Init(sender, swapData, BigInt(timeout), signature ?? "0x", feeRate));
225
- this.logger.debug("txsInitPayIn(): create swap init TX, swap: " + swapData.getClaimHash() +
226
- " feerate: " + feeRate);
227
- return txs;
228
- }
229
- getInitGas(swapData) {
230
- let totalGas = EVMSwapInit.GasCosts.BASE;
231
- if (swapData.isPayIn()) {
232
- if (!swapData.isToken(this.root.getNativeCurrencyAddress())) {
233
- totalGas += EVMSwapInit.GasCosts.ERC20_TRANSFER;
234
- }
235
- }
236
- else {
237
- totalGas += EVMSwapInit.GasCosts.LP_VAULT_TRANSFER;
238
- }
239
- if (swapData.getTotalDeposit() > 0) {
240
- if (!swapData.isPayIn() || !swapData.isDepositToken(swapData.token)) {
241
- if (!swapData.isDepositToken(this.root.getNativeCurrencyAddress())) {
242
- totalGas += EVMSwapInit.GasCosts.ERC20_TRANSFER;
243
- }
244
- }
245
- }
246
- return totalGas;
247
- }
248
- /**
249
- * Get the estimated fee of the init transaction
250
- */
251
- async getInitFee(swapData, feeRate) {
252
- feeRate ?? (feeRate = await this.root.Fees.getFeeRate());
253
- let totalFee = EVMFees_1.EVMFees.getGasFee(this.getInitGas(swapData), feeRate);
254
- if (swapData.isPayIn()) {
255
- if (!swapData.isToken(this.root.getNativeCurrencyAddress())) {
256
- totalFee += await this.root.Tokens.getApproveFee(feeRate);
257
- }
258
- }
259
- if (swapData.getTotalDeposit() > 0) {
260
- if (!swapData.isPayIn() || !swapData.isDepositToken(swapData.token)) {
261
- if (!swapData.isDepositToken(this.root.getNativeCurrencyAddress())) {
262
- totalFee += await this.root.Tokens.getApproveFee(feeRate);
263
- }
264
- }
265
- }
266
- return totalFee;
267
- }
268
- }
269
- exports.EVMSwapInit = EVMSwapInit;
270
- EVMSwapInit.GasCosts = {
271
- BASE: 45000 + 21000,
272
- ERC20_TRANSFER: 40000,
273
- LP_VAULT_TRANSFER: 10000
274
- };
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.EVMSwapInit = void 0;
4
+ const base_1 = require("@atomiqlabs/base");
5
+ const EVMSwapModule_1 = require("../EVMSwapModule");
6
+ const ethers_1 = require("ethers");
7
+ const EVMFees_1 = require("../../chain/modules/EVMFees");
8
+ const Utils_1 = require("../../../utils/Utils");
9
+ const Initialize = [
10
+ { name: "swapHash", type: "bytes32" },
11
+ { name: "offerer", type: "address" },
12
+ { name: "claimer", type: "address" },
13
+ { name: "amount", type: "uint256" },
14
+ { name: "token", type: "address" },
15
+ { name: "payIn", type: "bool" },
16
+ { name: "payOut", type: "bool" },
17
+ { name: "trackingReputation", type: "bool" },
18
+ { name: "claimHandler", type: "address" },
19
+ { name: "claimData", type: "bytes32" },
20
+ { name: "refundHandler", type: "address" },
21
+ { name: "refundData", type: "bytes32" },
22
+ { name: "securityDeposit", type: "uint256" },
23
+ { name: "claimerBounty", type: "uint256" },
24
+ { name: "depositToken", type: "address" },
25
+ { name: "claimActionHash", type: "bytes32" },
26
+ { name: "deadline", type: "uint256" },
27
+ { name: "extraDataHash", type: "bytes32" }
28
+ ];
29
+ class EVMSwapInit extends EVMSwapModule_1.EVMSwapModule {
30
+ /**
31
+ * bare Init action based on the data passed in swapData
32
+ *
33
+ * @param sender
34
+ * @param swapData
35
+ * @param timeout
36
+ * @param signature
37
+ * @param feeRate
38
+ * @private
39
+ */
40
+ async Init(sender, swapData, timeout, signature, feeRate) {
41
+ let value = 0n;
42
+ if (swapData.isPayIn()) {
43
+ if (swapData.isOfferer(sender) && swapData.isToken(this.root.getNativeCurrencyAddress()))
44
+ value += swapData.getAmount();
45
+ }
46
+ if (swapData.isDepositToken(this.root.getNativeCurrencyAddress()))
47
+ value += swapData.getTotalDeposit();
48
+ const tx = await this.swapContract.initialize.populateTransaction(swapData.toEscrowStruct(), signature, timeout, "0x" + (swapData.extraData ?? ""), {
49
+ value
50
+ });
51
+ tx.from = sender;
52
+ EVMFees_1.EVMFees.applyFeeRate(tx, this.getInitGas(swapData), feeRate);
53
+ return tx;
54
+ }
55
+ /**
56
+ * Returns auth prefix to be used with a specific swap, payIn=true & payIn=false use different prefixes (these
57
+ * actually have no meaning for the smart contract in the EVM case)
58
+ *
59
+ * @param swapData
60
+ * @private
61
+ */
62
+ getAuthPrefix(swapData) {
63
+ return swapData.isPayIn() ? "claim_initialize" : "initialize";
64
+ }
65
+ async preFetchForInitSignatureVerification() {
66
+ return {
67
+ safeBlockTime: await this.root.Blocks.getBlockTime(this.root.config.safeBlockTag)
68
+ };
69
+ }
70
+ /**
71
+ * Signs swap initialization authorization, using data from preFetchedBlockData if provided & still valid (subject
72
+ * to SIGNATURE_PREFETCH_DATA_VALIDITY)
73
+ *
74
+ * @param signer
75
+ * @param swapData
76
+ * @param authorizationTimeout
77
+ * @public
78
+ */
79
+ async signSwapInitialization(signer, swapData, authorizationTimeout) {
80
+ const authExpiry = Math.floor(Date.now() / 1000) + authorizationTimeout;
81
+ const signature = await this.root.Signatures.signTypedMessage(this.contract.contractAddress, signer, Initialize, "Initialize", {
82
+ "swapHash": "0x" + swapData.getEscrowHash(),
83
+ "offerer": swapData.offerer,
84
+ "claimer": swapData.claimer,
85
+ "amount": swapData.amount,
86
+ "token": swapData.token,
87
+ "payIn": swapData.isPayIn(),
88
+ "payOut": swapData.isPayOut(),
89
+ "trackingReputation": swapData.reputation,
90
+ "claimHandler": swapData.claimHandler,
91
+ "claimData": "0x" + swapData.getClaimHash(),
92
+ "refundHandler": swapData.refundHandler,
93
+ "refundData": swapData.refundData.startsWith("0x") ? swapData.refundData : "0x" + swapData.refundData,
94
+ "securityDeposit": swapData.securityDeposit,
95
+ "claimerBounty": swapData.claimerBounty,
96
+ "depositToken": swapData.depositToken,
97
+ "claimActionHash": ethers_1.ZeroHash,
98
+ "deadline": authExpiry,
99
+ "extraDataHash": (0, ethers_1.keccak256)("0x" + (swapData.extraData ?? ""))
100
+ });
101
+ return {
102
+ prefix: this.getAuthPrefix(swapData),
103
+ timeout: authExpiry.toString(10),
104
+ signature
105
+ };
106
+ }
107
+ /**
108
+ * Checks whether the provided signature data is valid, using preFetchedData if provided and still valid
109
+ *
110
+ * @param sender
111
+ * @param swapData
112
+ * @param timeout
113
+ * @param prefix
114
+ * @param signature
115
+ * @param preFetchData
116
+ * @public
117
+ */
118
+ async isSignatureValid(sender, swapData, timeout, prefix, signature, preFetchData) {
119
+ if (!swapData.isOfferer(sender) && !swapData.isClaimer(sender))
120
+ throw new base_1.SignatureVerificationError("TX sender not offerer nor claimer");
121
+ const signer = swapData.isOfferer(sender) ? swapData.claimer : swapData.offerer;
122
+ if (await this.contract.isExpired(sender, swapData)) {
123
+ throw new base_1.SignatureVerificationError("Swap will expire too soon!");
124
+ }
125
+ if (prefix !== this.getAuthPrefix(swapData))
126
+ throw new base_1.SignatureVerificationError("Invalid prefix");
127
+ const currentTimestamp = BigInt(Math.floor(Date.now() / 1000));
128
+ const timeoutBN = BigInt(timeout);
129
+ const isExpired = (timeoutBN - currentTimestamp) < BigInt(this.contract.authGracePeriod);
130
+ if (isExpired)
131
+ throw new base_1.SignatureVerificationError("Authorization expired!");
132
+ if (await this.isSignatureExpired(timeout, preFetchData))
133
+ throw new base_1.SignatureVerificationError("Authorization expired!");
134
+ const valid = await this.root.Signatures.isValidSignature(this.contract.contractAddress, signature, signer, Initialize, "Initialize", {
135
+ "swapHash": "0x" + swapData.getEscrowHash(),
136
+ "offerer": swapData.offerer,
137
+ "claimer": swapData.claimer,
138
+ "amount": swapData.amount,
139
+ "token": swapData.token,
140
+ "payIn": swapData.isPayIn(),
141
+ "payOut": swapData.isPayOut(),
142
+ "trackingReputation": swapData.reputation,
143
+ "claimHandler": swapData.claimHandler,
144
+ "claimData": "0x" + swapData.getClaimHash(),
145
+ "refundHandler": swapData.refundHandler,
146
+ "refundData": swapData.refundData.startsWith("0x") ? swapData.refundData : "0x" + swapData.refundData,
147
+ "securityDeposit": swapData.securityDeposit,
148
+ "claimerBounty": swapData.claimerBounty,
149
+ "depositToken": swapData.depositToken,
150
+ "claimActionHash": ethers_1.ZeroHash,
151
+ "deadline": timeoutBN,
152
+ "extraDataHash": (0, ethers_1.keccak256)("0x" + (swapData.extraData ?? ""))
153
+ });
154
+ if (!valid)
155
+ throw new base_1.SignatureVerificationError("Invalid signature!");
156
+ return null;
157
+ }
158
+ /**
159
+ * Gets expiry of the provided signature data, this is a minimum of slot expiry & swap signature expiry
160
+ *
161
+ * @param timeout
162
+ * @public
163
+ */
164
+ async getSignatureExpiry(timeout) {
165
+ const now = Date.now();
166
+ const timeoutExpiryTime = (parseInt(timeout) - this.contract.authGracePeriod) * 1000;
167
+ if (timeoutExpiryTime < now)
168
+ return 0;
169
+ return timeoutExpiryTime;
170
+ }
171
+ /**
172
+ * Checks whether signature is expired for good, compares the timestamp to the current "pending" block timestamp
173
+ *
174
+ * @param timeout
175
+ * @param preFetchData
176
+ * @public
177
+ */
178
+ async isSignatureExpired(timeout, preFetchData) {
179
+ if (preFetchData == null || preFetchData.safeBlockTime == null) {
180
+ preFetchData = await this.preFetchForInitSignatureVerification();
181
+ }
182
+ return preFetchData.safeBlockTime > parseInt(timeout);
183
+ }
184
+ /**
185
+ * Creates init transaction with a valid signature from an LP
186
+ *
187
+ * @param sender
188
+ * @param swapData swap to initialize
189
+ * @param timeout init signature timeout
190
+ * @param prefix init signature prefix
191
+ * @param signature init signature
192
+ * @param skipChecks whether to skip signature validity checks
193
+ * @param feeRate fee rate to use for the transaction
194
+ */
195
+ async txsInit(sender, swapData, timeout, prefix, signature, skipChecks, feeRate) {
196
+ var _a;
197
+ if (swapData.isClaimer(sender) && swapData.isPayIn() &&
198
+ swapData.isToken(this.root.getNativeCurrencyAddress()))
199
+ throw new Error("Cannot initialize as claimer for payIn=true and native currency!");
200
+ if (!skipChecks) {
201
+ const [_, payStatus] = await Promise.all([
202
+ swapData.isOfferer(sender) && !swapData.reputation ? Promise.resolve() : (0, Utils_1.tryWithRetries)(() => this.isSignatureValid(sender, swapData, timeout, prefix, signature), this.retryPolicy, (e) => e instanceof base_1.SignatureVerificationError),
203
+ (0, Utils_1.tryWithRetries)(() => this.contract.getCommitStatus(sender, swapData), this.retryPolicy)
204
+ ]);
205
+ if (payStatus.type !== base_1.SwapCommitStateType.NOT_COMMITED)
206
+ throw new base_1.SwapDataVerificationError("Invoice already being paid for or paid");
207
+ }
208
+ feeRate ?? (feeRate = await this.root.Fees.getFeeRate());
209
+ const txs = [];
210
+ const requiredApprovals = {};
211
+ if (swapData.isPayIn() && swapData.isOfferer(sender)) {
212
+ if (!swapData.isToken(this.root.getNativeCurrencyAddress())) {
213
+ requiredApprovals[swapData.token.toLowerCase()] = swapData.amount;
214
+ }
215
+ }
216
+ if (swapData.getTotalDeposit() !== 0n) {
217
+ if (!swapData.isDepositToken(this.root.getNativeCurrencyAddress())) {
218
+ requiredApprovals[_a = swapData.depositToken.toLowerCase()] ?? (requiredApprovals[_a] = 0n);
219
+ requiredApprovals[swapData.depositToken.toLowerCase()] += swapData.getTotalDeposit();
220
+ }
221
+ }
222
+ const requiredApprovalTxns = await Promise.all(Object.keys(requiredApprovals).map(token => this.root.Tokens.checkAndGetApproveTx(sender, token, requiredApprovals[token], this.contract.contractAddress, feeRate)));
223
+ requiredApprovalTxns.forEach(tx => tx != null && txs.push(tx));
224
+ txs.push(await this.Init(sender, swapData, BigInt(timeout), signature ?? "0x", feeRate));
225
+ this.logger.debug("txsInitPayIn(): create swap init TX, swap: " + swapData.getClaimHash() +
226
+ " feerate: " + feeRate);
227
+ return txs;
228
+ }
229
+ getInitGas(swapData) {
230
+ let totalGas = EVMSwapInit.GasCosts.BASE;
231
+ if (swapData.isPayIn()) {
232
+ if (!swapData.isToken(this.root.getNativeCurrencyAddress())) {
233
+ totalGas += EVMSwapInit.GasCosts.ERC20_TRANSFER;
234
+ }
235
+ }
236
+ else {
237
+ totalGas += EVMSwapInit.GasCosts.LP_VAULT_TRANSFER;
238
+ }
239
+ if (swapData.getTotalDeposit() > 0) {
240
+ if (!swapData.isPayIn() || !swapData.isDepositToken(swapData.token)) {
241
+ if (!swapData.isDepositToken(this.root.getNativeCurrencyAddress())) {
242
+ totalGas += EVMSwapInit.GasCosts.ERC20_TRANSFER;
243
+ }
244
+ }
245
+ }
246
+ return totalGas;
247
+ }
248
+ /**
249
+ * Get the estimated fee of the init transaction
250
+ */
251
+ async getInitFee(swapData, feeRate) {
252
+ feeRate ?? (feeRate = await this.root.Fees.getFeeRate());
253
+ let totalFee = EVMFees_1.EVMFees.getGasFee(this.getInitGas(swapData), feeRate);
254
+ if (swapData.isPayIn()) {
255
+ if (!swapData.isToken(this.root.getNativeCurrencyAddress())) {
256
+ totalFee += await this.root.Tokens.getApproveFee(feeRate);
257
+ }
258
+ }
259
+ if (swapData.getTotalDeposit() > 0) {
260
+ if (!swapData.isPayIn() || !swapData.isDepositToken(swapData.token)) {
261
+ if (!swapData.isDepositToken(this.root.getNativeCurrencyAddress())) {
262
+ totalFee += await this.root.Tokens.getApproveFee(feeRate);
263
+ }
264
+ }
265
+ }
266
+ return totalFee;
267
+ }
268
+ }
269
+ exports.EVMSwapInit = EVMSwapInit;
270
+ EVMSwapInit.GasCosts = {
271
+ BASE: 45000 + 21000,
272
+ ERC20_TRANSFER: 40000,
273
+ LP_VAULT_TRANSFER: 10000
274
+ };