@atomiqlabs/chain-evm 1.0.0-dev.89 → 1.0.0-dev.93

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 +125 -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 +132 -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 +54 -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 +46 -46
  41. package/dist/evm/chain/modules/EVMEvents.js +151 -137
  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 +288 -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 +412 -412
  60. package/dist/evm/providers/JsonRpcProviderWithRetries.d.ts +16 -16
  61. package/dist/evm/providers/JsonRpcProviderWithRetries.js +27 -27
  62. package/dist/evm/providers/ReconnectingWebSocketProvider.d.ts +22 -22
  63. package/dist/evm/providers/ReconnectingWebSocketProvider.js +91 -91
  64. package/dist/evm/providers/SocketProvider.d.ts +111 -111
  65. package/dist/evm/providers/SocketProvider.js +336 -336
  66. package/dist/evm/providers/WebSocketProviderWithRetries.d.ts +17 -17
  67. package/dist/evm/providers/WebSocketProviderWithRetries.js +23 -23
  68. package/dist/evm/spv_swap/EVMSpvVaultContract.d.ts +107 -79
  69. package/dist/evm/spv_swap/EVMSpvVaultContract.js +578 -482
  70. package/dist/evm/spv_swap/EVMSpvVaultData.d.ts +40 -39
  71. package/dist/evm/spv_swap/EVMSpvVaultData.js +184 -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 +199 -193
  79. package/dist/evm/swaps/EVMSwapContract.js +394 -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 +230 -230
  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 +19 -19
  123. package/dist/utils/Utils.js +98 -98
  124. package/package.json +39 -39
  125. package/src/chains/botanix/BotanixChainType.ts +28 -28
  126. package/src/chains/botanix/BotanixInitializer.ts +175 -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 +182 -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 +158 -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 +182 -156
  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 +327 -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 +533 -533
  154. package/src/evm/providers/JsonRpcProviderWithRetries.ts +33 -33
  155. package/src/evm/providers/ReconnectingWebSocketProvider.ts +106 -106
  156. package/src/evm/providers/SocketProvider.ts +371 -371
  157. package/src/evm/providers/WebSocketProviderWithRetries.ts +34 -34
  158. package/src/evm/spv_swap/EVMSpvVaultContract.ts +723 -615
  159. package/src/evm/spv_swap/EVMSpvVaultData.ts +228 -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 +621 -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 +307 -307
  183. package/src/evm/wallet/EVMSigner.ts +31 -31
  184. package/src/index.ts +53 -53
  185. package/src/utils/Utils.ts +111 -111
