@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.
- package/dest/cmds/aztec_node/get_node_info.d.ts +1 -1
- package/dest/cmds/aztec_node/get_node_info.d.ts.map +1 -1
- package/dest/cmds/aztec_node/get_node_info.js +0 -2
- package/dest/cmds/l1/deploy_l1_contracts_cmd.d.ts +1 -1
- package/dest/cmds/l1/deploy_l1_contracts_cmd.d.ts.map +1 -1
- package/dest/cmds/l1/deploy_l1_contracts_cmd.js +0 -1
- package/dest/cmds/l1/deploy_new_rollup.d.ts +1 -1
- package/dest/cmds/l1/deploy_new_rollup.d.ts.map +1 -1
- package/dest/cmds/l1/deploy_new_rollup.js +2 -4
- package/dest/cmds/l1/update_l1_validators.js +5 -5
- package/dest/config/cached_fetch.d.ts +19 -10
- package/dest/config/cached_fetch.d.ts.map +1 -1
- package/dest/config/cached_fetch.js +110 -32
- package/dest/config/chain_l2_config.d.ts +1 -1
- package/dest/config/chain_l2_config.d.ts.map +1 -1
- package/dest/config/chain_l2_config.js +3 -1
- package/dest/config/generated/networks.d.ts +43 -39
- package/dest/config/generated/networks.d.ts.map +1 -1
- package/dest/config/generated/networks.js +44 -40
- package/dest/config/network_config.d.ts +1 -1
- package/dest/config/network_config.d.ts.map +1 -1
- package/dest/config/network_config.js +6 -2
- package/dest/utils/aztec.d.ts +1 -2
- package/dest/utils/aztec.d.ts.map +1 -1
- package/dest/utils/aztec.js +2 -3
- package/package.json +30 -30
- package/src/cmds/aztec_node/get_node_info.ts +0 -2
- package/src/cmds/l1/deploy_l1_contracts_cmd.ts +0 -1
- package/src/cmds/l1/deploy_new_rollup.ts +1 -3
- package/src/cmds/l1/update_l1_validators.ts +5 -5
- package/src/config/cached_fetch.ts +119 -31
- package/src/config/chain_l2_config.ts +3 -1
- package/src/config/generated/networks.ts +42 -38
- package/src/config/network_config.ts +6 -2
- 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,
|
|
3
|
+
import { mkdir, readFile, writeFile } from 'fs/promises';
|
|
4
4
|
import { dirname } from 'path';
|
|
5
5
|
|
|
6
6
|
export interface CachedFetchOptions {
|
|
7
|
-
/**
|
|
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
|
|
15
|
-
*
|
|
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
|
|
19
|
-
* @param
|
|
20
|
-
* @param
|
|
21
|
-
* @returns The fetched and parsed JSON data, or undefined if fetch fails
|
|
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 {
|
|
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
|
|
62
|
+
// Try to read metadata
|
|
63
|
+
let meta: CacheMeta | undefined;
|
|
32
64
|
try {
|
|
33
|
-
|
|
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('
|
|
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
|
-
|
|
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
|
|
101
|
+
return cachedData;
|
|
49
102
|
}
|
|
50
103
|
|
|
51
|
-
|
|
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
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
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
|
-
|
|
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:
|
|
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
|
-
|
|
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:
|
|
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:
|
|
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:
|
|
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
|
-
|
|
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:
|
|
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:
|
|
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:
|
|
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:
|
|
124
|
+
SPONSORED_FPC: false,
|
|
126
125
|
TRANSACTIONS_DISABLED: false,
|
|
127
|
-
|
|
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
|
-
|
|
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:
|
|
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:
|
|
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.
|
|
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:
|
|
186
|
-
AZTEC_PROVING_COST_PER_MANA:
|
|
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:
|
|
193
|
-
|
|
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:
|
|
202
|
+
P2P_MAX_PENDING_TX_COUNT: 1000,
|
|
198
203
|
P2P_TX_POOL_DELETE_TXS_AFTER_REORG: true,
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
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
|
}
|
package/src/utils/aztec.ts
CHANGED
|
@@ -49,7 +49,7 @@ export async function deployNewRollupContracts(
|
|
|
49
49
|
feeJuicePortalInitialBalance: bigint,
|
|
50
50
|
config: L1ContractsConfig,
|
|
51
51
|
realVerifier: boolean,
|
|
52
|
-
): Promise<{ rollup: RollupContract
|
|
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
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
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
|
/**
|