@aztec/ethereum 0.65.1 → 0.66.0
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.
- package/dest/constants.d.ts +1 -0
- package/dest/constants.d.ts.map +1 -1
- package/dest/constants.js +2 -1
- package/dest/contracts/rollup.d.ts +5 -0
- package/dest/contracts/rollup.d.ts.map +1 -1
- package/dest/contracts/rollup.js +16 -1
- package/dest/deploy_l1_contracts.d.ts +5 -1
- package/dest/deploy_l1_contracts.d.ts.map +1 -1
- package/dest/deploy_l1_contracts.js +109 -41
- package/dest/eth_cheat_codes.d.ts +155 -0
- package/dest/eth_cheat_codes.d.ts.map +1 -0
- package/dest/eth_cheat_codes.js +291 -0
- package/dest/index.d.ts +4 -1
- package/dest/index.d.ts.map +1 -1
- package/dest/index.js +5 -2
- package/dest/l1_contract_addresses.d.ts +4 -1
- package/dest/l1_contract_addresses.d.ts.map +1 -1
- package/dest/l1_contract_addresses.js +8 -1
- package/dest/l1_reader.d.ts +1 -0
- package/dest/l1_reader.d.ts.map +1 -1
- package/dest/l1_reader.js +5 -2
- package/dest/l1_tx_utils.d.ts +100 -0
- package/dest/l1_tx_utils.d.ts.map +1 -0
- package/dest/l1_tx_utils.js +253 -0
- package/dest/utils.js +2 -2
- package/package.json +5 -3
- package/src/constants.ts +1 -0
- package/src/contracts/rollup.ts +20 -0
- package/src/deploy_l1_contracts.ts +127 -44
- package/src/eth_cheat_codes.ts +316 -0
- package/src/index.ts +4 -1
- package/src/l1_contract_addresses.ts +7 -0
- package/src/l1_reader.ts +5 -1
- package/src/l1_tx_utils.ts +400 -0
- package/src/utils.ts +1 -1
|
@@ -0,0 +1,253 @@
|
|
|
1
|
+
import { bigintConfigHelper, getDefaultConfig, numberConfigHelper, } from '@aztec/foundation/config';
|
|
2
|
+
import { makeBackoff, retry } from '@aztec/foundation/retry';
|
|
3
|
+
import { sleep } from '@aztec/foundation/sleep';
|
|
4
|
+
import { formatGwei, } from 'viem';
|
|
5
|
+
// 1_000_000_000 Gwei = 1 ETH
|
|
6
|
+
// 1_000_000_000 Wei = 1 Gwei
|
|
7
|
+
// 1_000_000_000_000_000_000 Wei = 1 ETH
|
|
8
|
+
const WEI_CONST = 1000000000n;
|
|
9
|
+
// setting a minimum bump percentage to 10% due to geth's implementation
|
|
10
|
+
// https://github.com/ethereum/go-ethereum/blob/e3d61e6db028c412f74bc4d4c7e117a9e29d0de0/core/txpool/legacypool/list.go#L298
|
|
11
|
+
const MIN_REPLACEMENT_BUMP_PERCENTAGE = 10n;
|
|
12
|
+
// Avg ethereum block time is ~12s
|
|
13
|
+
const BLOCK_TIME_MS = 12000;
|
|
14
|
+
export const l1TxUtilsConfigMappings = {
|
|
15
|
+
gasLimitBufferPercentage: {
|
|
16
|
+
description: 'How much to increase gas price by each attempt (percentage)',
|
|
17
|
+
env: 'L1_GAS_LIMIT_BUFFER_PERCENTAGE',
|
|
18
|
+
...bigintConfigHelper(20n),
|
|
19
|
+
},
|
|
20
|
+
minGwei: {
|
|
21
|
+
description: 'Minimum gas price in gwei',
|
|
22
|
+
env: 'L1_GAS_PRICE_MIN',
|
|
23
|
+
...bigintConfigHelper(1n),
|
|
24
|
+
},
|
|
25
|
+
maxGwei: {
|
|
26
|
+
description: 'Maximum gas price in gwei',
|
|
27
|
+
env: 'L1_GAS_PRICE_MAX',
|
|
28
|
+
...bigintConfigHelper(100n),
|
|
29
|
+
},
|
|
30
|
+
priorityFeeBumpPercentage: {
|
|
31
|
+
description: 'How much to increase priority fee by each attempt (percentage)',
|
|
32
|
+
env: 'L1_PRIORITY_FEE_BUMP_PERCENTAGE',
|
|
33
|
+
...bigintConfigHelper(20n),
|
|
34
|
+
},
|
|
35
|
+
priorityFeeRetryBumpPercentage: {
|
|
36
|
+
description: 'How much to increase priority fee by each retry attempt (percentage)',
|
|
37
|
+
env: 'L1_PRIORITY_FEE_RETRY_BUMP_PERCENTAGE',
|
|
38
|
+
...bigintConfigHelper(50n),
|
|
39
|
+
},
|
|
40
|
+
maxAttempts: {
|
|
41
|
+
description: 'Maximum number of speed-up attempts',
|
|
42
|
+
env: 'L1_TX_MONITOR_MAX_ATTEMPTS',
|
|
43
|
+
...numberConfigHelper(3),
|
|
44
|
+
},
|
|
45
|
+
checkIntervalMs: {
|
|
46
|
+
description: 'How often to check tx status',
|
|
47
|
+
env: 'L1_TX_MONITOR_CHECK_INTERVAL_MS',
|
|
48
|
+
...numberConfigHelper(10000),
|
|
49
|
+
},
|
|
50
|
+
stallTimeMs: {
|
|
51
|
+
description: 'How long before considering tx stalled',
|
|
52
|
+
env: 'L1_TX_MONITOR_STALL_TIME_MS',
|
|
53
|
+
...numberConfigHelper(30000),
|
|
54
|
+
},
|
|
55
|
+
txTimeoutMs: {
|
|
56
|
+
description: 'How long to wait for a tx to be mined before giving up. Set to 0 to disable.',
|
|
57
|
+
env: 'L1_TX_MONITOR_TX_TIMEOUT_MS',
|
|
58
|
+
...numberConfigHelper(300000), // 5 mins
|
|
59
|
+
},
|
|
60
|
+
};
|
|
61
|
+
export const defaultL1TxUtilsConfig = getDefaultConfig(l1TxUtilsConfigMappings);
|
|
62
|
+
export class L1TxUtils {
|
|
63
|
+
constructor(publicClient, walletClient, logger, config) {
|
|
64
|
+
this.publicClient = publicClient;
|
|
65
|
+
this.walletClient = walletClient;
|
|
66
|
+
this.logger = logger;
|
|
67
|
+
this.config = {
|
|
68
|
+
...defaultL1TxUtilsConfig,
|
|
69
|
+
...(config || {}),
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* Sends a transaction with gas estimation and pricing
|
|
74
|
+
* @param request - The transaction request (to, data, value)
|
|
75
|
+
* @param gasConfig - Optional gas configuration
|
|
76
|
+
* @returns The transaction hash and parameters used
|
|
77
|
+
*/
|
|
78
|
+
async sendTransaction(request, _gasConfig) {
|
|
79
|
+
const gasConfig = { ...this.config, ..._gasConfig };
|
|
80
|
+
const account = this.walletClient.account;
|
|
81
|
+
let gasLimit;
|
|
82
|
+
if (gasConfig.fixedGas) {
|
|
83
|
+
gasLimit = gasConfig.fixedGas;
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
gasLimit = await this.estimateGas(account, request);
|
|
87
|
+
}
|
|
88
|
+
const gasPrice = await this.getGasPrice(gasConfig);
|
|
89
|
+
const txHash = await this.walletClient.sendTransaction({
|
|
90
|
+
...request,
|
|
91
|
+
gas: gasLimit,
|
|
92
|
+
maxFeePerGas: gasPrice.maxFeePerGas,
|
|
93
|
+
maxPriorityFeePerGas: gasPrice.maxPriorityFeePerGas,
|
|
94
|
+
});
|
|
95
|
+
this.logger?.verbose(`Sent L1 transaction ${txHash} with gas limit ${gasLimit} and price ${formatGwei(gasPrice.maxFeePerGas)} gwei`);
|
|
96
|
+
return { txHash, gasLimit, gasPrice };
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
* Monitors a transaction until completion, handling speed-ups if needed
|
|
100
|
+
* @param request - Original transaction request (needed for speed-ups)
|
|
101
|
+
* @param initialTxHash - Hash of the initial transaction
|
|
102
|
+
* @param params - Parameters used in the initial transaction
|
|
103
|
+
* @param gasConfig - Optional gas configuration
|
|
104
|
+
*/
|
|
105
|
+
async monitorTransaction(request, initialTxHash, params, _gasConfig) {
|
|
106
|
+
const gasConfig = { ...this.config, ..._gasConfig };
|
|
107
|
+
const account = this.walletClient.account;
|
|
108
|
+
// Retry a few times, in case the tx is not yet propagated.
|
|
109
|
+
const tx = await retry(() => this.publicClient.getTransaction({ hash: initialTxHash }), `Getting L1 transaction ${initialTxHash}`, makeBackoff([1, 2, 3]), this.logger, true);
|
|
110
|
+
if (tx?.nonce === undefined || tx?.nonce === null) {
|
|
111
|
+
throw new Error(`Failed to get L1 transaction ${initialTxHash} nonce`);
|
|
112
|
+
}
|
|
113
|
+
const nonce = tx.nonce;
|
|
114
|
+
const txHashes = new Set([initialTxHash]);
|
|
115
|
+
let currentTxHash = initialTxHash;
|
|
116
|
+
let attempts = 0;
|
|
117
|
+
let lastAttemptSent = Date.now();
|
|
118
|
+
const initialTxTime = lastAttemptSent;
|
|
119
|
+
let txTimedOut = false;
|
|
120
|
+
while (!txTimedOut) {
|
|
121
|
+
try {
|
|
122
|
+
const currentNonce = await this.publicClient.getTransactionCount({ address: account.address });
|
|
123
|
+
if (currentNonce > nonce) {
|
|
124
|
+
for (const hash of txHashes) {
|
|
125
|
+
try {
|
|
126
|
+
const receipt = await this.publicClient.getTransactionReceipt({ hash });
|
|
127
|
+
if (receipt) {
|
|
128
|
+
this.logger?.debug(`L1 Transaction ${hash} confirmed`);
|
|
129
|
+
if (receipt.status === 'reverted') {
|
|
130
|
+
this.logger?.error(`L1 Transaction ${hash} reverted`);
|
|
131
|
+
}
|
|
132
|
+
return receipt;
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
catch (err) {
|
|
136
|
+
if (err instanceof Error && err.message.includes('reverted')) {
|
|
137
|
+
throw err;
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
// Retry a few times, in case the tx is not yet propagated.
|
|
143
|
+
const tx = await retry(() => this.publicClient.getTransaction({ hash: currentTxHash }), `Getting L1 transaction ${currentTxHash}`, makeBackoff([1, 2, 3]), this.logger, true);
|
|
144
|
+
const timePassed = Date.now() - lastAttemptSent;
|
|
145
|
+
if (tx && timePassed < gasConfig.stallTimeMs) {
|
|
146
|
+
this.logger?.debug(`L1 Transaction ${currentTxHash} pending. Time passed: ${timePassed}ms`);
|
|
147
|
+
// Check timeout before continuing
|
|
148
|
+
if (gasConfig.txTimeoutMs) {
|
|
149
|
+
txTimedOut = Date.now() - initialTxTime > gasConfig.txTimeoutMs;
|
|
150
|
+
if (txTimedOut) {
|
|
151
|
+
break;
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
await sleep(gasConfig.checkIntervalMs);
|
|
155
|
+
continue;
|
|
156
|
+
}
|
|
157
|
+
if (timePassed > gasConfig.stallTimeMs && attempts < gasConfig.maxAttempts) {
|
|
158
|
+
attempts++;
|
|
159
|
+
const newGasPrice = await this.getGasPrice(gasConfig, attempts, tx.maxFeePerGas && tx.maxPriorityFeePerGas
|
|
160
|
+
? { maxFeePerGas: tx.maxFeePerGas, maxPriorityFeePerGas: tx.maxPriorityFeePerGas }
|
|
161
|
+
: undefined);
|
|
162
|
+
this.logger?.debug(`L1 Transaction ${currentTxHash} appears stuck. Attempting speed-up ${attempts}/${gasConfig.maxAttempts} ` +
|
|
163
|
+
`with new priority fee ${formatGwei(newGasPrice.maxPriorityFeePerGas)} gwei`);
|
|
164
|
+
currentTxHash = await this.walletClient.sendTransaction({
|
|
165
|
+
...request,
|
|
166
|
+
nonce,
|
|
167
|
+
gas: params.gasLimit,
|
|
168
|
+
maxFeePerGas: newGasPrice.maxFeePerGas,
|
|
169
|
+
maxPriorityFeePerGas: newGasPrice.maxPriorityFeePerGas,
|
|
170
|
+
});
|
|
171
|
+
txHashes.add(currentTxHash);
|
|
172
|
+
lastAttemptSent = Date.now();
|
|
173
|
+
}
|
|
174
|
+
await sleep(gasConfig.checkIntervalMs);
|
|
175
|
+
}
|
|
176
|
+
catch (err) {
|
|
177
|
+
this.logger?.warn(`Error monitoring tx ${currentTxHash}:`, err);
|
|
178
|
+
if (err.message?.includes('reverted')) {
|
|
179
|
+
throw err;
|
|
180
|
+
}
|
|
181
|
+
await sleep(gasConfig.checkIntervalMs);
|
|
182
|
+
}
|
|
183
|
+
// Check if tx has timed out.
|
|
184
|
+
if (gasConfig.txTimeoutMs) {
|
|
185
|
+
txTimedOut = Date.now() - initialTxTime > gasConfig.txTimeoutMs;
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
throw new Error(`L1 Transaction ${currentTxHash} timed out`);
|
|
189
|
+
}
|
|
190
|
+
/**
|
|
191
|
+
* Sends a transaction and monitors it until completion
|
|
192
|
+
* @param request - The transaction request (to, data, value)
|
|
193
|
+
* @param gasConfig - Optional gas configuration
|
|
194
|
+
* @returns The receipt of the successful transaction
|
|
195
|
+
*/
|
|
196
|
+
async sendAndMonitorTransaction(request, gasConfig) {
|
|
197
|
+
const { txHash, gasLimit } = await this.sendTransaction(request, gasConfig);
|
|
198
|
+
return this.monitorTransaction(request, txHash, { gasLimit }, gasConfig);
|
|
199
|
+
}
|
|
200
|
+
/**
|
|
201
|
+
* Gets the current gas price with bounds checking
|
|
202
|
+
*/
|
|
203
|
+
async getGasPrice(_gasConfig, attempt = 0, previousGasPrice) {
|
|
204
|
+
const gasConfig = { ...this.config, ..._gasConfig };
|
|
205
|
+
const block = await this.publicClient.getBlock({ blockTag: 'latest' });
|
|
206
|
+
const baseFee = block.baseFeePerGas ?? 0n;
|
|
207
|
+
// Get initial priority fee from the network
|
|
208
|
+
let priorityFee = await this.publicClient.estimateMaxPriorityFeePerGas();
|
|
209
|
+
let maxFeePerGas = baseFee;
|
|
210
|
+
// Bump base fee so it's valid for next blocks if it stalls
|
|
211
|
+
const numBlocks = Math.ceil(gasConfig.stallTimeMs / BLOCK_TIME_MS);
|
|
212
|
+
for (let i = 0; i < numBlocks; i++) {
|
|
213
|
+
// each block can go up 12.5% from previous baseFee
|
|
214
|
+
maxFeePerGas = (maxFeePerGas * (1000n + 125n)) / 1000n;
|
|
215
|
+
}
|
|
216
|
+
if (attempt > 0) {
|
|
217
|
+
const configBump = gasConfig.priorityFeeRetryBumpPercentage ?? defaultL1TxUtilsConfig.priorityFeeRetryBumpPercentage;
|
|
218
|
+
const bumpPercentage = configBump > MIN_REPLACEMENT_BUMP_PERCENTAGE ? configBump : MIN_REPLACEMENT_BUMP_PERCENTAGE;
|
|
219
|
+
// Calculate minimum required fees based on previous attempt
|
|
220
|
+
const minPriorityFee = (previousGasPrice.maxPriorityFeePerGas * (100n + bumpPercentage)) / 100n;
|
|
221
|
+
const minMaxFee = (previousGasPrice.maxFeePerGas * (100n + bumpPercentage)) / 100n;
|
|
222
|
+
// Add priority fee to maxFeePerGas
|
|
223
|
+
maxFeePerGas += priorityFee;
|
|
224
|
+
// Use maximum between current network values and minimum required values
|
|
225
|
+
priorityFee = priorityFee > minPriorityFee ? priorityFee : minPriorityFee;
|
|
226
|
+
maxFeePerGas = maxFeePerGas > minMaxFee ? maxFeePerGas : minMaxFee;
|
|
227
|
+
}
|
|
228
|
+
else {
|
|
229
|
+
// first attempt, just bump priority fee
|
|
230
|
+
priorityFee = (priorityFee * (100n + (gasConfig.priorityFeeBumpPercentage || 0n))) / 100n;
|
|
231
|
+
maxFeePerGas += priorityFee;
|
|
232
|
+
}
|
|
233
|
+
// Ensure we don't exceed maxGwei
|
|
234
|
+
const maxGweiInWei = gasConfig.maxGwei * WEI_CONST;
|
|
235
|
+
maxFeePerGas = maxFeePerGas > maxGweiInWei ? maxGweiInWei : maxFeePerGas;
|
|
236
|
+
// Ensure priority fee doesn't exceed max fee
|
|
237
|
+
const maxPriorityFeePerGas = priorityFee > maxFeePerGas ? maxFeePerGas : priorityFee;
|
|
238
|
+
this.logger?.debug(`Gas price calculation (attempt ${attempt}): baseFee=${formatGwei(baseFee)}, ` +
|
|
239
|
+
`maxPriorityFee=${formatGwei(maxPriorityFeePerGas)}, maxFee=${formatGwei(maxFeePerGas)}`);
|
|
240
|
+
return { maxFeePerGas, maxPriorityFeePerGas };
|
|
241
|
+
}
|
|
242
|
+
/**
|
|
243
|
+
* Estimates gas and adds buffer
|
|
244
|
+
*/
|
|
245
|
+
async estimateGas(account, request, _gasConfig) {
|
|
246
|
+
const gasConfig = { ...this.config, ..._gasConfig };
|
|
247
|
+
const initialEstimate = await this.publicClient.estimateGas({ account, ...request });
|
|
248
|
+
// Add buffer based on either fixed amount or percentage
|
|
249
|
+
const withBuffer = initialEstimate + (initialEstimate * (gasConfig.gasLimitBufferPercentage ?? 0n)) / 100n;
|
|
250
|
+
return withBuffer;
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"l1_tx_utils.js","sourceRoot":"","sources":["../src/l1_tx_utils.ts"],"names":[],"mappings":"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"}
|
package/dest/utils.js
CHANGED
|
@@ -8,7 +8,7 @@ export function extractEvent(logs, address, abi, eventName, filter, logger) {
|
|
|
8
8
|
}
|
|
9
9
|
function tryExtractEvent(logs, address, abi, eventName, filter, logger) {
|
|
10
10
|
for (const log of logs) {
|
|
11
|
-
if (log.address === address) {
|
|
11
|
+
if (log.address.toLowerCase() === address.toLowerCase()) {
|
|
12
12
|
try {
|
|
13
13
|
const decodedEvent = decodeEventLog({ abi, ...log });
|
|
14
14
|
if (decodedEvent.eventName === eventName) {
|
|
@@ -24,4 +24,4 @@ function tryExtractEvent(logs, address, abi, eventName, filter, logger) {
|
|
|
24
24
|
}
|
|
25
25
|
}
|
|
26
26
|
}
|
|
27
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsT0FBTyxFQU1MLGNBQWMsR0FDZixNQUFNLE1BQU0sQ0FBQztBQVNkLE1BQU0sVUFBVSxZQUFZLENBSzFCLElBQVcsRUFDWCxPQUFZLEVBQ1osR0FBUyxFQUNULFNBQXFCLEVBQ3JCLE1BQXFDLEVBQ3JDLE1BQW9CO0lBRXBCLE1BQU0sS0FBSyxHQUFHLGVBQWUsQ0FBQyxJQUFJLEVBQUUsT0FBTyxFQUFFLEdBQUcsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQzdFLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUNYLE1BQU0sSUFBSSxLQUFLLENBQUMsaUNBQWlDLFNBQVMsaUJBQWlCLE9BQU8sRUFBRSxDQUFDLENBQUM7SUFDeEYsQ0FBQztJQUNELE9BQU8sS0FBSyxDQUFDO0FBQ2YsQ0FBQztBQUVELFNBQVMsZUFBZSxDQUt0QixJQUFXLEVBQ1gsT0FBWSxFQUNaLEdBQVMsRUFDVCxTQUFxQixFQUNyQixNQUFxQyxFQUNyQyxNQUFvQjtJQUVwQixLQUFLLE1BQU0sR0FBRyxJQUFJLElBQUksRUFBRSxDQUFDO1FBQ3ZCLElBQUksR0FBRyxDQUFDLE9BQU8sQ0FBQyxXQUFXLEVBQUUsS0FBSyxPQUFPLENBQUMsV0FBVyxFQUFFLEVBQUUsQ0FBQztZQUN4RCxJQUFJLENBQUM7Z0JBQ0gsTUFBTSxZQUFZLEdBQUcsY0FBYyxDQUFDLEVBQUUsR0FBRyxFQUFFLEdBQUcsR0FBRyxFQUFFLENBQUMsQ0FBQztnQkFDckQsSUFBSSxZQUFZLENBQUMsU0FBUyxLQUFLLFNBQVMsRUFBRSxDQUFDO29CQUN6QyxNQUFNLGFBQWEsR0FBRyxZQUEwQixDQUFDO29CQUNqRCxJQUFJLENBQUMsTUFBTSxJQUFJLE1BQU0sQ0FBQyxhQUFhLENBQUMsRUFBRSxDQUFDO3dCQUNyQyxPQUFPLGFBQWEsQ0FBQztvQkFDdkIsQ0FBQztnQkFDSCxDQUFDO1lBQ0gsQ0FBQztZQUFDLE9BQU8sR0FBRyxFQUFFLENBQUM7Z0JBQ2IsTUFBTSxFQUFFLElBQUksQ0FBQywyQ0FBMkMsT0FBTyxLQUFLLEdBQUcsRUFBRSxDQUFDLENBQUM7WUFDN0UsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDO0FBQ0gsQ0FBQyJ9
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@aztec/ethereum",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.66.0",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"exports": {
|
|
6
6
|
".": "./dest/index.js",
|
|
@@ -28,8 +28,8 @@
|
|
|
28
28
|
"../package.common.json"
|
|
29
29
|
],
|
|
30
30
|
"dependencies": {
|
|
31
|
-
"@aztec/foundation": "0.
|
|
32
|
-
"@aztec/l1-artifacts": "0.
|
|
31
|
+
"@aztec/foundation": "0.66.0",
|
|
32
|
+
"@aztec/l1-artifacts": "0.66.0",
|
|
33
33
|
"@viem/anvil": "^0.0.10",
|
|
34
34
|
"dotenv": "^16.0.3",
|
|
35
35
|
"get-port": "^7.1.0",
|
|
@@ -41,6 +41,8 @@
|
|
|
41
41
|
"@jest/globals": "^29.5.0",
|
|
42
42
|
"@types/jest": "^29.5.0",
|
|
43
43
|
"@types/node": "^18.14.6",
|
|
44
|
+
"@viem/anvil": "^0.0.10",
|
|
45
|
+
"get-port": "^7.1.0",
|
|
44
46
|
"jest": "^29.5.0",
|
|
45
47
|
"ts-node": "^10.9.1",
|
|
46
48
|
"typescript": "^5.0.4"
|
package/src/constants.ts
CHANGED
package/src/contracts/rollup.ts
CHANGED
|
@@ -44,6 +44,26 @@ export class RollupContract {
|
|
|
44
44
|
return this.rollup.read.getCurrentSlot();
|
|
45
45
|
}
|
|
46
46
|
|
|
47
|
+
getCommitteeAt(timestamp: bigint) {
|
|
48
|
+
return this.rollup.read.getCommitteeAt([timestamp]);
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
getSampleSeedAt(timestamp: bigint) {
|
|
52
|
+
return this.rollup.read.getSampleSeedAt([timestamp]);
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
getCurrentSampleSeed() {
|
|
56
|
+
return this.rollup.read.getCurrentSampleSeed();
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
getCurrentEpochCommittee() {
|
|
60
|
+
return this.rollup.read.getCurrentEpochCommittee();
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
getCurrentProposer() {
|
|
64
|
+
return this.rollup.read.getCurrentProposer();
|
|
65
|
+
}
|
|
66
|
+
|
|
47
67
|
async getEpochNumber(blockNumber?: bigint) {
|
|
48
68
|
blockNumber ??= await this.getBlockNumber();
|
|
49
69
|
return this.rollup.read.getEpochForBlock([BigInt(blockNumber)]);
|