@aztec/cli 0.0.1-commit.e558bd1c → 0.0.1-commit.e588bc7e5
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/infrastructure/setup_l2_contract.d.ts +1 -1
- package/dest/cmds/infrastructure/setup_l2_contract.d.ts.map +1 -1
- package/dest/cmds/infrastructure/setup_l2_contract.js +3 -2
- 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 -30
- package/dest/config/generated/networks.d.ts.map +1 -1
- package/dest/config/generated/networks.js +44 -31
- 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/package.json +30 -30
- package/src/cmds/infrastructure/setup_l2_contract.ts +4 -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 -29
- package/src/config/network_config.ts +6 -2
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
// Do not edit manually - run yarn generate to regenerate
|
|
3
3
|
export const devnetConfig = {
|
|
4
4
|
ETHEREUM_SLOT_DURATION: 12,
|
|
5
|
-
AZTEC_SLOT_DURATION:
|
|
5
|
+
AZTEC_SLOT_DURATION: 72,
|
|
6
6
|
AZTEC_TARGET_COMMITTEE_SIZE: 48,
|
|
7
7
|
AZTEC_ACTIVATION_THRESHOLD: 100000000000000000000,
|
|
8
8
|
AZTEC_EJECTION_THRESHOLD: 50000000000000000000,
|
|
@@ -26,12 +26,14 @@ export const devnetConfig = {
|
|
|
26
26
|
SLASH_MIN_PENALTY_PERCENTAGE: 0.5,
|
|
27
27
|
SLASH_MAX_PENALTY_PERCENTAGE: 2,
|
|
28
28
|
SLASH_OFFENSE_EXPIRATION_ROUNDS: 4,
|
|
29
|
-
SLASH_MAX_PAYLOAD_SIZE:
|
|
29
|
+
SLASH_MAX_PAYLOAD_SIZE: 80,
|
|
30
30
|
SLASH_EXECUTE_ROUNDS_LOOK_BACK: 4,
|
|
31
31
|
P2P_ENABLED: true,
|
|
32
32
|
BOOTSTRAP_NODES: '',
|
|
33
|
-
SEQ_MIN_TX_PER_BLOCK:
|
|
33
|
+
SEQ_MIN_TX_PER_BLOCK: 1,
|
|
34
34
|
SEQ_BUILD_CHECKPOINT_IF_EMPTY: true,
|
|
35
|
+
SEQ_BLOCK_DURATION_MS: 6000,
|
|
36
|
+
SEQ_L1_PUBLISHING_TIME_ALLOWANCE_IN_SLOT: 36,
|
|
35
37
|
DATA_STORE_MAP_SIZE_KB: 134217728,
|
|
36
38
|
ARCHIVER_STORE_MAP_SIZE_KB: 1073741824,
|
|
37
39
|
NOTE_HASH_TREE_MAP_SIZE_KB: 1073741824,
|
|
@@ -47,7 +49,7 @@ export const devnetConfig = {
|
|
|
47
49
|
TEST_ACCOUNTS: true,
|
|
48
50
|
SPONSORED_FPC: true,
|
|
49
51
|
TRANSACTIONS_DISABLED: false,
|
|
50
|
-
SEQ_MAX_TX_PER_BLOCK:
|
|
52
|
+
SEQ_MAX_TX_PER_BLOCK: 18,
|
|
51
53
|
PROVER_REAL_PROOFS: false,
|
|
52
54
|
PXE_PROVER_ENABLED: false,
|
|
53
55
|
SYNC_SNAPSHOTS_URLS: '',
|
|
@@ -55,8 +57,6 @@ export const devnetConfig = {
|
|
|
55
57
|
BLOB_ALLOW_EMPTY_SOURCES: false,
|
|
56
58
|
P2P_MAX_PENDING_TX_COUNT: 1000,
|
|
57
59
|
P2P_TX_POOL_DELETE_TXS_AFTER_REORG: false,
|
|
58
|
-
AUTO_UPDATE: 'none',
|
|
59
|
-
AUTO_UPDATE_URL: '',
|
|
60
60
|
PUBLIC_OTEL_OPT_OUT: true,
|
|
61
61
|
PUBLIC_OTEL_EXPORTER_OTLP_METRICS_ENDPOINT: '',
|
|
62
62
|
PUBLIC_OTEL_COLLECT_FROM: '',
|
|
@@ -67,10 +67,12 @@ export const devnetConfig = {
|
|
|
67
67
|
SLASH_INACTIVITY_PENALTY: 10000000000000000000,
|
|
68
68
|
SLASH_PROPOSE_INVALID_ATTESTATIONS_PENALTY: 10000000000000000000,
|
|
69
69
|
SLASH_DUPLICATE_PROPOSAL_PENALTY: 10000000000000000000,
|
|
70
|
+
SLASH_DUPLICATE_ATTESTATION_PENALTY: 10000000000000000000,
|
|
70
71
|
SLASH_ATTEST_DESCENDANT_OF_INVALID_PENALTY: 10000000000000000000,
|
|
71
72
|
SLASH_UNKNOWN_PENALTY: 10000000000000000000,
|
|
72
73
|
SLASH_INVALID_BLOCK_PENALTY: 10000000000000000000,
|
|
73
|
-
SLASH_GRACE_PERIOD_L2_SLOTS: 0
|
|
74
|
+
SLASH_GRACE_PERIOD_L2_SLOTS: 0,
|
|
75
|
+
ENABLE_VERSION_CHECK: true
|
|
74
76
|
};
|
|
75
77
|
export const testnetConfig = {
|
|
76
78
|
ETHEREUM_SLOT_DURATION: 12,
|
|
@@ -81,25 +83,23 @@ export const testnetConfig = {
|
|
|
81
83
|
AZTEC_EXIT_DELAY_SECONDS: 172800,
|
|
82
84
|
AZTEC_INBOX_LAG: 1,
|
|
83
85
|
AZTEC_PROOF_SUBMISSION_EPOCHS: 1,
|
|
84
|
-
AZTEC_PROVING_COST_PER_MANA: 100,
|
|
85
86
|
AZTEC_INITIAL_ETH_PER_FEE_ASSET: 10000000,
|
|
86
87
|
AZTEC_SLASHER_FLAVOR: 'tally',
|
|
87
88
|
AZTEC_SLASHING_ROUND_SIZE_IN_EPOCHS: 4,
|
|
88
89
|
AZTEC_SLASHING_LIFETIME_IN_ROUNDS: 5,
|
|
89
90
|
AZTEC_SLASHING_OFFSET_IN_ROUNDS: 2,
|
|
90
91
|
AZTEC_SLASHING_DISABLE_DURATION: 432000,
|
|
91
|
-
AZTEC_SLASH_AMOUNT_SMALL: 10000000000000000000,
|
|
92
|
-
AZTEC_SLASH_AMOUNT_MEDIUM: 20000000000000000000,
|
|
93
|
-
AZTEC_SLASH_AMOUNT_LARGE: 50000000000000000000,
|
|
94
92
|
SLASH_MIN_PENALTY_PERCENTAGE: 0.5,
|
|
95
93
|
SLASH_MAX_PENALTY_PERCENTAGE: 2,
|
|
96
94
|
SLASH_OFFENSE_EXPIRATION_ROUNDS: 4,
|
|
97
|
-
SLASH_MAX_PAYLOAD_SIZE:
|
|
95
|
+
SLASH_MAX_PAYLOAD_SIZE: 80,
|
|
98
96
|
SLASH_EXECUTE_ROUNDS_LOOK_BACK: 4,
|
|
99
97
|
P2P_ENABLED: true,
|
|
100
98
|
BOOTSTRAP_NODES: '',
|
|
101
|
-
SEQ_MIN_TX_PER_BLOCK:
|
|
99
|
+
SEQ_MIN_TX_PER_BLOCK: 1,
|
|
102
100
|
SEQ_BUILD_CHECKPOINT_IF_EMPTY: true,
|
|
101
|
+
SEQ_BLOCK_DURATION_MS: 6000,
|
|
102
|
+
SEQ_L1_PUBLISHING_TIME_ALLOWANCE_IN_SLOT: 36,
|
|
103
103
|
DATA_STORE_MAP_SIZE_KB: 134217728,
|
|
104
104
|
ARCHIVER_STORE_MAP_SIZE_KB: 1073741824,
|
|
105
105
|
NOTE_HASH_TREE_MAP_SIZE_KB: 1073741824,
|
|
@@ -116,13 +116,18 @@ export const testnetConfig = {
|
|
|
116
116
|
AZTEC_SLASHING_QUORUM: 33,
|
|
117
117
|
AZTEC_GOVERNANCE_PROPOSER_ROUND_SIZE: 100,
|
|
118
118
|
AZTEC_GOVERNANCE_PROPOSER_QUORUM: 60,
|
|
119
|
-
AZTEC_MANA_TARGET:
|
|
119
|
+
AZTEC_MANA_TARGET: 75000000,
|
|
120
|
+
AZTEC_PROVING_COST_PER_MANA: 25000000,
|
|
121
|
+
AZTEC_SLASH_AMOUNT_SMALL: 1E+23,
|
|
122
|
+
AZTEC_SLASH_AMOUNT_MEDIUM: 1E+23,
|
|
123
|
+
AZTEC_SLASH_AMOUNT_LARGE: 1E+23,
|
|
120
124
|
L1_CHAIN_ID: 11155111,
|
|
121
125
|
TEST_ACCOUNTS: false,
|
|
122
|
-
SPONSORED_FPC:
|
|
126
|
+
SPONSORED_FPC: false,
|
|
123
127
|
TRANSACTIONS_DISABLED: false,
|
|
124
|
-
|
|
128
|
+
SEQ_MAX_TX_PER_CHECKPOINT: 72,
|
|
125
129
|
PROVER_REAL_PROOFS: true,
|
|
130
|
+
P2P_MAX_PENDING_TX_COUNT: 1000,
|
|
126
131
|
P2P_TX_POOL_DELETE_TXS_AFTER_REORG: true,
|
|
127
132
|
SLASH_PRUNE_PENALTY: 10000000000000000000,
|
|
128
133
|
SLASH_DATA_WITHHOLDING_PENALTY: 10000000000000000000,
|
|
@@ -131,14 +136,17 @@ export const testnetConfig = {
|
|
|
131
136
|
SLASH_INACTIVITY_PENALTY: 10000000000000000000,
|
|
132
137
|
SLASH_PROPOSE_INVALID_ATTESTATIONS_PENALTY: 10000000000000000000,
|
|
133
138
|
SLASH_DUPLICATE_PROPOSAL_PENALTY: 10000000000000000000,
|
|
139
|
+
SLASH_DUPLICATE_ATTESTATION_PENALTY: 10000000000000000000,
|
|
134
140
|
SLASH_ATTEST_DESCENDANT_OF_INVALID_PENALTY: 10000000000000000000,
|
|
135
141
|
SLASH_UNKNOWN_PENALTY: 10000000000000000000,
|
|
136
142
|
SLASH_INVALID_BLOCK_PENALTY: 10000000000000000000,
|
|
137
|
-
SLASH_GRACE_PERIOD_L2_SLOTS: 64
|
|
143
|
+
SLASH_GRACE_PERIOD_L2_SLOTS: 64,
|
|
144
|
+
ENABLE_VERSION_CHECK: true
|
|
138
145
|
};
|
|
139
146
|
export const mainnetConfig = {
|
|
140
147
|
ETHEREUM_SLOT_DURATION: 12,
|
|
141
148
|
AZTEC_EPOCH_DURATION: 32,
|
|
149
|
+
AZTEC_TARGET_COMMITTEE_SIZE: 48,
|
|
142
150
|
AZTEC_LAG_IN_EPOCHS_FOR_VALIDATOR_SET: 2,
|
|
143
151
|
AZTEC_LAG_IN_EPOCHS_FOR_RANDAO: 2,
|
|
144
152
|
AZTEC_INBOX_LAG: 1,
|
|
@@ -150,12 +158,14 @@ export const mainnetConfig = {
|
|
|
150
158
|
SLASH_MIN_PENALTY_PERCENTAGE: 0.5,
|
|
151
159
|
SLASH_MAX_PENALTY_PERCENTAGE: 2,
|
|
152
160
|
SLASH_OFFENSE_EXPIRATION_ROUNDS: 4,
|
|
153
|
-
SLASH_MAX_PAYLOAD_SIZE:
|
|
161
|
+
SLASH_MAX_PAYLOAD_SIZE: 80,
|
|
154
162
|
SLASH_EXECUTE_ROUNDS_LOOK_BACK: 4,
|
|
155
163
|
P2P_ENABLED: true,
|
|
156
164
|
BOOTSTRAP_NODES: '',
|
|
157
|
-
SEQ_MIN_TX_PER_BLOCK:
|
|
165
|
+
SEQ_MIN_TX_PER_BLOCK: 1,
|
|
158
166
|
SEQ_BUILD_CHECKPOINT_IF_EMPTY: true,
|
|
167
|
+
SEQ_BLOCK_DURATION_MS: 6000,
|
|
168
|
+
SEQ_L1_PUBLISHING_TIME_ALLOWANCE_IN_SLOT: 36,
|
|
159
169
|
DATA_STORE_MAP_SIZE_KB: 134217728,
|
|
160
170
|
ARCHIVER_STORE_MAP_SIZE_KB: 1073741824,
|
|
161
171
|
NOTE_HASH_TREE_MAP_SIZE_KB: 1073741824,
|
|
@@ -164,10 +174,9 @@ export const mainnetConfig = {
|
|
|
164
174
|
PUBLIC_OTEL_INCLUDE_METRICS: 'aztec.validator,aztec.tx_collector,aztec.mempool,aztec.p2p.gossip.agg_,aztec.ivc_verifier.agg_',
|
|
165
175
|
SENTINEL_ENABLED: true,
|
|
166
176
|
AZTEC_SLOT_DURATION: 72,
|
|
167
|
-
AZTEC_TARGET_COMMITTEE_SIZE: 24,
|
|
168
177
|
AZTEC_ACTIVATION_THRESHOLD: 2E+23,
|
|
169
178
|
AZTEC_EJECTION_THRESHOLD: 1E+23,
|
|
170
|
-
AZTEC_LOCAL_EJECTION_THRESHOLD: 1.
|
|
179
|
+
AZTEC_LOCAL_EJECTION_THRESHOLD: 1.9E+23,
|
|
171
180
|
AZTEC_SLASH_AMOUNT_SMALL: 2E+21,
|
|
172
181
|
AZTEC_SLASH_AMOUNT_MEDIUM: 2E+21,
|
|
173
182
|
AZTEC_SLASH_AMOUNT_LARGE: 2E+21,
|
|
@@ -177,24 +186,27 @@ export const mainnetConfig = {
|
|
|
177
186
|
AZTEC_SLASHING_QUORUM: 65,
|
|
178
187
|
AZTEC_GOVERNANCE_PROPOSER_QUORUM: 600,
|
|
179
188
|
AZTEC_GOVERNANCE_PROPOSER_ROUND_SIZE: 1000,
|
|
180
|
-
AZTEC_MANA_TARGET:
|
|
181
|
-
AZTEC_PROVING_COST_PER_MANA:
|
|
189
|
+
AZTEC_MANA_TARGET: 75000000,
|
|
190
|
+
AZTEC_PROVING_COST_PER_MANA: 25000000,
|
|
182
191
|
AZTEC_EXIT_DELAY_SECONDS: 345600,
|
|
183
192
|
AZTEC_SLASHING_DISABLE_DURATION: 259200,
|
|
193
|
+
AZTEC_ENTRY_QUEUE_BOOTSTRAP_VALIDATOR_SET_SIZE: 500,
|
|
194
|
+
AZTEC_ENTRY_QUEUE_BOOTSTRAP_FLUSH_SIZE: 500,
|
|
195
|
+
AZTEC_ENTRY_QUEUE_FLUSH_SIZE_MIN: 1,
|
|
196
|
+
AZTEC_ENTRY_QUEUE_FLUSH_SIZE_QUOTIENT: 400,
|
|
197
|
+
AZTEC_ENTRY_QUEUE_MAX_FLUSH_SIZE: 4,
|
|
184
198
|
L1_CHAIN_ID: 1,
|
|
185
199
|
TEST_ACCOUNTS: false,
|
|
186
200
|
SPONSORED_FPC: false,
|
|
187
|
-
TRANSACTIONS_DISABLED:
|
|
188
|
-
|
|
201
|
+
TRANSACTIONS_DISABLED: false,
|
|
202
|
+
SEQ_MAX_TX_PER_CHECKPOINT: 72,
|
|
189
203
|
PROVER_REAL_PROOFS: true,
|
|
190
|
-
SYNC_SNAPSHOTS_URLS: 'https://aztec-labs-snapshots.com/mainnet/',
|
|
191
204
|
BLOB_ALLOW_EMPTY_SOURCES: true,
|
|
192
|
-
P2P_MAX_PENDING_TX_COUNT:
|
|
205
|
+
P2P_MAX_PENDING_TX_COUNT: 1000,
|
|
193
206
|
P2P_TX_POOL_DELETE_TXS_AFTER_REORG: true,
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
PUBLIC_OTEL_COLLECT_FROM: 'sequencer',
|
|
207
|
+
PUBLIC_OTEL_EXPORTER_OTLP_METRICS_ENDPOINT: '',
|
|
208
|
+
PUBLIC_OTEL_COLLECT_FROM: '',
|
|
209
|
+
ENABLE_VERSION_CHECK: false,
|
|
198
210
|
SLASH_PRUNE_PENALTY: 0,
|
|
199
211
|
SLASH_DATA_WITHHOLDING_PENALTY: 0,
|
|
200
212
|
SLASH_INACTIVITY_TARGET_PERCENTAGE: 0.8,
|
|
@@ -202,6 +214,7 @@ export const mainnetConfig = {
|
|
|
202
214
|
SLASH_INACTIVITY_PENALTY: 2E+21,
|
|
203
215
|
SLASH_PROPOSE_INVALID_ATTESTATIONS_PENALTY: 2E+21,
|
|
204
216
|
SLASH_DUPLICATE_PROPOSAL_PENALTY: 2E+21,
|
|
217
|
+
SLASH_DUPLICATE_ATTESTATION_PENALTY: 2E+21,
|
|
205
218
|
SLASH_ATTEST_DESCENDANT_OF_INVALID_PENALTY: 2E+21,
|
|
206
219
|
SLASH_UNKNOWN_PENALTY: 2E+21,
|
|
207
220
|
SLASH_INVALID_BLOCK_PENALTY: 2E+21,
|
|
@@ -19,4 +19,4 @@ export declare function getNetworkConfig(networkName: NetworkNames, cacheDir?: s
|
|
|
19
19
|
* Does not throw if the network simply doesn't exist in the config - just returns without enriching
|
|
20
20
|
*/
|
|
21
21
|
export declare function enrichEnvironmentWithNetworkConfig(networkName: NetworkNames): Promise<void>;
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmV0d29ya19jb25maWcuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb25maWcvbmV0d29ya19jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLEtBQUssYUFBYSxFQUEwQixLQUFLLFlBQVksRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBWXpHOzs7Ozs7OztHQVFHO0FBQ0gsd0JBQXNCLGdCQUFnQixDQUNwQyxXQUFXLEVBQUUsWUFBWSxFQUN6QixRQUFRLENBQUMsRUFBRSxNQUFNLEdBQ2hCLE9BQU8sQ0FBQyxhQUFhLEdBQUcsU0FBUyxDQUFDLENBOEJwQztBQXNERDs7Ozs7Ozs7R0FRRztBQUNILHdCQUFzQixrQ0FBa0MsQ0FBQyxXQUFXLEVBQUUsWUFBWSxpQkFpQ2pGIn0=
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"network_config.d.ts","sourceRoot":"","sources":["../../src/config/network_config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,aAAa,EAA0B,KAAK,YAAY,EAAE,MAAM,0BAA0B,CAAC;
|
|
1
|
+
{"version":3,"file":"network_config.d.ts","sourceRoot":"","sources":["../../src/config/network_config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,aAAa,EAA0B,KAAK,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAYzG;;;;;;;;GAQG;AACH,wBAAsB,gBAAgB,CACpC,WAAW,EAAE,YAAY,EACzB,QAAQ,CAAC,EAAE,MAAM,GAChB,OAAO,CAAC,aAAa,GAAG,SAAS,CAAC,CA8BpC;AAsDD;;;;;;;;GAQG;AACH,wBAAsB,kCAAkC,CAAC,WAAW,EAAE,YAAY,iBAiCjF"}
|
|
@@ -5,7 +5,6 @@ import { cachedFetch } from './cached_fetch.js';
|
|
|
5
5
|
import { enrichEthAddressVar, enrichVar } from './enrich_env.js';
|
|
6
6
|
const DEFAULT_CONFIG_URL = 'https://raw.githubusercontent.com/AztecProtocol/networks/refs/heads/main/network_config.json';
|
|
7
7
|
const FALLBACK_CONFIG_URL = 'https://metadata.aztec.network/network_config.json';
|
|
8
|
-
const NETWORK_CONFIG_CACHE_DURATION_MS = 60 * 60 * 1000; // 1 hour
|
|
9
8
|
/**
|
|
10
9
|
* Fetches remote network configuration from GitHub with caching support.
|
|
11
10
|
* Uses the reusable cachedFetch utility. Falls back to metadata.aztec.network if the default URL fails.
|
|
@@ -64,7 +63,6 @@ const NETWORK_CONFIG_CACHE_DURATION_MS = 60 * 60 * 1000; // 1 hour
|
|
|
64
63
|
let rawConfig;
|
|
65
64
|
if (url.protocol === 'http:' || url.protocol === 'https:') {
|
|
66
65
|
rawConfig = await cachedFetch(url.href, {
|
|
67
|
-
cacheDurationMs: NETWORK_CONFIG_CACHE_DURATION_MS,
|
|
68
66
|
cacheFile: cacheDir ? join(cacheDir, networkName, 'network_config.json') : undefined
|
|
69
67
|
});
|
|
70
68
|
} else if (url.protocol === 'file:') {
|
|
@@ -109,7 +107,13 @@ const NETWORK_CONFIG_CACHE_DURATION_MS = 60 * 60 * 1000; // 1 hour
|
|
|
109
107
|
if (networkConfig.blobFileStoreUrls?.length) {
|
|
110
108
|
enrichVar('BLOB_FILE_STORE_URLS', networkConfig.blobFileStoreUrls.join(','));
|
|
111
109
|
}
|
|
110
|
+
if (networkConfig.txCollectionFileStoreUrls?.length) {
|
|
111
|
+
enrichVar('TX_COLLECTION_FILE_STORE_URLS', networkConfig.txCollectionFileStoreUrls.join(','));
|
|
112
|
+
}
|
|
112
113
|
if (networkConfig.blockDurationMs !== undefined) {
|
|
113
114
|
enrichVar('SEQ_BLOCK_DURATION_MS', String(networkConfig.blockDurationMs));
|
|
114
115
|
}
|
|
116
|
+
if (networkConfig.txPublicSetupAllowListExtend) {
|
|
117
|
+
enrichVar('TX_PUBLIC_SETUP_ALLOWLIST', networkConfig.txPublicSetupAllowListExtend);
|
|
118
|
+
}
|
|
115
119
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@aztec/cli",
|
|
3
|
-
"version": "0.0.1-commit.
|
|
3
|
+
"version": "0.0.1-commit.e588bc7e5",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"exports": {
|
|
6
6
|
"./contracts": "./dest/cmds/contracts/index.js",
|
|
@@ -77,23 +77,23 @@
|
|
|
77
77
|
]
|
|
78
78
|
},
|
|
79
79
|
"dependencies": {
|
|
80
|
-
"@aztec/accounts": "0.0.1-commit.
|
|
81
|
-
"@aztec/archiver": "0.0.1-commit.
|
|
82
|
-
"@aztec/aztec.js": "0.0.1-commit.
|
|
83
|
-
"@aztec/constants": "0.0.1-commit.
|
|
84
|
-
"@aztec/entrypoints": "0.0.1-commit.
|
|
85
|
-
"@aztec/ethereum": "0.0.1-commit.
|
|
86
|
-
"@aztec/foundation": "0.0.1-commit.
|
|
87
|
-
"@aztec/l1-artifacts": "0.0.1-commit.
|
|
88
|
-
"@aztec/node-keystore": "0.0.1-commit.
|
|
89
|
-
"@aztec/node-lib": "0.0.1-commit.
|
|
90
|
-
"@aztec/p2p": "0.0.1-commit.
|
|
91
|
-
"@aztec/protocol-contracts": "0.0.1-commit.
|
|
92
|
-
"@aztec/sequencer-client": "0.0.1-commit.
|
|
93
|
-
"@aztec/slasher": "0.0.1-commit.
|
|
94
|
-
"@aztec/stdlib": "0.0.1-commit.
|
|
95
|
-
"@aztec/
|
|
96
|
-
"@aztec/world-state": "0.0.1-commit.
|
|
80
|
+
"@aztec/accounts": "0.0.1-commit.e588bc7e5",
|
|
81
|
+
"@aztec/archiver": "0.0.1-commit.e588bc7e5",
|
|
82
|
+
"@aztec/aztec.js": "0.0.1-commit.e588bc7e5",
|
|
83
|
+
"@aztec/constants": "0.0.1-commit.e588bc7e5",
|
|
84
|
+
"@aztec/entrypoints": "0.0.1-commit.e588bc7e5",
|
|
85
|
+
"@aztec/ethereum": "0.0.1-commit.e588bc7e5",
|
|
86
|
+
"@aztec/foundation": "0.0.1-commit.e588bc7e5",
|
|
87
|
+
"@aztec/l1-artifacts": "0.0.1-commit.e588bc7e5",
|
|
88
|
+
"@aztec/node-keystore": "0.0.1-commit.e588bc7e5",
|
|
89
|
+
"@aztec/node-lib": "0.0.1-commit.e588bc7e5",
|
|
90
|
+
"@aztec/p2p": "0.0.1-commit.e588bc7e5",
|
|
91
|
+
"@aztec/protocol-contracts": "0.0.1-commit.e588bc7e5",
|
|
92
|
+
"@aztec/sequencer-client": "0.0.1-commit.e588bc7e5",
|
|
93
|
+
"@aztec/slasher": "0.0.1-commit.e588bc7e5",
|
|
94
|
+
"@aztec/stdlib": "0.0.1-commit.e588bc7e5",
|
|
95
|
+
"@aztec/wallets": "0.0.1-commit.e588bc7e5",
|
|
96
|
+
"@aztec/world-state": "0.0.1-commit.e588bc7e5",
|
|
97
97
|
"@ethersproject/wallet": "^5.8.0",
|
|
98
98
|
"@iarna/toml": "^2.2.5",
|
|
99
99
|
"@libp2p/peer-id-factory": "^3.0.4",
|
|
@@ -107,9 +107,9 @@
|
|
|
107
107
|
"viem": "npm:@aztec/viem@2.38.2"
|
|
108
108
|
},
|
|
109
109
|
"devDependencies": {
|
|
110
|
-
"@aztec/aztec-node": "0.0.1-commit.
|
|
111
|
-
"@aztec/kv-store": "0.0.1-commit.
|
|
112
|
-
"@aztec/telemetry-client": "0.0.1-commit.
|
|
110
|
+
"@aztec/aztec-node": "0.0.1-commit.e588bc7e5",
|
|
111
|
+
"@aztec/kv-store": "0.0.1-commit.e588bc7e5",
|
|
112
|
+
"@aztec/telemetry-client": "0.0.1-commit.e588bc7e5",
|
|
113
113
|
"@jest/globals": "^30.0.0",
|
|
114
114
|
"@types/jest": "^30.0.0",
|
|
115
115
|
"@types/lodash.chunk": "^4.2.9",
|
|
@@ -126,15 +126,15 @@
|
|
|
126
126
|
"typescript": "^5.3.3"
|
|
127
127
|
},
|
|
128
128
|
"peerDependencies": {
|
|
129
|
-
"@aztec/accounts": "0.0.1-commit.
|
|
130
|
-
"@aztec/bb-prover": "0.0.1-commit.
|
|
131
|
-
"@aztec/ethereum": "0.0.1-commit.
|
|
132
|
-
"@aztec/l1-artifacts": "0.0.1-commit.
|
|
133
|
-
"@aztec/noir-contracts.js": "0.0.1-commit.
|
|
134
|
-
"@aztec/noir-protocol-circuits-types": "0.0.1-commit.
|
|
135
|
-
"@aztec/noir-test-contracts.js": "0.0.1-commit.
|
|
136
|
-
"@aztec/protocol-contracts": "0.0.1-commit.
|
|
137
|
-
"@aztec/stdlib": "0.0.1-commit.
|
|
129
|
+
"@aztec/accounts": "0.0.1-commit.e588bc7e5",
|
|
130
|
+
"@aztec/bb-prover": "0.0.1-commit.e588bc7e5",
|
|
131
|
+
"@aztec/ethereum": "0.0.1-commit.e588bc7e5",
|
|
132
|
+
"@aztec/l1-artifacts": "0.0.1-commit.e588bc7e5",
|
|
133
|
+
"@aztec/noir-contracts.js": "0.0.1-commit.e588bc7e5",
|
|
134
|
+
"@aztec/noir-protocol-circuits-types": "0.0.1-commit.e588bc7e5",
|
|
135
|
+
"@aztec/noir-test-contracts.js": "0.0.1-commit.e588bc7e5",
|
|
136
|
+
"@aztec/protocol-contracts": "0.0.1-commit.e588bc7e5",
|
|
137
|
+
"@aztec/stdlib": "0.0.1-commit.e588bc7e5"
|
|
138
138
|
},
|
|
139
139
|
"files": [
|
|
140
140
|
"dest",
|
|
@@ -1,12 +1,13 @@
|
|
|
1
1
|
import { getInitialTestAccountsData } from '@aztec/accounts/testing';
|
|
2
|
-
import
|
|
2
|
+
import { AztecAddress } from '@aztec/aztec.js/addresses';
|
|
3
3
|
import type { WaitOpts } from '@aztec/aztec.js/contracts';
|
|
4
4
|
import { createAztecNodeClient } from '@aztec/aztec.js/node';
|
|
5
5
|
import { AccountManager } from '@aztec/aztec.js/wallet';
|
|
6
6
|
import { jsonStringify } from '@aztec/foundation/json-rpc';
|
|
7
7
|
import type { LogFn } from '@aztec/foundation/log';
|
|
8
8
|
import { ProtocolContractAddress } from '@aztec/protocol-contracts';
|
|
9
|
-
import {
|
|
9
|
+
import { EmbeddedWallet } from '@aztec/wallets/embedded';
|
|
10
|
+
import { deployFundedSchnorrAccounts } from '@aztec/wallets/testing';
|
|
10
11
|
|
|
11
12
|
export async function setupL2Contracts(nodeUrl: string, testAccounts: boolean, json: boolean, log: LogFn) {
|
|
12
13
|
const waitOpts: WaitOpts = {
|
|
@@ -16,7 +17,7 @@ export async function setupL2Contracts(nodeUrl: string, testAccounts: boolean, j
|
|
|
16
17
|
log('setupL2Contracts: Wait options' + jsonStringify(waitOpts));
|
|
17
18
|
log('setupL2Contracts: Creating PXE client...');
|
|
18
19
|
const node = createAztecNodeClient(nodeUrl);
|
|
19
|
-
const wallet = await
|
|
20
|
+
const wallet = await EmbeddedWallet.create(node);
|
|
20
21
|
|
|
21
22
|
let deployedAccountManagers: AccountManager[] = [];
|
|
22
23
|
if (testAccounts) {
|
|
@@ -2,7 +2,7 @@ import { createEthereumChain, isAnvilTestChain } from '@aztec/ethereum/chain';
|
|
|
2
2
|
import { createExtendedL1Client, getPublicClient } from '@aztec/ethereum/client';
|
|
3
3
|
import { getL1ContractsConfigEnvVars } from '@aztec/ethereum/config';
|
|
4
4
|
import { GSEContract, RollupContract } from '@aztec/ethereum/contracts';
|
|
5
|
-
import {
|
|
5
|
+
import { createL1TxUtils } from '@aztec/ethereum/l1-tx-utils';
|
|
6
6
|
import { EthCheatCodes } from '@aztec/ethereum/test';
|
|
7
7
|
import type { EthAddress } from '@aztec/foundation/eth-address';
|
|
8
8
|
import type { LogFn, Logger } from '@aztec/foundation/log';
|
|
@@ -88,7 +88,7 @@ export async function addL1Validator({
|
|
|
88
88
|
const gse = new GSEContract(l1Client, gseAddress);
|
|
89
89
|
const registrationTuple = await gse.makeRegistrationTuple(blsSecretKey);
|
|
90
90
|
|
|
91
|
-
const l1TxUtils =
|
|
91
|
+
const l1TxUtils = createL1TxUtils(l1Client, { logger: debugLogger });
|
|
92
92
|
const proofParamsObj = ZkPassportProofParams.fromBuffer(proofParams);
|
|
93
93
|
|
|
94
94
|
// Step 1: Claim STK tokens from the faucet
|
|
@@ -194,7 +194,7 @@ export async function addL1ValidatorViaRollup({
|
|
|
194
194
|
|
|
195
195
|
const registrationTuple = await gse.makeRegistrationTuple(blsSecretKey);
|
|
196
196
|
|
|
197
|
-
const l1TxUtils =
|
|
197
|
+
const l1TxUtils = createL1TxUtils(l1Client, { logger: debugLogger });
|
|
198
198
|
|
|
199
199
|
const { receipt } = await l1TxUtils.sendAndMonitorTransaction({
|
|
200
200
|
to: rollupAddress.toString(),
|
|
@@ -241,7 +241,7 @@ export async function removeL1Validator({
|
|
|
241
241
|
const account = getAccount(privateKey, mnemonic);
|
|
242
242
|
const chain = createEthereumChain(rpcUrls, chainId);
|
|
243
243
|
const l1Client = createExtendedL1Client(rpcUrls, account, chain.chainInfo);
|
|
244
|
-
const l1TxUtils =
|
|
244
|
+
const l1TxUtils = createL1TxUtils(l1Client, { logger: debugLogger });
|
|
245
245
|
|
|
246
246
|
dualLog(`Removing validator ${validatorAddress.toString()} from rollup ${rollupAddress.toString()}`);
|
|
247
247
|
const { receipt } = await l1TxUtils.sendAndMonitorTransaction({
|
|
@@ -268,7 +268,7 @@ export async function pruneRollup({
|
|
|
268
268
|
const account = getAccount(privateKey, mnemonic);
|
|
269
269
|
const chain = createEthereumChain(rpcUrls, chainId);
|
|
270
270
|
const l1Client = createExtendedL1Client(rpcUrls, account, chain.chainInfo);
|
|
271
|
-
const l1TxUtils =
|
|
271
|
+
const l1TxUtils = createL1TxUtils(l1Client, { logger: debugLogger });
|
|
272
272
|
|
|
273
273
|
dualLog(`Trying prune`);
|
|
274
274
|
const { receipt } = await l1TxUtils.sendAndMonitorTransaction({
|
|
@@ -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
|
}
|