@aztec/node-lib 5.0.0-private.20260319 → 6.0.0-nightly.20260603
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/actions/snapshot-sync.d.ts +4 -3
- package/dest/actions/snapshot-sync.d.ts.map +1 -1
- package/dest/actions/snapshot-sync.js +15 -13
- package/dest/factories/l1_tx_utils.js +1 -1
- package/dest/metrics/l1_tx_metrics.d.ts +1 -1
- package/dest/metrics/l1_tx_metrics.d.ts.map +1 -1
- package/dest/metrics/l1_tx_metrics.js +12 -12
- package/package.json +20 -20
- package/src/actions/snapshot-sync.ts +24 -17
- package/src/factories/l1_tx_utils.ts +1 -1
- package/src/metrics/l1_tx_metrics.ts +16 -14
|
@@ -4,10 +4,11 @@ import type { L1ContractsConfig } from '@aztec/ethereum/config';
|
|
|
4
4
|
import type { EthAddress } from '@aztec/foundation/eth-address';
|
|
5
5
|
import type { Logger } from '@aztec/foundation/log';
|
|
6
6
|
import type { ChainConfig } from '@aztec/stdlib/config';
|
|
7
|
+
import { type ReadOnlyFileStore } from '@aztec/stdlib/file-store';
|
|
7
8
|
import type { DataStoreConfig } from '@aztec/stdlib/kv-store';
|
|
8
9
|
import { type SnapshotMetadata } from '@aztec/stdlib/snapshots';
|
|
9
10
|
import type { SharedNodeConfig } from '../config/index.js';
|
|
10
|
-
type SnapshotSyncConfig = Pick<SharedNodeConfig, 'syncMode'> & Pick<ChainConfig, 'l1ChainId' | 'rollupVersion'> & Pick<L1ContractsConfig, 'aztecEpochDuration'> & Pick<ArchiverConfig, 'archiverStoreMapSizeKb'
|
|
11
|
+
type SnapshotSyncConfig = Pick<SharedNodeConfig, 'syncMode'> & Pick<ChainConfig, 'l1ChainId' | 'rollupVersion'> & Pick<L1ContractsConfig, 'aztecEpochDuration'> & Pick<ArchiverConfig, 'archiverStoreMapSizeKb'> & DataStoreConfig & Required<Pick<DataStoreConfig, 'rollupAddress'>> & EthereumClientConfig & {
|
|
11
12
|
snapshotsUrls?: string[];
|
|
12
13
|
minL1BlocksToTriggerReplace?: number;
|
|
13
14
|
};
|
|
@@ -22,7 +23,7 @@ export declare function trySnapshotSync(config: SnapshotSyncConfig, log: Logger)
|
|
|
22
23
|
export declare function snapshotSync(snapshot: Pick<SnapshotMetadata, 'dataUrls'>, log: Logger, config: {
|
|
23
24
|
dataDirectory: string;
|
|
24
25
|
rollupAddress: EthAddress;
|
|
25
|
-
|
|
26
|
+
fileStore: ReadOnlyFileStore;
|
|
26
27
|
}): Promise<void>;
|
|
27
28
|
export {};
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic25hcHNob3Qtc3luYy5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2FjdGlvbnMvc25hcHNob3Qtc3luYy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBR0wsS0FBSyxjQUFjLEVBR3BCLE1BQU0saUJBQWlCLENBQUM7QUFFekIsT0FBTyxFQUFFLEtBQUssb0JBQW9CLEVBQW1CLE1BQU0sd0JBQXdCLENBQUM7QUFDcEYsT0FBTyxLQUFLLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUNoRSxPQUFPLEtBQUssRUFBRSxVQUFVLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUVoRSxPQUFPLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUdwRCxPQUFPLEtBQUssRUFBRSxXQUFXLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUV4RCxPQUFPLEVBQUUsS0FBSyxpQkFBaUIsRUFBMkIsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRixPQUFPLEtBQUssRUFBRSxlQUFlLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUM5RCxPQUFPLEVBQ0wsS0FBSyxnQkFBZ0IsRUFLdEIsTUFBTSx5QkFBeUIsQ0FBQztBQU1qQyxPQUFPLEtBQUssRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBSzNELEtBQUssa0JBQWtCLEdBQUcsSUFBSSxDQUFDLGdCQUFnQixFQUFFLFVBQVUsQ0FBQyxHQUMxRCxJQUFJLENBQUMsV0FBVyxFQUFFLFdBQVcsR0FBRyxlQUFlLENBQUMsR0FDaEQsSUFBSSxDQUFDLGlCQUFpQixFQUFFLG9CQUFvQixDQUFDLEdBQzdDLElBQUksQ0FBQyxjQUFjLEVBQUUsd0JBQXdCLENBQUMsR0FDOUMsZUFBZSxHQUNmLFFBQVEsQ0FBQyxJQUFJLENBQUMsZUFBZSxFQUFFLGVBQWUsQ0FBQyxDQUFDLEdBQ2hELG9CQUFvQixHQUFHO0lBQ3JCLGFBQWEsQ0FBQyxFQUFFLE1BQU0sRUFBRSxDQUFDO0lBQ3pCLDJCQUEyQixDQUFDLEVBQUUsTUFBTSxDQUFDO0NBQ3RDLENBQUM7QUFFSjs7O0dBR0c7QUFDSCx3QkFBc0IsZUFBZSxDQUFDLE1BQU0sRUFBRSxrQkFBa0IsRUFBRSxHQUFHLEVBQUUsTUFBTSxvQkF1SzVFO0FBRUQ7O0dBRUc7QUFDSCx3QkFBc0IsWUFBWSxDQUNoQyxRQUFRLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixFQUFFLFVBQVUsQ0FBQyxFQUM1QyxHQUFHLEVBQUUsTUFBTSxFQUNYLE1BQU0sRUFBRTtJQUFFLGFBQWEsRUFBRSxNQUFNLENBQUM7SUFBQyxhQUFhLEVBQUUsVUFBVSxDQUFDO0lBQUMsU0FBUyxFQUFFLGlCQUFpQixDQUFBO0NBQUUsaUJBbUQzRiJ9
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"snapshot-sync.d.ts","sourceRoot":"","sources":["../../src/actions/snapshot-sync.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"snapshot-sync.d.ts","sourceRoot":"","sources":["../../src/actions/snapshot-sync.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,KAAK,cAAc,EAGpB,MAAM,iBAAiB,CAAC;AAEzB,OAAO,EAAE,KAAK,oBAAoB,EAAmB,MAAM,wBAAwB,CAAC;AACpF,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAChE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAEhE,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAGpD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAExD,OAAO,EAAE,KAAK,iBAAiB,EAA2B,MAAM,0BAA0B,CAAC;AAC3F,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAC9D,OAAO,EACL,KAAK,gBAAgB,EAKtB,MAAM,yBAAyB,CAAC;AAMjC,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAK3D,KAAK,kBAAkB,GAAG,IAAI,CAAC,gBAAgB,EAAE,UAAU,CAAC,GAC1D,IAAI,CAAC,WAAW,EAAE,WAAW,GAAG,eAAe,CAAC,GAChD,IAAI,CAAC,iBAAiB,EAAE,oBAAoB,CAAC,GAC7C,IAAI,CAAC,cAAc,EAAE,wBAAwB,CAAC,GAC9C,eAAe,GACf,QAAQ,CAAC,IAAI,CAAC,eAAe,EAAE,eAAe,CAAC,CAAC,GAChD,oBAAoB,GAAG;IACrB,aAAa,CAAC,EAAE,MAAM,EAAE,CAAC;IACzB,2BAA2B,CAAC,EAAE,MAAM,CAAC;CACtC,CAAC;AAEJ;;;GAGG;AACH,wBAAsB,eAAe,CAAC,MAAM,EAAE,kBAAkB,EAAE,GAAG,EAAE,MAAM,oBAuK5E;AAED;;GAEG;AACH,wBAAsB,YAAY,CAChC,QAAQ,EAAE,IAAI,CAAC,gBAAgB,EAAE,UAAU,CAAC,EAC5C,GAAG,EAAE,MAAM,EACX,MAAM,EAAE;IAAE,aAAa,EAAE,MAAM,CAAC;IAAC,aAAa,EAAE,UAAU,CAAC;IAAC,SAAS,EAAE,iBAAiB,CAAA;CAAE,iBAmD3F"}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
import { ARCHIVER_DB_VERSION, ARCHIVER_STORE_NAME, createArchiverStore } from '@aztec/archiver';
|
|
1
|
+
import { ARCHIVER_DB_VERSION, ARCHIVER_STORE_NAME, createArchiverStore, getArchiverSynchPoint } from '@aztec/archiver';
|
|
2
2
|
import { INITIAL_L2_BLOCK_NUM } from '@aztec/constants';
|
|
3
3
|
import { getPublicClient } from '@aztec/ethereum/client';
|
|
4
4
|
import { tryRmDir } from '@aztec/foundation/fs';
|
|
5
5
|
import { P2P_STORE_NAME } from '@aztec/p2p';
|
|
6
|
+
import { GENESIS_BLOCK_HEADER_HASH } from '@aztec/stdlib/block';
|
|
6
7
|
import { DatabaseVersionManager } from '@aztec/stdlib/database-version/manager';
|
|
7
8
|
import { createReadOnlyFileStore } from '@aztec/stdlib/file-store';
|
|
8
9
|
import { downloadSnapshot, getLatestSnapshotMetadata, makeSnapshotPaths } from '@aztec/stdlib/snapshots';
|
|
@@ -15,7 +16,7 @@ const MIN_L1_BLOCKS_TO_TRIGGER_REPLACE = 86400 / 2 / 12;
|
|
|
15
16
|
* Connects to a remote snapshot index and downloads the latest snapshot if the local archiver is behind.
|
|
16
17
|
* Behaviour depends on syncing mode.
|
|
17
18
|
*/ export async function trySnapshotSync(config, log) {
|
|
18
|
-
const { syncMode, snapshotsUrls, dataDirectory, l1ChainId, rollupVersion,
|
|
19
|
+
const { syncMode, snapshotsUrls, dataDirectory, l1ChainId, rollupVersion, rollupAddress } = config;
|
|
19
20
|
if (syncMode === 'full') {
|
|
20
21
|
log.debug('Snapshot sync is disabled. Running full sync.', {
|
|
21
22
|
syncMode: syncMode
|
|
@@ -30,22 +31,24 @@ const MIN_L1_BLOCKS_TO_TRIGGER_REPLACE = 86400 / 2 / 12;
|
|
|
30
31
|
log.verbose('Snapshot sync is disabled. No local data directory defined.');
|
|
31
32
|
return false;
|
|
32
33
|
}
|
|
33
|
-
// Create an archiver store to check the current state (do this only once)
|
|
34
|
+
// Create an archiver store to check the current state (do this only once). This temporary store is only
|
|
35
|
+
// read for its sync point and never serves tagged-log queries, so the genesis block hash it carries is
|
|
36
|
+
// immaterial — pass the protocol constant.
|
|
34
37
|
log.verbose(`Creating temporary archiver data store`);
|
|
35
|
-
const archiverStore = await createArchiverStore(config);
|
|
38
|
+
const archiverStore = await createArchiverStore(config, GENESIS_BLOCK_HEADER_HASH);
|
|
36
39
|
let archiverL1BlockNumber;
|
|
37
40
|
let archiverL2BlockNumber;
|
|
38
41
|
try {
|
|
39
42
|
[archiverL1BlockNumber, archiverL2BlockNumber] = await Promise.all([
|
|
40
|
-
archiverStore
|
|
41
|
-
archiverStore.
|
|
43
|
+
getArchiverSynchPoint(archiverStore).then((s)=>s.blocksSynchedTo),
|
|
44
|
+
archiverStore.blocks.getLatestL2BlockNumber()
|
|
42
45
|
]);
|
|
43
46
|
} finally{
|
|
44
47
|
log.verbose(`Closing temporary archiver data store`, {
|
|
45
48
|
archiverL1BlockNumber,
|
|
46
49
|
archiverL2BlockNumber
|
|
47
50
|
});
|
|
48
|
-
await archiverStore.close();
|
|
51
|
+
await archiverStore.db.close();
|
|
49
52
|
}
|
|
50
53
|
const minL1BlocksToTriggerReplace = config.minL1BlocksToTriggerReplace ?? MIN_L1_BLOCKS_TO_TRIGGER_REPLACE;
|
|
51
54
|
if (syncMode === 'snapshot' && archiverL2BlockNumber !== undefined && archiverL2BlockNumber >= INITIAL_L2_BLOCK_NUM) {
|
|
@@ -64,7 +67,7 @@ const MIN_L1_BLOCKS_TO_TRIGGER_REPLACE = 86400 / 2 / 12;
|
|
|
64
67
|
const indexMetadata = {
|
|
65
68
|
l1ChainId,
|
|
66
69
|
rollupVersion,
|
|
67
|
-
rollupAddress
|
|
70
|
+
rollupAddress
|
|
68
71
|
};
|
|
69
72
|
const snapshotCandidates = [];
|
|
70
73
|
for (const snapshotsUrl of snapshotsUrls){
|
|
@@ -132,7 +135,7 @@ const MIN_L1_BLOCKS_TO_TRIGGER_REPLACE = 86400 / 2 / 12;
|
|
|
132
135
|
// Sort candidates by L1 block number (highest first)
|
|
133
136
|
snapshotCandidates.sort((a, b)=>b.snapshot.l1BlockNumber - a.snapshot.l1BlockNumber);
|
|
134
137
|
// Try each candidate in order until one succeeds
|
|
135
|
-
for (const { snapshot, url } of snapshotCandidates){
|
|
138
|
+
for (const { snapshot, url, fileStore } of snapshotCandidates){
|
|
136
139
|
const { l1BlockNumber, l2BlockNumber } = snapshot;
|
|
137
140
|
log.info(`Attempting to sync from snapshot at L1 block ${l1BlockNumber} L2 block ${l2BlockNumber}`, {
|
|
138
141
|
snapshot,
|
|
@@ -141,8 +144,8 @@ const MIN_L1_BLOCKS_TO_TRIGGER_REPLACE = 86400 / 2 / 12;
|
|
|
141
144
|
try {
|
|
142
145
|
await snapshotSync(snapshot, log, {
|
|
143
146
|
dataDirectory: config.dataDirectory,
|
|
144
|
-
rollupAddress: config.
|
|
145
|
-
|
|
147
|
+
rollupAddress: config.rollupAddress,
|
|
148
|
+
fileStore
|
|
146
149
|
});
|
|
147
150
|
log.info(`Snapshot synced to L1 block ${l1BlockNumber} L2 block ${l2BlockNumber}`, {
|
|
148
151
|
snapshot,
|
|
@@ -165,11 +168,10 @@ const MIN_L1_BLOCKS_TO_TRIGGER_REPLACE = 86400 / 2 / 12;
|
|
|
165
168
|
/**
|
|
166
169
|
* Downloads the given snapshot replacing any local data stores.
|
|
167
170
|
*/ export async function snapshotSync(snapshot, log, config) {
|
|
168
|
-
const { dataDirectory, rollupAddress } = config;
|
|
171
|
+
const { dataDirectory, rollupAddress, fileStore } = config;
|
|
169
172
|
if (!dataDirectory) {
|
|
170
173
|
throw new Error(`No local data directory defined. Cannot sync snapshot.`);
|
|
171
174
|
}
|
|
172
|
-
const fileStore = await createReadOnlyFileStore(config.snapshotsUrl, log);
|
|
173
175
|
let downloadDir;
|
|
174
176
|
try {
|
|
175
177
|
// Download the snapshot to a temp location.
|
|
@@ -13,7 +13,7 @@ const L1_TX_STORE_NAME = 'l1-tx-utils';
|
|
|
13
13
|
const logger = deps.logger ?? createLogger('l1-tx-utils');
|
|
14
14
|
// Note that we do NOT bind them to the rollup address, since we still need to
|
|
15
15
|
// monitor and cancel txs for previous rollups to free up our nonces.
|
|
16
|
-
const noRollupConfig = omit(config, '
|
|
16
|
+
const noRollupConfig = omit(config, 'rollupAddress');
|
|
17
17
|
const kvStore = await createStore(L1_TX_STORE_NAME, L1TxStore.SCHEMA_VERSION, noRollupConfig, logger.getBindings());
|
|
18
18
|
const store = new L1TxStore(kvStore, logger);
|
|
19
19
|
const meter = deps.telemetry.getMeter('L1TxUtils');
|
|
@@ -26,4 +26,4 @@ export declare class L1TxMetrics implements IL1TxMetrics {
|
|
|
26
26
|
recordMinedTx(state: L1TxState, l1Timestamp: Date): void;
|
|
27
27
|
recordDroppedTx(state: L1TxState): void;
|
|
28
28
|
}
|
|
29
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibDFfdHhfbWV0cmljcy5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL21ldHJpY3MvbDFfdHhfbWV0cmljcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssRUFBRSxZQUFZLEVBQUUsU0FBUyxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFHM0UsT0FBTyxFQUdMLEtBQUssS0FBSyxFQUlYLE1BQU0seUJBQXlCLENBQUM7QUFFakMsTUFBTSxNQUFNLFNBQVMsR0FBRyxXQUFXLEdBQUcsUUFBUSxHQUFHLE9BQU8sQ0FBQztBQUV6RDs7R0FFRztBQUNILHFCQUFhLFdBQVksWUFBVyxZQUFZO0lBbUI1QyxPQUFPLENBQUMsS0FBSztJQUNiLE9BQU8sQ0FBQyxLQUFLO0lBQ2IsT0FBTyxDQUFDLE1BQU07SUFuQmhCLE9BQU8sQ0FBQyxlQUFlLENBQVk7SUFHbkMsT0FBTyxDQUFDLG9CQUFvQixDQUFZO0lBR3hDLE9BQU8sQ0FBQyxZQUFZLENBQWdCO0lBQ3BDLE9BQU8sQ0FBQyxlQUFlLENBQWdCO0lBQ3ZDLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBZ0I7SUFDeEMsT0FBTyxDQUFDLGVBQWUsQ0FBZ0I7SUFHdkMsT0FBTyxDQUFDLHVCQUF1QixDQUFZO0lBQzNDLE9BQU8sQ0FBQyxlQUFlLENBQVk7SUFDbkMsT0FBTyxDQUFDLGdCQUFnQixDQUFZO0lBRXBDLFlBQ1UsS0FBSyxFQUFFLEtBQUssRUFDWixLQUFLLEdBQUUsU0FBbUIsRUFDMUIsTUFBTSx5Q0FBc0MsRUFvQnJEO0lBRUQ7Ozs7T0FJRztJQUNJLGFBQWEsQ0FBQyxLQUFLLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxJQUFJLEdBQUcsSUFBSSxDQXNEOUQ7SUFFTSxlQUFlLENBQUMsS0FBSyxFQUFFLFNBQVMsR0FBRyxJQUFJLENBaUI3QztDQUNGIn0=
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"l1_tx_metrics.d.ts","sourceRoot":"","sources":["../../src/metrics/l1_tx_metrics.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AAG3E,OAAO,EAGL,KAAK,KAAK,EAIX,MAAM,yBAAyB,CAAC;AAEjC,MAAM,MAAM,SAAS,GAAG,WAAW,GAAG,QAAQ,GAAG,OAAO,CAAC;AAEzD;;GAEG;AACH,qBAAa,WAAY,YAAW,YAAY;IAmB5C,OAAO,CAAC,KAAK;IACb,OAAO,CAAC,KAAK;IACb,OAAO,CAAC,MAAM;IAnBhB,OAAO,CAAC,eAAe,CAAY;IAGnC,OAAO,CAAC,oBAAoB,CAAY;IAGxC,OAAO,CAAC,YAAY,CAAgB;IACpC,OAAO,CAAC,eAAe,CAAgB;IACvC,OAAO,CAAC,gBAAgB,CAAgB;IACxC,OAAO,CAAC,eAAe,CAAgB;IAGvC,OAAO,CAAC,uBAAuB,CAAY;IAC3C,OAAO,CAAC,eAAe,CAAY;IACnC,OAAO,CAAC,gBAAgB,CAAY;IAEpC,YACU,KAAK,EAAE,KAAK,EACZ,KAAK,GAAE,SAAmB,EAC1B,MAAM,yCAAsC,EAoBrD;IAED;;;;OAIG;IACI,aAAa,CAAC,KAAK,EAAE,SAAS,EAAE,WAAW,EAAE,IAAI,GAAG,IAAI,
|
|
1
|
+
{"version":3,"file":"l1_tx_metrics.d.ts","sourceRoot":"","sources":["../../src/metrics/l1_tx_metrics.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AAG3E,OAAO,EAGL,KAAK,KAAK,EAIX,MAAM,yBAAyB,CAAC;AAEjC,MAAM,MAAM,SAAS,GAAG,WAAW,GAAG,QAAQ,GAAG,OAAO,CAAC;AAEzD;;GAEG;AACH,qBAAa,WAAY,YAAW,YAAY;IAmB5C,OAAO,CAAC,KAAK;IACb,OAAO,CAAC,KAAK;IACb,OAAO,CAAC,MAAM;IAnBhB,OAAO,CAAC,eAAe,CAAY;IAGnC,OAAO,CAAC,oBAAoB,CAAY;IAGxC,OAAO,CAAC,YAAY,CAAgB;IACpC,OAAO,CAAC,eAAe,CAAgB;IACvC,OAAO,CAAC,gBAAgB,CAAgB;IACxC,OAAO,CAAC,eAAe,CAAgB;IAGvC,OAAO,CAAC,uBAAuB,CAAY;IAC3C,OAAO,CAAC,eAAe,CAAY;IACnC,OAAO,CAAC,gBAAgB,CAAY;IAEpC,YACU,KAAK,EAAE,KAAK,EACZ,KAAK,GAAE,SAAmB,EAC1B,MAAM,yCAAsC,EAoBrD;IAED;;;;OAIG;IACI,aAAa,CAAC,KAAK,EAAE,SAAS,EAAE,WAAW,EAAE,IAAI,GAAG,IAAI,CAsD9D;IAEM,eAAe,CAAC,KAAK,EAAE,SAAS,GAAG,IAAI,CAiB7C;CACF"}
|
|
@@ -69,15 +69,15 @@ import { Attributes, Metrics, createUpDownCounterWithDefault } from '@aztec/tele
|
|
|
69
69
|
// Record number of attempts until mined
|
|
70
70
|
const attempts = isCancelTx ? state.cancelTxHashes.length : state.txHashes.length;
|
|
71
71
|
this.txAttemptsUntilMined.record(attempts, attributes);
|
|
72
|
-
// Record gas prices at end state
|
|
73
|
-
const
|
|
74
|
-
const
|
|
75
|
-
const
|
|
76
|
-
|
|
77
|
-
this.
|
|
78
|
-
|
|
79
|
-
if (
|
|
80
|
-
this.blobFeeHistogram.record(
|
|
72
|
+
// Record gas prices at end state, converted from wei to gwei to match metric unit definitions
|
|
73
|
+
const weiToGwei = 1e9;
|
|
74
|
+
const maxPriorityFeeGwei = Number(state.gasPrice.maxPriorityFeePerGas) / weiToGwei;
|
|
75
|
+
const maxFeeGwei = Number(state.gasPrice.maxFeePerGas) / weiToGwei;
|
|
76
|
+
const blobFeeGwei = state.gasPrice.maxFeePerBlobGas ? Number(state.gasPrice.maxFeePerBlobGas) / weiToGwei : undefined;
|
|
77
|
+
this.maxPriorityFeeHistogram.record(maxPriorityFeeGwei, attributes);
|
|
78
|
+
this.maxFeeHistogram.record(maxFeeGwei, attributes);
|
|
79
|
+
if (blobFeeGwei !== undefined) {
|
|
80
|
+
this.blobFeeHistogram.record(blobFeeGwei, attributes);
|
|
81
81
|
}
|
|
82
82
|
this.logger.debug(`Recorded tx end state metrics`, {
|
|
83
83
|
status: TxUtilsState[state.status],
|
|
@@ -85,9 +85,9 @@ import { Attributes, Metrics, createUpDownCounterWithDefault } from '@aztec/tele
|
|
|
85
85
|
isCancelTx,
|
|
86
86
|
isReverted,
|
|
87
87
|
scope: this.scope,
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
88
|
+
maxPriorityFeeGwei,
|
|
89
|
+
maxFeeGwei,
|
|
90
|
+
blobFeeGwei
|
|
91
91
|
});
|
|
92
92
|
}
|
|
93
93
|
recordDroppedTx(state) {
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@aztec/node-lib",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "6.0.0-nightly.20260603",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"typedocOptions": {
|
|
6
6
|
"entryPoints": [
|
|
@@ -66,28 +66,28 @@
|
|
|
66
66
|
]
|
|
67
67
|
},
|
|
68
68
|
"dependencies": {
|
|
69
|
-
"@aztec/archiver": "
|
|
70
|
-
"@aztec/bb-prover": "
|
|
71
|
-
"@aztec/blob-client": "
|
|
72
|
-
"@aztec/constants": "
|
|
73
|
-
"@aztec/epoch-cache": "
|
|
74
|
-
"@aztec/ethereum": "
|
|
75
|
-
"@aztec/foundation": "
|
|
76
|
-
"@aztec/kv-store": "
|
|
77
|
-
"@aztec/p2p": "
|
|
78
|
-
"@aztec/protocol-contracts": "
|
|
79
|
-
"@aztec/prover-client": "
|
|
80
|
-
"@aztec/sequencer-client": "
|
|
81
|
-
"@aztec/simulator": "
|
|
82
|
-
"@aztec/stdlib": "
|
|
83
|
-
"@aztec/telemetry-client": "
|
|
84
|
-
"@aztec/validator-client": "
|
|
85
|
-
"@aztec/world-state": "
|
|
69
|
+
"@aztec/archiver": "6.0.0-nightly.20260603",
|
|
70
|
+
"@aztec/bb-prover": "6.0.0-nightly.20260603",
|
|
71
|
+
"@aztec/blob-client": "6.0.0-nightly.20260603",
|
|
72
|
+
"@aztec/constants": "6.0.0-nightly.20260603",
|
|
73
|
+
"@aztec/epoch-cache": "6.0.0-nightly.20260603",
|
|
74
|
+
"@aztec/ethereum": "6.0.0-nightly.20260603",
|
|
75
|
+
"@aztec/foundation": "6.0.0-nightly.20260603",
|
|
76
|
+
"@aztec/kv-store": "6.0.0-nightly.20260603",
|
|
77
|
+
"@aztec/p2p": "6.0.0-nightly.20260603",
|
|
78
|
+
"@aztec/protocol-contracts": "6.0.0-nightly.20260603",
|
|
79
|
+
"@aztec/prover-client": "6.0.0-nightly.20260603",
|
|
80
|
+
"@aztec/sequencer-client": "6.0.0-nightly.20260603",
|
|
81
|
+
"@aztec/simulator": "6.0.0-nightly.20260603",
|
|
82
|
+
"@aztec/stdlib": "6.0.0-nightly.20260603",
|
|
83
|
+
"@aztec/telemetry-client": "6.0.0-nightly.20260603",
|
|
84
|
+
"@aztec/validator-client": "6.0.0-nightly.20260603",
|
|
85
|
+
"@aztec/world-state": "6.0.0-nightly.20260603",
|
|
86
86
|
"tslib": "^2.4.0"
|
|
87
87
|
},
|
|
88
88
|
"devDependencies": {
|
|
89
|
-
"@aztec/blob-lib": "
|
|
90
|
-
"@aztec/node-keystore": "
|
|
89
|
+
"@aztec/blob-lib": "6.0.0-nightly.20260603",
|
|
90
|
+
"@aztec/node-keystore": "6.0.0-nightly.20260603",
|
|
91
91
|
"@jest/globals": "^30.0.0",
|
|
92
92
|
"@types/jest": "^30.0.0",
|
|
93
93
|
"@types/node": "^22.15.17",
|
|
@@ -1,4 +1,10 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import {
|
|
2
|
+
ARCHIVER_DB_VERSION,
|
|
3
|
+
ARCHIVER_STORE_NAME,
|
|
4
|
+
type ArchiverConfig,
|
|
5
|
+
createArchiverStore,
|
|
6
|
+
getArchiverSynchPoint,
|
|
7
|
+
} from '@aztec/archiver';
|
|
2
8
|
import { INITIAL_L2_BLOCK_NUM } from '@aztec/constants';
|
|
3
9
|
import { type EthereumClientConfig, getPublicClient } from '@aztec/ethereum/client';
|
|
4
10
|
import type { L1ContractsConfig } from '@aztec/ethereum/config';
|
|
@@ -6,6 +12,7 @@ import type { EthAddress } from '@aztec/foundation/eth-address';
|
|
|
6
12
|
import { tryRmDir } from '@aztec/foundation/fs';
|
|
7
13
|
import type { Logger } from '@aztec/foundation/log';
|
|
8
14
|
import { P2P_STORE_NAME } from '@aztec/p2p';
|
|
15
|
+
import { GENESIS_BLOCK_HEADER_HASH } from '@aztec/stdlib/block';
|
|
9
16
|
import type { ChainConfig } from '@aztec/stdlib/config';
|
|
10
17
|
import { DatabaseVersionManager } from '@aztec/stdlib/database-version/manager';
|
|
11
18
|
import { type ReadOnlyFileStore, createReadOnlyFileStore } from '@aztec/stdlib/file-store';
|
|
@@ -30,9 +37,9 @@ const MIN_L1_BLOCKS_TO_TRIGGER_REPLACE = 86400 / 2 / 12;
|
|
|
30
37
|
type SnapshotSyncConfig = Pick<SharedNodeConfig, 'syncMode'> &
|
|
31
38
|
Pick<ChainConfig, 'l1ChainId' | 'rollupVersion'> &
|
|
32
39
|
Pick<L1ContractsConfig, 'aztecEpochDuration'> &
|
|
33
|
-
Pick<ArchiverConfig, 'archiverStoreMapSizeKb'
|
|
40
|
+
Pick<ArchiverConfig, 'archiverStoreMapSizeKb'> &
|
|
34
41
|
DataStoreConfig &
|
|
35
|
-
Required<Pick<DataStoreConfig, '
|
|
42
|
+
Required<Pick<DataStoreConfig, 'rollupAddress'>> &
|
|
36
43
|
EthereumClientConfig & {
|
|
37
44
|
snapshotsUrls?: string[];
|
|
38
45
|
minL1BlocksToTriggerReplace?: number;
|
|
@@ -43,7 +50,7 @@ type SnapshotSyncConfig = Pick<SharedNodeConfig, 'syncMode'> &
|
|
|
43
50
|
* Behaviour depends on syncing mode.
|
|
44
51
|
*/
|
|
45
52
|
export async function trySnapshotSync(config: SnapshotSyncConfig, log: Logger) {
|
|
46
|
-
const { syncMode, snapshotsUrls, dataDirectory, l1ChainId, rollupVersion,
|
|
53
|
+
const { syncMode, snapshotsUrls, dataDirectory, l1ChainId, rollupVersion, rollupAddress } = config;
|
|
47
54
|
if (syncMode === 'full') {
|
|
48
55
|
log.debug('Snapshot sync is disabled. Running full sync.', { syncMode: syncMode });
|
|
49
56
|
return false;
|
|
@@ -59,19 +66,21 @@ export async function trySnapshotSync(config: SnapshotSyncConfig, log: Logger) {
|
|
|
59
66
|
return false;
|
|
60
67
|
}
|
|
61
68
|
|
|
62
|
-
// Create an archiver store to check the current state (do this only once)
|
|
69
|
+
// Create an archiver store to check the current state (do this only once). This temporary store is only
|
|
70
|
+
// read for its sync point and never serves tagged-log queries, so the genesis block hash it carries is
|
|
71
|
+
// immaterial — pass the protocol constant.
|
|
63
72
|
log.verbose(`Creating temporary archiver data store`);
|
|
64
|
-
const archiverStore = await createArchiverStore(config);
|
|
73
|
+
const archiverStore = await createArchiverStore(config, GENESIS_BLOCK_HEADER_HASH);
|
|
65
74
|
let archiverL1BlockNumber: bigint | undefined;
|
|
66
75
|
let archiverL2BlockNumber: number | undefined;
|
|
67
76
|
try {
|
|
68
77
|
[archiverL1BlockNumber, archiverL2BlockNumber] = await Promise.all([
|
|
69
|
-
archiverStore
|
|
70
|
-
archiverStore.
|
|
78
|
+
getArchiverSynchPoint(archiverStore).then(s => s.blocksSynchedTo),
|
|
79
|
+
archiverStore.blocks.getLatestL2BlockNumber(),
|
|
71
80
|
] as const);
|
|
72
81
|
} finally {
|
|
73
82
|
log.verbose(`Closing temporary archiver data store`, { archiverL1BlockNumber, archiverL2BlockNumber });
|
|
74
|
-
await archiverStore.close();
|
|
83
|
+
await archiverStore.db.close();
|
|
75
84
|
}
|
|
76
85
|
|
|
77
86
|
const minL1BlocksToTriggerReplace = config.minL1BlocksToTriggerReplace ?? MIN_L1_BLOCKS_TO_TRIGGER_REPLACE;
|
|
@@ -100,7 +109,7 @@ export async function trySnapshotSync(config: SnapshotSyncConfig, log: Logger) {
|
|
|
100
109
|
const indexMetadata: SnapshotsIndexMetadata = {
|
|
101
110
|
l1ChainId,
|
|
102
111
|
rollupVersion,
|
|
103
|
-
rollupAddress
|
|
112
|
+
rollupAddress,
|
|
104
113
|
};
|
|
105
114
|
|
|
106
115
|
// Fetch latest snapshot from each URL
|
|
@@ -178,7 +187,7 @@ export async function trySnapshotSync(config: SnapshotSyncConfig, log: Logger) {
|
|
|
178
187
|
snapshotCandidates.sort((a, b) => b.snapshot.l1BlockNumber - a.snapshot.l1BlockNumber);
|
|
179
188
|
|
|
180
189
|
// Try each candidate in order until one succeeds
|
|
181
|
-
for (const { snapshot, url } of snapshotCandidates) {
|
|
190
|
+
for (const { snapshot, url, fileStore } of snapshotCandidates) {
|
|
182
191
|
const { l1BlockNumber, l2BlockNumber } = snapshot;
|
|
183
192
|
log.info(`Attempting to sync from snapshot at L1 block ${l1BlockNumber} L2 block ${l2BlockNumber}`, {
|
|
184
193
|
snapshot,
|
|
@@ -188,8 +197,8 @@ export async function trySnapshotSync(config: SnapshotSyncConfig, log: Logger) {
|
|
|
188
197
|
try {
|
|
189
198
|
await snapshotSync(snapshot, log, {
|
|
190
199
|
dataDirectory: config.dataDirectory!,
|
|
191
|
-
rollupAddress: config.
|
|
192
|
-
|
|
200
|
+
rollupAddress: config.rollupAddress,
|
|
201
|
+
fileStore,
|
|
193
202
|
});
|
|
194
203
|
log.info(`Snapshot synced to L1 block ${l1BlockNumber} L2 block ${l2BlockNumber}`, {
|
|
195
204
|
snapshot,
|
|
@@ -215,15 +224,13 @@ export async function trySnapshotSync(config: SnapshotSyncConfig, log: Logger) {
|
|
|
215
224
|
export async function snapshotSync(
|
|
216
225
|
snapshot: Pick<SnapshotMetadata, 'dataUrls'>,
|
|
217
226
|
log: Logger,
|
|
218
|
-
config: { dataDirectory: string; rollupAddress: EthAddress;
|
|
227
|
+
config: { dataDirectory: string; rollupAddress: EthAddress; fileStore: ReadOnlyFileStore },
|
|
219
228
|
) {
|
|
220
|
-
const { dataDirectory, rollupAddress } = config;
|
|
229
|
+
const { dataDirectory, rollupAddress, fileStore } = config;
|
|
221
230
|
if (!dataDirectory) {
|
|
222
231
|
throw new Error(`No local data directory defined. Cannot sync snapshot.`);
|
|
223
232
|
}
|
|
224
233
|
|
|
225
|
-
const fileStore = await createReadOnlyFileStore(config.snapshotsUrl, log);
|
|
226
|
-
|
|
227
234
|
let downloadDir: string | undefined;
|
|
228
235
|
|
|
229
236
|
try {
|
|
@@ -34,7 +34,7 @@ async function createSharedDeps(
|
|
|
34
34
|
|
|
35
35
|
// Note that we do NOT bind them to the rollup address, since we still need to
|
|
36
36
|
// monitor and cancel txs for previous rollups to free up our nonces.
|
|
37
|
-
const noRollupConfig = omit(config, '
|
|
37
|
+
const noRollupConfig = omit(config, 'rollupAddress');
|
|
38
38
|
const kvStore = await createStore(L1_TX_STORE_NAME, L1TxStore.SCHEMA_VERSION, noRollupConfig, logger.getBindings());
|
|
39
39
|
const store = new L1TxStore(kvStore, logger);
|
|
40
40
|
|
|
@@ -92,17 +92,19 @@ export class L1TxMetrics implements IL1TxMetrics {
|
|
|
92
92
|
const attempts = isCancelTx ? state.cancelTxHashes.length : state.txHashes.length;
|
|
93
93
|
this.txAttemptsUntilMined.record(attempts, attributes);
|
|
94
94
|
|
|
95
|
-
// Record gas prices at end state
|
|
96
|
-
const
|
|
97
|
-
const
|
|
98
|
-
const
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
95
|
+
// Record gas prices at end state, converted from wei to gwei to match metric unit definitions
|
|
96
|
+
const weiToGwei = 1e9;
|
|
97
|
+
const maxPriorityFeeGwei = Number(state.gasPrice.maxPriorityFeePerGas) / weiToGwei;
|
|
98
|
+
const maxFeeGwei = Number(state.gasPrice.maxFeePerGas) / weiToGwei;
|
|
99
|
+
const blobFeeGwei = state.gasPrice.maxFeePerBlobGas
|
|
100
|
+
? Number(state.gasPrice.maxFeePerBlobGas) / weiToGwei
|
|
101
|
+
: undefined;
|
|
102
|
+
|
|
103
|
+
this.maxPriorityFeeHistogram.record(maxPriorityFeeGwei, attributes);
|
|
104
|
+
this.maxFeeHistogram.record(maxFeeGwei, attributes);
|
|
105
|
+
|
|
106
|
+
if (blobFeeGwei !== undefined) {
|
|
107
|
+
this.blobFeeHistogram.record(blobFeeGwei, attributes);
|
|
106
108
|
}
|
|
107
109
|
|
|
108
110
|
this.logger.debug(`Recorded tx end state metrics`, {
|
|
@@ -111,9 +113,9 @@ export class L1TxMetrics implements IL1TxMetrics {
|
|
|
111
113
|
isCancelTx,
|
|
112
114
|
isReverted,
|
|
113
115
|
scope: this.scope,
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
116
|
+
maxPriorityFeeGwei,
|
|
117
|
+
maxFeeGwei,
|
|
118
|
+
blobFeeGwei,
|
|
117
119
|
});
|
|
118
120
|
}
|
|
119
121
|
|