@aztec/ethereum 0.0.0-test.0 → 0.0.1-commit.21caa21
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/account.d.ts +2 -0
- package/dest/account.d.ts.map +1 -0
- package/dest/account.js +4 -0
- package/dest/chain.d.ts +1 -1
- package/dest/client.d.ts +6 -4
- package/dest/client.d.ts.map +1 -1
- package/dest/client.js +16 -2
- package/dest/config.d.ts +111 -17
- package/dest/config.d.ts.map +1 -1
- package/dest/config.js +462 -22
- package/dest/constants.d.ts +1 -1
- package/dest/contracts/empire_base.d.ts +24 -8
- package/dest/contracts/empire_base.d.ts.map +1 -1
- package/dest/contracts/empire_base.js +75 -2
- package/dest/contracts/empire_slashing_proposer.d.ts +66 -0
- package/dest/contracts/empire_slashing_proposer.d.ts.map +1 -0
- package/dest/contracts/empire_slashing_proposer.js +200 -0
- package/dest/contracts/errors.d.ts +7 -0
- package/dest/contracts/errors.d.ts.map +1 -0
- package/dest/contracts/errors.js +12 -0
- package/dest/contracts/fee_asset_handler.d.ts +19 -0
- package/dest/contracts/fee_asset_handler.d.ts.map +1 -0
- package/dest/contracts/fee_asset_handler.js +57 -0
- package/dest/contracts/fee_juice.d.ts +6 -7
- package/dest/contracts/fee_juice.d.ts.map +1 -1
- package/dest/contracts/fee_juice.js +27 -20
- package/dest/contracts/governance.d.ts +43 -32
- package/dest/contracts/governance.d.ts.map +1 -1
- package/dest/contracts/governance.js +87 -84
- package/dest/contracts/governance_proposer.d.ts +16 -13
- package/dest/contracts/governance_proposer.d.ts.map +1 -1
- package/dest/contracts/governance_proposer.js +37 -17
- package/dest/contracts/gse.d.ts +32 -0
- package/dest/contracts/gse.d.ts.map +1 -0
- package/dest/contracts/gse.js +72 -0
- package/dest/contracts/inbox.d.ts +26 -0
- package/dest/contracts/inbox.d.ts.map +1 -0
- package/dest/contracts/inbox.js +45 -0
- package/dest/contracts/index.d.ts +9 -3
- package/dest/contracts/index.d.ts.map +1 -1
- package/dest/contracts/index.js +8 -2
- package/dest/contracts/multicall.d.ts +21 -0
- package/dest/contracts/multicall.d.ts.map +1 -0
- package/dest/contracts/multicall.js +156 -0
- package/dest/contracts/registry.d.ts +10 -5
- package/dest/contracts/registry.d.ts.map +1 -1
- package/dest/contracts/registry.js +44 -16
- package/dest/contracts/rollup.d.ts +204 -40
- package/dest/contracts/rollup.d.ts.map +1 -1
- package/dest/contracts/rollup.js +529 -79
- package/dest/contracts/slasher_contract.d.ts +44 -0
- package/dest/contracts/slasher_contract.d.ts.map +1 -0
- package/dest/contracts/slasher_contract.js +75 -0
- package/dest/contracts/tally_slashing_proposer.d.ts +139 -0
- package/dest/contracts/tally_slashing_proposer.d.ts.map +1 -0
- package/dest/contracts/tally_slashing_proposer.js +313 -0
- package/dest/contracts/utils.d.ts +3 -0
- package/dest/contracts/utils.d.ts.map +1 -0
- package/dest/contracts/utils.js +11 -0
- package/dest/deploy_l1_contracts.d.ts +577 -21114
- package/dest/deploy_l1_contracts.d.ts.map +1 -1
- package/dest/deploy_l1_contracts.js +1225 -421
- package/dest/eth-signer/eth-signer.d.ts +21 -0
- package/dest/eth-signer/eth-signer.d.ts.map +1 -0
- package/dest/eth-signer/eth-signer.js +5 -0
- package/dest/eth-signer/index.d.ts +2 -0
- package/dest/eth-signer/index.d.ts.map +1 -0
- package/dest/eth-signer/index.js +1 -0
- package/dest/index.d.ts +7 -3
- package/dest/index.d.ts.map +1 -1
- package/dest/index.js +6 -2
- package/dest/l1_artifacts.d.ts +77344 -0
- package/dest/l1_artifacts.d.ts.map +1 -0
- package/dest/l1_artifacts.js +166 -0
- package/dest/l1_contract_addresses.d.ts +24 -4
- package/dest/l1_contract_addresses.d.ts.map +1 -1
- package/dest/l1_contract_addresses.js +22 -18
- package/dest/l1_reader.d.ts +2 -2
- package/dest/l1_reader.d.ts.map +1 -1
- package/dest/l1_reader.js +8 -8
- package/dest/l1_tx_utils/config.d.ts +59 -0
- package/dest/l1_tx_utils/config.d.ts.map +1 -0
- package/dest/l1_tx_utils/config.js +82 -0
- package/dest/l1_tx_utils/constants.d.ts +6 -0
- package/dest/l1_tx_utils/constants.d.ts.map +1 -0
- package/dest/l1_tx_utils/constants.js +14 -0
- package/dest/l1_tx_utils/factory.d.ts +24 -0
- package/dest/l1_tx_utils/factory.d.ts.map +1 -0
- package/dest/l1_tx_utils/factory.js +12 -0
- package/dest/l1_tx_utils/index.d.ts +10 -0
- package/dest/l1_tx_utils/index.d.ts.map +1 -0
- package/dest/l1_tx_utils/index.js +10 -0
- package/dest/l1_tx_utils/interfaces.d.ts +76 -0
- package/dest/l1_tx_utils/interfaces.d.ts.map +1 -0
- package/dest/l1_tx_utils/interfaces.js +4 -0
- package/dest/l1_tx_utils/l1_tx_utils.d.ts +94 -0
- package/dest/l1_tx_utils/l1_tx_utils.d.ts.map +1 -0
- package/dest/l1_tx_utils/l1_tx_utils.js +610 -0
- package/dest/l1_tx_utils/l1_tx_utils_with_blobs.d.ts +26 -0
- package/dest/l1_tx_utils/l1_tx_utils_with_blobs.d.ts.map +1 -0
- package/dest/l1_tx_utils/l1_tx_utils_with_blobs.js +26 -0
- package/dest/l1_tx_utils/readonly_l1_tx_utils.d.ts +94 -0
- package/dest/l1_tx_utils/readonly_l1_tx_utils.d.ts.map +1 -0
- package/dest/l1_tx_utils/readonly_l1_tx_utils.js +430 -0
- package/dest/l1_tx_utils/signer.d.ts +4 -0
- package/dest/l1_tx_utils/signer.d.ts.map +1 -0
- package/dest/l1_tx_utils/signer.js +16 -0
- package/dest/l1_tx_utils/types.d.ts +67 -0
- package/dest/l1_tx_utils/types.d.ts.map +1 -0
- package/dest/l1_tx_utils/types.js +26 -0
- package/dest/l1_tx_utils/utils.d.ts +4 -0
- package/dest/l1_tx_utils/utils.d.ts.map +1 -0
- package/dest/l1_tx_utils/utils.js +14 -0
- package/dest/l1_types.d.ts +6 -0
- package/dest/l1_types.d.ts.map +1 -0
- package/dest/l1_types.js +1 -0
- package/dest/publisher_manager.d.ts +15 -0
- package/dest/publisher_manager.d.ts.map +1 -0
- package/dest/publisher_manager.js +88 -0
- package/dest/queries.d.ts +4 -2
- package/dest/queries.d.ts.map +1 -1
- package/dest/queries.js +53 -12
- package/dest/test/chain_monitor.d.ts +73 -0
- package/dest/test/chain_monitor.d.ts.map +1 -0
- package/dest/test/chain_monitor.js +215 -0
- package/dest/test/delayed_tx_utils.d.ts +8 -3
- package/dest/test/delayed_tx_utils.d.ts.map +1 -1
- package/dest/test/delayed_tx_utils.js +13 -6
- package/dest/test/eth_cheat_codes.d.ts +217 -0
- package/dest/test/eth_cheat_codes.d.ts.map +1 -0
- package/dest/test/eth_cheat_codes.js +558 -0
- package/dest/test/eth_cheat_codes_with_state.d.ts +2 -2
- package/dest/test/eth_cheat_codes_with_state.d.ts.map +1 -1
- package/dest/test/eth_cheat_codes_with_state.js +1 -1
- package/dest/test/index.d.ts +4 -1
- package/dest/test/index.d.ts.map +1 -1
- package/dest/test/index.js +3 -0
- package/dest/test/rollup_cheat_codes.d.ts +87 -0
- package/dest/test/rollup_cheat_codes.d.ts.map +1 -0
- package/dest/test/rollup_cheat_codes.js +266 -0
- package/dest/test/start_anvil.d.ts +7 -1
- package/dest/test/start_anvil.d.ts.map +1 -1
- package/dest/test/start_anvil.js +16 -7
- package/dest/test/tx_delayer.d.ts +18 -7
- package/dest/test/tx_delayer.d.ts.map +1 -1
- package/dest/test/tx_delayer.js +95 -19
- package/dest/test/upgrade_utils.d.ts +6 -5
- package/dest/test/upgrade_utils.d.ts.map +1 -1
- package/dest/test/upgrade_utils.js +23 -16
- package/dest/types.d.ts +7 -8
- package/dest/types.d.ts.map +1 -1
- package/dest/types.js +3 -1
- package/dest/utils.d.ts +2 -1
- package/dest/utils.d.ts.map +1 -1
- package/dest/utils.js +43 -88
- package/dest/zkPassportVerifierAddress.d.ts +15 -0
- package/dest/zkPassportVerifierAddress.d.ts.map +1 -0
- package/dest/zkPassportVerifierAddress.js +11 -0
- package/package.json +28 -19
- package/src/account.ts +5 -0
- package/src/client.ts +42 -4
- package/src/config.ts +592 -31
- package/src/contracts/empire_base.ts +77 -7
- package/src/contracts/empire_slashing_proposer.ts +265 -0
- package/src/contracts/errors.ts +13 -0
- package/src/contracts/fee_asset_handler.ts +63 -0
- package/src/contracts/fee_juice.ts +29 -15
- package/src/contracts/governance.ts +80 -77
- package/src/contracts/governance_proposer.ts +66 -24
- package/src/contracts/gse.ts +88 -0
- package/src/contracts/inbox.ts +63 -0
- package/src/contracts/index.ts +8 -2
- package/src/contracts/multicall.ts +155 -0
- package/src/contracts/registry.ts +51 -26
- package/src/contracts/rollup.ts +596 -74
- package/src/contracts/slasher_contract.ts +89 -0
- package/src/contracts/tally_slashing_proposer.ts +316 -0
- package/src/contracts/utils.ts +14 -0
- package/src/deploy_l1_contracts.ts +1459 -538
- package/src/eth-signer/eth-signer.ts +25 -0
- package/src/eth-signer/index.ts +1 -0
- package/src/index.ts +6 -2
- package/src/l1_artifacts.ts +254 -0
- package/src/l1_contract_addresses.ts +32 -19
- package/src/l1_reader.ts +9 -9
- package/src/l1_tx_utils/README.md +177 -0
- package/src/l1_tx_utils/config.ts +143 -0
- package/src/l1_tx_utils/constants.ts +18 -0
- package/src/l1_tx_utils/factory.ts +64 -0
- package/src/l1_tx_utils/index.ts +12 -0
- package/src/l1_tx_utils/interfaces.ts +86 -0
- package/src/l1_tx_utils/l1_tx_utils.ts +718 -0
- package/src/l1_tx_utils/l1_tx_utils_with_blobs.ts +77 -0
- package/src/l1_tx_utils/readonly_l1_tx_utils.ts +558 -0
- package/src/l1_tx_utils/signer.ts +28 -0
- package/src/l1_tx_utils/types.ts +85 -0
- package/src/l1_tx_utils/utils.ts +16 -0
- package/src/l1_types.ts +6 -0
- package/src/publisher_manager.ts +106 -0
- package/src/queries.ts +73 -15
- package/src/test/chain_monitor.ts +243 -0
- package/src/test/delayed_tx_utils.ts +34 -6
- package/src/test/eth_cheat_codes.ts +588 -0
- package/src/test/eth_cheat_codes_with_state.ts +1 -1
- package/src/test/index.ts +3 -0
- package/src/test/rollup_cheat_codes.ts +307 -0
- package/src/test/start_anvil.ts +22 -5
- package/src/test/tx_delayer.ts +127 -26
- package/src/test/upgrade_utils.ts +30 -21
- package/src/types.ts +10 -8
- package/src/utils.ts +49 -90
- package/src/zkPassportVerifierAddress.ts +15 -0
- package/dest/contracts/forwarder.d.ts +0 -24
- package/dest/contracts/forwarder.d.ts.map +0 -1
- package/dest/contracts/forwarder.js +0 -101
- package/dest/contracts/slashing_proposer.d.ts +0 -21
- package/dest/contracts/slashing_proposer.d.ts.map +0 -1
- package/dest/contracts/slashing_proposer.js +0 -47
- package/dest/eth_cheat_codes.d.ts +0 -147
- package/dest/eth_cheat_codes.d.ts.map +0 -1
- package/dest/eth_cheat_codes.js +0 -303
- package/dest/l1_tx_utils.d.ts +0 -192
- package/dest/l1_tx_utils.d.ts.map +0 -1
- package/dest/l1_tx_utils.js +0 -641
- package/dest/l1_tx_utils_with_blobs.d.ts +0 -12
- package/dest/l1_tx_utils_with_blobs.d.ts.map +0 -1
- package/dest/l1_tx_utils_with_blobs.js +0 -64
- package/src/contracts/forwarder.ts +0 -132
- package/src/contracts/slashing_proposer.ts +0 -51
- package/src/eth_cheat_codes.ts +0 -314
- package/src/l1_tx_utils.ts +0 -847
- package/src/l1_tx_utils_with_blobs.ts +0 -86
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import type { BlobKzgInstance } from '@aztec/blob-lib/types';
|
|
2
|
+
import { EthAddress } from '@aztec/foundation/eth-address';
|
|
3
|
+
import type { ViemTransactionSignature } from '@aztec/foundation/eth-signature';
|
|
4
|
+
|
|
5
|
+
import type { Abi, Address, Hex, TransactionReceipt, TransactionSerializable } from 'viem';
|
|
6
|
+
|
|
7
|
+
import type { L1TxUtilsConfig } from './config.js';
|
|
8
|
+
|
|
9
|
+
export interface L1TxRequest {
|
|
10
|
+
to: Address | null;
|
|
11
|
+
data?: Hex;
|
|
12
|
+
value?: bigint;
|
|
13
|
+
abi?: Abi;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
export type L1TxConfig = Partial<L1TxUtilsConfig> & { gasLimit?: bigint; txTimeoutAt?: Date };
|
|
17
|
+
|
|
18
|
+
export interface L1BlobInputs {
|
|
19
|
+
blobs: Uint8Array[];
|
|
20
|
+
kzg: BlobKzgInstance;
|
|
21
|
+
maxFeePerBlobGas?: bigint;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export interface GasPrice {
|
|
25
|
+
maxFeePerGas: bigint;
|
|
26
|
+
maxPriorityFeePerGas: bigint;
|
|
27
|
+
maxFeePerBlobGas?: bigint;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
export type TransactionStats = {
|
|
31
|
+
/** Address of the sender. */
|
|
32
|
+
sender: string;
|
|
33
|
+
/** Hash of the transaction. */
|
|
34
|
+
transactionHash: string;
|
|
35
|
+
/** Size in bytes of the tx calldata */
|
|
36
|
+
calldataSize: number;
|
|
37
|
+
/** Gas required to pay for the calldata inclusion (depends on size and number of zeros) */
|
|
38
|
+
calldataGas: number;
|
|
39
|
+
};
|
|
40
|
+
|
|
41
|
+
export enum TxUtilsState {
|
|
42
|
+
IDLE,
|
|
43
|
+
SENT,
|
|
44
|
+
SPEED_UP,
|
|
45
|
+
CANCELLED,
|
|
46
|
+
NOT_MINED,
|
|
47
|
+
MINED,
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
export const TerminalTxUtilsState = [TxUtilsState.IDLE, TxUtilsState.MINED, TxUtilsState.NOT_MINED];
|
|
51
|
+
|
|
52
|
+
export type L1TxState = {
|
|
53
|
+
id: number;
|
|
54
|
+
txHashes: Hex[];
|
|
55
|
+
cancelTxHashes: Hex[];
|
|
56
|
+
gasLimit: bigint;
|
|
57
|
+
gasPrice: GasPrice;
|
|
58
|
+
txConfigOverrides: L1TxConfig;
|
|
59
|
+
request: L1TxRequest;
|
|
60
|
+
status: TxUtilsState;
|
|
61
|
+
nonce: number;
|
|
62
|
+
sentAtL1Ts: Date;
|
|
63
|
+
lastSentAtL1Ts: Date;
|
|
64
|
+
receipt?: TransactionReceipt;
|
|
65
|
+
blobInputs: L1BlobInputs | undefined;
|
|
66
|
+
};
|
|
67
|
+
|
|
68
|
+
export type SigningCallback = (
|
|
69
|
+
transaction: TransactionSerializable,
|
|
70
|
+
signingAddress: EthAddress,
|
|
71
|
+
) => Promise<ViemTransactionSignature>;
|
|
72
|
+
|
|
73
|
+
export class UnknownMinedTxError extends Error {
|
|
74
|
+
constructor(nonce: number, account: string) {
|
|
75
|
+
super(`Nonce ${nonce} from account ${account} is MINED but not by one of our expected transactions`);
|
|
76
|
+
this.name = 'UnknownMinedTxError';
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
export class DroppedTransactionError extends Error {
|
|
81
|
+
constructor(nonce: number, account: string) {
|
|
82
|
+
super(`Transaction with nonce ${nonce} from account ${account} was dropped from the mempool`);
|
|
83
|
+
this.name = 'DroppedTransactionError';
|
|
84
|
+
}
|
|
85
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { compactArray } from '@aztec/foundation/collection';
|
|
2
|
+
|
|
3
|
+
import type { ContractFunctionExecutionError } from 'viem';
|
|
4
|
+
|
|
5
|
+
export function tryGetCustomErrorNameContractFunction(err: ContractFunctionExecutionError) {
|
|
6
|
+
return compactArray([err.shortMessage, ...(err.metaMessages ?? []).slice(0, 2).map(s => s.trim())]).join(' ');
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
/*
|
|
10
|
+
* Returns cost of calldata usage in Ethereum.
|
|
11
|
+
* @param data - Calldata.
|
|
12
|
+
* @returns 4 for each zero byte, 16 for each nonzero.
|
|
13
|
+
*/
|
|
14
|
+
export function getCalldataGasUsage(data: Uint8Array) {
|
|
15
|
+
return data.filter(byte => byte === 0).length * 4 + data.filter(byte => byte !== 0).length * 16;
|
|
16
|
+
}
|
package/src/l1_types.ts
ADDED
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
import { pick } from '@aztec/foundation/collection';
|
|
2
|
+
import { createLogger } from '@aztec/foundation/log';
|
|
3
|
+
|
|
4
|
+
import { L1TxUtils, TxUtilsState } from './l1_tx_utils/index.js';
|
|
5
|
+
|
|
6
|
+
// Defines the order in which we prioritise publishers based on their state (first is better)
|
|
7
|
+
const sortOrder = [
|
|
8
|
+
// Always prefer sending from idle publishers
|
|
9
|
+
TxUtilsState.IDLE,
|
|
10
|
+
// Then from publishers that have sent a tx and it got mined
|
|
11
|
+
TxUtilsState.MINED,
|
|
12
|
+
// Then from publishers that have sent a tx but it's in-flight
|
|
13
|
+
TxUtilsState.SPEED_UP,
|
|
14
|
+
TxUtilsState.SENT,
|
|
15
|
+
// We leave cancelled and not-mined states for last, since these represent failures to mines and could be problematic
|
|
16
|
+
TxUtilsState.CANCELLED,
|
|
17
|
+
TxUtilsState.NOT_MINED,
|
|
18
|
+
];
|
|
19
|
+
|
|
20
|
+
// Which states represent a busy publisher that we should avoid if possible
|
|
21
|
+
const busyStates: TxUtilsState[] = [
|
|
22
|
+
TxUtilsState.SENT,
|
|
23
|
+
TxUtilsState.SPEED_UP,
|
|
24
|
+
TxUtilsState.CANCELLED,
|
|
25
|
+
TxUtilsState.NOT_MINED,
|
|
26
|
+
];
|
|
27
|
+
|
|
28
|
+
export type PublisherFilter<UtilsType extends L1TxUtils> = (utils: UtilsType) => boolean;
|
|
29
|
+
|
|
30
|
+
export class PublisherManager<UtilsType extends L1TxUtils = L1TxUtils> {
|
|
31
|
+
private log = createLogger('publisher:manager');
|
|
32
|
+
private config: { publisherAllowInvalidStates?: boolean };
|
|
33
|
+
|
|
34
|
+
constructor(
|
|
35
|
+
private publishers: UtilsType[],
|
|
36
|
+
config: { publisherAllowInvalidStates?: boolean },
|
|
37
|
+
) {
|
|
38
|
+
this.log.info(`PublisherManager initialized with ${publishers.length} publishers.`);
|
|
39
|
+
this.publishers = publishers;
|
|
40
|
+
this.config = pick(config, 'publisherAllowInvalidStates');
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
/** Loads the state of all publishers and resumes monitoring any pending txs */
|
|
44
|
+
public async loadState(): Promise<void> {
|
|
45
|
+
await Promise.all(this.publishers.map(pub => pub.loadStateAndResumeMonitoring()));
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
// Finds and prioritises available publishers based on
|
|
49
|
+
// 1. Validity as per the provided filter function
|
|
50
|
+
// 2. Validity based on the state the publisher is in
|
|
51
|
+
// 3. Priority based on state as defined by sortOrder
|
|
52
|
+
// 4. Then priority based on highest balance
|
|
53
|
+
// 5. Then priority based on least recently used
|
|
54
|
+
public async getAvailablePublisher(filter: PublisherFilter<UtilsType> = () => true): Promise<UtilsType> {
|
|
55
|
+
this.log.debug(`Getting available publisher`, {
|
|
56
|
+
publishers: this.publishers.map(p => ({
|
|
57
|
+
address: p.getSenderAddress(),
|
|
58
|
+
state: p.state,
|
|
59
|
+
lastMined: p.lastMinedAtBlockNumber,
|
|
60
|
+
})),
|
|
61
|
+
});
|
|
62
|
+
|
|
63
|
+
// Extract the valid publishers
|
|
64
|
+
let validPublishers = this.publishers.filter((pub: UtilsType) => !busyStates.includes(pub.state) && filter(pub));
|
|
65
|
+
|
|
66
|
+
// If none found but we allow invalid (busy) states, try again including them
|
|
67
|
+
if (validPublishers.length === 0 && this.config.publisherAllowInvalidStates) {
|
|
68
|
+
this.log.warn(`No valid publishers found. Trying again including invalid states.`);
|
|
69
|
+
validPublishers = this.publishers.filter(pub => filter(pub));
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
// Error if none found
|
|
73
|
+
if (validPublishers.length === 0) {
|
|
74
|
+
throw new Error(`Failed to find an available publisher.`);
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
// Get the balances
|
|
78
|
+
const publishersWithBalance = await Promise.all(
|
|
79
|
+
validPublishers.map(async pub => {
|
|
80
|
+
return { balance: await pub.getSenderBalance(), publisher: pub };
|
|
81
|
+
}),
|
|
82
|
+
);
|
|
83
|
+
|
|
84
|
+
// Sort based on state, then balance, then time since last use
|
|
85
|
+
const sortedPublishers = publishersWithBalance.sort((a, b) => {
|
|
86
|
+
const stateComparison = sortOrder.indexOf(a.publisher.state) - sortOrder.indexOf(b.publisher.state);
|
|
87
|
+
if (stateComparison !== 0) {
|
|
88
|
+
return stateComparison;
|
|
89
|
+
}
|
|
90
|
+
const balanceComparison = Number(b.balance - a.balance);
|
|
91
|
+
if (balanceComparison !== 0) {
|
|
92
|
+
return balanceComparison;
|
|
93
|
+
}
|
|
94
|
+
const lastUsedComparison = Number(
|
|
95
|
+
(a.publisher.lastMinedAtBlockNumber ?? 0n) - (b.publisher.lastMinedAtBlockNumber ?? 0n),
|
|
96
|
+
);
|
|
97
|
+
return lastUsedComparison;
|
|
98
|
+
});
|
|
99
|
+
|
|
100
|
+
return sortedPublishers[0].publisher;
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
public interrupt() {
|
|
104
|
+
this.publishers.forEach(pub => pub.interrupt());
|
|
105
|
+
}
|
|
106
|
+
}
|
package/src/queries.ts
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { EthAddress } from '@aztec/foundation/eth-address';
|
|
2
2
|
|
|
3
3
|
import type { L1ContractsConfig } from './config.js';
|
|
4
|
-
import {
|
|
4
|
+
import { ReadOnlyGovernanceContract } from './contracts/governance.js';
|
|
5
|
+
import { GovernanceProposerContract } from './contracts/governance_proposer.js';
|
|
5
6
|
import { RollupContract } from './contracts/rollup.js';
|
|
6
7
|
import type { ViemPublicClient } from './types.js';
|
|
7
8
|
|
|
@@ -9,50 +10,107 @@ import type { ViemPublicClient } from './types.js';
|
|
|
9
10
|
export async function getL1ContractsConfig(
|
|
10
11
|
publicClient: ViemPublicClient,
|
|
11
12
|
addresses: { governanceAddress: EthAddress; rollupAddress?: EthAddress },
|
|
12
|
-
): Promise<
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
13
|
+
): Promise<
|
|
14
|
+
Omit<L1ContractsConfig, 'ethereumSlotDuration'> & {
|
|
15
|
+
l1StartBlock: bigint;
|
|
16
|
+
l1GenesisTime: bigint;
|
|
17
|
+
rollupVersion: number;
|
|
18
|
+
genesisArchiveTreeRoot: `0x${string}`;
|
|
19
|
+
}
|
|
20
|
+
> {
|
|
21
|
+
const governance = new ReadOnlyGovernanceContract(addresses.governanceAddress.toString(), publicClient);
|
|
22
|
+
const governanceProposerAddress = await governance.getGovernanceProposerAddress();
|
|
23
|
+
const governanceProposer = new GovernanceProposerContract(publicClient, governanceProposerAddress.toString());
|
|
24
|
+
const rollupAddress = addresses.rollupAddress ?? (await governanceProposer.getRollupAddress());
|
|
16
25
|
const rollup = new RollupContract(publicClient, rollupAddress.toString());
|
|
17
26
|
const slasherProposer = await rollup.getSlashingProposer();
|
|
27
|
+
const slasher = await rollup.getSlasherContract();
|
|
18
28
|
|
|
19
29
|
const [
|
|
20
30
|
l1StartBlock,
|
|
21
31
|
l1GenesisTime,
|
|
22
32
|
aztecEpochDuration,
|
|
23
|
-
aztecProofSubmissionWindow,
|
|
24
33
|
aztecSlotDuration,
|
|
34
|
+
aztecProofSubmissionEpochs,
|
|
25
35
|
aztecTargetCommitteeSize,
|
|
26
|
-
|
|
36
|
+
lagInEpochsForValidatorSet,
|
|
37
|
+
lagInEpochsForRandao,
|
|
38
|
+
activationThreshold,
|
|
39
|
+
ejectionThreshold,
|
|
40
|
+
localEjectionThreshold,
|
|
27
41
|
governanceProposerQuorum,
|
|
28
42
|
governanceProposerRoundSize,
|
|
29
43
|
slashingQuorum,
|
|
30
44
|
slashingRoundSize,
|
|
45
|
+
slashingLifetimeInRounds,
|
|
46
|
+
slashingExecutionDelayInRounds,
|
|
47
|
+
slashingOffsetInRounds,
|
|
48
|
+
slashingAmounts,
|
|
49
|
+
slashingVetoer,
|
|
50
|
+
slashingDisableDuration,
|
|
51
|
+
manaTarget,
|
|
52
|
+
provingCostPerMana,
|
|
53
|
+
rollupVersion,
|
|
54
|
+
genesisArchiveTreeRoot,
|
|
55
|
+
exitDelay,
|
|
31
56
|
] = await Promise.all([
|
|
32
57
|
rollup.getL1StartBlock(),
|
|
33
58
|
rollup.getL1GenesisTime(),
|
|
34
59
|
rollup.getEpochDuration(),
|
|
35
|
-
rollup.getProofSubmissionWindow(),
|
|
36
60
|
rollup.getSlotDuration(),
|
|
61
|
+
rollup.getProofSubmissionEpochs(),
|
|
37
62
|
rollup.getTargetCommitteeSize(),
|
|
38
|
-
rollup.
|
|
63
|
+
rollup.getLagInEpochsForValidatorSet(),
|
|
64
|
+
rollup.getLagInEpochsForRandao(),
|
|
65
|
+
rollup.getActivationThreshold(),
|
|
66
|
+
rollup.getEjectionThreshold(),
|
|
67
|
+
rollup.getLocalEjectionThreshold(),
|
|
39
68
|
governanceProposer.getQuorumSize(),
|
|
40
69
|
governanceProposer.getRoundSize(),
|
|
41
|
-
slasherProposer
|
|
42
|
-
slasherProposer
|
|
70
|
+
slasherProposer?.getQuorumSize() ?? 0n,
|
|
71
|
+
slasherProposer?.getRoundSize() ?? 0n,
|
|
72
|
+
slasherProposer?.getLifetimeInRounds() ?? 0n,
|
|
73
|
+
slasherProposer?.getExecutionDelayInRounds() ?? 0n,
|
|
74
|
+
slasherProposer?.type === 'tally' ? slasherProposer.getSlashOffsetInRounds() : 0n,
|
|
75
|
+
slasherProposer?.type === 'tally' ? slasherProposer.getSlashingAmounts() : [0n, 0n, 0n],
|
|
76
|
+
slasher?.getVetoer() ?? EthAddress.ZERO,
|
|
77
|
+
slasher?.getSlashingDisableDuration() ?? 0,
|
|
78
|
+
rollup.getManaTarget(),
|
|
79
|
+
rollup.getProvingCostPerMana(),
|
|
80
|
+
rollup.getVersion(),
|
|
81
|
+
rollup.getGenesisArchiveTreeRoot(),
|
|
82
|
+
rollup.getExitDelay(),
|
|
43
83
|
] as const);
|
|
44
84
|
|
|
45
85
|
return {
|
|
46
86
|
l1StartBlock,
|
|
47
87
|
l1GenesisTime,
|
|
48
88
|
aztecEpochDuration: Number(aztecEpochDuration),
|
|
49
|
-
aztecProofSubmissionWindow: Number(aztecProofSubmissionWindow),
|
|
50
89
|
aztecSlotDuration: Number(aztecSlotDuration),
|
|
90
|
+
aztecProofSubmissionEpochs: Number(aztecProofSubmissionEpochs),
|
|
51
91
|
aztecTargetCommitteeSize: Number(aztecTargetCommitteeSize),
|
|
92
|
+
lagInEpochsForValidatorSet: Number(lagInEpochsForValidatorSet),
|
|
93
|
+
lagInEpochsForRandao: Number(lagInEpochsForRandao),
|
|
52
94
|
governanceProposerQuorum: Number(governanceProposerQuorum),
|
|
53
95
|
governanceProposerRoundSize: Number(governanceProposerRoundSize),
|
|
54
|
-
|
|
96
|
+
activationThreshold,
|
|
97
|
+
ejectionThreshold,
|
|
98
|
+
localEjectionThreshold,
|
|
55
99
|
slashingQuorum: Number(slashingQuorum),
|
|
56
|
-
|
|
100
|
+
slashingRoundSizeInEpochs: Number(slashingRoundSize / aztecEpochDuration),
|
|
101
|
+
slashingLifetimeInRounds: Number(slashingLifetimeInRounds),
|
|
102
|
+
slashingExecutionDelayInRounds: Number(slashingExecutionDelayInRounds),
|
|
103
|
+
slashingVetoer,
|
|
104
|
+
slashingDisableDuration,
|
|
105
|
+
manaTarget,
|
|
106
|
+
provingCostPerMana: provingCostPerMana,
|
|
107
|
+
rollupVersion: Number(rollupVersion),
|
|
108
|
+
genesisArchiveTreeRoot,
|
|
109
|
+
exitDelaySeconds: Number(exitDelay),
|
|
110
|
+
slasherFlavor: slasherProposer?.type ?? 'tally',
|
|
111
|
+
slashingOffsetInRounds: Number(slashingOffsetInRounds),
|
|
112
|
+
slashAmountSmall: slashingAmounts[0],
|
|
113
|
+
slashAmountMedium: slashingAmounts[1],
|
|
114
|
+
slashAmountLarge: slashingAmounts[2],
|
|
57
115
|
};
|
|
58
116
|
}
|
|
@@ -0,0 +1,243 @@
|
|
|
1
|
+
import { InboxContract, type RollupContract } from '@aztec/ethereum/contracts';
|
|
2
|
+
import { EpochNumber, SlotNumber } from '@aztec/foundation/branded-types';
|
|
3
|
+
import { EthAddress } from '@aztec/foundation/eth-address';
|
|
4
|
+
import { createLogger } from '@aztec/foundation/log';
|
|
5
|
+
import { promiseWithResolvers } from '@aztec/foundation/promise';
|
|
6
|
+
import { DateProvider } from '@aztec/foundation/timer';
|
|
7
|
+
|
|
8
|
+
import { EventEmitter } from 'events';
|
|
9
|
+
|
|
10
|
+
import type { ViemClient } from '../types.js';
|
|
11
|
+
|
|
12
|
+
export type ChainMonitorEventMap = {
|
|
13
|
+
'l1-block': [{ l1BlockNumber: number; timestamp: bigint }];
|
|
14
|
+
checkpoint: [{ checkpointNumber: number; l1BlockNumber: number; l2SlotNumber: SlotNumber; timestamp: bigint }];
|
|
15
|
+
'checkpoint-proven': [{ provenCheckpointNumber: number; l1BlockNumber: number; timestamp: bigint }];
|
|
16
|
+
'l2-messages': [{ totalL2Messages: number; l1BlockNumber: number }];
|
|
17
|
+
'l2-epoch': [{ l2EpochNumber: EpochNumber; timestamp: bigint; committee: EthAddress[] | undefined }];
|
|
18
|
+
'l2-slot': [{ l2SlotNumber: SlotNumber; timestamp: bigint }];
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
/** Utility class that polls the chain on quick intervals and logs new L1 blocks, L2 blocks, and L2 proofs. */
|
|
22
|
+
export class ChainMonitor extends EventEmitter<ChainMonitorEventMap> {
|
|
23
|
+
private readonly l1Client: ViemClient;
|
|
24
|
+
private inbox: InboxContract | undefined;
|
|
25
|
+
private handle: NodeJS.Timeout | undefined;
|
|
26
|
+
// eslint-disable-next-line aztec-custom/no-non-primitive-in-collections
|
|
27
|
+
private running: Set<Promise<void>> = new Set();
|
|
28
|
+
|
|
29
|
+
/** Current L1 block number */
|
|
30
|
+
public l1BlockNumber!: number;
|
|
31
|
+
/** Current checkpoint number */
|
|
32
|
+
public checkpointNumber!: number;
|
|
33
|
+
/** Current proven checkpoint number */
|
|
34
|
+
public provenCheckpointNumber!: number;
|
|
35
|
+
/** L1 timestamp for the current checkpoint */
|
|
36
|
+
public checkpointTimestamp!: bigint;
|
|
37
|
+
/** L1 timestamp for the proven checkpoint */
|
|
38
|
+
public provenCheckpointTimestamp!: bigint;
|
|
39
|
+
/** Total number of L2 messages pushed into the Inbox */
|
|
40
|
+
public totalL2Messages: number = 0;
|
|
41
|
+
/** Current L2 epoch number */
|
|
42
|
+
public l2EpochNumber!: EpochNumber;
|
|
43
|
+
/** Current L2 slot number */
|
|
44
|
+
public l2SlotNumber!: SlotNumber;
|
|
45
|
+
|
|
46
|
+
constructor(
|
|
47
|
+
private readonly rollup: RollupContract,
|
|
48
|
+
private readonly dateProvider: DateProvider = new DateProvider(),
|
|
49
|
+
private readonly logger = createLogger('aztecjs:utils:chain_monitor'),
|
|
50
|
+
private readonly intervalMs = 200,
|
|
51
|
+
) {
|
|
52
|
+
super();
|
|
53
|
+
this.l1Client = rollup.client;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
start() {
|
|
57
|
+
if (this.handle) {
|
|
58
|
+
throw new Error('Chain monitor already started');
|
|
59
|
+
}
|
|
60
|
+
this.handle = setInterval(this.safeRun.bind(this), this.intervalMs);
|
|
61
|
+
return this;
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
async stop() {
|
|
65
|
+
try {
|
|
66
|
+
this.removeAllListeners();
|
|
67
|
+
if (this.handle) {
|
|
68
|
+
clearInterval(this.handle!);
|
|
69
|
+
this.handle = undefined;
|
|
70
|
+
}
|
|
71
|
+
await Promise.allSettled([...this.running]);
|
|
72
|
+
} catch (err) {
|
|
73
|
+
this.logger.error('Error stopping chain monitor', err);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
private async getInbox() {
|
|
78
|
+
if (!this.inbox) {
|
|
79
|
+
const { inboxAddress } = await this.rollup.getRollupAddresses();
|
|
80
|
+
this.inbox = new InboxContract(this.l1Client, inboxAddress);
|
|
81
|
+
}
|
|
82
|
+
return this.inbox;
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
protected safeRun() {
|
|
86
|
+
const running = promiseWithResolvers<void>();
|
|
87
|
+
this.running.add(running.promise);
|
|
88
|
+
|
|
89
|
+
void this.run()
|
|
90
|
+
.catch(error => {
|
|
91
|
+
this.logger.error('Error in chain monitor loop', error);
|
|
92
|
+
})
|
|
93
|
+
.finally(() => {
|
|
94
|
+
running.resolve();
|
|
95
|
+
this.running.delete(running.promise);
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
async run(force = false) {
|
|
100
|
+
const newL1BlockNumber = Number(await this.l1Client.getBlockNumber({ cacheTime: 0 }));
|
|
101
|
+
if (!force && this.l1BlockNumber === newL1BlockNumber) {
|
|
102
|
+
return this;
|
|
103
|
+
}
|
|
104
|
+
this.l1BlockNumber = newL1BlockNumber;
|
|
105
|
+
|
|
106
|
+
const [l2SlotNumber, l2Epoch, l1block] = await Promise.all([
|
|
107
|
+
this.rollup.getSlotNumber(),
|
|
108
|
+
this.rollup.getCurrentEpoch(),
|
|
109
|
+
this.l1Client.getBlock({ blockNumber: BigInt(newL1BlockNumber), includeTransactions: false }),
|
|
110
|
+
]);
|
|
111
|
+
|
|
112
|
+
const timestamp = l1block.timestamp;
|
|
113
|
+
const timestampString = new Date(Number(timestamp) * 1000).toTimeString().split(' ')[0];
|
|
114
|
+
|
|
115
|
+
this.emit('l1-block', { l1BlockNumber: newL1BlockNumber, timestamp });
|
|
116
|
+
let msg = `L1 block ${newL1BlockNumber} mined at ${timestampString}`;
|
|
117
|
+
|
|
118
|
+
const newCheckpointNumber = Number(await this.rollup.getCheckpointNumber());
|
|
119
|
+
if (this.checkpointNumber !== newCheckpointNumber) {
|
|
120
|
+
const epochNumber = await this.rollup.getEpochNumberForCheckpoint(BigInt(newCheckpointNumber));
|
|
121
|
+
msg += ` with new checkpoint ${newCheckpointNumber} for epoch ${epochNumber}`;
|
|
122
|
+
this.checkpointNumber = newCheckpointNumber;
|
|
123
|
+
this.checkpointTimestamp = timestamp;
|
|
124
|
+
this.emit('checkpoint', {
|
|
125
|
+
checkpointNumber: newCheckpointNumber,
|
|
126
|
+
l1BlockNumber: newL1BlockNumber,
|
|
127
|
+
l2SlotNumber,
|
|
128
|
+
timestamp,
|
|
129
|
+
});
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
const newProvenCheckpointNumber = Number(await this.rollup.getProvenCheckpointNumber());
|
|
133
|
+
if (this.provenCheckpointNumber !== newProvenCheckpointNumber) {
|
|
134
|
+
const epochNumber = await this.rollup.getEpochNumberForCheckpoint(BigInt(newProvenCheckpointNumber));
|
|
135
|
+
msg += ` with proof up to checkpoint ${newProvenCheckpointNumber} for epoch ${epochNumber}`;
|
|
136
|
+
this.provenCheckpointNumber = newProvenCheckpointNumber;
|
|
137
|
+
this.provenCheckpointTimestamp = timestamp;
|
|
138
|
+
this.emit('checkpoint-proven', {
|
|
139
|
+
provenCheckpointNumber: newProvenCheckpointNumber,
|
|
140
|
+
l1BlockNumber: newL1BlockNumber,
|
|
141
|
+
timestamp,
|
|
142
|
+
});
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
const inbox = await this.getInbox();
|
|
146
|
+
const newTotalL2Messages = await inbox.getState().then(s => Number(s.totalMessagesInserted));
|
|
147
|
+
if (this.totalL2Messages !== newTotalL2Messages) {
|
|
148
|
+
msg += ` with ${newTotalL2Messages - this.totalL2Messages} new L2 messages (total ${newTotalL2Messages})`;
|
|
149
|
+
this.totalL2Messages = newTotalL2Messages;
|
|
150
|
+
this.emit('l2-messages', { totalL2Messages: newTotalL2Messages, l1BlockNumber: newL1BlockNumber });
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
let committee: EthAddress[] | undefined;
|
|
154
|
+
if (l2Epoch !== this.l2EpochNumber) {
|
|
155
|
+
this.l2EpochNumber = l2Epoch;
|
|
156
|
+
committee = (await this.rollup.getCurrentEpochCommittee())?.map(addr => EthAddress.fromString(addr));
|
|
157
|
+
this.emit('l2-epoch', { l2EpochNumber: l2Epoch, timestamp, committee });
|
|
158
|
+
msg += ` starting new epoch ${this.l2EpochNumber} `;
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
if (l2SlotNumber !== this.l2SlotNumber) {
|
|
162
|
+
this.l2SlotNumber = l2SlotNumber;
|
|
163
|
+
this.emit('l2-slot', { l2SlotNumber, timestamp });
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
this.logger.info(msg, {
|
|
167
|
+
currentTimestamp: this.dateProvider.nowInSeconds(),
|
|
168
|
+
l1Timestamp: timestamp,
|
|
169
|
+
l1BlockNumber: this.l1BlockNumber,
|
|
170
|
+
l2SlotNumber,
|
|
171
|
+
l2Epoch,
|
|
172
|
+
checkpointNumber: this.checkpointNumber,
|
|
173
|
+
provenCheckpointNumber: this.provenCheckpointNumber,
|
|
174
|
+
totalL2Messages: this.totalL2Messages,
|
|
175
|
+
committee,
|
|
176
|
+
});
|
|
177
|
+
|
|
178
|
+
return this;
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
public waitUntilL2Slot(slot: SlotNumber): Promise<void> {
|
|
182
|
+
if (this.l2SlotNumber >= slot) {
|
|
183
|
+
return Promise.resolve();
|
|
184
|
+
}
|
|
185
|
+
return new Promise(resolve => {
|
|
186
|
+
const listener = (data: { l2SlotNumber: SlotNumber; timestamp: bigint }) => {
|
|
187
|
+
if (data.l2SlotNumber >= slot) {
|
|
188
|
+
this.off('l2-slot', listener);
|
|
189
|
+
resolve();
|
|
190
|
+
}
|
|
191
|
+
};
|
|
192
|
+
this.on('l2-slot', listener);
|
|
193
|
+
});
|
|
194
|
+
}
|
|
195
|
+
|
|
196
|
+
public waitUntilL1Block(block: number | bigint): Promise<void> {
|
|
197
|
+
const targetBlock = typeof block === 'bigint' ? block.valueOf() : block;
|
|
198
|
+
if (this.l1BlockNumber >= targetBlock) {
|
|
199
|
+
return Promise.resolve();
|
|
200
|
+
}
|
|
201
|
+
return new Promise(resolve => {
|
|
202
|
+
const listener = (data: { l1BlockNumber: number; timestamp: bigint }) => {
|
|
203
|
+
if (data.l1BlockNumber >= targetBlock) {
|
|
204
|
+
this.off('l1-block', listener);
|
|
205
|
+
resolve();
|
|
206
|
+
}
|
|
207
|
+
};
|
|
208
|
+
this.on('l1-block', listener);
|
|
209
|
+
});
|
|
210
|
+
}
|
|
211
|
+
|
|
212
|
+
public waitUntilL1Timestamp(timestamp: number | bigint): Promise<void> {
|
|
213
|
+
const targetTimestamp = typeof timestamp === 'bigint' ? timestamp.valueOf() : timestamp;
|
|
214
|
+
if (this.l1BlockNumber >= targetTimestamp) {
|
|
215
|
+
return Promise.resolve();
|
|
216
|
+
}
|
|
217
|
+
return new Promise(resolve => {
|
|
218
|
+
const listener = (data: { l1BlockNumber: number; timestamp: bigint }) => {
|
|
219
|
+
if (data.timestamp >= targetTimestamp) {
|
|
220
|
+
this.off('l1-block', listener);
|
|
221
|
+
resolve();
|
|
222
|
+
}
|
|
223
|
+
};
|
|
224
|
+
this.on('l1-block', listener);
|
|
225
|
+
});
|
|
226
|
+
}
|
|
227
|
+
|
|
228
|
+
public waitUntilCheckpoint(checkpointNumber: number | bigint): Promise<void> {
|
|
229
|
+
const targetBlock = typeof checkpointNumber === 'bigint' ? checkpointNumber.valueOf() : checkpointNumber;
|
|
230
|
+
if (this.checkpointNumber >= targetBlock) {
|
|
231
|
+
return Promise.resolve();
|
|
232
|
+
}
|
|
233
|
+
return new Promise(resolve => {
|
|
234
|
+
const listener = (data: { checkpointNumber: number; timestamp: bigint }) => {
|
|
235
|
+
if (data.checkpointNumber >= targetBlock) {
|
|
236
|
+
this.off('checkpoint', listener);
|
|
237
|
+
resolve();
|
|
238
|
+
}
|
|
239
|
+
};
|
|
240
|
+
this.on('checkpoint', listener);
|
|
241
|
+
});
|
|
242
|
+
}
|
|
243
|
+
}
|
|
@@ -1,24 +1,52 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { EthAddress } from '@aztec/foundation/eth-address';
|
|
2
|
+
import { type Logger, createLogger } from '@aztec/foundation/log';
|
|
3
|
+
import { DateProvider } from '@aztec/foundation/timer';
|
|
4
|
+
|
|
5
|
+
import { type L1TxUtilsConfig, createViemSigner } from '../l1_tx_utils/index.js';
|
|
6
|
+
import { L1TxUtilsWithBlobs } from '../l1_tx_utils/l1_tx_utils_with_blobs.js';
|
|
7
|
+
import type { ExtendedViemWalletClient } from '../types.js';
|
|
2
8
|
import { type Delayer, withDelayer } from './tx_delayer.js';
|
|
3
9
|
|
|
4
10
|
export class DelayedTxUtils extends L1TxUtilsWithBlobs {
|
|
5
11
|
public delayer: Delayer | undefined;
|
|
6
12
|
|
|
7
|
-
public static fromL1TxUtils(
|
|
8
|
-
|
|
13
|
+
public static fromL1TxUtils(
|
|
14
|
+
l1TxUtils: L1TxUtilsWithBlobs,
|
|
15
|
+
ethereumSlotDuration: number,
|
|
16
|
+
wallet: ExtendedViemWalletClient,
|
|
17
|
+
) {
|
|
18
|
+
const { client, delayer } = withDelayer(wallet, l1TxUtils.dateProvider, {
|
|
9
19
|
ethereumSlotDuration,
|
|
10
20
|
});
|
|
11
21
|
const casted = l1TxUtils as unknown as DelayedTxUtils;
|
|
12
22
|
casted.delayer = delayer;
|
|
13
|
-
casted.
|
|
23
|
+
casted.client = client;
|
|
14
24
|
return casted;
|
|
15
25
|
}
|
|
16
26
|
|
|
17
27
|
public enableDelayer(ethereumSlotDuration: number) {
|
|
18
|
-
const { client, delayer } = withDelayer(this.
|
|
28
|
+
const { client, delayer } = withDelayer(this.client, this.dateProvider, {
|
|
19
29
|
ethereumSlotDuration,
|
|
20
30
|
});
|
|
21
31
|
this.delayer = delayer;
|
|
22
|
-
this.
|
|
32
|
+
this.client = client;
|
|
23
33
|
}
|
|
24
34
|
}
|
|
35
|
+
|
|
36
|
+
export function createDelayedL1TxUtilsFromViemWallet(
|
|
37
|
+
client: ExtendedViemWalletClient,
|
|
38
|
+
logger: Logger = createLogger('L1TxUtils'),
|
|
39
|
+
dateProvider: DateProvider = new DateProvider(),
|
|
40
|
+
config?: Partial<L1TxUtilsConfig>,
|
|
41
|
+
debugMaxGasLimit: boolean = false,
|
|
42
|
+
) {
|
|
43
|
+
return new DelayedTxUtils(
|
|
44
|
+
client,
|
|
45
|
+
EthAddress.fromString(client.account.address),
|
|
46
|
+
createViemSigner(client),
|
|
47
|
+
logger,
|
|
48
|
+
dateProvider,
|
|
49
|
+
config,
|
|
50
|
+
debugMaxGasLimit,
|
|
51
|
+
);
|
|
52
|
+
}
|