@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.
@@ -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' | 'maxLogs'> & DataStoreConfig & Required<Pick<DataStoreConfig, 'l1Contracts'>> & EthereumClientConfig & {
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
- snapshotsUrl: string;
26
+ fileStore: ReadOnlyFileStore;
26
27
  }): Promise<void>;
27
28
  export {};
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic25hcHNob3Qtc3luYy5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2FjdGlvbnMvc25hcHNob3Qtc3luYy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQTRDLEtBQUssY0FBYyxFQUF1QixNQUFNLGlCQUFpQixDQUFDO0FBRXJILE9BQU8sRUFBRSxLQUFLLG9CQUFvQixFQUFtQixNQUFNLHdCQUF3QixDQUFDO0FBQ3BGLE9BQU8sS0FBSyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDaEUsT0FBTyxLQUFLLEVBQUUsVUFBVSxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFFaEUsT0FBTyxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFFcEQsT0FBTyxLQUFLLEVBQUUsV0FBVyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFHeEQsT0FBTyxLQUFLLEVBQUUsZUFBZSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDOUQsT0FBTyxFQUNMLEtBQUssZ0JBQWdCLEVBS3RCLE1BQU0seUJBQXlCLENBQUM7QUFNakMsT0FBTyxLQUFLLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUszRCxLQUFLLGtCQUFrQixHQUFHLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxVQUFVLENBQUMsR0FDMUQsSUFBSSxDQUFDLFdBQVcsRUFBRSxXQUFXLEdBQUcsZUFBZSxDQUFDLEdBQ2hELElBQUksQ0FBQyxpQkFBaUIsRUFBRSxvQkFBb0IsQ0FBQyxHQUM3QyxJQUFJLENBQUMsY0FBYyxFQUFFLHdCQUF3QixHQUFHLFNBQVMsQ0FBQyxHQUMxRCxlQUFlLEdBQ2YsUUFBUSxDQUFDLElBQUksQ0FBQyxlQUFlLEVBQUUsYUFBYSxDQUFDLENBQUMsR0FDOUMsb0JBQW9CLEdBQUc7SUFDckIsYUFBYSxDQUFDLEVBQUUsTUFBTSxFQUFFLENBQUM7SUFDekIsMkJBQTJCLENBQUMsRUFBRSxNQUFNLENBQUM7Q0FDdEMsQ0FBQztBQUVKOzs7R0FHRztBQUNILHdCQUFzQixlQUFlLENBQUMsTUFBTSxFQUFFLGtCQUFrQixFQUFFLEdBQUcsRUFBRSxNQUFNLG9CQXFLNUU7QUFFRDs7R0FFRztBQUNILHdCQUFzQixZQUFZLENBQ2hDLFFBQVEsRUFBRSxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsVUFBVSxDQUFDLEVBQzVDLEdBQUcsRUFBRSxNQUFNLEVBQ1gsTUFBTSxFQUFFO0lBQUUsYUFBYSxFQUFFLE1BQU0sQ0FBQztJQUFDLGFBQWEsRUFBRSxVQUFVLENBQUM7SUFBQyxZQUFZLEVBQUUsTUFBTSxDQUFBO0NBQUUsaUJBcURuRiJ9
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,EAA4C,KAAK,cAAc,EAAuB,MAAM,iBAAiB,CAAC;AAErH,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;AAEpD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAGxD,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,GAAG,SAAS,CAAC,GAC1D,eAAe,GACf,QAAQ,CAAC,IAAI,CAAC,eAAe,EAAE,aAAa,CAAC,CAAC,GAC9C,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,oBAqK5E;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,YAAY,EAAE,MAAM,CAAA;CAAE,iBAqDnF"}
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, l1Contracts } = config;
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.getSynchPoint().then((s)=>s.blocksSynchedTo),
41
- archiverStore.getLatestBlockNumber()
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: l1Contracts.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.l1Contracts.rollupAddress,
145
- snapshotsUrl: url
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, 'l1Contracts');
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibDFfdHhfbWV0cmljcy5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL21ldHJpY3MvbDFfdHhfbWV0cmljcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssRUFBRSxZQUFZLEVBQUUsU0FBUyxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFHM0UsT0FBTyxFQUdMLEtBQUssS0FBSyxFQUlYLE1BQU0seUJBQXlCLENBQUM7QUFFakMsTUFBTSxNQUFNLFNBQVMsR0FBRyxXQUFXLEdBQUcsUUFBUSxHQUFHLE9BQU8sQ0FBQztBQUV6RDs7R0FFRztBQUNILHFCQUFhLFdBQVksWUFBVyxZQUFZO0lBbUI1QyxPQUFPLENBQUMsS0FBSztJQUNiLE9BQU8sQ0FBQyxLQUFLO0lBQ2IsT0FBTyxDQUFDLE1BQU07SUFuQmhCLE9BQU8sQ0FBQyxlQUFlLENBQVk7SUFHbkMsT0FBTyxDQUFDLG9CQUFvQixDQUFZO0lBR3hDLE9BQU8sQ0FBQyxZQUFZLENBQWdCO0lBQ3BDLE9BQU8sQ0FBQyxlQUFlLENBQWdCO0lBQ3ZDLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBZ0I7SUFDeEMsT0FBTyxDQUFDLGVBQWUsQ0FBZ0I7SUFHdkMsT0FBTyxDQUFDLHVCQUF1QixDQUFZO0lBQzNDLE9BQU8sQ0FBQyxlQUFlLENBQVk7SUFDbkMsT0FBTyxDQUFDLGdCQUFnQixDQUFZO0lBRXBDLFlBQ1UsS0FBSyxFQUFFLEtBQUssRUFDWixLQUFLLEdBQUUsU0FBbUIsRUFDMUIsTUFBTSx5Q0FBc0MsRUFvQnJEO0lBRUQ7Ozs7T0FJRztJQUNJLGFBQWEsQ0FBQyxLQUFLLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxJQUFJLEdBQUcsSUFBSSxDQW9EOUQ7SUFFTSxlQUFlLENBQUMsS0FBSyxFQUFFLFNBQVMsR0FBRyxJQUFJLENBaUI3QztDQUNGIn0=
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,CAoD9D;IAEM,eAAe,CAAC,KAAK,EAAE,SAAS,GAAG,IAAI,CAiB7C;CACF"}
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 (in wei as integers)
73
- const maxPriorityFeeWei = Number(state.gasPrice.maxPriorityFeePerGas);
74
- const maxFeeWei = Number(state.gasPrice.maxFeePerGas);
75
- const blobFeeWei = state.gasPrice.maxFeePerBlobGas ? Number(state.gasPrice.maxFeePerBlobGas) : undefined;
76
- this.maxPriorityFeeHistogram.record(maxPriorityFeeWei, attributes);
77
- this.maxFeeHistogram.record(maxFeeWei, attributes);
78
- // Record blob fee if present (in wei as integer)
79
- if (blobFeeWei !== undefined) {
80
- this.blobFeeHistogram.record(blobFeeWei, attributes);
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
- maxPriorityFeeWei,
89
- maxFeeWei,
90
- blobFeeWei
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": "5.0.0-private.20260319",
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": "5.0.0-private.20260319",
70
- "@aztec/bb-prover": "5.0.0-private.20260319",
71
- "@aztec/blob-client": "5.0.0-private.20260319",
72
- "@aztec/constants": "5.0.0-private.20260319",
73
- "@aztec/epoch-cache": "5.0.0-private.20260319",
74
- "@aztec/ethereum": "5.0.0-private.20260319",
75
- "@aztec/foundation": "5.0.0-private.20260319",
76
- "@aztec/kv-store": "5.0.0-private.20260319",
77
- "@aztec/p2p": "5.0.0-private.20260319",
78
- "@aztec/protocol-contracts": "5.0.0-private.20260319",
79
- "@aztec/prover-client": "5.0.0-private.20260319",
80
- "@aztec/sequencer-client": "5.0.0-private.20260319",
81
- "@aztec/simulator": "5.0.0-private.20260319",
82
- "@aztec/stdlib": "5.0.0-private.20260319",
83
- "@aztec/telemetry-client": "5.0.0-private.20260319",
84
- "@aztec/validator-client": "5.0.0-private.20260319",
85
- "@aztec/world-state": "5.0.0-private.20260319",
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": "5.0.0-private.20260319",
90
- "@aztec/node-keystore": "5.0.0-private.20260319",
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 { ARCHIVER_DB_VERSION, ARCHIVER_STORE_NAME, type ArchiverConfig, createArchiverStore } from '@aztec/archiver';
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' | 'maxLogs'> &
40
+ Pick<ArchiverConfig, 'archiverStoreMapSizeKb'> &
34
41
  DataStoreConfig &
35
- Required<Pick<DataStoreConfig, 'l1Contracts'>> &
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, l1Contracts } = config;
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.getSynchPoint().then(s => s.blocksSynchedTo),
70
- archiverStore.getLatestBlockNumber(),
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: l1Contracts.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.l1Contracts.rollupAddress,
192
- snapshotsUrl: url,
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; snapshotsUrl: string },
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, 'l1Contracts');
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 (in wei as integers)
96
- const maxPriorityFeeWei = Number(state.gasPrice.maxPriorityFeePerGas);
97
- const maxFeeWei = Number(state.gasPrice.maxFeePerGas);
98
- const blobFeeWei = state.gasPrice.maxFeePerBlobGas ? Number(state.gasPrice.maxFeePerBlobGas) : undefined;
99
-
100
- this.maxPriorityFeeHistogram.record(maxPriorityFeeWei, attributes);
101
- this.maxFeeHistogram.record(maxFeeWei, attributes);
102
-
103
- // Record blob fee if present (in wei as integer)
104
- if (blobFeeWei !== undefined) {
105
- this.blobFeeHistogram.record(blobFeeWei, attributes);
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
- maxPriorityFeeWei,
115
- maxFeeWei,
116
- blobFeeWei,
116
+ maxPriorityFeeGwei,
117
+ maxFeeGwei,
118
+ blobFeeGwei,
117
119
  });
118
120
  }
119
121