@aztec/cli 0.0.1-commit.e2b2873ed → 0.0.1-commit.e304674f1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (35) hide show
  1. package/dest/cmds/aztec_node/get_node_info.d.ts +1 -1
  2. package/dest/cmds/aztec_node/get_node_info.d.ts.map +1 -1
  3. package/dest/cmds/aztec_node/get_node_info.js +0 -2
  4. package/dest/cmds/l1/deploy_l1_contracts_cmd.d.ts +1 -1
  5. package/dest/cmds/l1/deploy_l1_contracts_cmd.d.ts.map +1 -1
  6. package/dest/cmds/l1/deploy_l1_contracts_cmd.js +0 -1
  7. package/dest/cmds/l1/deploy_new_rollup.d.ts +1 -1
  8. package/dest/cmds/l1/deploy_new_rollup.d.ts.map +1 -1
  9. package/dest/cmds/l1/deploy_new_rollup.js +2 -4
  10. package/dest/cmds/l1/update_l1_validators.js +5 -5
  11. package/dest/config/cached_fetch.d.ts +19 -10
  12. package/dest/config/cached_fetch.d.ts.map +1 -1
  13. package/dest/config/cached_fetch.js +110 -32
  14. package/dest/config/chain_l2_config.d.ts +1 -1
  15. package/dest/config/chain_l2_config.d.ts.map +1 -1
  16. package/dest/config/chain_l2_config.js +3 -1
  17. package/dest/config/generated/networks.d.ts +43 -39
  18. package/dest/config/generated/networks.d.ts.map +1 -1
  19. package/dest/config/generated/networks.js +44 -40
  20. package/dest/config/network_config.d.ts +1 -1
  21. package/dest/config/network_config.d.ts.map +1 -1
  22. package/dest/config/network_config.js +6 -2
  23. package/dest/utils/aztec.d.ts +1 -2
  24. package/dest/utils/aztec.d.ts.map +1 -1
  25. package/dest/utils/aztec.js +2 -3
  26. package/package.json +30 -30
  27. package/src/cmds/aztec_node/get_node_info.ts +0 -2
  28. package/src/cmds/l1/deploy_l1_contracts_cmd.ts +0 -1
  29. package/src/cmds/l1/deploy_new_rollup.ts +1 -3
  30. package/src/cmds/l1/update_l1_validators.ts +5 -5
  31. package/src/config/cached_fetch.ts +119 -31
  32. package/src/config/chain_l2_config.ts +3 -1
  33. package/src/config/generated/networks.ts +42 -38
  34. package/src/config/network_config.ts +6 -2
  35. package/src/utils/aztec.ts +12 -18
@@ -1,24 +1,48 @@
1
1
  import { createLogger } from '@aztec/aztec.js/log';
2
2
 
3
- import { mkdir, readFile, stat, writeFile } from 'fs/promises';
3
+ import { mkdir, readFile, writeFile } from 'fs/promises';
4
4
  import { dirname } from 'path';
5
5
 
6
6
  export interface CachedFetchOptions {
7
- /** Cache duration in milliseconds */
8
- cacheDurationMs: number;
9
- /** The cache file */
7
+ /** The cache file path for storing data. If not provided, no caching is performed. */
10
8
  cacheFile?: string;
9
+ /** Fallback max-age in milliseconds when server sends no Cache-Control header. Defaults to 5 minutes. */
10
+ defaultMaxAgeMs?: number;
11
+ }
12
+
13
+ /** Cache metadata stored in a sidecar .meta file alongside the data file. */
14
+ interface CacheMeta {
15
+ etag?: string;
16
+ expiresAt: number;
17
+ }
18
+
19
+ const DEFAULT_MAX_AGE_MS = 5 * 60 * 1000; // 5 minutes
20
+
21
+ /** Extracts max-age value in milliseconds from a Response's Cache-Control header. Returns undefined if not present. */
22
+ export function parseMaxAge(response: { headers: { get(name: string): string | null } }): number | undefined {
23
+ const cacheControl = response.headers.get('cache-control');
24
+ if (!cacheControl) {
25
+ return undefined;
26
+ }
27
+ const match = cacheControl.match(/max-age=(\d+)/);
28
+ if (!match) {
29
+ return undefined;
30
+ }
31
+ return parseInt(match[1], 10) * 1000;
11
32
  }
