@aztec/aztec 0.0.1-commit.fce3e4f → 0.0.1-commit.ffe5b04ea
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/bin/index.js +12 -5
- package/dest/cli/admin_api_key_store.d.ts +45 -0
- package/dest/cli/admin_api_key_store.d.ts.map +1 -0
- package/dest/cli/admin_api_key_store.js +98 -0
- package/dest/cli/aztec_start_action.d.ts +1 -1
- package/dest/cli/aztec_start_action.d.ts.map +1 -1
- package/dest/cli/aztec_start_action.js +55 -16
- package/dest/cli/aztec_start_options.d.ts +1 -1
- package/dest/cli/aztec_start_options.d.ts.map +1 -1
- package/dest/cli/aztec_start_options.js +41 -36
- package/dest/cli/cli.d.ts +1 -1
- package/dest/cli/cli.d.ts.map +1 -1
- package/dest/cli/cli.js +4 -37
- package/dest/cli/cmds/compile.d.ts +4 -0
- package/dest/cli/cmds/compile.d.ts.map +1 -0
- package/dest/cli/cmds/compile.js +160 -0
- package/dest/cli/cmds/migrate_ha_db.d.ts +3 -0
- package/dest/cli/cmds/migrate_ha_db.d.ts.map +1 -0
- package/dest/cli/cmds/migrate_ha_db.js +27 -0
- package/dest/cli/cmds/profile.d.ts +4 -0
- package/dest/cli/cmds/profile.d.ts.map +1 -0
- package/dest/cli/cmds/profile.js +8 -0
- package/dest/cli/cmds/profile_flamegraph.d.ts +4 -0
- package/dest/cli/cmds/profile_flamegraph.d.ts.map +1 -0
- package/dest/cli/cmds/profile_flamegraph.js +51 -0
- package/dest/cli/cmds/profile_gates.d.ts +4 -0
- package/dest/cli/cmds/profile_gates.d.ts.map +1 -0
- package/dest/cli/cmds/profile_gates.js +57 -0
- package/dest/cli/cmds/profile_utils.d.ts +18 -0
- package/dest/cli/cmds/profile_utils.d.ts.map +1 -0
- package/dest/cli/cmds/profile_utils.js +50 -0
- package/dest/cli/cmds/standby.d.ts +27 -0
- package/dest/cli/cmds/standby.d.ts.map +1 -0
- package/dest/cli/cmds/standby.js +78 -0
- package/dest/cli/cmds/start_archiver.d.ts +2 -2
- package/dest/cli/cmds/start_archiver.d.ts.map +1 -1
- package/dest/cli/cmds/start_archiver.js +12 -14
- package/dest/cli/cmds/start_bot.d.ts +3 -3
- package/dest/cli/cmds/start_bot.d.ts.map +1 -1
- package/dest/cli/cmds/start_bot.js +10 -6
- package/dest/cli/cmds/start_node.d.ts +3 -2
- package/dest/cli/cmds/start_node.d.ts.map +1 -1
- package/dest/cli/cmds/start_node.js +79 -29
- package/dest/cli/cmds/start_p2p_bootstrap.d.ts +2 -2
- package/dest/cli/cmds/start_p2p_bootstrap.d.ts.map +1 -1
- package/dest/cli/cmds/start_p2p_bootstrap.js +2 -3
- package/dest/cli/cmds/start_prover_agent.d.ts +1 -1
- package/dest/cli/cmds/start_prover_agent.d.ts.map +1 -1
- package/dest/cli/cmds/start_prover_agent.js +4 -4
- package/dest/cli/cmds/start_prover_broker.d.ts +1 -1
- package/dest/cli/cmds/start_prover_broker.d.ts.map +1 -1
- package/dest/cli/cmds/start_prover_broker.js +9 -9
- package/dest/cli/cmds/utils/artifacts.d.ts +21 -0
- package/dest/cli/cmds/utils/artifacts.d.ts.map +1 -0
- package/dest/cli/cmds/utils/artifacts.js +24 -0
- package/dest/cli/cmds/utils/spawn.d.ts +3 -0
- package/dest/cli/cmds/utils/spawn.d.ts.map +1 -0
- package/dest/cli/cmds/utils/spawn.js +16 -0
- package/dest/cli/util.d.ts +9 -20
- package/dest/cli/util.d.ts.map +1 -1
- package/dest/cli/util.js +51 -87
- package/dest/examples/token.js +9 -9
- package/dest/examples/util.d.ts +2 -2
- package/dest/examples/util.d.ts.map +1 -1
- package/dest/local-network/banana_fpc.d.ts +1 -1
- package/dest/local-network/banana_fpc.d.ts.map +1 -1
- package/dest/local-network/banana_fpc.js +4 -4
- package/dest/local-network/local-network.d.ts +13 -14
- package/dest/local-network/local-network.d.ts.map +1 -1
- package/dest/local-network/local-network.js +86 -43
- package/dest/testing/anvil_test_watcher.d.ts +10 -2
- package/dest/testing/anvil_test_watcher.d.ts.map +1 -1
- package/dest/testing/anvil_test_watcher.js +53 -16
- package/dest/testing/cheat_codes.d.ts +3 -1
- package/dest/testing/cheat_codes.d.ts.map +1 -1
- package/dest/testing/epoch_test_settler.d.ts +19 -0
- package/dest/testing/epoch_test_settler.d.ts.map +1 -0
- package/dest/testing/epoch_test_settler.js +62 -0
- package/dest/testing/index.d.ts +3 -1
- package/dest/testing/index.d.ts.map +1 -1
- package/dest/testing/index.js +2 -0
- package/dest/testing/token_allowed_setup.d.ts +7 -0
- package/dest/testing/token_allowed_setup.d.ts.map +1 -0
- package/dest/testing/token_allowed_setup.js +20 -0
- package/package.json +37 -35
- package/scripts/add_crate.sh +102 -0
- package/scripts/aztec.sh +19 -9
- package/scripts/init.sh +23 -19
- package/scripts/new.sh +48 -24
- package/scripts/setup_workspace.sh +68 -0
- package/src/bin/index.ts +13 -5
- package/src/cli/admin_api_key_store.ts +128 -0
- package/src/cli/aztec_start_action.ts +58 -11
- package/src/cli/aztec_start_options.ts +42 -35
- package/src/cli/cli.ts +4 -37
- package/src/cli/cmds/compile.ts +184 -0
- package/src/cli/cmds/migrate_ha_db.ts +43 -0
- package/src/cli/cmds/profile.ts +25 -0
- package/src/cli/cmds/profile_flamegraph.ts +63 -0
- package/src/cli/cmds/profile_gates.ts +67 -0
- package/src/cli/cmds/profile_utils.ts +58 -0
- package/src/cli/cmds/standby.ts +111 -0
- package/src/cli/cmds/start_archiver.ts +8 -19
- package/src/cli/cmds/start_bot.ts +9 -6
- package/src/cli/cmds/start_node.ts +78 -35
- package/src/cli/cmds/start_p2p_bootstrap.ts +3 -3
- package/src/cli/cmds/start_prover_agent.ts +4 -12
- package/src/cli/cmds/start_prover_broker.ts +13 -16
- package/src/cli/cmds/utils/artifacts.ts +44 -0
- package/src/cli/cmds/utils/spawn.ts +16 -0
- package/src/cli/util.ts +60 -98
- package/src/examples/token.ts +10 -10
- package/src/examples/util.ts +1 -1
- package/src/local-network/banana_fpc.ts +12 -8
- package/src/local-network/local-network.ts +120 -85
- package/src/testing/anvil_test_watcher.ts +61 -17
- package/src/testing/cheat_codes.ts +3 -2
- package/src/testing/epoch_test_settler.ts +71 -0
- package/src/testing/index.ts +2 -0
- package/src/testing/token_allowed_setup.ts +19 -0
- package/dest/cli/cmds/start_blob_sink.d.ts +0 -3
- package/dest/cli/cmds/start_blob_sink.d.ts.map +0 -1
- package/dest/cli/cmds/start_blob_sink.js +0 -33
- package/dest/cli/cmds/start_prover_node.d.ts +0 -7
- package/dest/cli/cmds/start_prover_node.d.ts.map +0 -1
- package/dest/cli/cmds/start_prover_node.js +0 -108
- package/dest/cli/release_version.d.ts +0 -2
- package/dest/cli/release_version.d.ts.map +0 -1
- package/dest/cli/release_version.js +0 -14
- package/scripts/compile.sh +0 -44
- package/scripts/extract_function.js +0 -47
- package/scripts/flamegraph.sh +0 -59
- package/scripts/setup_project.sh +0 -31
- package/src/cli/cmds/start_blob_sink.ts +0 -57
- package/src/cli/cmds/start_prover_node.ts +0 -124
- package/src/cli/release_version.ts +0 -21
package/src/cli/util.ts
CHANGED
|
@@ -1,18 +1,18 @@
|
|
|
1
1
|
import type { AztecNodeConfig } from '@aztec/aztec-node';
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import type { ViemClient } from '@aztec/ethereum';
|
|
6
|
-
import type { ConfigMappingsType } from '@aztec/foundation/config';
|
|
2
|
+
import type { AccountManager } from '@aztec/aztec.js/wallet';
|
|
3
|
+
import { getNetworkConfig } from '@aztec/cli/config';
|
|
4
|
+
import { RegistryContract } from '@aztec/ethereum/contracts';
|
|
5
|
+
import type { ViemClient } from '@aztec/ethereum/types';
|
|
6
|
+
import type { ConfigMappingsType, NetworkNames } from '@aztec/foundation/config';
|
|
7
|
+
import { jsonStringify } from '@aztec/foundation/json-rpc';
|
|
7
8
|
import { type LogFn, createLogger } from '@aztec/foundation/log';
|
|
8
|
-
import type { SharedNodeConfig } from '@aztec/node-lib/config';
|
|
9
9
|
import type { ProverConfig } from '@aztec/stdlib/interfaces/server';
|
|
10
|
-
import {
|
|
11
|
-
import {
|
|
12
|
-
import type { TestWallet } from '@aztec/test-wallet/server';
|
|
10
|
+
import { type VersionCheck, getPackageVersion } from '@aztec/stdlib/update-checker';
|
|
11
|
+
import type { EmbeddedWallet } from '@aztec/wallets/embedded';
|
|
13
12
|
|
|
14
13
|
import chalk from 'chalk';
|
|
15
14
|
import type { Command } from 'commander';
|
|
15
|
+
import type { Hex } from 'viem';
|
|
16
16
|
|
|
17
17
|
import { type AztecStartOption, aztecStartOptions } from './aztec_start_options.js';
|
|
18
18
|
|
|
@@ -37,7 +37,7 @@ export function shutdown(logFn: LogFn, exitCode: ExitCode, cb?: Array<() => Prom
|
|
|
37
37
|
|
|
38
38
|
logFn('Shutting down...', { exitCode });
|
|
39
39
|
if (cb) {
|
|
40
|
-
shutdownPromise = Promise.allSettled(cb).then(() => process.exit(exitCode));
|
|
40
|
+
shutdownPromise = Promise.allSettled(cb.map(fn => fn())).then(() => process.exit(exitCode));
|
|
41
41
|
} else {
|
|
42
42
|
// synchronously shuts down the process
|
|
43
43
|
// no need to set shutdownPromise on this branch of the if statement because no more code will be executed
|
|
@@ -69,30 +69,19 @@ export const installSignalHandlers = (logFn: LogFn, cb?: Array<() => Promise<voi
|
|
|
69
69
|
/**
|
|
70
70
|
* Creates logs for the initial accounts
|
|
71
71
|
* @param accounts - The initial accounts
|
|
72
|
-
* @param wallet - A
|
|
72
|
+
* @param wallet - A EmbeddedWallet instance to get the registered accounts
|
|
73
73
|
* @returns A string array containing the initial accounts details
|
|
74
74
|
*/
|
|
75
|
-
export async function createAccountLogs(
|
|
76
|
-
accountsWithSecretKeys: {
|
|
77
|
-
/**
|
|
78
|
-
* The account object
|
|
79
|
-
*/
|
|
80
|
-
account: AccountManager;
|
|
81
|
-
/**
|
|
82
|
-
* The secret key of the account
|
|
83
|
-
*/
|
|
84
|
-
secretKey: Fr;
|
|
85
|
-
}[],
|
|
86
|
-
wallet: TestWallet,
|
|
87
|
-
) {
|
|
75
|
+
export async function createAccountLogs(accountManagers: AccountManager[], wallet: EmbeddedWallet) {
|
|
88
76
|
const registeredAccounts = await wallet.getAccounts();
|
|
89
77
|
const accountLogStrings = [`Initial Accounts:\n\n`];
|
|
90
|
-
for (const
|
|
91
|
-
const
|
|
78
|
+
for (const accountManager of accountManagers) {
|
|
79
|
+
const account = await accountManager.getAccount();
|
|
80
|
+
const completeAddress = account.getCompleteAddress();
|
|
92
81
|
if (registeredAccounts.find(a => a.item.equals(completeAddress.address))) {
|
|
93
82
|
accountLogStrings.push(` Address: ${completeAddress.address.toString()}\n`);
|
|
94
83
|
accountLogStrings.push(` Partial Address: ${completeAddress.partialAddress.toString()}\n`);
|
|
95
|
-
accountLogStrings.push(` Secret Key: ${
|
|
84
|
+
accountLogStrings.push(` Secret Key: ${account.getSecretKey().toString()}\n`);
|
|
96
85
|
accountLogStrings.push(
|
|
97
86
|
` Master nullifier public key: ${completeAddress.publicKeys.masterNullifierPublicKey.toString()}\n`,
|
|
98
87
|
);
|
|
@@ -283,7 +272,7 @@ export async function preloadCrsDataForVerifying(
|
|
|
283
272
|
): Promise<void> {
|
|
284
273
|
if (realProofs) {
|
|
285
274
|
const { Crs, GrumpkinCrs } = await import('@aztec/bb.js');
|
|
286
|
-
await Promise.all([Crs.new(2 ** 1, undefined, log), GrumpkinCrs.new(2 ** 16
|
|
275
|
+
await Promise.all([Crs.new(2 ** 1, undefined, log), GrumpkinCrs.new(2 ** 16, undefined, log)]);
|
|
287
276
|
}
|
|
288
277
|
}
|
|
289
278
|
|
|
@@ -298,93 +287,66 @@ export async function preloadCrsDataForServerSideProving(
|
|
|
298
287
|
): Promise<void> {
|
|
299
288
|
if (realProofs) {
|
|
300
289
|
const { Crs, GrumpkinCrs } = await import('@aztec/bb.js');
|
|
301
|
-
await Promise.all([Crs.new(2 ** 25
|
|
290
|
+
await Promise.all([Crs.new(2 ** 25, undefined, log), GrumpkinCrs.new(2 ** 18, undefined, log)]);
|
|
302
291
|
}
|
|
303
292
|
}
|
|
304
293
|
|
|
305
|
-
export async function
|
|
306
|
-
|
|
307
|
-
updatesLocation: URL,
|
|
294
|
+
export async function setupVersionChecker(
|
|
295
|
+
network: NetworkNames,
|
|
308
296
|
followsCanonicalRollup: boolean,
|
|
309
297
|
publicClient: ViemClient,
|
|
310
|
-
registryContractAddress: EthAddress,
|
|
311
298
|
signalHandlers: Array<() => Promise<void>>,
|
|
312
|
-
|
|
313
|
-
) {
|
|
314
|
-
const
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
registryContractAddress,
|
|
319
|
-
});
|
|
299
|
+
cacheDir?: string,
|
|
300
|
+
): Promise<void> {
|
|
301
|
+
const networkConfig = await getNetworkConfig(network, cacheDir);
|
|
302
|
+
if (!networkConfig) {
|
|
303
|
+
return;
|
|
304
|
+
}
|
|
320
305
|
|
|
321
|
-
|
|
322
|
-
checker.on('newRollupVersion', async ({ latestVersion, currentVersion }) => {
|
|
323
|
-
if (isShuttingDown()) {
|
|
324
|
-
return;
|
|
325
|
-
}
|
|
306
|
+
const { VersionChecker } = await import('@aztec/stdlib/update-checker');
|
|
326
307
|
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
return;
|
|
330
|
-
}
|
|
308
|
+
const logger = createLogger('version_check');
|
|
309
|
+
const registry = new RegistryContract(publicClient, networkConfig.registryAddress as Hex);
|
|
331
310
|
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
311
|
+
const checks: Array<VersionCheck> = [];
|
|
312
|
+
checks.push({
|
|
313
|
+
name: 'node',
|
|
314
|
+
currentVersion: getPackageVersion() ?? 'unknown',
|
|
315
|
+
getLatestVersion: async () => {
|
|
316
|
+
const cfg = await getNetworkConfig(network, cacheDir);
|
|
317
|
+
return cfg?.nodeVersion;
|
|
318
|
+
},
|
|
338
319
|
});
|
|
339
320
|
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
return;
|
|
344
|
-
}
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
321
|
+
if (followsCanonicalRollup) {
|
|
322
|
+
const getLatestVersion = async () => {
|
|
323
|
+
const version = (await registry.getRollupVersions()).at(-1);
|
|
324
|
+
return version !== undefined ? String(version) : undefined;
|
|
325
|
+
};
|
|
326
|
+
const currentVersion = await getLatestVersion();
|
|
327
|
+
if (currentVersion !== undefined) {
|
|
328
|
+
checks.push({
|
|
329
|
+
name: 'rollup',
|
|
330
|
+
currentVersion,
|
|
331
|
+
getLatestVersion,
|
|
332
|
+
});
|
|
350
333
|
}
|
|
351
|
-
}
|
|
334
|
+
}
|
|
352
335
|
|
|
353
|
-
|
|
354
|
-
checker.on('
|
|
336
|
+
const checker = new VersionChecker(checks, 600_000, logger);
|
|
337
|
+
checker.on('newVersion', ({ name, latestVersion, currentVersion }) => {
|
|
355
338
|
if (isShuttingDown()) {
|
|
356
339
|
return;
|
|
357
340
|
}
|
|
358
341
|
|
|
359
|
-
|
|
360
|
-
logger.warn(`Config change detected. Updating node`, config);
|
|
361
|
-
try {
|
|
362
|
-
await updateNodeConfig(config);
|
|
363
|
-
} catch (err) {
|
|
364
|
-
logger.warn('Failed to update config', { err });
|
|
365
|
-
}
|
|
366
|
-
}
|
|
367
|
-
// don't notify on these config changes
|
|
342
|
+
logger.warn(`New ${name} version available`, { latestVersion, currentVersion });
|
|
368
343
|
});
|
|
369
|
-
|
|
370
|
-
checker.on('updatePublicTelemetryConfig', config => {
|
|
371
|
-
if (autoUpdateMode === 'config' || autoUpdateMode === 'config-and-version') {
|
|
372
|
-
logger.warn(`Public telemetry config change detected. Updating telemetry client`, config);
|
|
373
|
-
try {
|
|
374
|
-
const publicIncludeMetrics: unknown = (config as any).publicIncludeMetrics;
|
|
375
|
-
if (Array.isArray(publicIncludeMetrics) && publicIncludeMetrics.every(m => typeof m === 'string')) {
|
|
376
|
-
getTelemetryClient().setExportedPublicTelemetry(publicIncludeMetrics);
|
|
377
|
-
}
|
|
378
|
-
const publicMetricsCollectFrom: unknown = (config as any).publicMetricsCollectFrom;
|
|
379
|
-
if (Array.isArray(publicMetricsCollectFrom) && publicMetricsCollectFrom.every(m => typeof m === 'string')) {
|
|
380
|
-
getTelemetryClient().setPublicTelemetryCollectFrom(publicMetricsCollectFrom);
|
|
381
|
-
}
|
|
382
|
-
} catch (err) {
|
|
383
|
-
logger.warn('Failed to update config', { err });
|
|
384
|
-
}
|
|
385
|
-
}
|
|
386
|
-
// don't notify on these config changes
|
|
387
|
-
});
|
|
388
|
-
|
|
389
344
|
checker.start();
|
|
345
|
+
signalHandlers.push(() => checker.stop());
|
|
346
|
+
}
|
|
347
|
+
|
|
348
|
+
export function stringifyConfig(config: object): string {
|
|
349
|
+
return Object.entries(config)
|
|
350
|
+
.map(([key, value]) => `${key}=${jsonStringify(value)}`)
|
|
351
|
+
.join(' ');
|
|
390
352
|
}
|
package/src/examples/token.ts
CHANGED
|
@@ -2,7 +2,7 @@ import { getInitialTestAccountsData } from '@aztec/accounts/testing';
|
|
|
2
2
|
import { createAztecNodeClient } from '@aztec/aztec.js/node';
|
|
3
3
|
import { createLogger } from '@aztec/foundation/log';
|
|
4
4
|
import { TokenContract } from '@aztec/noir-contracts.js/Token';
|
|
5
|
-
import {
|
|
5
|
+
import { EmbeddedWallet } from '@aztec/wallets/embedded';
|
|
6
6
|
|
|
7
7
|
const logger = createLogger('example:token');
|
|
8
8
|
|
|
@@ -19,7 +19,7 @@ const TRANSFER_AMOUNT = 33n;
|
|
|
19
19
|
async function main() {
|
|
20
20
|
logger.info('Running token contract test on HTTP interface.');
|
|
21
21
|
|
|
22
|
-
const wallet = await
|
|
22
|
+
const wallet = await EmbeddedWallet.create(node);
|
|
23
23
|
|
|
24
24
|
// During local network setup we deploy a few accounts. Below we add them to our wallet.
|
|
25
25
|
const [aliceInitialAccountData, bobInitialAccountData] = await getInitialTestAccountsData();
|
|
@@ -32,29 +32,29 @@ async function main() {
|
|
|
32
32
|
logger.info(`Fetched Alice and Bob accounts: ${alice.toString()}, ${bob.toString()}`);
|
|
33
33
|
|
|
34
34
|
logger.info('Deploying Token...');
|
|
35
|
-
const token = await TokenContract.deploy(wallet, alice, 'TokenName', 'TokenSymbol', 18)
|
|
36
|
-
|
|
37
|
-
|
|
35
|
+
const { contract: token } = await TokenContract.deploy(wallet, alice, 'TokenName', 'TokenSymbol', 18).send({
|
|
36
|
+
from: alice,
|
|
37
|
+
});
|
|
38
38
|
logger.info('Token deployed');
|
|
39
39
|
|
|
40
40
|
// Mint tokens to Alice
|
|
41
41
|
logger.info(`Minting ${ALICE_MINT_BALANCE} more coins to Alice...`);
|
|
42
|
-
await token.methods.mint_to_private(alice, ALICE_MINT_BALANCE).send({ from: alice })
|
|
42
|
+
await token.methods.mint_to_private(alice, ALICE_MINT_BALANCE).send({ from: alice });
|
|
43
43
|
|
|
44
44
|
logger.info(`${ALICE_MINT_BALANCE} tokens were successfully minted by Alice and transferred to private`);
|
|
45
45
|
|
|
46
|
-
const balanceAfterMint = await token.methods.balance_of_private(alice).simulate({ from: alice });
|
|
46
|
+
const { result: balanceAfterMint } = await token.methods.balance_of_private(alice).simulate({ from: alice });
|
|
47
47
|
logger.info(`Tokens successfully minted. New Alice's balance: ${balanceAfterMint}`);
|
|
48
48
|
|
|
49
49
|
// We will now transfer tokens from Alice to Bob
|
|
50
50
|
logger.info(`Transferring ${TRANSFER_AMOUNT} tokens from Alice to Bob...`);
|
|
51
|
-
await token.methods.transfer(bob, TRANSFER_AMOUNT).send({ from: alice })
|
|
51
|
+
await token.methods.transfer(bob, TRANSFER_AMOUNT).send({ from: alice });
|
|
52
52
|
|
|
53
53
|
// Check the new balances
|
|
54
|
-
const aliceBalance = await token.methods.balance_of_private(alice).simulate({ from: alice });
|
|
54
|
+
const { result: aliceBalance } = await token.methods.balance_of_private(alice).simulate({ from: alice });
|
|
55
55
|
logger.info(`Alice's balance ${aliceBalance}`);
|
|
56
56
|
|
|
57
|
-
const bobBalance = await token.methods.balance_of_private(bob).simulate({ from: bob });
|
|
57
|
+
const { result: bobBalance } = await token.methods.balance_of_private(bob).simulate({ from: bob });
|
|
58
58
|
logger.info(`Bob's balance ${bobBalance}`);
|
|
59
59
|
}
|
|
60
60
|
|
package/src/examples/util.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { EthAddress } from '@aztec/aztec.js/addresses';
|
|
2
|
-
import type { ExtendedViemWalletClient } from '@aztec/ethereum';
|
|
2
|
+
import type { ExtendedViemWalletClient } from '@aztec/ethereum/types';
|
|
3
3
|
import { jsonStringify } from '@aztec/foundation/json-rpc';
|
|
4
4
|
|
|
5
5
|
import type { Abi, Narrow } from 'abitype';
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { type InitialAccountData, getInitialTestAccountsData } from '@aztec/accounts/testing';
|
|
2
2
|
import type { Wallet } from '@aztec/aztec.js/wallet';
|
|
3
|
-
import { Fr } from '@aztec/foundation/
|
|
3
|
+
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
4
4
|
import type { LogFn } from '@aztec/foundation/log';
|
|
5
5
|
import { FPCContract } from '@aztec/noir-contracts.js/FPC';
|
|
6
6
|
import { TokenContract } from '@aztec/noir-contracts.js/Token';
|
|
@@ -48,13 +48,17 @@ export async function getBananaFPCAddress(initialAccounts: InitialAccountData[])
|
|
|
48
48
|
export async function setupBananaFPC(initialAccounts: InitialAccountData[], wallet: Wallet, log: LogFn) {
|
|
49
49
|
const bananaCoinAddress = await getBananaCoinAddress(initialAccounts);
|
|
50
50
|
const admin = getBananaAdmin(initialAccounts);
|
|
51
|
-
const [bananaCoin, fpc] = await Promise.all([
|
|
52
|
-
TokenContract.deploy(wallet, admin, bananaCoinArgs.name, bananaCoinArgs.symbol, bananaCoinArgs.decimal)
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
51
|
+
const [{ contract: bananaCoin }, { contract: fpc }] = await Promise.all([
|
|
52
|
+
TokenContract.deploy(wallet, admin, bananaCoinArgs.name, bananaCoinArgs.symbol, bananaCoinArgs.decimal).send({
|
|
53
|
+
from: admin,
|
|
54
|
+
contractAddressSalt: BANANA_COIN_SALT,
|
|
55
|
+
universalDeploy: true,
|
|
56
|
+
}),
|
|
57
|
+
FPCContract.deploy(wallet, bananaCoinAddress, admin).send({
|
|
58
|
+
from: admin,
|
|
59
|
+
contractAddressSalt: BANANA_FPC_SALT,
|
|
60
|
+
universalDeploy: true,
|
|
61
|
+
}),
|
|
58
62
|
]);
|
|
59
63
|
|
|
60
64
|
log(`BananaCoin: ${bananaCoin.address}`);
|
|
@@ -1,40 +1,45 @@
|
|
|
1
1
|
#!/usr/bin/env -S node --no-warnings
|
|
2
2
|
import { getInitialTestAccountsData } from '@aztec/accounts/testing';
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
3
|
+
import { AztecNodeService } from '@aztec/aztec-node';
|
|
4
|
+
import { type AztecNodeConfig, getConfigEnvVars } from '@aztec/aztec-node/config';
|
|
5
|
+
import { Fr } from '@aztec/aztec.js/fields';
|
|
6
|
+
import { createLogger } from '@aztec/aztec.js/log';
|
|
7
|
+
import { type BlobClientInterface, createBlobClient } from '@aztec/blob-client/client';
|
|
6
8
|
import { GENESIS_ARCHIVE_ROOT } from '@aztec/constants';
|
|
7
|
-
import {
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
getL1ContractsConfigEnvVars,
|
|
13
|
-
waitForPublicClient,
|
|
14
|
-
} from '@aztec/ethereum';
|
|
9
|
+
import { createEthereumChain } from '@aztec/ethereum/chain';
|
|
10
|
+
import { waitForPublicClient } from '@aztec/ethereum/client';
|
|
11
|
+
import { getL1ContractsConfigEnvVars } from '@aztec/ethereum/config';
|
|
12
|
+
import { NULL_KEY } from '@aztec/ethereum/constants';
|
|
13
|
+
import { deployAztecL1Contracts } from '@aztec/ethereum/deploy-aztec-l1-contracts';
|
|
15
14
|
import { EthCheatCodes } from '@aztec/ethereum/test';
|
|
16
15
|
import { SecretValue } from '@aztec/foundation/config';
|
|
17
|
-
import {
|
|
18
|
-
import {
|
|
16
|
+
import { EthAddress } from '@aztec/foundation/eth-address';
|
|
17
|
+
import type { LogFn } from '@aztec/foundation/log';
|
|
19
18
|
import { DateProvider, TestDateProvider } from '@aztec/foundation/timer';
|
|
20
19
|
import { getVKTreeRoot } from '@aztec/noir-protocol-circuits-types/vk-tree';
|
|
21
20
|
import { protocolContractsHash } from '@aztec/protocol-contracts';
|
|
21
|
+
import { SequencerState } from '@aztec/sequencer-client';
|
|
22
|
+
import { AztecAddress } from '@aztec/stdlib/aztec-address';
|
|
23
|
+
import type { ProvingJobBroker } from '@aztec/stdlib/interfaces/server';
|
|
22
24
|
import type { PublicDataTreeLeaf } from '@aztec/stdlib/trees';
|
|
23
25
|
import {
|
|
24
26
|
type TelemetryClient,
|
|
25
27
|
getConfigEnvVars as getTelemetryClientConfig,
|
|
26
28
|
initTelemetryClient,
|
|
27
29
|
} from '@aztec/telemetry-client';
|
|
28
|
-
import {
|
|
30
|
+
import { EmbeddedWallet } from '@aztec/wallets/embedded';
|
|
31
|
+
import { deployFundedSchnorrAccounts } from '@aztec/wallets/testing';
|
|
29
32
|
import { getGenesisValues } from '@aztec/world-state/testing';
|
|
30
33
|
|
|
31
|
-
import { type
|
|
34
|
+
import { type Hex, createPublicClient, fallback, http as httpViemTransport } from 'viem';
|
|
32
35
|
import { mnemonicToAccount, privateKeyToAddress } from 'viem/accounts';
|
|
33
36
|
import { foundry } from 'viem/chains';
|
|
34
37
|
|
|
35
38
|
import { createAccountLogs } from '../cli/util.js';
|
|
36
39
|
import { DefaultMnemonic } from '../mnemonic.js';
|
|
37
40
|
import { AnvilTestWatcher } from '../testing/anvil_test_watcher.js';
|
|
41
|
+
import { EpochTestSettler } from '../testing/epoch_test_settler.js';
|
|
42
|
+
import { getTokenAllowedSetupFunctions } from '../testing/token_allowed_setup.js';
|
|
38
43
|
import { getBananaFPCAddress, setupBananaFPC } from './banana_fpc.js';
|
|
39
44
|
import { getSponsoredFPCAddress } from './sponsored_fpc.js';
|
|
40
45
|
|
|
@@ -49,42 +54,25 @@ const localAnvil = foundry;
|
|
|
49
54
|
*/
|
|
50
55
|
export async function deployContractsToL1(
|
|
51
56
|
aztecNodeConfig: AztecNodeConfig,
|
|
52
|
-
|
|
53
|
-
contractDeployLogger = logger,
|
|
57
|
+
privateKey: Hex,
|
|
54
58
|
opts: {
|
|
55
|
-
assumeProvenThroughBlockNumber?: number;
|
|
56
|
-
salt?: number;
|
|
57
59
|
genesisArchiveRoot?: Fr;
|
|
58
60
|
feeJuicePortalInitialBalance?: bigint;
|
|
59
61
|
} = {},
|
|
60
62
|
) {
|
|
61
|
-
const chain =
|
|
62
|
-
aztecNodeConfig.l1RpcUrls.length > 0
|
|
63
|
-
? createEthereumChain(aztecNodeConfig.l1RpcUrls, aztecNodeConfig.l1ChainId)
|
|
64
|
-
: { chainInfo: localAnvil };
|
|
65
|
-
|
|
66
63
|
await waitForPublicClient(aztecNodeConfig);
|
|
67
64
|
|
|
68
|
-
const l1Contracts = await
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
salt: opts.salt,
|
|
80
|
-
feeJuicePortalInitialBalance: opts.feeJuicePortalInitialBalance,
|
|
81
|
-
aztecTargetCommitteeSize: 0, // no committee in local network
|
|
82
|
-
slasherFlavor: 'none', // no slashing in local network
|
|
83
|
-
realVerifier: false,
|
|
84
|
-
},
|
|
85
|
-
);
|
|
86
|
-
|
|
87
|
-
await deployMulticall3(l1Contracts.l1Client, logger);
|
|
65
|
+
const l1Contracts = await deployAztecL1Contracts(aztecNodeConfig.l1RpcUrls[0], privateKey, foundry.id, {
|
|
66
|
+
...getL1ContractsConfigEnvVars(), // TODO: We should not need to be loading config from env again, caller should handle this
|
|
67
|
+
...aztecNodeConfig,
|
|
68
|
+
vkTreeRoot: getVKTreeRoot(),
|
|
69
|
+
protocolContractsHash,
|
|
70
|
+
genesisArchiveRoot: opts.genesisArchiveRoot ?? new Fr(GENESIS_ARCHIVE_ROOT),
|
|
71
|
+
feeJuicePortalInitialBalance: opts.feeJuicePortalInitialBalance,
|
|
72
|
+
aztecTargetCommitteeSize: 0, // no committee in local network
|
|
73
|
+
slasherFlavor: 'none', // no slashing in local network
|
|
74
|
+
realVerifier: false,
|
|
75
|
+
});
|
|
88
76
|
|
|
89
77
|
aztecNodeConfig.l1Contracts = l1Contracts.l1ContractAddresses;
|
|
90
78
|
aztecNodeConfig.rollupVersion = l1Contracts.rollupVersion;
|
|
@@ -96,8 +84,6 @@ export async function deployContractsToL1(
|
|
|
96
84
|
export type LocalNetworkConfig = AztecNodeConfig & {
|
|
97
85
|
/** Mnemonic used to derive the L1 deployer private key.*/
|
|
98
86
|
l1Mnemonic: string;
|
|
99
|
-
/** Salt used to deploy L1 contracts.*/
|
|
100
|
-
deployAztecContractsSalt: string;
|
|
101
87
|
/** Whether to deploy test accounts on local network start.*/
|
|
102
88
|
testAccounts: boolean;
|
|
103
89
|
};
|
|
@@ -116,15 +102,26 @@ export async function createLocalNetwork(config: Partial<LocalNetworkConfig> = {
|
|
|
116
102
|
if ((config.l1RpcUrls?.length || 0) > 1) {
|
|
117
103
|
logger.warn(`Multiple L1 RPC URLs provided. Local networks will only use the first one: ${l1RpcUrl}`);
|
|
118
104
|
}
|
|
119
|
-
|
|
105
|
+
|
|
106
|
+
// The local network deploys a banana FPC with Token contracts, so include Token entries
|
|
107
|
+
// in the setup allowlist so FPC-based fee payments work out of the box.
|
|
108
|
+
const tokenAllowList = await getTokenAllowedSetupFunctions();
|
|
109
|
+
|
|
110
|
+
const aztecNodeConfig: AztecNodeConfig = {
|
|
111
|
+
...getConfigEnvVars(),
|
|
112
|
+
...config,
|
|
113
|
+
txPublicSetupAllowListExtend: [...tokenAllowList, ...(config.txPublicSetupAllowListExtend ?? [])],
|
|
114
|
+
};
|
|
120
115
|
const hdAccount = mnemonicToAccount(config.l1Mnemonic || DefaultMnemonic);
|
|
121
116
|
if (
|
|
122
|
-
aztecNodeConfig.
|
|
123
|
-
!aztecNodeConfig.
|
|
124
|
-
aztecNodeConfig.
|
|
117
|
+
aztecNodeConfig.sequencerPublisherPrivateKeys == undefined ||
|
|
118
|
+
!aztecNodeConfig.sequencerPublisherPrivateKeys.length ||
|
|
119
|
+
aztecNodeConfig.sequencerPublisherPrivateKeys[0].getValue() === NULL_KEY
|
|
125
120
|
) {
|
|
126
121
|
const privKey = hdAccount.getHdKey().privateKey;
|
|
127
|
-
aztecNodeConfig.
|
|
122
|
+
aztecNodeConfig.sequencerPublisherPrivateKeys = [
|
|
123
|
+
new SecretValue(`0x${Buffer.from(privKey!).toString('hex')}` as const),
|
|
124
|
+
];
|
|
128
125
|
}
|
|
129
126
|
if (!aztecNodeConfig.validatorPrivateKeys?.getValue().length) {
|
|
130
127
|
const privKey = hdAccount.getHdKey().privateKey;
|
|
@@ -148,20 +145,28 @@ export async function createLocalNetwork(config: Partial<LocalNetworkConfig> = {
|
|
|
148
145
|
|
|
149
146
|
const bananaFPC = await getBananaFPCAddress(initialAccounts);
|
|
150
147
|
const sponsoredFPC = await getSponsoredFPCAddress();
|
|
151
|
-
const
|
|
152
|
-
|
|
153
|
-
|
|
148
|
+
const prefundAddresses = (aztecNodeConfig.prefundAddresses ?? []).map(a => AztecAddress.fromString(a));
|
|
149
|
+
const fundedAddresses = [
|
|
150
|
+
...initialAccounts.map(a => a.address),
|
|
151
|
+
...(initialAccounts.length ? [bananaFPC, sponsoredFPC] : []),
|
|
152
|
+
...prefundAddresses,
|
|
153
|
+
];
|
|
154
154
|
const { genesisArchiveRoot, prefilledPublicData, fundingNeeded } = await getGenesisValues(fundedAddresses);
|
|
155
155
|
|
|
156
|
-
let watcher: AnvilTestWatcher | undefined = undefined;
|
|
157
156
|
const dateProvider = new TestDateProvider();
|
|
157
|
+
|
|
158
|
+
let cheatcodes: EthCheatCodes | undefined;
|
|
159
|
+
let rollupAddress: EthAddress | undefined;
|
|
160
|
+
let watcher: AnvilTestWatcher | undefined;
|
|
158
161
|
if (!aztecNodeConfig.p2pEnabled) {
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
162
|
+
({ rollupAddress } = await deployContractsToL1(
|
|
163
|
+
aztecNodeConfig,
|
|
164
|
+
aztecNodeConfig.validatorPrivateKeys.getValue()[0],
|
|
165
|
+
{
|
|
166
|
+
genesisArchiveRoot,
|
|
167
|
+
feeJuicePortalInitialBalance: fundingNeeded,
|
|
168
|
+
},
|
|
169
|
+
));
|
|
165
170
|
|
|
166
171
|
const chain =
|
|
167
172
|
aztecNodeConfig.l1RpcUrls.length > 0
|
|
@@ -173,36 +178,56 @@ export async function createLocalNetwork(config: Partial<LocalNetworkConfig> = {
|
|
|
173
178
|
transport: fallback([httpViemTransport(l1RpcUrl)]) as any,
|
|
174
179
|
});
|
|
175
180
|
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
publicClient,
|
|
180
|
-
dateProvider,
|
|
181
|
-
);
|
|
181
|
+
cheatcodes = new EthCheatCodes([l1RpcUrl], dateProvider);
|
|
182
|
+
|
|
183
|
+
watcher = new AnvilTestWatcher(cheatcodes, rollupAddress, publicClient, dateProvider);
|
|
182
184
|
watcher.setisLocalNetwork(true);
|
|
185
|
+
watcher.setIsMarkingAsProven(false); // Do not mark as proven in the watcher. It's marked in the epochTestSettler after the out hash is set.
|
|
186
|
+
|
|
183
187
|
await watcher.start();
|
|
184
188
|
}
|
|
185
189
|
|
|
186
|
-
const telemetry = initTelemetryClient(getTelemetryClientConfig());
|
|
187
|
-
// Create a local blob
|
|
188
|
-
const
|
|
189
|
-
const node = await createAztecNode(
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
190
|
+
const telemetry = await initTelemetryClient(getTelemetryClientConfig());
|
|
191
|
+
// Create a local blob client client inside the local network, no http connectivity
|
|
192
|
+
const blobClient = createBlobClient();
|
|
193
|
+
const node = await createAztecNode(aztecNodeConfig, { telemetry, blobClient, dateProvider }, { prefilledPublicData });
|
|
194
|
+
|
|
195
|
+
// Now that the node is up, let the watcher check for pending txs so it can skip unfilled slots faster when
|
|
196
|
+
// transactions are waiting in the mempool. Also let it check if the sequencer is actively building, to avoid
|
|
197
|
+
// warping time out from under an in-progress block.
|
|
198
|
+
watcher?.setGetPendingTxCount(() => node.getPendingTxCount());
|
|
199
|
+
const sequencer = node.getSequencer()?.getSequencer();
|
|
200
|
+
if (sequencer) {
|
|
201
|
+
const idleStates: Set<string> = new Set([
|
|
202
|
+
SequencerState.STOPPED,
|
|
203
|
+
SequencerState.STOPPING,
|
|
204
|
+
SequencerState.IDLE,
|
|
205
|
+
SequencerState.SYNCHRONIZING,
|
|
206
|
+
]);
|
|
207
|
+
watcher?.setIsSequencerBuilding(() => !idleStates.has(sequencer.getState()));
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
let epochTestSettler: EpochTestSettler | undefined;
|
|
211
|
+
if (!aztecNodeConfig.p2pEnabled) {
|
|
212
|
+
epochTestSettler = new EpochTestSettler(
|
|
213
|
+
cheatcodes!,
|
|
214
|
+
rollupAddress!,
|
|
215
|
+
node.getBlockSource(),
|
|
216
|
+
logger.createChild('epoch-settler'),
|
|
217
|
+
{ pollingIntervalMs: 200 },
|
|
218
|
+
);
|
|
219
|
+
await epochTestSettler.start();
|
|
220
|
+
}
|
|
194
221
|
|
|
195
222
|
if (initialAccounts.length) {
|
|
196
|
-
const
|
|
197
|
-
|
|
223
|
+
const wallet = await EmbeddedWallet.create(node, {
|
|
224
|
+
pxeConfig: { proverEnabled: aztecNodeConfig.realProofs },
|
|
225
|
+
ephemeral: true,
|
|
226
|
+
});
|
|
198
227
|
|
|
199
228
|
userLog('Setting up funded test accounts...');
|
|
200
|
-
const accountManagers = await deployFundedSchnorrAccounts(wallet,
|
|
201
|
-
const
|
|
202
|
-
account: manager,
|
|
203
|
-
secretKey: initialAccounts[i].secret,
|
|
204
|
-
}));
|
|
205
|
-
const accLogs = await createAccountLogs(accountsWithSecrets, wallet);
|
|
229
|
+
const accountManagers = await deployFundedSchnorrAccounts(wallet, initialAccounts);
|
|
230
|
+
const accLogs = await createAccountLogs(accountManagers, wallet);
|
|
206
231
|
userLog(accLogs.join(''));
|
|
207
232
|
|
|
208
233
|
await setupBananaFPC(initialAccounts, wallet, userLog);
|
|
@@ -216,6 +241,7 @@ export async function createLocalNetwork(config: Partial<LocalNetworkConfig> = {
|
|
|
216
241
|
const stop = async () => {
|
|
217
242
|
await node.stop();
|
|
218
243
|
await watcher?.stop();
|
|
244
|
+
await epochTestSettler?.stop();
|
|
219
245
|
};
|
|
220
246
|
|
|
221
247
|
return { node, stop };
|
|
@@ -227,7 +253,12 @@ export async function createLocalNetwork(config: Partial<LocalNetworkConfig> = {
|
|
|
227
253
|
*/
|
|
228
254
|
export async function createAztecNode(
|
|
229
255
|
config: Partial<AztecNodeConfig> = {},
|
|
230
|
-
deps: {
|
|
256
|
+
deps: {
|
|
257
|
+
telemetry?: TelemetryClient;
|
|
258
|
+
blobClient?: BlobClientInterface;
|
|
259
|
+
dateProvider?: DateProvider;
|
|
260
|
+
proverBroker?: ProvingJobBroker;
|
|
261
|
+
} = {},
|
|
231
262
|
options: { prefilledPublicData?: PublicDataTreeLeaf[] } = {},
|
|
232
263
|
) {
|
|
233
264
|
// TODO(#12272): will clean this up. This is criminal.
|
|
@@ -237,6 +268,10 @@ export async function createAztecNode(
|
|
|
237
268
|
...config,
|
|
238
269
|
l1Contracts: { ...l1Contracts, ...config.l1Contracts },
|
|
239
270
|
};
|
|
240
|
-
const node = await AztecNodeService.createAndSync(
|
|
271
|
+
const node = await AztecNodeService.createAndSync(
|
|
272
|
+
aztecNodeConfig,
|
|
273
|
+
{ ...deps, proverNodeDeps: { broker: deps.proverBroker } },
|
|
274
|
+
options,
|
|
275
|
+
);
|
|
241
276
|
return node;
|
|
242
277
|
}
|