@@ -1,74 +1,74 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.EVMFees = void 0;
4
- const Utils_1 = require("../../../utils/Utils");
5
- class EVMFees {
6
- constructor(provider, maxFeeRatePerGas = 500n * 1000000000n, priorityFee = 1n * 1000000000n, feeMultiplier = 1.25) {
7
- this.MAX_FEE_AGE = 5000;
8
- this.logger = (0, Utils_1.getLogger)("EVMFees: ");
9
- this.blockFeeCache = null;
10
- this.provider = provider;
11
- this.maxFeeRatePerGas = maxFeeRatePerGas;
12
- this.priorityFee = priorityFee;
13
- this.feeMultiplierPPM = BigInt(Math.floor(feeMultiplier * 1000000));
14
- }
15
- /**
16
- * Gets evm fee rate
17
- *
18
- * @private
19
- * @returns {Promise<bigint>} L1 gas price denominated in Wei
20
- */
21
- async _getFeeRate() {
22
- const block = await this.provider.getBlock("latest");
23
- const baseFee = block.baseFeePerGas * this.feeMultiplierPPM / 1000000n;
24
- this.logger.debug("_getFeeRate(): Base fee rate: " + baseFee.toString(10));
25
- return baseFee;
26
- }
27
- /**
28
- * Gets the gas price with caching, format: <base fee Wei>,<priority fee Wei>
29
- *
30
- * @private
31
- */
32
- async getFeeRate() {
33
- if (this.blockFeeCache == null || Date.now() - this.blockFeeCache.timestamp > this.MAX_FEE_AGE) {
34
- let obj = {
35
- timestamp: Date.now(),
36
- feeRate: null
37
- };
38
- obj.feeRate = this._getFeeRate().catch(e => {
39
- if (this.blockFeeCache === obj)
40
- this.blockFeeCache = null;
41
- throw e;
42
- });
43
- this.blockFeeCache = obj;
44
- }
45
- let baseFee = await this.blockFeeCache.feeRate;
46
- if (baseFee > this.maxFeeRatePerGas)
47
- baseFee = this.maxFeeRatePerGas;
48
- const fee = baseFee.toString(10) + "," + this.priorityFee.toString(10);
49
- this.logger.debug("getFeeRate(): calculated fee: " + fee);
50
- return fee;
51
- }
52
- /**
53
- * Calculates the total gas fee paid for a given gas limit at a given fee rate
54
- *
55
- * @param gas
56
- * @param feeRate
57
- */
58
- static getGasFee(gas, feeRate) {
59
- if (feeRate == null)
60
- return 0n;
61
- const [baseFee, priorityFee] = feeRate.split(",");
62
- return BigInt(gas) * (BigInt(baseFee) + BigInt(priorityFee));
63
- }
64
- static applyFeeRate(tx, gas, feeRate) {
65
- if (feeRate == null)
66
- return null;
67
- const [baseFee, priorityFee] = feeRate.split(",");
68
- tx.maxFeePerGas = BigInt(baseFee) + BigInt(priorityFee);
69
- tx.maxPriorityFeePerGas = BigInt(priorityFee);
70
- if (gas != null)
71
- tx.gasLimit = BigInt(gas);
72
- }
73
- }
74
- exports.EVMFees = EVMFees;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.EVMFees = void 0;
4
+ const Utils_1 = require("../../../utils/Utils");
5
+ class EVMFees {
6
+ constructor(provider, maxFeeRatePerGas = 500n * 1000000000n, priorityFee = 1n * 1000000000n, feeMultiplier = 1.25) {
7
+ this.MAX_FEE_AGE = 5000;
8
+ this.logger = (0, Utils_1.getLogger)("EVMFees: ");
9
+ this.blockFeeCache = null;
10
+ this.provider = provider;
11
+ this.maxFeeRatePerGas = maxFeeRatePerGas;
12
+ this.priorityFee = priorityFee;
13
+ this.feeMultiplierPPM = BigInt(Math.floor(feeMultiplier * 1000000));
14
+ }
15
+ /**
16
+ * Gets evm fee rate
17
+ *
18
+ * @private
19
+ * @returns {Promise<bigint>} L1 gas price denominated in Wei
20
+ */
21
+ async _getFeeRate() {
22
+ const block = await this.provider.getBlock("latest");
23
+ const baseFee = block.baseFeePerGas * this.feeMultiplierPPM / 1000000n;
24
+ this.logger.debug("_getFeeRate(): Base fee rate: " + baseFee.toString(10));
25
+ return baseFee;
26
+ }
27
+ /**
28
+ * Gets the gas price with caching, format: <base fee Wei>,<priority fee Wei>
29
+ *
30
+ * @private
31
+ */
32
+ async getFeeRate() {
33
+ if (this.blockFeeCache == null || Date.now() - this.blockFeeCache.timestamp > this.MAX_FEE_AGE) {
34
+ let obj = {
35
+ timestamp: Date.now(),
36
+ feeRate: null
37
+ };
38
+ obj.feeRate = this._getFeeRate().catch(e => {
39
+ if (this.blockFeeCache === obj)
40
+ this.blockFeeCache = null;
41
+ throw e;
42
+ });
43
+ this.blockFeeCache = obj;
44
+ }
45
+ let baseFee = await this.blockFeeCache.feeRate;
46
+ if (baseFee > this.maxFeeRatePerGas)
47
+ baseFee = this.maxFeeRatePerGas;
48
+ const fee = baseFee.toString(10) + "," + this.priorityFee.toString(10);
49
+ this.logger.debug("getFeeRate(): calculated fee: " + fee);
50
+ return fee;
51
+ }
52
+ /**
53
+ * Calculates the total gas fee paid for a given gas limit at a given fee rate
54
+ *
55
+ * @param gas
56
+ * @param feeRate
57
+ */
58
+ static getGasFee(gas, feeRate) {
59
+ if (feeRate == null)
60
+ return 0n;
61
+ const [baseFee, priorityFee] = feeRate.split(",");
62
+ return BigInt(gas) * (BigInt(baseFee) + BigInt(priorityFee));
63
+ }
64
+ static applyFeeRate(tx, gas, feeRate) {
65
+ if (feeRate == null)
66
+ return null;
67
+ const [baseFee, priorityFee] = feeRate.split(",");
68
+ tx.maxFeePerGas = BigInt(baseFee) + BigInt(priorityFee);
69
+ tx.maxPriorityFeePerGas = BigInt(priorityFee);
70
+ if (gas != null)
71
+ tx.gasLimit = BigInt(gas);
72
+ }
73
+ }
74
+ exports.EVMFees = EVMFees;
@@ -1,29 +1,29 @@
1
- /// <reference types="node" />
2
- /// <reference types="node" />
3
- import { EVMSigner } from "../../wallet/EVMSigner";
4
- import { EVMModule } from "../EVMModule";
5
- import { EVMChainInterface } from "../EVMChainInterface";
6
- import { TypedDataField } from "ethers";
7
- export declare class EVMSignatures extends EVMModule<any> {
8
- private readonly domainName;
9
- constructor(root: EVMChainInterface<any>, domainName?: string);
10
- signTypedMessage(contract: string, signer: EVMSigner, type: TypedDataField[], typeName: string, message: object): Promise<string>;
11
- isValidSignature(contract: string, signature: string, address: string, type: TypedDataField[], typeName: string, message: object): Promise<boolean>;
12
- /**
13
- * Produces a signature over the sha256 of a specified data Buffer, only works with providers which
14
- * expose their private key (i.e. backend based, not browser wallet based)
15
- *
16
- * @param signer
17
- * @param data data to sign
18
- */
19
- getDataSignature(signer: EVMSigner, data: Buffer): Promise<string>;
20
- /**
21
- * Checks whether a signature is a valid signature produced by the account over a data message (computes
22
- * sha256 hash of the message)
23
- *
24
- * @param data signed data
25
- * @param signature data signature
26
- * @param address public key of the signer
27
- */
28
- isValidDataSignature(data: Buffer, signature: string, address: string): Promise<boolean>;
29
- }
1
+ /// <reference types="node" />
2
+ /// <reference types="node" />
3
+ import { EVMSigner } from "../../wallet/EVMSigner";
4
+ import { EVMModule } from "../EVMModule";
5
+ import { EVMChainInterface } from "../EVMChainInterface";
6
+ import { TypedDataField } from "ethers";
7
+ export declare class EVMSignatures extends EVMModule<any> {
8
+ private readonly domainName;
9
+ constructor(root: EVMChainInterface<any>, domainName?: string);
10
+ signTypedMessage(contract: string, signer: EVMSigner, type: TypedDataField[], typeName: string, message: object): Promise<string>;
11
+ isValidSignature(contract: string, signature: string, address: string, type: TypedDataField[], typeName: string, message: object): Promise<boolean>;
12
+ /**
13
+ * Produces a signature over the sha256 of a specified data Buffer, only works with providers which
14
+ * expose their private key (i.e. backend based, not browser wallet based)
15
+ *
16
+ * @param signer
17
+ * @param data data to sign
18
+ */
19
+ getDataSignature(signer: EVMSigner, data: Buffer): Promise<string>;
20
+ /**
21
+ * Checks whether a signature is a valid signature produced by the account over a data message (computes
22
+ * sha256 hash of the message)
23
+ *
24
+ * @param data signed data
25
+ * @param signature data signature
26
+ * @param address public key of the signer
27
+ */
28
+ isValidDataSignature(data: Buffer, signature: string, address: string): Promise<boolean>;
29
+ }
@@ -1,68 +1,68 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.EVMSignatures = void 0;
4
- const EVMModule_1 = require("../EVMModule");
5
- const ethers_1 = require("ethers");
6
- const DataHash = [
7
- { name: "dataHash", type: "bytes32" }
8
- ];
9
- class EVMSignatures extends EVMModule_1.EVMModule {
10
- constructor(root, domainName = "atomiq.exchange") {
11
- super(root);
12
- this.domainName = domainName;
13
- }
14
- async signTypedMessage(contract, signer, type, typeName, message) {
15
- return signer.account.signTypedData({
16
- name: this.domainName,
17
- version: "1",
18
- chainId: BigInt(this.root.evmChainId),
19
- verifyingContract: contract
20
- }, { [typeName]: type }, message);
21
- }
22
- async isValidSignature(contract, signature, address, type, typeName, message) {
23
- return Promise.resolve(address === (0, ethers_1.verifyTypedData)({
24
- name: this.domainName,
25
- version: "1",
26
- chainId: BigInt(this.root.evmChainId),
27
- verifyingContract: contract
28
- }, { [typeName]: type }, message, signature));
29
- }
30
- ///////////////////
31
- //// Data signatures
32
- /**
33
- * Produces a signature over the sha256 of a specified data Buffer, only works with providers which
34
- * expose their private key (i.e. backend based, not browser wallet based)
35
- *
36
- * @param signer
37
- * @param data data to sign
38
- */
39
- getDataSignature(signer, data) {
40
- return signer.account.signTypedData({
41
- name: this.domainName,
42
- version: "1",
43
- chainId: BigInt(this.root.evmChainId),
44
- verifyingContract: "0x0000000000000000000000000000000000000000"
45
- }, { DataHash }, {
46
- dataHash: (0, ethers_1.sha256)(data)
47
- });
48
- }
49
- /**
50
- * Checks whether a signature is a valid signature produced by the account over a data message (computes
51
- * sha256 hash of the message)
52
- *
53
- * @param data signed data
54
- * @param signature data signature
55
- * @param address public key of the signer
56
- */
57
- isValidDataSignature(data, signature, address) {
58
- return Promise.resolve(address === (0, ethers_1.verifyTypedData)({
59
- name: this.domainName,
60
- version: "1",
61
- chainId: BigInt(this.root.evmChainId),
62
- verifyingContract: "0x0000000000000000000000000000000000000000"
63
- }, { DataHash }, {
64
- dataHash: (0, ethers_1.sha256)(data)
65
- }, signature));
66
- }
67
- }
68
- exports.EVMSignatures = EVMSignatures;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.EVMSignatures = void 0;
4
+ const EVMModule_1 = require("../EVMModule");
5
+ const ethers_1 = require("ethers");
6
+ const DataHash = [
7
+ { name: "dataHash", type: "bytes32" }
8
+ ];
9
+ class EVMSignatures extends EVMModule_1.EVMModule {
10
+ constructor(root, domainName = "atomiq.exchange") {
11
+ super(root);
12
+ this.domainName = domainName;
13
+ }
14
+ async signTypedMessage(contract, signer, type, typeName, message) {
15
+ return signer.account.signTypedData({
16
+ name: this.domainName,
17
+ version: "1",
18
+ chainId: BigInt(this.root.evmChainId),
19
+ verifyingContract: contract
20
+ }, { [typeName]: type }, message);
21
+ }
22
+ async isValidSignature(contract, signature, address, type, typeName, message) {
23
+ return Promise.resolve(address === (0, ethers_1.verifyTypedData)({
24
+ name: this.domainName,
25
+ version: "1",
26
+ chainId: BigInt(this.root.evmChainId),
27
+ verifyingContract: contract
28
+ }, { [typeName]: type }, message, signature));
29
+ }
30
+ ///////////////////
31
+ //// Data signatures
32
+ /**
33
+ * Produces a signature over the sha256 of a specified data Buffer, only works with providers which
34
+ * expose their private key (i.e. backend based, not browser wallet based)
35
+ *
36
+ * @param signer
37
+ * @param data data to sign
38
+ */
39
+ getDataSignature(signer, data) {
40
+ return signer.account.signTypedData({
41
+ name: this.domainName,
42
+ version: "1",
43
+ chainId: BigInt(this.root.evmChainId),
44
+ verifyingContract: "0x0000000000000000000000000000000000000000"
45
+ }, { DataHash }, {
46
+ dataHash: (0, ethers_1.sha256)(data)
47
+ });
48
+ }
49
+ /**
50
+ * Checks whether a signature is a valid signature produced by the account over a data message (computes
51
+ * sha256 hash of the message)
52
+ *
53
+ * @param data signed data
54
+ * @param signature data signature
55
+ * @param address public key of the signer
56
+ */
57
+ isValidDataSignature(data, signature, address) {
58
+ return Promise.resolve(address === (0, ethers_1.verifyTypedData)({
59
+ name: this.domainName,
60
+ version: "1",
61
+ chainId: BigInt(this.root.evmChainId),
62
+ verifyingContract: "0x0000000000000000000000000000000000000000"
63
+ }, { DataHash }, {
64
+ dataHash: (0, ethers_1.sha256)(data)
65
+ }, signature));
66
+ }
67
+ }
68
+ exports.EVMSignatures = EVMSignatures;
@@ -1,70 +1,70 @@
1
- import { EVMModule } from "../EVMModule";
2
- import { TransactionRequest } from "ethers";
3
- export declare class EVMTokens extends EVMModule<any> {
4
- static readonly ETH_ADDRESS = "0x0000000000000000000000000000000000000000";
5
- static readonly GasCosts: {
6
- TRANSFER: number;
7
- APPROVE: number;
8
- };
9
- private getContract;
10
- /**
11
- * Checks if the provided string is a valid starknet token
12
- *
13
- * @param token
14
- */
15
- isValidToken(token: string): boolean;
16
- /**
17
- * Returns the token balance of the address
18
- *
19
- * @param address
20
- * @param token
21
- */
22
- getTokenBalance(address: string, token: string): Promise<bigint>;
23
- /**
24
- * Returns the authorized allowance of specific address towards a spender contract
25
- *
26
- * @param spender A contract trying to spend user's erc20 balance
27
- * @param address Wallet address
28
- * @param token ERC-20 token
29
- */
30
- getTokenAllowance(spender: string, address: string, token: string): Promise<bigint>;
31
- /**
32
- * Returns the native currency address
33
- */
34
- getNativeCurrencyAddress(): string;
35
- /**
36
- * Creates transactions for sending the over the tokens
37
- *
38
- * @param signer
39
- * @param token token to send
40
- * @param amount amount of the token to send
41
- * @param recipient recipient's address
42
- * @param feeRate fee rate to use for the transactions
43
- * @private
44
- */
45
- Transfer(signer: string, token: string, amount: bigint, recipient: string, feeRate?: string): Promise<TransactionRequest>;
46
- /**
47
- * Creates transactions for approving spending of tokens
48
- *
49
- * @param signer
50
- * @param token token to send
51
- * @param amount amount of the token to send
52
- * @param spender recipient's address
53
- * @param feeRate fee rate to use for the transactions
54
- * @private
55
- */
56
- Approve(signer: string, token: string, amount: bigint, spender: string, feeRate?: string): Promise<TransactionRequest>;
57
- /**
58
- * Checks whether an approve transaction is required for a given token and either returns the tx
59
- * or null in case the approve is not required
60
- *
61
- * @param signer
62
- * @param token token to approve for
63
- * @param amount amount of the token to send
64
- * @param spender spending contract address
65
- * @param feeRate fee rate to use for the transactions
66
- */
67
- checkAndGetApproveTx(signer: string, token: string, amount: bigint, spender: string, feeRate?: string): Promise<TransactionRequest | null>;
68
- getApproveFee(feeRate?: string): Promise<bigint>;
69
- getTransferFee(feeRate?: string): Promise<bigint>;
70
- }
1
+ import { EVMModule } from "../EVMModule";
2
+ import { TransactionRequest } from "ethers";
3
+ export declare class EVMTokens extends EVMModule<any> {
4
+ static readonly ETH_ADDRESS = "0x0000000000000000000000000000000000000000";
5
+ static readonly GasCosts: {
6
+ TRANSFER: number;
7
+ APPROVE: number;
8
+ };
9
+ private getContract;
10
+ /**
11
+ * Checks if the provided string is a valid starknet token
12
+ *
13
+ * @param token
14
+ */
15
+ isValidToken(token: string): boolean;
16
+ /**
17
+ * Returns the token balance of the address
18
+ *
19
+ * @param address
20
+ * @param token
21
+ */
22
+ getTokenBalance(address: string, token: string): Promise<bigint>;
23
+ /**
24
+ * Returns the authorized allowance of specific address towards a spender contract
25
+ *
26
+ * @param spender A contract trying to spend user's erc20 balance
27
+ * @param address Wallet address
28
+ * @param token ERC-20 token
29
+ */
30
+ getTokenAllowance(spender: string, address: string, token: string): Promise<bigint>;
31
+ /**
32
+ * Returns the native currency address
33
+ */
34
+ getNativeCurrencyAddress(): string;
35
+ /**
36
+ * Creates transactions for sending the over the tokens
37
+ *
38
+ * @param signer
39
+ * @param token token to send
40
+ * @param amount amount of the token to send
41
+ * @param recipient recipient's address
42
+ * @param feeRate fee rate to use for the transactions
43
+ * @private
44
+ */
45
+ Transfer(signer: string, token: string, amount: bigint, recipient: string, feeRate?: string): Promise<TransactionRequest>;
46
+ /**
47
+ * Creates transactions for approving spending of tokens
48
+ *
49
+ * @param signer
50
+ * @param token token to send
51
+ * @param amount amount of the token to send
52
+ * @param spender recipient's address
53
+ * @param feeRate fee rate to use for the transactions
54
+ * @private
55
+ */
56
+ Approve(signer: string, token: string, amount: bigint, spender: string, feeRate?: string): Promise<TransactionRequest>;
57
+ /**
58
+ * Checks whether an approve transaction is required for a given token and either returns the tx
59
+ * or null in case the approve is not required
60
+ *
61
+ * @param signer
62
+ * @param token token to approve for
63
+ * @param amount amount of the token to send
64
+ * @param spender spending contract address
65
+ * @param feeRate fee rate to use for the transactions
66
+ */
67
+ checkAndGetApproveTx(signer: string, token: string, amount: bigint, spender: string, feeRate?: string): Promise<TransactionRequest | null>;
68
+ getApproveFee(feeRate?: string): Promise<bigint>;
69
+ getTransferFee(feeRate?: string): Promise<bigint>;
70
+ }