@aztec/ethereum 0.0.0-test.1 → 0.0.1-commit.03f7ef2

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 (272) hide show
  1. package/dest/account.d.ts +2 -0
  2. package/dest/account.d.ts.map +1 -0
  3. package/dest/account.js +4 -0
  4. package/dest/chain.d.ts +1 -1
  5. package/dest/client.d.ts +6 -4
  6. package/dest/client.d.ts.map +1 -1
  7. package/dest/client.js +21 -3
  8. package/dest/config.d.ts +71 -16
  9. package/dest/config.d.ts.map +1 -1
  10. package/dest/config.js +138 -22
  11. package/dest/constants.d.ts +1 -1
  12. package/dest/contracts/empire_base.d.ts +25 -8
  13. package/dest/contracts/empire_base.d.ts.map +1 -1
  14. package/dest/contracts/empire_base.js +75 -2
  15. package/dest/contracts/empire_slashing_proposer.d.ts +67 -0
  16. package/dest/contracts/empire_slashing_proposer.d.ts.map +1 -0
  17. package/dest/contracts/empire_slashing_proposer.js +209 -0
  18. package/dest/contracts/errors.d.ts +7 -0
  19. package/dest/contracts/errors.d.ts.map +1 -0
  20. package/dest/contracts/errors.js +12 -0
  21. package/dest/contracts/fee_asset_handler.d.ts +19 -0
  22. package/dest/contracts/fee_asset_handler.d.ts.map +1 -0
  23. package/dest/contracts/fee_asset_handler.js +57 -0
  24. package/dest/contracts/fee_juice.d.ts +6 -7
  25. package/dest/contracts/fee_juice.d.ts.map +1 -1
  26. package/dest/contracts/fee_juice.js +27 -20
  27. package/dest/contracts/governance.d.ts +43 -32
  28. package/dest/contracts/governance.d.ts.map +1 -1
  29. package/dest/contracts/governance.js +87 -84
  30. package/dest/contracts/governance_proposer.d.ts +17 -13
  31. package/dest/contracts/governance_proposer.d.ts.map +1 -1
  32. package/dest/contracts/governance_proposer.js +46 -17
  33. package/dest/contracts/gse.d.ts +32 -0
  34. package/dest/contracts/gse.d.ts.map +1 -0
  35. package/dest/contracts/gse.js +72 -0
  36. package/dest/contracts/inbox.d.ts +26 -0
  37. package/dest/contracts/inbox.d.ts.map +1 -0
  38. package/dest/contracts/inbox.js +45 -0
  39. package/dest/contracts/index.d.ts +9 -3
  40. package/dest/contracts/index.d.ts.map +1 -1
  41. package/dest/contracts/index.js +8 -2
  42. package/dest/contracts/multicall.d.ts +21 -0
  43. package/dest/contracts/multicall.d.ts.map +1 -0
  44. package/dest/contracts/multicall.js +156 -0
  45. package/dest/contracts/registry.d.ts +10 -5
  46. package/dest/contracts/registry.d.ts.map +1 -1
  47. package/dest/contracts/registry.js +44 -16
  48. package/dest/contracts/rollup.d.ts +221 -41
  49. package/dest/contracts/rollup.d.ts.map +1 -1
  50. package/dest/contracts/rollup.js +549 -81
  51. package/dest/contracts/slasher_contract.d.ts +44 -0
  52. package/dest/contracts/slasher_contract.d.ts.map +1 -0
  53. package/dest/contracts/slasher_contract.js +75 -0
  54. package/dest/contracts/tally_slashing_proposer.d.ts +140 -0
  55. package/dest/contracts/tally_slashing_proposer.d.ts.map +1 -0
  56. package/dest/contracts/tally_slashing_proposer.js +313 -0
  57. package/dest/contracts/utils.d.ts +3 -0
  58. package/dest/contracts/utils.d.ts.map +1 -0
  59. package/dest/contracts/utils.js +11 -0
  60. package/dest/deploy_aztec_l1_contracts.d.ts +245 -0
  61. package/dest/deploy_aztec_l1_contracts.d.ts.map +1 -0
  62. package/dest/deploy_aztec_l1_contracts.js +335 -0
  63. package/dest/deploy_l1_contract.d.ts +68 -0
  64. package/dest/deploy_l1_contract.d.ts.map +1 -0
  65. package/dest/deploy_l1_contract.js +312 -0
  66. package/dest/eth-signer/eth-signer.d.ts +21 -0
  67. package/dest/eth-signer/eth-signer.d.ts.map +1 -0
  68. package/dest/eth-signer/eth-signer.js +5 -0
  69. package/dest/eth-signer/index.d.ts +2 -0
  70. package/dest/eth-signer/index.d.ts.map +1 -0
  71. package/dest/eth-signer/index.js +1 -0
  72. package/dest/forwarder_proxy.d.ts +32 -0
  73. package/dest/forwarder_proxy.d.ts.map +1 -0
  74. package/dest/forwarder_proxy.js +93 -0
  75. package/dest/l1_artifacts.d.ts +77364 -0
  76. package/dest/l1_artifacts.d.ts.map +1 -0
  77. package/dest/l1_artifacts.js +166 -0
  78. package/dest/l1_contract_addresses.d.ts +24 -4
  79. package/dest/l1_contract_addresses.d.ts.map +1 -1
  80. package/dest/l1_contract_addresses.js +25 -21
  81. package/dest/l1_reader.d.ts +4 -2
  82. package/dest/l1_reader.d.ts.map +1 -1
  83. package/dest/l1_reader.js +14 -8
  84. package/dest/l1_tx_utils/config.d.ts +59 -0
  85. package/dest/l1_tx_utils/config.d.ts.map +1 -0
  86. package/dest/l1_tx_utils/config.js +96 -0
  87. package/dest/l1_tx_utils/constants.d.ts +12 -0
  88. package/dest/l1_tx_utils/constants.d.ts.map +1 -0
  89. package/dest/l1_tx_utils/constants.js +39 -0
  90. package/dest/l1_tx_utils/factory.d.ts +24 -0
  91. package/dest/l1_tx_utils/factory.d.ts.map +1 -0
  92. package/dest/l1_tx_utils/factory.js +12 -0
  93. package/dest/l1_tx_utils/fee-strategies/index.d.ts +9 -0
  94. package/dest/l1_tx_utils/fee-strategies/index.d.ts.map +1 -0
  95. package/dest/l1_tx_utils/fee-strategies/index.js +11 -0
  96. package/dest/l1_tx_utils/fee-strategies/p75_competitive.d.ts +18 -0
  97. package/dest/l1_tx_utils/fee-strategies/p75_competitive.d.ts.map +1 -0
  98. package/dest/l1_tx_utils/fee-strategies/p75_competitive.js +111 -0
  99. package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.d.ts +32 -0
  100. package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.d.ts.map +1 -0
  101. package/dest/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.js +173 -0
  102. package/dest/l1_tx_utils/fee-strategies/types.d.ts +64 -0
  103. package/dest/l1_tx_utils/fee-strategies/types.d.ts.map +1 -0
  104. package/dest/l1_tx_utils/fee-strategies/types.js +24 -0
  105. package/dest/l1_tx_utils/forwarder_l1_tx_utils.d.ts +41 -0
  106. package/dest/l1_tx_utils/forwarder_l1_tx_utils.d.ts.map +1 -0
  107. package/dest/l1_tx_utils/forwarder_l1_tx_utils.js +48 -0
  108. package/dest/l1_tx_utils/index-blobs.d.ts +3 -0
  109. package/dest/l1_tx_utils/index-blobs.d.ts.map +1 -0
  110. package/dest/l1_tx_utils/index-blobs.js +2 -0
  111. package/dest/l1_tx_utils/index.d.ts +12 -0
  112. package/dest/l1_tx_utils/index.d.ts.map +1 -0
  113. package/dest/l1_tx_utils/index.js +12 -0
  114. package/dest/l1_tx_utils/interfaces.d.ts +76 -0
  115. package/dest/l1_tx_utils/interfaces.d.ts.map +1 -0
  116. package/dest/l1_tx_utils/interfaces.js +4 -0
  117. package/dest/l1_tx_utils/l1_fee_analyzer.d.ts +233 -0
  118. package/dest/l1_tx_utils/l1_fee_analyzer.d.ts.map +1 -0
  119. package/dest/l1_tx_utils/l1_fee_analyzer.js +506 -0
  120. package/dest/l1_tx_utils/l1_tx_utils.d.ts +94 -0
  121. package/dest/l1_tx_utils/l1_tx_utils.d.ts.map +1 -0
  122. package/dest/l1_tx_utils/l1_tx_utils.js +623 -0
  123. package/dest/l1_tx_utils/l1_tx_utils_with_blobs.d.ts +26 -0
  124. package/dest/l1_tx_utils/l1_tx_utils_with_blobs.d.ts.map +1 -0
  125. package/dest/l1_tx_utils/l1_tx_utils_with_blobs.js +26 -0
  126. package/dest/l1_tx_utils/readonly_l1_tx_utils.d.ts +87 -0
  127. package/dest/l1_tx_utils/readonly_l1_tx_utils.d.ts.map +1 -0
  128. package/dest/l1_tx_utils/readonly_l1_tx_utils.js +360 -0
  129. package/dest/l1_tx_utils/signer.d.ts +4 -0
  130. package/dest/l1_tx_utils/signer.d.ts.map +1 -0
  131. package/dest/l1_tx_utils/signer.js +16 -0
  132. package/dest/l1_tx_utils/types.d.ts +67 -0
  133. package/dest/l1_tx_utils/types.d.ts.map +1 -0
  134. package/dest/l1_tx_utils/types.js +26 -0
  135. package/dest/l1_tx_utils/utils.d.ts +4 -0
  136. package/dest/l1_tx_utils/utils.d.ts.map +1 -0
  137. package/dest/l1_tx_utils/utils.js +14 -0
  138. package/dest/l1_types.d.ts +6 -0
  139. package/dest/l1_types.d.ts.map +1 -0
  140. package/dest/l1_types.js +1 -0
  141. package/dest/publisher_manager.d.ts +15 -0
  142. package/dest/publisher_manager.d.ts.map +1 -0
  143. package/dest/publisher_manager.js +88 -0
  144. package/dest/queries.d.ts +4 -2
  145. package/dest/queries.d.ts.map +1 -1
  146. package/dest/queries.js +53 -12
  147. package/dest/test/chain_monitor.d.ts +75 -0
  148. package/dest/test/chain_monitor.d.ts.map +1 -0
  149. package/dest/test/chain_monitor.js +214 -0
  150. package/dest/test/delayed_tx_utils.d.ts +8 -3
  151. package/dest/test/delayed_tx_utils.d.ts.map +1 -1
  152. package/dest/test/delayed_tx_utils.js +13 -6
  153. package/dest/test/eth_cheat_codes.d.ts +217 -0
  154. package/dest/test/eth_cheat_codes.d.ts.map +1 -0
  155. package/dest/test/eth_cheat_codes.js +560 -0
  156. package/dest/test/eth_cheat_codes_with_state.d.ts +2 -2
  157. package/dest/test/eth_cheat_codes_with_state.d.ts.map +1 -1
  158. package/dest/test/eth_cheat_codes_with_state.js +1 -1
  159. package/dest/test/index.d.ts +4 -1
  160. package/dest/test/index.d.ts.map +1 -1
  161. package/dest/test/index.js +3 -0
  162. package/dest/test/rollup_cheat_codes.d.ts +87 -0
  163. package/dest/test/rollup_cheat_codes.d.ts.map +1 -0
  164. package/dest/test/rollup_cheat_codes.js +275 -0
  165. package/dest/test/start_anvil.d.ts +9 -1
  166. package/dest/test/start_anvil.d.ts.map +1 -1
  167. package/dest/test/start_anvil.js +16 -7
  168. package/dest/test/tx_delayer.d.ts +18 -7
  169. package/dest/test/tx_delayer.d.ts.map +1 -1
  170. package/dest/test/tx_delayer.js +97 -20
  171. package/dest/test/upgrade_utils.d.ts +6 -5
  172. package/dest/test/upgrade_utils.d.ts.map +1 -1
  173. package/dest/test/upgrade_utils.js +23 -16
  174. package/dest/types.d.ts +62 -8
  175. package/dest/types.d.ts.map +1 -1
  176. package/dest/types.js +3 -1
  177. package/dest/utils.d.ts +16 -3
  178. package/dest/utils.d.ts.map +1 -1
  179. package/dest/utils.js +61 -88
  180. package/dest/zkPassportVerifierAddress.d.ts +15 -0
  181. package/dest/zkPassportVerifierAddress.d.ts.map +1 -0
  182. package/dest/zkPassportVerifierAddress.js +11 -0
  183. package/package.json +50 -23
  184. package/src/account.ts +5 -0
  185. package/src/client.ts +43 -5
  186. package/src/config.ts +188 -31
  187. package/src/contracts/empire_base.ts +77 -7
  188. package/src/contracts/empire_slashing_proposer.ts +270 -0
  189. package/src/contracts/errors.ts +13 -0
  190. package/src/contracts/fee_asset_handler.ts +63 -0
  191. package/src/contracts/fee_juice.ts +29 -15
  192. package/src/contracts/governance.ts +80 -77
  193. package/src/contracts/governance_proposer.ts +71 -24
  194. package/src/contracts/gse.ts +88 -0
  195. package/src/contracts/inbox.ts +63 -0
  196. package/src/contracts/index.ts +8 -2
  197. package/src/contracts/multicall.ts +155 -0
  198. package/src/contracts/registry.ts +51 -26
  199. package/src/contracts/rollup.ts +624 -78
  200. package/src/contracts/slasher_contract.ts +89 -0
  201. package/src/contracts/tally_slashing_proposer.ts +318 -0
  202. package/src/contracts/utils.ts +14 -0
  203. package/src/deploy_aztec_l1_contracts.ts +556 -0
  204. package/src/deploy_l1_contract.ts +362 -0
  205. package/src/eth-signer/eth-signer.ts +25 -0
  206. package/src/eth-signer/index.ts +1 -0
  207. package/src/forwarder_proxy.ts +108 -0
  208. package/src/l1_artifacts.ts +254 -0
  209. package/src/l1_contract_addresses.ts +49 -34
  210. package/src/l1_reader.ts +17 -9
  211. package/src/l1_tx_utils/README.md +177 -0
  212. package/src/l1_tx_utils/config.ts +161 -0
  213. package/src/l1_tx_utils/constants.ts +29 -0
  214. package/src/l1_tx_utils/factory.ts +64 -0
  215. package/src/l1_tx_utils/fee-strategies/index.ts +22 -0
  216. package/src/l1_tx_utils/fee-strategies/p75_competitive.ts +159 -0
  217. package/src/l1_tx_utils/fee-strategies/p75_competitive_blob_txs_only.ts +241 -0
  218. package/src/l1_tx_utils/fee-strategies/types.ts +88 -0
  219. package/src/l1_tx_utils/forwarder_l1_tx_utils.ts +119 -0
  220. package/src/l1_tx_utils/index-blobs.ts +2 -0
  221. package/src/l1_tx_utils/index.ts +14 -0
  222. package/src/l1_tx_utils/interfaces.ts +86 -0
  223. package/src/l1_tx_utils/l1_fee_analyzer.ts +804 -0
  224. package/src/l1_tx_utils/l1_tx_utils.ts +738 -0
  225. package/src/l1_tx_utils/l1_tx_utils_with_blobs.ts +77 -0
  226. package/src/l1_tx_utils/readonly_l1_tx_utils.ts +458 -0
  227. package/src/l1_tx_utils/signer.ts +28 -0
  228. package/src/l1_tx_utils/types.ts +85 -0
  229. package/src/l1_tx_utils/utils.ts +16 -0
  230. package/src/l1_types.ts +6 -0
  231. package/src/publisher_manager.ts +106 -0
  232. package/src/queries.ts +73 -15
  233. package/src/test/chain_monitor.ts +245 -0
  234. package/src/test/delayed_tx_utils.ts +34 -6
  235. package/src/test/eth_cheat_codes.ts +588 -0
  236. package/src/test/eth_cheat_codes_with_state.ts +1 -1
  237. package/src/test/index.ts +3 -0
  238. package/src/test/rollup_cheat_codes.ts +312 -0
  239. package/src/test/start_anvil.ts +24 -5
  240. package/src/test/tx_delayer.ts +130 -27
  241. package/src/test/upgrade_utils.ts +30 -21
  242. package/src/types.ts +71 -7
  243. package/src/utils.ts +79 -91
  244. package/src/zkPassportVerifierAddress.ts +15 -0
  245. package/dest/contracts/forwarder.d.ts +0 -24
  246. package/dest/contracts/forwarder.d.ts.map +0 -1
  247. package/dest/contracts/forwarder.js +0 -101
  248. package/dest/contracts/slashing_proposer.d.ts +0 -21
  249. package/dest/contracts/slashing_proposer.d.ts.map +0 -1
  250. package/dest/contracts/slashing_proposer.js +0 -47
  251. package/dest/deploy_l1_contracts.d.ts +0 -21210
  252. package/dest/deploy_l1_contracts.d.ts.map +0 -1
  253. package/dest/deploy_l1_contracts.js +0 -687
  254. package/dest/eth_cheat_codes.d.ts +0 -147
  255. package/dest/eth_cheat_codes.d.ts.map +0 -1
  256. package/dest/eth_cheat_codes.js +0 -303
  257. package/dest/index.d.ts +0 -14
  258. package/dest/index.d.ts.map +0 -1
  259. package/dest/index.js +0 -13
  260. package/dest/l1_tx_utils.d.ts +0 -192
  261. package/dest/l1_tx_utils.d.ts.map +0 -1
  262. package/dest/l1_tx_utils.js +0 -641
  263. package/dest/l1_tx_utils_with_blobs.d.ts +0 -12
  264. package/dest/l1_tx_utils_with_blobs.d.ts.map +0 -1
  265. package/dest/l1_tx_utils_with_blobs.js +0 -64
  266. package/src/contracts/forwarder.ts +0 -132
  267. package/src/contracts/slashing_proposer.ts +0 -51
  268. package/src/deploy_l1_contracts.ts +0 -948
  269. package/src/eth_cheat_codes.ts +0 -314
  270. package/src/index.ts +0 -13
  271. package/src/l1_tx_utils.ts +0 -847
  272. package/src/l1_tx_utils_with_blobs.ts +0 -86
