@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,64 +1,64 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.EVMBlocks = void 0;
4
- const EVMModule_1 = require("../EVMModule");
5
- class EVMBlocks extends EVMModule_1.EVMModule {
6
- constructor() {
7
- super(...arguments);
8
- this.BLOCK_CACHE_TIME = 5 * 1000;
9
- this.blockCache = {};
10
- }
11
- /**
12
- * Initiates fetch of a given block & saves it to cache
13
- *
14
- * @private
15
- * @param blockTag
16
- */
17
- fetchAndSaveBlockTime(blockTag) {
18
- const blockTagStr = blockTag.toString(10);
19
- const blockTimePromise = this.provider.getBlock(blockTag, false).then(result => result.timestamp);
20
- const timestamp = Date.now();
21
- this.blockCache[blockTagStr] = {
22
- blockTime: blockTimePromise,
23
- timestamp
24
- };
25
- blockTimePromise.catch(e => {
26
- if (this.blockCache[blockTagStr] != null && this.blockCache[blockTagStr].blockTime === blockTimePromise)
27
- delete this.blockCache[blockTagStr];
28
- throw e;
29
- });
30
- return {
31
- blockTime: blockTimePromise,
32
- timestamp
33
- };
34
- }
35
- cleanupBlocks() {
36
- const currentTime = Date.now();
37
- //Keys are in order that they were added, so we can stop at the first non-expired block
38
- for (let key in this.blockCache) {
39
- const block = this.blockCache[key];
40
- if (currentTime - block.timestamp > this.BLOCK_CACHE_TIME) {
41
- delete this.blockCache[key];
42
- }
43
- else {
44
- break;
45
- }
46
- }
47
- }
48
- ///////////////////
49
- //// Blocks
50
- /**
51
- * Gets the block for a given blocktag, with caching
52
- *
53
- * @param blockTag
54
- */
55
- getBlockTime(blockTag) {
56
- this.cleanupBlocks();
57
- let cachedBlockData = this.blockCache[blockTag.toString(10)];
58
- if (cachedBlockData == null || Date.now() - cachedBlockData.timestamp > this.BLOCK_CACHE_TIME) {
59
- cachedBlockData = this.fetchAndSaveBlockTime(blockTag);
60
- }
61
- return cachedBlockData.blockTime;
62
- }
63
- }
64
- exports.EVMBlocks = EVMBlocks;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.EVMBlocks = void 0;
4
+ const EVMModule_1 = require("../EVMModule");
5
+ class EVMBlocks extends EVMModule_1.EVMModule {
6
+ constructor() {
7
+ super(...arguments);
8
+ this.BLOCK_CACHE_TIME = 5 * 1000;
9
+ this.blockCache = {};
10
+ }
11
+ /**
12
+ * Initiates fetch of a given block & saves it to cache
13
+ *
14
+ * @private
15
+ * @param blockTag
16
+ */
17
+ fetchAndSaveBlockTime(blockTag) {
18
+ const blockTagStr = blockTag.toString(10);
19
+ const blockTimePromise = this.provider.getBlock(blockTag, false).then(result => result.timestamp);
20
+ const timestamp = Date.now();
21
+ this.blockCache[blockTagStr] = {
22
+ blockTime: blockTimePromise,
23
+ timestamp
24
+ };
25
+ blockTimePromise.catch(e => {
26
+ if (this.blockCache[blockTagStr] != null && this.blockCache[blockTagStr].blockTime === blockTimePromise)
27
+ delete this.blockCache[blockTagStr];
28
+ throw e;
29
+ });
30
+ return {
31
+ blockTime: blockTimePromise,
32
+ timestamp
33
+ };
34
+ }
35
+ cleanupBlocks() {
36
+ const currentTime = Date.now();
37
+ //Keys are in order that they were added, so we can stop at the first non-expired block
38
+ for (let key in this.blockCache) {
39
+ const block = this.blockCache[key];
40
+ if (currentTime - block.timestamp > this.BLOCK_CACHE_TIME) {
41
+ delete this.blockCache[key];
42
+ }
43
+ else {
44
+ break;
45
+ }
46
+ }
47
+ }
48
+ ///////////////////
49
+ //// Blocks
50
+ /**
51
+ * Gets the block for a given blocktag, with caching
52
+ *
53
+ * @param blockTag
54
+ */
55
+ getBlockTime(blockTag) {
56
+ this.cleanupBlocks();
57
+ let cachedBlockData = this.blockCache[blockTag.toString(10)];
58
+ if (cachedBlockData == null || Date.now() - cachedBlockData.timestamp > this.BLOCK_CACHE_TIME) {
59
+ cachedBlockData = this.fetchAndSaveBlockTime(blockTag);
60
+ }
61
+ return cachedBlockData.blockTime;
62
+ }
63
+ }
64
+ exports.EVMBlocks = EVMBlocks;
@@ -1,46 +1,46 @@
1
- import { EVMModule } from "../EVMModule";
2
- import { Log } from "ethers";
3
- export declare class EVMEvents extends EVMModule<any> {
4
- /**
5
- * Wrapper for provider.getLogs(), automatically retries with smaller ranges if limits are reached
6
- *
7
- * @param contract
8
- * @param topics
9
- * @param startBlock
10
- * @param endBlock
11
- * @private
12
- */
13
- private getLogs;
14
- /**
15
- * Returns the all the events occuring in a block range as identified by the contract and keys
16
- *
17
- * @param contract
18
- * @param topics
19
- * @param startBlock
20
- * @param endBlock
21
- * @param abortSignal
22
- */
23
- getBlockEvents(contract: string, topics: (string[] | string | null)[], startBlock: number, endBlock?: number, abortSignal?: AbortSignal): Promise<Log[]>;
24
- /**
25
- * Runs a search backwards in time, processing events from a specific contract and keys
26
- *
27
- * @param contract
28
- * @param topics
29
- * @param processor called for every batch of returned signatures, should return a value if the correct signature
30
- * was found, or null if the search should continue
31
- * @param abortSignal
32
- * @param genesisHeight Height when the contract was deployed
33
- */
34
- findInEvents<T>(contract: string, topics: (string[] | string | null)[], processor: (signatures: Log[]) => Promise<T>, abortSignal?: AbortSignal, genesisHeight?: number): Promise<T>;
35
- /**
36
- * Runs a search forwards in time, processing events from a specific contract and keys
37
- *
38
- * @param contract
39
- * @param topics
40
- * @param processor called for every batch of returned signatures, should return a value if the correct signature
41
- * was found, or null if the search should continue
42
- * @param abortSignal
43
- * @param startHeight Blockheight at which to start
44
- */
45
- findInEventsForward<T>(contract: string, topics: (string[] | string | null)[], processor: (signatures: Log[]) => Promise<T>, abortSignal?: AbortSignal, startHeight?: number): Promise<T>;
46
- }
1
+ import { EVMModule } from "../EVMModule";
2
+ import { Log } from "ethers";
3
+ export declare class EVMEvents extends EVMModule<any> {
4
+ /**
5
+ * Wrapper for provider.getLogs(), automatically retries with smaller ranges if limits are reached
6
+ *
7
+ * @param contract
8
+ * @param topics
9
+ * @param startBlock
10
+ * @param endBlock
11
+ * @private
12
+ */
13
+ private getLogs;
14
+ /**
15
+ * Returns the all the events occuring in a block range as identified by the contract and keys
16
+ *
17
+ * @param contract
18
+ * @param topics
19
+ * @param startBlock
20
+ * @param endBlock
21
+ * @param abortSignal
22
+ */
23
+ getBlockEvents(contract: string, topics: (string[] | string | null)[], startBlock: number, endBlock?: number, abortSignal?: AbortSignal): Promise<Log[]>;
24
+ /**
25
+ * Runs a search backwards in time, processing events from a specific contract and keys
26
+ *
27
+ * @param contract
28
+ * @param topics
29
+ * @param processor called for every batch of returned signatures, should return a value if the correct signature
30
+ * was found, or null if the search should continue
31
+ * @param abortSignal
32
+ * @param genesisHeight Height when the contract was deployed
33
+ */
34
+ findInEvents<T>(contract: string, topics: (string[] | string | null)[], processor: (signatures: Log[]) => Promise<T>, abortSignal?: AbortSignal, genesisHeight?: number): Promise<T>;
35
+ /**
36
+ * Runs a search forwards in time, processing events from a specific contract and keys
37
+ *
38
+ * @param contract
39
+ * @param topics
40
+ * @param processor called for every batch of returned signatures, should return a value if the correct signature
41
+ * was found, or null if the search should continue
42
+ * @param abortSignal
43
+ * @param startHeight Blockheight at which to start
44
+ */
45
+ findInEventsForward<T>(contract: string, topics: (string[] | string | null)[], processor: (signatures: Log[]) => Promise<T>, abortSignal?: AbortSignal, startHeight?: number): Promise<T>;
46
+ }
@@ -1,137 +1,151 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.EVMEvents = void 0;
4
- const EVMModule_1 = require("../EVMModule");
5
- class EVMEvents extends EVMModule_1.EVMModule {
6
- /**
7
- * Wrapper for provider.getLogs(), automatically retries with smaller ranges if limits are reached
8
- *
9
- * @param contract
10
- * @param topics
11
- * @param startBlock
12
- * @param endBlock
13
- * @private
14
- */
15
- async getLogs(contract, topics, startBlock, endBlock) {
16
- try {
17
- return await this.root.provider.getLogs({
18
- address: contract,
19
- fromBlock: startBlock,
20
- toBlock: endBlock,
21
- topics
22
- });
23
- }
24
- catch (e) {
25
- if (e.error?.code === -32008 || //Response is too big
26
- e.error?.code === -32005 //Limit exceeded
27
- ) {
28
- if (startBlock === endBlock)
29
- throw e;
30
- const difference = (endBlock - startBlock) / 2;
31
- const midpoint = startBlock + Math.floor(difference);
32
- this.logger.warn(`getLogs(): Error getting logs, limits reached, splitting to 2 ranges: ${startBlock}..${midpoint} & ${midpoint + 1}..${endBlock}: `, e);
33
- return [
34
- ...await this.getLogs(contract, topics, startBlock, midpoint),
35
- ...await this.getLogs(contract, topics, midpoint + 1, endBlock),
36
- ];
37
- }
38
- throw e;
39
- }
40
- }
41
- /**
42
- * Returns the all the events occuring in a block range as identified by the contract and keys
43
- *
44
- * @param contract
45
- * @param topics
46
- * @param startBlock
47
- * @param endBlock
48
- * @param abortSignal
49
- */
50
- async getBlockEvents(contract, topics, startBlock, endBlock = startBlock, abortSignal) {
51
- let events = [];
52
- if (startBlock === endBlock) {
53
- events = await this.root.provider.getLogs({
54
- address: contract,
55
- fromBlock: startBlock,
56
- toBlock: endBlock == null ? this.root.config.safeBlockTag : endBlock,
57
- topics
58
- });
59
- }
60
- else if (endBlock == null) {
61
- const safeBlock = await this.root.provider.getBlock(this.root.config.safeBlockTag);
62
- if (safeBlock.number - startBlock > this.root.config.maxLogsBlockRange) {
63
- for (let i = startBlock + this.root.config.maxLogsBlockRange; i < safeBlock.number; i += this.root.config.maxLogsBlockRange) {
64
- events.push(...await this.getLogs(contract, topics, i - this.root.config.maxLogsBlockRange, i));
65
- startBlock = i;
66
- }
67
- }
68
- events.push(...await this.getLogs(contract, topics, startBlock, safeBlock.number));
69
- }
70
- else {
71
- //Both numeric
72
- if (endBlock - startBlock > this.root.config.maxLogsBlockRange) {
73
- for (let i = startBlock + this.root.config.maxLogsBlockRange; i < endBlock; i += this.root.config.maxLogsBlockRange) {
74
- events.push(...await this.getLogs(contract, topics, i - this.root.config.maxLogsBlockRange, i));
75
- startBlock = i;
76
- }
77
- }
78
- events.push(...await this.getLogs(contract, topics, startBlock, endBlock));
79
- }
80
- return events.filter(val => !val.removed);
81
- }
82
- /**
83
- * Runs a search backwards in time, processing events from a specific contract and keys
84
- *
85
- * @param contract
86
- * @param topics
87
- * @param processor called for every batch of returned signatures, should return a value if the correct signature
88
- * was found, or null if the search should continue
89
- * @param abortSignal
90
- * @param genesisHeight Height when the contract was deployed
91
- */
92
- async findInEvents(contract, topics, processor, abortSignal, genesisHeight) {
93
- const { number: latestBlockNumber } = await this.provider.getBlock(this.root.config.safeBlockTag);
94
- for (let blockNumber = latestBlockNumber; blockNumber >= (genesisHeight ?? 0); blockNumber -= this.root.config.maxLogsBlockRange) {
95
- const eventsResult = await this.provider.getLogs({
96
- address: contract,
97
- topics,
98
- fromBlock: Math.max(blockNumber - this.root.config.maxLogsBlockRange, 0),
99
- toBlock: blockNumber === latestBlockNumber ? this.root.config.safeBlockTag : blockNumber
100
- });
101
- if (abortSignal != null)
102
- abortSignal.throwIfAborted();
103
- const result = await processor(eventsResult.reverse()); //Newest events first
104
- if (result != null)
105
- return result;
106
- }
107
- return null;
108
- }
109
- /**
110
- * Runs a search forwards in time, processing events from a specific contract and keys
111
- *
112
- * @param contract
113
- * @param topics
114
- * @param processor called for every batch of returned signatures, should return a value if the correct signature
115
- * was found, or null if the search should continue
116
- * @param abortSignal
117
- * @param startHeight Blockheight at which to start
118
- */
119
- async findInEventsForward(contract, topics, processor, abortSignal, startHeight) {
120
- const { number: latestBlockNumber } = await this.provider.getBlock(this.root.config.safeBlockTag);
121
- for (let blockNumber = startHeight ?? 0; blockNumber < latestBlockNumber; blockNumber += this.root.config.maxLogsBlockRange) {
122
- const eventsResult = await this.provider.getLogs({
123
- address: contract,
124
- topics,
125
- fromBlock: blockNumber,
126
- toBlock: (blockNumber + this.root.config.maxLogsBlockRange) > latestBlockNumber ? this.root.config.safeBlockTag : blockNumber + this.root.config.maxLogsBlockRange
127
- });
128
- if (abortSignal != null)
129
- abortSignal.throwIfAborted();
130
- const result = await processor(eventsResult); //Oldest events first
131
- if (result != null)
132
- return result;
133
- }
134
- return null;
135
- }
136
- }
137
- exports.EVMEvents = EVMEvents;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.EVMEvents = void 0;
4
+ const EVMModule_1 = require("../EVMModule");
5
+ class EVMEvents extends EVMModule_1.EVMModule {
6
+ /**
7
+ * Wrapper for provider.getLogs(), automatically retries with smaller ranges if limits are reached
8
+ *
9
+ * @param contract
10
+ * @param topics
11
+ * @param startBlock
12
+ * @param endBlock
13
+ * @private
14
+ */
15
+ async getLogs(contract, topics, startBlock, endBlock) {
16
+ try {
17
+ return await this.root.provider.getLogs({
18
+ address: contract,
19
+ fromBlock: startBlock,
20
+ toBlock: endBlock,
21
+ topics
22
+ });
23
+ }
24
+ catch (e) {
25
+ if (e.error?.code === -32008 || //Response is too big
26
+ e.error?.code === -32005 //Limit exceeded
27
+ ) {
28
+ if (startBlock === endBlock)
29
+ throw e;
30
+ const difference = (endBlock - startBlock) / 2;
31
+ const midpoint = startBlock + Math.floor(difference);
32
+ this.logger.warn(`getLogs(): Error getting logs, limits reached, splitting to 2 ranges: ${startBlock}..${midpoint} & ${midpoint + 1}..${endBlock}: `, e);
33
+ return [
34
+ ...await this.getLogs(contract, topics, startBlock, midpoint),
35
+ ...await this.getLogs(contract, topics, midpoint + 1, endBlock),
36
+ ];
37
+ }
38
+ throw e;
39
+ }
40
+ }
41
+ /**
42
+ * Returns the all the events occuring in a block range as identified by the contract and keys
43
+ *
44
+ * @param contract
45
+ * @param topics
46
+ * @param startBlock
47
+ * @param endBlock
48
+ * @param abortSignal
49
+ */
50
+ async getBlockEvents(contract, topics, startBlock, endBlock = startBlock, abortSignal) {
51
+ let events = [];
52
+ if (startBlock === endBlock) {
53
+ events = await this.root.provider.getLogs({
54
+ address: contract,
55
+ fromBlock: startBlock,
56
+ toBlock: endBlock == null ? this.root.config.safeBlockTag : endBlock,
57
+ topics
58
+ });
59
+ }
60
+ else if (endBlock == null) {
61
+ const safeBlock = await this.root.provider.getBlock(this.root.config.safeBlockTag);
62
+ if (safeBlock.number - startBlock > this.root.config.maxLogsBlockRange) {
63
+ for (let i = startBlock + this.root.config.maxLogsBlockRange; i < safeBlock.number; i += this.root.config.maxLogsBlockRange) {
64
+ events.push(...await this.getLogs(contract, topics, i - this.root.config.maxLogsBlockRange, i));
65
+ startBlock = i;
66
+ }
67
+ }
68
+ events.push(...await this.getLogs(contract, topics, startBlock, safeBlock.number));
69
+ }
70
+ else {
71
+ //Both numeric
72
+ if (endBlock - startBlock > this.root.config.maxLogsBlockRange) {
73
+ for (let i = startBlock + this.root.config.maxLogsBlockRange; i < endBlock; i += this.root.config.maxLogsBlockRange) {
74
+ events.push(...await this.getLogs(contract, topics, i - this.root.config.maxLogsBlockRange, i));
75
+ startBlock = i;
76
+ }
77
+ }
78
+ events.push(...await this.getLogs(contract, topics, startBlock, endBlock));
79
+ }
80
+ return events.filter(val => !val.removed);
81
+ }
82
+ /**
83
+ * Runs a search backwards in time, processing events from a specific contract and keys
84
+ *
85
+ * @param contract
86
+ * @param topics
87
+ * @param processor called for every batch of returned signatures, should return a value if the correct signature
88
+ * was found, or null if the search should continue
89
+ * @param abortSignal
90
+ * @param genesisHeight Height when the contract was deployed
91
+ */
92
+ async findInEvents(contract, topics, processor, abortSignal, genesisHeight) {
93
+ const { number: latestBlockNumber } = await this.provider.getBlock(this.root.config.safeBlockTag);
94
+ let promises = [];
95
+ for (let blockNumber = latestBlockNumber; blockNumber >= (genesisHeight ?? 0); blockNumber -= this.root.config.maxLogsBlockRange) {
96
+ promises.push(this.getLogs(contract, topics, Math.max(blockNumber - this.root.config.maxLogsBlockRange, 0), blockNumber));
97
+ if (promises.length >= this.root.config.maxParallelLogRequests) {
98
+ const eventsResult = (await Promise.all(promises)).map(arr => arr.reverse() //Oldest events first
99
+ ).flat();
100
+ promises = [];
101
+ if (abortSignal != null)
102
+ abortSignal.throwIfAborted();
103
+ const result = await processor(eventsResult);
104
+ if (result != null)
105
+ return result;
106
+ }
107
+ }
108
+ const eventsResult = (await Promise.all(promises)).map(arr => arr.reverse() //Oldest events first
109
+ ).flat();
110
+ if (abortSignal != null)
111
+ abortSignal.throwIfAborted();
112
+ const result = await processor(eventsResult); //Oldest events first
113
+ if (result != null)
114
+ return result;
115
+ return null;
116
+ }
117
+ /**
118
+ * Runs a search forwards in time, processing events from a specific contract and keys
119
+ *
120
+ * @param contract
121
+ * @param topics
122
+ * @param processor called for every batch of returned signatures, should return a value if the correct signature
123
+ * was found, or null if the search should continue
124
+ * @param abortSignal
125
+ * @param startHeight Blockheight at which to start
126
+ */
127
+ async findInEventsForward(contract, topics, processor, abortSignal, startHeight) {
128
+ const { number: latestBlockNumber } = await this.provider.getBlock(this.root.config.safeBlockTag);
129
+ let promises = [];
130
+ for (let blockNumber = startHeight ?? 0; blockNumber < latestBlockNumber; blockNumber += this.root.config.maxLogsBlockRange) {
131
+ promises.push(this.getLogs(contract, topics, blockNumber, Math.min(blockNumber + this.root.config.maxLogsBlockRange, latestBlockNumber)));
132
+ if (promises.length >= this.root.config.maxParallelLogRequests) {
133
+ const eventsResult = (await Promise.all(promises)).flat();
134
+ promises = [];
135
+ if (abortSignal != null)
136
+ abortSignal.throwIfAborted();
137
+ const result = await processor(eventsResult); //Oldest events first
138
+ if (result != null)
139
+ return result;
140
+ }
141
+ }
142
+ const eventsResult = (await Promise.all(promises)).flat();
143
+ if (abortSignal != null)
144
+ abortSignal.throwIfAborted();
145
+ const result = await processor(eventsResult); //Oldest events first
146
+ if (result != null)
147
+ return result;
148
+ return null;
149
+ }
150
+ }
151
+ exports.EVMEvents = EVMEvents;
@@ -1,36 +1,36 @@
1
- import { JsonRpcApiProvider, TransactionRequest } from "ethers";
2
- export type EVMFeeRate = {
3
- maxFeePerGas: bigint;
4
- maxPriorityFee: bigint;
5
- };
6
- export declare class EVMFees {
7
- protected MAX_FEE_AGE: number;
8
- protected readonly logger: import("../../../utils/Utils").LoggerType;
9
- protected readonly provider: JsonRpcApiProvider;
10
- protected readonly maxFeeRatePerGas: bigint;
11
- protected readonly priorityFee: bigint;
12
- protected readonly feeMultiplierPPM: bigint;
13
- private blockFeeCache;
14
- constructor(provider: JsonRpcApiProvider, maxFeeRatePerGas?: bigint, priorityFee?: bigint, feeMultiplier?: number);
15
- /**
16
- * Gets evm fee rate
17
- *
18
- * @private
19
- * @returns {Promise<bigint>} L1 gas price denominated in Wei
20
- */
21
- private _getFeeRate;
22
- /**
23
- * Gets the gas price with caching, format: <base fee Wei>,<priority fee Wei>
24
- *
25
- * @private
26
- */
27
- getFeeRate(): Promise<string>;
28
- /**
29
- * Calculates the total gas fee paid for a given gas limit at a given fee rate
30
- *
31
- * @param gas
32
- * @param feeRate
33
- */
34
- static getGasFee(gas: number, feeRate: string): bigint;
35
- static applyFeeRate(tx: TransactionRequest, gas: number, feeRate: string): any;
36
- }
1
+ import { JsonRpcApiProvider, TransactionRequest } from "ethers";
2
+ export type EVMFeeRate = {
3
+ maxFeePerGas: bigint;
4
+ maxPriorityFee: bigint;
5
+ };
6
+ export declare class EVMFees {
7
+ protected MAX_FEE_AGE: number;
8
+ protected readonly logger: import("../../../utils/Utils").LoggerType;
9
+ protected readonly provider: JsonRpcApiProvider;
10
+ protected readonly maxFeeRatePerGas: bigint;
11
+ protected readonly priorityFee: bigint;
12
+ protected readonly feeMultiplierPPM: bigint;
13
+ private blockFeeCache;
14
+ constructor(provider: JsonRpcApiProvider, maxFeeRatePerGas?: bigint, priorityFee?: bigint, feeMultiplier?: number);
15
+ /**
16
+ * Gets evm fee rate
17
+ *
18
+ * @private
19
+ * @returns {Promise<bigint>} L1 gas price denominated in Wei
20
+ */
21
+ private _getFeeRate;
22
+ /**
23
+ * Gets the gas price with caching, format: <base fee Wei>,<priority fee Wei>
24
+ *
25
+ * @private
26
+ */
27
+ getFeeRate(): Promise<string>;
28
+ /**
29
+ * Calculates the total gas fee paid for a given gas limit at a given fee rate
30
+ *
31
+ * @param gas
32
+ * @param feeRate
33
+ */
34
+ static getGasFee(gas: number, feeRate: string): bigint;
35
+ static applyFeeRate(tx: TransactionRequest, gas: number, feeRate: string): any;
36
+ }