12
33
 
13
34
  /**
14
- * Fetches data from a URL with file-based caching support.
15
- * This utility can be used by both remote config and bootnodes fetching.
35
+ * Fetches data from a URL with file-based HTTP conditional caching.
36
+ *
37
+ * Data is stored as raw JSON in the cache file (same format as the server returns).
38
+ * Caching metadata (ETag, expiry) is stored in a separate sidecar `.meta` file.
39
+ * This keeps the data file human-readable and backward-compatible with older code.
16
40
  *
17
41
  * @param url - The URL to fetch from
18
- * @param networkName - Network name for cache directory structure
19
- * @param options - Caching and error handling options
20
- * @param cacheDir - Optional cache directory (defaults to no caching)
21
- * @returns The fetched and parsed JSON data, or undefined if fetch fails and throwOnError is false
42
+ * @param options - Caching options
43
+ * @param fetch - Fetch implementation (defaults to globalThis.fetch)
44
+ * @param log - Logger instance
45
+ * @returns The fetched and parsed JSON data, or undefined if fetch fails
22
46
  */
23
47
  export async function cachedFetch<T = any>(
24
48
  url: string,
@@ -26,42 +50,106 @@ export async function cachedFetch<T = any>(
26
50
  fetch = globalThis.fetch,
27
51
  log = createLogger('cached_fetch'),
28
52
  ): Promise<T | undefined> {
29
- const { cacheDurationMs, cacheFile } = options;
53
+ const { cacheFile, defaultMaxAgeMs = DEFAULT_MAX_AGE_MS } = options;
54
+
55
+ // If no cacheFile, just fetch normally without caching
56
+ if (!cacheFile) {
57
+ return fetchAndParse<T>(url, fetch, log);
58
+ }
59
+
60
+ const metaFile = cacheFile + '.meta';
30
61
 
31
- // Try to read from cache first
62
+ // Try to read metadata
63
+ let meta: CacheMeta | undefined;
32
64
  try {
33
- if (cacheFile) {
34
- const info = await stat(cacheFile);
35
- if (info.mtimeMs + cacheDurationMs > Date.now()) {
36
- const cachedData = JSON.parse(await readFile(cacheFile, 'utf-8'));
37
- return cachedData;
38
- }
39
- }
65
+ meta = JSON.parse(await readFile(metaFile, 'utf-8'));
40
66
  } catch {
41
- log.trace('Failed to read data from cache');
67
+ log.trace('No usable cache metadata found');
42
68
  }
43
69
 
70
+ // Try to read cached data
71
+ let cachedData: T | undefined;
44
72
  try {
45
- const response = await fetch(url);
73
+ cachedData = JSON.parse(await readFile(cacheFile, 'utf-8'));
74
+ } catch {
75
+ log.trace('No usable cached data found');
76
+ }
77
+
78
+ // If metadata and data exist and cache is fresh, return directly
79
+ if (meta && cachedData !== undefined && meta.expiresAt > Date.now()) {
80
+ return cachedData;
81
+ }
82
+
83
+ // Cache is stale or missing — make a (possibly conditional) request
84
+ try {
85
+ const headers: Record<string, string> = {};
86
+ if (meta?.etag && cachedData !== undefined) {
87
+ headers['If-None-Match'] = meta.etag;
88
+ }
89
+
90
+ const response = await fetch(url, { headers });
91
+
92
+ if (response.status === 304 && cachedData !== undefined) {
93
+ // Not modified — recompute expiry from new response headers and return cached data
94
+ const maxAgeMs = parseMaxAge(response) ?? defaultMaxAgeMs;
95
+ await writeMetaFile(metaFile, { etag: meta?.etag, expiresAt: Date.now() + maxAgeMs }, log);
96
+ return cachedData;
97
+ }
98
+
46
99
  if (!response.ok) {
47
100
  log.warn(`Failed to fetch from ${url}: ${response.status} ${response.statusText}`);
48
- return undefined;
101
+ return cachedData;
49
102
  }
50
103
 
51
- const data = await response.json();
104
+ // 200 — parse new data and cache it
105
+ const data = (await response.json()) as T;
106
+ const maxAgeMs = parseMaxAge(response) ?? defaultMaxAgeMs;
107
+ const etag = response.headers.get('etag') ?? undefined;
52
108
 
53
- try {
54
- if (cacheFile) {
55
- await mkdir(dirname(cacheFile), { recursive: true });
56
- await writeFile(cacheFile, JSON.stringify(data), 'utf-8');
57
- }
58
- } catch (err) {
59
- log.warn('Failed to cache data on disk: ' + cacheFile, { cacheFile, err });
60
- }
109
+ await ensureDir(cacheFile, log);
110
+ await Promise.all([
111
+ writeFile(cacheFile, JSON.stringify(data), 'utf-8'),
112
+ writeFile(metaFile, JSON.stringify({ etag, expiresAt: Date.now() + maxAgeMs }), 'utf-8'),
113
+ ]);
61
114
 
62
115
  return data;
116
+ } catch (err) {
117
+ log.warn(`Failed to fetch from ${url}`, { err });
118
+ return cachedData;
119
+ }
120
+ }
121
+
122
+ async function fetchAndParse<T>(
123
+ url: string,
124
+ fetch: typeof globalThis.fetch,
125
+ log: ReturnType<typeof createLogger>,
126
+ ): Promise<T | undefined> {
127
+ try {
128
+ const response = await fetch(url);
129
+ if (!response.ok) {
130
+ log.warn(`Failed to fetch from ${url}: ${response.status} ${response.statusText}`);
131
+ return undefined;
132
+ }
133
+ return (await response.json()) as T;
63
134
  } catch (err) {
64
135
  log.warn(`Failed to fetch from ${url}`, { err });
65
136
  return undefined;
66
137
  }
67
138
  }
139
+
140
+ async function ensureDir(filePath: string, log: ReturnType<typeof createLogger>) {
141
+ try {
142
+ await mkdir(dirname(filePath), { recursive: true });
143
+ } catch (err) {
144
+ log.warn('Failed to create cache directory for: ' + filePath, { err });
145
+ }
146
+ }
147
+
148
+ async function writeMetaFile(metaFile: string, meta: CacheMeta, log: ReturnType<typeof createLogger>) {
149
+ try {
150
+ await mkdir(dirname(metaFile), { recursive: true });
151
+ await writeFile(metaFile, JSON.stringify(meta), 'utf-8');
152
+ } catch (err) {
153
+ log.warn('Failed to write cache metadata: ' + metaFile, { err });
154
+ }
155
+ }
@@ -45,7 +45,9 @@ export function enrichEnvironmentWithChainName(networkName: NetworkNames) {
45
45
  }
46
46
 
47
47
  // Apply generated network config from defaults.yml
48
- const generatedConfig = NetworkConfigs[networkName];
48
+ // For devnet iterations (v4-devnet-1, etc.), use the base devnet config
49
+ const configKey = /^v\d+-devnet-\d+$/.test(networkName) ? 'devnet' : networkName;
50
+ const generatedConfig = NetworkConfigs[configKey];
49
51
  if (generatedConfig) {
50
52
  enrichEnvironmentWithNetworkConfig(generatedConfig);
51
53
  }
@@ -3,7 +3,7 @@
3
3
 
4
4
  export const devnetConfig = {
5
5
  ETHEREUM_SLOT_DURATION: 12,
6
- AZTEC_SLOT_DURATION: 36,
6
+ AZTEC_SLOT_DURATION: 72,
7
7
  AZTEC_TARGET_COMMITTEE_SIZE: 48,
8
8
  AZTEC_ACTIVATION_THRESHOLD: 100000000000000000000,
9
9
  AZTEC_EJECTION_THRESHOLD: 50000000000000000000,
@@ -14,7 +14,7 @@ export const devnetConfig = {
14
14
  AZTEC_MANA_TARGET: 100000000,
15
15
  AZTEC_PROVING_COST_PER_MANA: 100,
16
16
  AZTEC_INITIAL_ETH_PER_FEE_ASSET: 10000000,
17
- AZTEC_SLASHER_FLAVOR: 'tally',
17
+ AZTEC_SLASHER_ENABLED: true,
18
18
  AZTEC_SLASHING_ROUND_SIZE_IN_EPOCHS: 4,
19
19
  AZTEC_SLASHING_LIFETIME_IN_ROUNDS: 5,
20
20
  AZTEC_SLASHING_OFFSET_IN_ROUNDS: 2,
@@ -24,15 +24,15 @@ export const devnetConfig = {
24
24
  AZTEC_SLASH_AMOUNT_MEDIUM: 20000000000000000000,
25
25
  AZTEC_SLASH_AMOUNT_LARGE: 50000000000000000000,
26
26
  AZTEC_GOVERNANCE_PROPOSER_ROUND_SIZE: 300,
27
- SLASH_MIN_PENALTY_PERCENTAGE: 0.5,
28
- SLASH_MAX_PENALTY_PERCENTAGE: 2,
29
27
  SLASH_OFFENSE_EXPIRATION_ROUNDS: 4,
30
- SLASH_MAX_PAYLOAD_SIZE: 50,
28
+ SLASH_MAX_PAYLOAD_SIZE: 80,
31
29
  SLASH_EXECUTE_ROUNDS_LOOK_BACK: 4,
32
30
  P2P_ENABLED: true,
33
31
  BOOTSTRAP_NODES: '',
34
- SEQ_MIN_TX_PER_BLOCK: 0,
32
+ SEQ_MIN_TX_PER_BLOCK: 1,
35
33
  SEQ_BUILD_CHECKPOINT_IF_EMPTY: true,
34
+ SEQ_BLOCK_DURATION_MS: 6000,
35
+ SEQ_L1_PUBLISHING_TIME_ALLOWANCE_IN_SLOT: 36,
36
36
  DATA_STORE_MAP_SIZE_KB: 134217728,
37
37
  ARCHIVER_STORE_MAP_SIZE_KB: 1073741824,
38
38
  NOTE_HASH_TREE_MAP_SIZE_KB: 1073741824,
@@ -48,7 +48,7 @@ export const devnetConfig = {
48
48
  TEST_ACCOUNTS: true,
49
49
  SPONSORED_FPC: true,
50
50
  TRANSACTIONS_DISABLED: false,
51
- SEQ_MAX_TX_PER_BLOCK: 32,
51
+ SEQ_MAX_TX_PER_BLOCK: 18,
52
52
  PROVER_REAL_PROOFS: false,
53
53
  PXE_PROVER_ENABLED: false,
54
54
  SYNC_SNAPSHOTS_URLS: '',
@@ -56,8 +56,6 @@ export const devnetConfig = {
56
56
  BLOB_ALLOW_EMPTY_SOURCES: false,
57
57
  P2P_MAX_PENDING_TX_COUNT: 1000,
58
58
  P2P_TX_POOL_DELETE_TXS_AFTER_REORG: false,
59
- AUTO_UPDATE: 'none',
60
- AUTO_UPDATE_URL: '',
61
59
  PUBLIC_OTEL_OPT_OUT: true,
62
60
  PUBLIC_OTEL_EXPORTER_OTLP_METRICS_ENDPOINT: '',
63
61
  PUBLIC_OTEL_COLLECT_FROM: '',
@@ -73,6 +71,7 @@ export const devnetConfig = {
73
71
  SLASH_UNKNOWN_PENALTY: 10000000000000000000,
74
72
  SLASH_INVALID_BLOCK_PENALTY: 10000000000000000000,
75
73
  SLASH_GRACE_PERIOD_L2_SLOTS: 0,
74
+ ENABLE_VERSION_CHECK: true,
76
75
  } as const;
77
76
 
78
77
  export const testnetConfig = {
@@ -84,25 +83,21 @@ export const testnetConfig = {
84
83
  AZTEC_EXIT_DELAY_SECONDS: 172800,
85
84
  AZTEC_INBOX_LAG: 1,
86
85
  AZTEC_PROOF_SUBMISSION_EPOCHS: 1,
87
- AZTEC_PROVING_COST_PER_MANA: 100,
88
86
  AZTEC_INITIAL_ETH_PER_FEE_ASSET: 10000000,
89
- AZTEC_SLASHER_FLAVOR: 'tally',
87
+ AZTEC_SLASHER_ENABLED: true,
90
88
  AZTEC_SLASHING_ROUND_SIZE_IN_EPOCHS: 4,
91
89
  AZTEC_SLASHING_LIFETIME_IN_ROUNDS: 5,
92
90
  AZTEC_SLASHING_OFFSET_IN_ROUNDS: 2,
93
91
  AZTEC_SLASHING_DISABLE_DURATION: 432000,
94
- AZTEC_SLASH_AMOUNT_SMALL: 10000000000000000000,
95
- AZTEC_SLASH_AMOUNT_MEDIUM: 20000000000000000000,
96
- AZTEC_SLASH_AMOUNT_LARGE: 50000000000000000000,
97
- SLASH_MIN_PENALTY_PERCENTAGE: 0.5,
98
- SLASH_MAX_PENALTY_PERCENTAGE: 2,
99
92
  SLASH_OFFENSE_EXPIRATION_ROUNDS: 4,
100
- SLASH_MAX_PAYLOAD_SIZE: 50,
93
+ SLASH_MAX_PAYLOAD_SIZE: 80,
101
94
  SLASH_EXECUTE_ROUNDS_LOOK_BACK: 4,
102
95
  P2P_ENABLED: true,
103
96
  BOOTSTRAP_NODES: '',
104
- SEQ_MIN_TX_PER_BLOCK: 0,
97
+ SEQ_MIN_TX_PER_BLOCK: 1,
105
98
  SEQ_BUILD_CHECKPOINT_IF_EMPTY: true,
99
+ SEQ_BLOCK_DURATION_MS: 6000,
100
+ SEQ_L1_PUBLISHING_TIME_ALLOWANCE_IN_SLOT: 36,
106
101
  DATA_STORE_MAP_SIZE_KB: 134217728,
107
102
  ARCHIVER_STORE_MAP_SIZE_KB: 1073741824,
108
103
  NOTE_HASH_TREE_MAP_SIZE_KB: 1073741824,
@@ -119,13 +114,18 @@ export const testnetConfig = {
119
114
  AZTEC_SLASHING_QUORUM: 33,
120
115
  AZTEC_GOVERNANCE_PROPOSER_ROUND_SIZE: 100,
121
116
  AZTEC_GOVERNANCE_PROPOSER_QUORUM: 60,
122
- AZTEC_MANA_TARGET: 150000000,
117
+ AZTEC_MANA_TARGET: 75000000,
118
+ AZTEC_PROVING_COST_PER_MANA: 25000000,
119
+ AZTEC_SLASH_AMOUNT_SMALL: 1E+23,
120
+ AZTEC_SLASH_AMOUNT_MEDIUM: 1E+23,
121
+ AZTEC_SLASH_AMOUNT_LARGE: 1E+23,
123
122
  L1_CHAIN_ID: 11155111,
124
123
  TEST_ACCOUNTS: false,
125
- SPONSORED_FPC: true,
124
+ SPONSORED_FPC: false,
126
125
  TRANSACTIONS_DISABLED: false,
127
- SEQ_MAX_TX_PER_BLOCK: 8,
126
+ SEQ_MAX_TX_PER_CHECKPOINT: 72,
128
127
  PROVER_REAL_PROOFS: true,
128
+ P2P_MAX_PENDING_TX_COUNT: 1000,
129
129
  P2P_TX_POOL_DELETE_TXS_AFTER_REORG: true,
130
130
  SLASH_PRUNE_PENALTY: 10000000000000000000,
131
131
  SLASH_DATA_WITHHOLDING_PENALTY: 10000000000000000000,
@@ -139,28 +139,30 @@ export const testnetConfig = {
139
139
  SLASH_UNKNOWN_PENALTY: 10000000000000000000,
140
140
  SLASH_INVALID_BLOCK_PENALTY: 10000000000000000000,
141
141
  SLASH_GRACE_PERIOD_L2_SLOTS: 64,
142
+ ENABLE_VERSION_CHECK: true,
142
143
  } as const;
143
144
 
144
145
  export const mainnetConfig = {
145
146
  ETHEREUM_SLOT_DURATION: 12,
146
147
  AZTEC_EPOCH_DURATION: 32,
148
+ AZTEC_TARGET_COMMITTEE_SIZE: 48,
147
149
  AZTEC_LAG_IN_EPOCHS_FOR_VALIDATOR_SET: 2,
148
150
  AZTEC_LAG_IN_EPOCHS_FOR_RANDAO: 2,
149
151
  AZTEC_INBOX_LAG: 1,
150
152
  AZTEC_PROOF_SUBMISSION_EPOCHS: 1,
151
153
  AZTEC_INITIAL_ETH_PER_FEE_ASSET: 10000000,
152
- AZTEC_SLASHER_FLAVOR: 'tally',
154
+ AZTEC_SLASHER_ENABLED: true,
153
155
  AZTEC_SLASHING_ROUND_SIZE_IN_EPOCHS: 4,
154
156
  AZTEC_SLASHING_OFFSET_IN_ROUNDS: 2,
155
- SLASH_MIN_PENALTY_PERCENTAGE: 0.5,
156
- SLASH_MAX_PENALTY_PERCENTAGE: 2,
157
157
  SLASH_OFFENSE_EXPIRATION_ROUNDS: 4,
158
- SLASH_MAX_PAYLOAD_SIZE: 50,
158
+ SLASH_MAX_PAYLOAD_SIZE: 80,
159
159
  SLASH_EXECUTE_ROUNDS_LOOK_BACK: 4,
160
160
  P2P_ENABLED: true,
161
161
  BOOTSTRAP_NODES: '',
162
- SEQ_MIN_TX_PER_BLOCK: 0,
162
+ SEQ_MIN_TX_PER_BLOCK: 1,
163
163
  SEQ_BUILD_CHECKPOINT_IF_EMPTY: true,
164
+ SEQ_BLOCK_DURATION_MS: 6000,
165
+ SEQ_L1_PUBLISHING_TIME_ALLOWANCE_IN_SLOT: 36,
164
166
  DATA_STORE_MAP_SIZE_KB: 134217728,
165
167
  ARCHIVER_STORE_MAP_SIZE_KB: 1073741824,
166
168
  NOTE_HASH_TREE_MAP_SIZE_KB: 1073741824,
@@ -169,10 +171,9 @@ export const mainnetConfig = {
169
171
  PUBLIC_OTEL_INCLUDE_METRICS: 'aztec.validator,aztec.tx_collector,aztec.mempool,aztec.p2p.gossip.agg_,aztec.ivc_verifier.agg_',
170
172
  SENTINEL_ENABLED: true,
171
173
  AZTEC_SLOT_DURATION: 72,
172
- AZTEC_TARGET_COMMITTEE_SIZE: 24,
173
174
  AZTEC_ACTIVATION_THRESHOLD: 2E+23,
174
175
  AZTEC_EJECTION_THRESHOLD: 1E+23,
175
- AZTEC_LOCAL_EJECTION_THRESHOLD: 1.96E+23,
176
+ AZTEC_LOCAL_EJECTION_THRESHOLD: 1.9E+23,
176
177
  AZTEC_SLASH_AMOUNT_SMALL: 2E+21,
177
178
  AZTEC_SLASH_AMOUNT_MEDIUM: 2E+21,
178
179
  AZTEC_SLASH_AMOUNT_LARGE: 2E+21,
@@ -182,24 +183,27 @@ export const mainnetConfig = {
182
183
  AZTEC_SLASHING_QUORUM: 65,
183
184
  AZTEC_GOVERNANCE_PROPOSER_QUORUM: 600,
184
185
  AZTEC_GOVERNANCE_PROPOSER_ROUND_SIZE: 1000,
185
- AZTEC_MANA_TARGET: 0,
186
- AZTEC_PROVING_COST_PER_MANA: 0,
186
+ AZTEC_MANA_TARGET: 75000000,
187
+ AZTEC_PROVING_COST_PER_MANA: 25000000,
187
188
  AZTEC_EXIT_DELAY_SECONDS: 345600,
188
189
  AZTEC_SLASHING_DISABLE_DURATION: 259200,
190
+ AZTEC_ENTRY_QUEUE_BOOTSTRAP_VALIDATOR_SET_SIZE: 500,
191
+ AZTEC_ENTRY_QUEUE_BOOTSTRAP_FLUSH_SIZE: 500,
192
+ AZTEC_ENTRY_QUEUE_FLUSH_SIZE_MIN: 1,
193
+ AZTEC_ENTRY_QUEUE_FLUSH_SIZE_QUOTIENT: 400,
194
+ AZTEC_ENTRY_QUEUE_MAX_FLUSH_SIZE: 4,
189
195
  L1_CHAIN_ID: 1,
190
196
  TEST_ACCOUNTS: false,
191
197
  SPONSORED_FPC: false,
192
- TRANSACTIONS_DISABLED: true,
193
- SEQ_MAX_TX_PER_BLOCK: 0,
198
+ TRANSACTIONS_DISABLED: false,
199
+ SEQ_MAX_TX_PER_CHECKPOINT: 72,
194
200
  PROVER_REAL_PROOFS: true,
195
- SYNC_SNAPSHOTS_URLS: 'https://aztec-labs-snapshots.com/mainnet/',
196
201
  BLOB_ALLOW_EMPTY_SOURCES: true,
197
- P2P_MAX_PENDING_TX_COUNT: 0,
202
+ P2P_MAX_PENDING_TX_COUNT: 1000,
198
203
  P2P_TX_POOL_DELETE_TXS_AFTER_REORG: true,
199
- AUTO_UPDATE: 'notify',
200
- AUTO_UPDATE_URL: 'https://storage.googleapis.com/aztec-mainnet/auto-update/mainnet.json',
201
- PUBLIC_OTEL_EXPORTER_OTLP_METRICS_ENDPOINT: 'https://telemetry.alpha-testnet.aztec-labs.com/v1/metrics',
202
- PUBLIC_OTEL_COLLECT_FROM: 'sequencer',
204
+ PUBLIC_OTEL_EXPORTER_OTLP_METRICS_ENDPOINT: '',
205
+ PUBLIC_OTEL_COLLECT_FROM: '',
206
+ ENABLE_VERSION_CHECK: false,
203
207
  SLASH_PRUNE_PENALTY: 0,
204
208
  SLASH_DATA_WITHHOLDING_PENALTY: 0,
205
209
  SLASH_INACTIVITY_TARGET_PERCENTAGE: 0.8,
@@ -9,7 +9,6 @@ import { enrichEthAddressVar, enrichVar } from './enrich_env.js';
9
9
  const DEFAULT_CONFIG_URL =
10
10
  'https://raw.githubusercontent.com/AztecProtocol/networks/refs/heads/main/network_config.json';
11
11
  const FALLBACK_CONFIG_URL = 'https://metadata.aztec.network/network_config.json';
12
- const NETWORK_CONFIG_CACHE_DURATION_MS = 60 * 60 * 1000; // 1 hour
13
12
 
14
13
  /**
15
14
  * Fetches remote network configuration from GitHub with caching support.
@@ -87,7 +86,6 @@ async function fetchNetworkConfigFromUrl(
87
86
 
88
87
  if (url.protocol === 'http:' || url.protocol === 'https:') {
89
88
  rawConfig = await cachedFetch(url.href, {
90
- cacheDurationMs: NETWORK_CONFIG_CACHE_DURATION_MS,
91
89
  cacheFile: cacheDir ? join(cacheDir, networkName, 'network_config.json') : undefined,
92
90
  });
93
91
  } else if (url.protocol === 'file:') {
@@ -141,7 +139,13 @@ export async function enrichEnvironmentWithNetworkConfig(networkName: NetworkNam
141
139
  if (networkConfig.blobFileStoreUrls?.length) {
142
140
  enrichVar('BLOB_FILE_STORE_URLS', networkConfig.blobFileStoreUrls.join(','));
143
141
  }
142
+ if (networkConfig.txCollectionFileStoreUrls?.length) {
143
+ enrichVar('TX_COLLECTION_FILE_STORE_URLS', networkConfig.txCollectionFileStoreUrls.join(','));
144
+ }
144
145
  if (networkConfig.blockDurationMs !== undefined) {
145
146
  enrichVar('SEQ_BLOCK_DURATION_MS', String(networkConfig.blockDurationMs));
146
147
  }
148
+ if (networkConfig.txPublicSetupAllowListExtend) {
149
+ enrichVar('TX_PUBLIC_SETUP_ALLOWLIST', networkConfig.txPublicSetupAllowListExtend);
150
+ }
147
151
  }
@@ -49,7 +49,7 @@ export async function deployNewRollupContracts(
49
49
  feeJuicePortalInitialBalance: bigint,
50
50
  config: L1ContractsConfig,
51
51
  realVerifier: boolean,
52
- ): Promise<{ rollup: RollupContract; slashFactoryAddress: EthAddress }> {
52
+ ): Promise<{ rollup: RollupContract }> {
53
53
  const { deployRollupForUpgrade } = await import('@aztec/ethereum/deploy-aztec-l1-contracts');
54
54
  const { mnemonicToAccount, privateKeyToAccount } = await import('viem/accounts');
55
55
  const { getVKTreeRoot } = await import('@aztec/noir-protocol-circuits-types/vk-tree');
@@ -80,23 +80,17 @@ export async function deployNewRollupContracts(
80
80
  logger.info('Initializing new rollup with old attesters', { initialValidators });
81
81
  }
82
82
 
83
- const { rollup, slashFactoryAddress } = await deployRollupForUpgrade(
84
- privateKey as Hex,
85
- rpcUrls[0],
86
- chainId,
87
- registryAddress,
88
- {
89
- vkTreeRoot: getVKTreeRoot(),
90
- protocolContractsHash,
91
- genesisArchiveRoot,
92
- initialValidators,
93
- feeJuicePortalInitialBalance,
94
- realVerifier,
95
- ...config,
96
- },
97
- );
98
-
99
- return { rollup, slashFactoryAddress: EthAddress.fromString(slashFactoryAddress!) };
83
+ const { rollup } = await deployRollupForUpgrade(privateKey as Hex, rpcUrls[0], chainId, registryAddress, {
84
+ vkTreeRoot: getVKTreeRoot(),
85
+ protocolContractsHash,
86
+ genesisArchiveRoot,
87
+ initialValidators,
88
+ feeJuicePortalInitialBalance,
89
+ realVerifier,
90
+ ...config,
91
+ });
92
+
93
+ return { rollup };
100
94
  }
101
95
 
102
96
  /**