@@ -0,0 +1,88 @@
1
+ import type { Logger } from '@aztec/foundation/log';
2
+
3
+ import type { ViemClient } from '../../types.js';
4
+ import type { L1TxUtilsConfig } from '../config.js';
5
+
6
+ /**
7
+ * Historical block count for fee history queries
8
+ */
9
+ export const HISTORICAL_BLOCK_COUNT = 5;
10
+
11
+ /**
12
+ * Result from a priority fee strategy calculation
13
+ */
14
+ export interface PriorityFeeStrategyResult {
15
+ /** The calculated priority fee in wei */
16
+ priorityFee: bigint;
17
+ /** Optional debug info about how the fee was calculated */
18
+ debugInfo?: Record<string, string | number>;
19
+ }
20
+
21
+ /**
22
+ * Context passed to the strategy calculation function (excluding promise results)
23
+ */
24
+ export interface PriorityFeeStrategyContext {
25
+ /** Gas configuration */
26
+ gasConfig: L1TxUtilsConfig;
27
+ /** Whether this is for a blob transaction */
28
+ isBlobTx: boolean;
29
+ /** Logger for debugging */
30
+ logger?: Logger;
31
+ }
32
+
33
+ /**
34
+ * A strategy for calculating the priority fee for L1 transactions.
35
+ * Each strategy defines what promises it needs and how to calculate the fee from their results.
36
+ * This design allows strategies to be plugged into both L1FeeAnalyzer and ReadOnlyL1TxUtils.
37
+ */
38
+ export interface PriorityFeeStrategy<TPromises extends Record<string, Promise<any>> = Record<string, Promise<any>>> {
39
+ /** Human-readable name for logging */
40
+ name: string;
41
+ /** Unique identifier for metrics */
42
+ id: string;
43
+ /**
44
+ * Returns the promises that need to be executed for this strategy.
45
+ * These will be run in parallel with Promise.allSettled.
46
+ * @param client - The viem client to use for RPC calls
47
+ * @returns An object of promises keyed by name
48
+ */
49
+ getRequiredPromises(client: ViemClient, opts: Partial<PriorityFeeStrategyContext>): TPromises;
50
+ /**
51
+ * Calculate the priority fee based on the settled promise results.
52
+ * @param results - The settled results of the promises from getRequiredPromises
53
+ * @param context - Contains gas config, whether it's a blob tx, and logger
54
+ * @returns The calculated priority fee result
55
+ */
56
+ calculate(
57
+ results: { [K in keyof TPromises]: PromiseSettledResult<Awaited<TPromises[K]>> },
58
+ context: PriorityFeeStrategyContext,
59
+ ): PriorityFeeStrategyResult;
60
+ }
61
+
62
+ /**
63
+ * Helper function to execute a strategy's promises and calculate the result.
64
+ * This can be used by both L1FeeAnalyzer and ReadOnlyL1TxUtils.
65
+ * @param strategy - The strategy to execute
66
+ * @param client - The viem client to use for RPC calls
67
+ * @param context - The context for calculation
68
+ * @returns The strategy result
69
+ */
70
+ export async function executeStrategy<TPromises extends Record<string, Promise<any>>>(
71
+ strategy: PriorityFeeStrategy<TPromises>,
72
+ client: ViemClient,
73
+ context: PriorityFeeStrategyContext,
74
+ ): Promise<PriorityFeeStrategyResult> {
75
+ const promises = strategy.getRequiredPromises(client, { isBlobTx: context.isBlobTx });
76
+ const keys = Object.keys(promises) as Array<keyof TPromises>;
77
+ const promiseArray = keys.map(k => promises[k]);
78
+
79
+ const settledResults = await Promise.allSettled(promiseArray);
80
+
81
+ // Reconstruct the results object with the same keys, preserving the type mapping
82
+ const results = {} as { [K in keyof TPromises]: PromiseSettledResult<Awaited<TPromises[K]>> };
83
+ keys.forEach((key, index) => {
84
+ results[key] = settledResults[index] as PromiseSettledResult<Awaited<TPromises[typeof key]>>;
85
+ });
86
+
87
+ return strategy.calculate(results, context);
88
+ }
@@ -0,0 +1,119 @@
1
+ import { EthAddress } from '@aztec/foundation/eth-address';
2
+ import type { Logger } from '@aztec/foundation/log';
3
+ import type { DateProvider } from '@aztec/foundation/timer';
4
+
5
+ import { type Hex, encodeFunctionData } from 'viem';
6
+
7
+ import type { EthSigner } from '../eth-signer/eth-signer.js';
8
+ import { FORWARDER_ABI } from '../forwarder_proxy.js';
9
+ import type { ExtendedViemWalletClient, ViemClient } from '../types.js';
10
+ import type { L1TxUtilsConfig } from './config.js';
11
+ import type { IL1TxMetrics, IL1TxStore } from './interfaces.js';
12
+ import { L1TxUtilsWithBlobs } from './l1_tx_utils_with_blobs.js';
13
+ import { createViemSigner } from './signer.js';
14
+ import type { L1BlobInputs, L1TxConfig, L1TxRequest, SigningCallback } from './types.js';
15
+
16
+ /**
17
+ * Extends L1TxUtilsWithBlobs to wrap all transactions through a forwarder contract.
18
+ * This is mainly used for testing the archiver's ability to decode transactions that go through proxies.
19
+ */
20
+ export class ForwarderL1TxUtils extends L1TxUtilsWithBlobs {
21
+ constructor(
22
+ client: ViemClient | ExtendedViemWalletClient,
23
+ senderAddress: EthAddress,
24
+ signingCallback: SigningCallback,
25
+ logger: Logger | undefined,
26
+ dateProvider: DateProvider | undefined,
27
+ config: Partial<L1TxUtilsConfig>,
28
+ debugMaxGasLimit: boolean,
29
+ store: IL1TxStore | undefined,
30
+ metrics: IL1TxMetrics | undefined,
31
+ private readonly forwarderAddress: EthAddress,
32
+ ) {
33
+ super(client, senderAddress, signingCallback, logger, dateProvider, config, debugMaxGasLimit, store, metrics);
34
+ }
35
+
36
+ /**
37
+ * Wraps the transaction request in a call to the forwarder contract.
38
+ */
39
+ private wrapInForwarder(request: L1TxRequest): L1TxRequest {
40
+ const forwarderCalldata = encodeFunctionData({
41
+ abi: FORWARDER_ABI,
42
+ functionName: 'forward',
43
+ args: [request.to as Hex, request.data as Hex],
44
+ });
45
+
46
+ return {
47
+ to: this.forwarderAddress.toString() as Hex,
48
+ data: forwarderCalldata,
49
+ value: request.value,
50
+ abi: request.abi, // Preserve the original ABI for error decoding
51
+ };
52
+ }
53
+
54
+ /**
55
+ * Override sendAndMonitorTransaction to wrap the request in a forwarder call.
56
+ */
57
+ public override sendAndMonitorTransaction(request: L1TxRequest, gasConfig?: L1TxConfig, blobInputs?: L1BlobInputs) {
58
+ this.logger.debug(`Wrapping transaction to ${request.to} in forwarder at ${this.forwarderAddress.toString()}`);
59
+ const wrappedRequest = this.wrapInForwarder(request);
60
+ return super.sendAndMonitorTransaction(wrappedRequest, gasConfig, blobInputs);
61
+ }
62
+ }
63
+
64
+ export function createForwarderL1TxUtilsFromViemWallet(
65
+ client: ExtendedViemWalletClient,
66
+ forwarderAddress: EthAddress,
67
+ deps: {
68
+ logger?: Logger;
69
+ dateProvider?: DateProvider;
70
+ store?: IL1TxStore;
71
+ metrics?: IL1TxMetrics;
72
+ } = {},
73
+ config: Partial<L1TxUtilsConfig> = {},
74
+ debugMaxGasLimit: boolean = false,
75
+ ) {
76
+ return new ForwarderL1TxUtils(
77
+ client,
78
+ EthAddress.fromString(client.account.address),
79
+ createViemSigner(client),
80
+ deps.logger,
81
+ deps.dateProvider,
82
+ config,
83
+ debugMaxGasLimit,
84
+ deps.store,
85
+ deps.metrics,
86
+ forwarderAddress,
87
+ );
88
+ }
89
+
90
+ export function createForwarderL1TxUtilsFromEthSigner(
91
+ client: ViemClient,
92
+ signer: EthSigner,
93
+ forwarderAddress: EthAddress,
94
+ deps: {
95
+ logger?: Logger;
96
+ dateProvider?: DateProvider;
97
+ store?: IL1TxStore;
98
+ metrics?: IL1TxMetrics;
99
+ } = {},
100
+ config: Partial<L1TxUtilsConfig> = {},
101
+ debugMaxGasLimit: boolean = false,
102
+ ) {
103
+ const callback: SigningCallback = async (transaction, _signingAddress) => {
104
+ return (await signer.signTransaction(transaction)).toViemTransactionSignature();
105
+ };
106
+
107
+ return new ForwarderL1TxUtils(
108
+ client,
109
+ signer.address,
110
+ callback,
111
+ deps.logger,
112
+ deps.dateProvider,
113
+ config,
114
+ debugMaxGasLimit,
115
+ deps.store,
116
+ deps.metrics,
117
+ forwarderAddress,
118
+ );
119
+ }
@@ -0,0 +1,2 @@
1
+ export * from './forwarder_l1_tx_utils.js';
2
+ export * from './l1_tx_utils_with_blobs.js';
@@ -0,0 +1,14 @@
1
+ export * from './config.js';
2
+ export * from './constants.js';
3
+ export * from './factory.js';
4
+ export * from './fee-strategies/index.js';
5
+ export * from './interfaces.js';
6
+ export * from './l1_fee_analyzer.js';
7
+ export * from './l1_tx_utils.js';
8
+ export * from './readonly_l1_tx_utils.js';
9
+ export * from './signer.js';
10
+ export * from './types.js';
11
+ export * from './utils.js';
12
+
13
+ // Note: We intentionally do not export l1_tx_utils_with_blobs.js
14
+ // to avoid accidentally importing blob-lib dependency.
@@ -0,0 +1,86 @@
1
+ import type { L1BlobInputs, L1TxState } from './types.js';
2
+
3
+ /**
4
+ * Interface for L1 transaction state storage.
5
+ * Implementations handle persistence of transaction states across restarts.
6
+ */
7
+ export interface IL1TxStore {
8
+ /**
9
+ * Gets the next available state ID for an account.
10
+ */
11
+ consumeNextStateId(account: string): Promise<number>;
12
+
13
+ /**
14
+ * Saves a single transaction state for a specific account.
15
+ * Does not save blob data (see saveBlobs).
16
+ * @param account - The sender account address
17
+ * @param state - Transaction state to save
18
+ */
19
+ saveState(account: string, state: L1TxState): Promise<L1TxState>;
20
+
21
+ /**
22
+ * Saves blobs for a given state.
23
+ * @param account - The sender account address
24
+ * @param stateId - The state ID
25
+ * @param blobInputs - Blob inputs to save
26
+ */
27
+ saveBlobs(account: string, stateId: number, blobInputs: L1BlobInputs | undefined): Promise<void>;
28
+
29
+ /**
30
+ * Loads all transaction states for a specific account.
31
+ * @param account - The sender account address
32
+ * @returns Array of transaction states with their IDs
33
+ */
34
+ loadStates(account: string): Promise<L1TxState[]>;
35
+
36
+ /**
37
+ * Loads a single state by ID.
38
+ * @param account - The sender account address
39
+ * @param stateId - The state ID
40
+ * @returns The transaction state or undefined if not found
41
+ */
42
+ loadState(account: string, stateId: number): Promise<L1TxState | undefined>;
43
+
44
+ /**
45
+ * Deletes a specific state and its associated blobs.
46
+ * @param account - The sender account address
47
+ * @param stateId - The state ID to delete
48
+ */
49
+ deleteState(account: string, ...stateId: number[]): Promise<void>;
50
+
51
+ /**
52
+ * Clears all transaction states for a specific account.
53
+ * @param account - The sender account address
54
+ */
55
+ clearStates(account: string): Promise<void>;
56
+
57
+ /**
58
+ * Gets all accounts that have stored states.
59
+ * @returns Array of account addresses
60
+ */
61
+ getAllAccounts(): Promise<string[]>;
62
+
63
+ /**
64
+ * Closes the store.
65
+ */
66
+ close(): Promise<void>;
67
+ }
68
+
69
+ /**
70
+ * Interface for L1 transaction metrics recording.
71
+ * Implementations handle tracking of transaction lifecycle and gas costs.
72
+ */
73
+ export interface IL1TxMetrics {
74
+ /**
75
+ * Records metrics when a transaction is mined
76
+ * @param state - The L1 transaction state
77
+ * @param l1Timestamp - The current L1 timestamp
78
+ */
79
+ recordMinedTx(state: L1TxState, l1Timestamp: Date): void;
80
+
81
+ /**
82
+ * Records metrics when a transaction is dropped
83
+ * @param state - The L1 transaction state
84
+ */
85
+ recordDroppedTx(state: L1TxState): void;
86
+ }