@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.
Files changed (136) hide show
  1. package/dest/bin/index.js +12 -5
  2. package/dest/cli/admin_api_key_store.d.ts +45 -0
  3. package/dest/cli/admin_api_key_store.d.ts.map +1 -0
  4. package/dest/cli/admin_api_key_store.js +98 -0
  5. package/dest/cli/aztec_start_action.d.ts +1 -1
  6. package/dest/cli/aztec_start_action.d.ts.map +1 -1
  7. package/dest/cli/aztec_start_action.js +55 -16
  8. package/dest/cli/aztec_start_options.d.ts +1 -1
  9. package/dest/cli/aztec_start_options.d.ts.map +1 -1
  10. package/dest/cli/aztec_start_options.js +41 -36
  11. package/dest/cli/cli.d.ts +1 -1
  12. package/dest/cli/cli.d.ts.map +1 -1
  13. package/dest/cli/cli.js +4 -37
  14. package/dest/cli/cmds/compile.d.ts +4 -0
  15. package/dest/cli/cmds/compile.d.ts.map +1 -0
  16. package/dest/cli/cmds/compile.js +160 -0
  17. package/dest/cli/cmds/migrate_ha_db.d.ts +3 -0
  18. package/dest/cli/cmds/migrate_ha_db.d.ts.map +1 -0
  19. package/dest/cli/cmds/migrate_ha_db.js +27 -0
  20. package/dest/cli/cmds/profile.d.ts +4 -0
  21. package/dest/cli/cmds/profile.d.ts.map +1 -0
  22. package/dest/cli/cmds/profile.js +8 -0
  23. package/dest/cli/cmds/profile_flamegraph.d.ts +4 -0
  24. package/dest/cli/cmds/profile_flamegraph.d.ts.map +1 -0
  25. package/dest/cli/cmds/profile_flamegraph.js +51 -0
  26. package/dest/cli/cmds/profile_gates.d.ts +4 -0
  27. package/dest/cli/cmds/profile_gates.d.ts.map +1 -0
  28. package/dest/cli/cmds/profile_gates.js +57 -0
  29. package/dest/cli/cmds/profile_utils.d.ts +18 -0
  30. package/dest/cli/cmds/profile_utils.d.ts.map +1 -0
  31. package/dest/cli/cmds/profile_utils.js +50 -0
  32. package/dest/cli/cmds/standby.d.ts +27 -0
  33. package/dest/cli/cmds/standby.d.ts.map +1 -0
  34. package/dest/cli/cmds/standby.js +78 -0
  35. package/dest/cli/cmds/start_archiver.d.ts +2 -2
  36. package/dest/cli/cmds/start_archiver.d.ts.map +1 -1
  37. package/dest/cli/cmds/start_archiver.js +12 -14
  38. package/dest/cli/cmds/start_bot.d.ts +3 -3
  39. package/dest/cli/cmds/start_bot.d.ts.map +1 -1
  40. package/dest/cli/cmds/start_bot.js +10 -6
  41. package/dest/cli/cmds/start_node.d.ts +3 -2
  42. package/dest/cli/cmds/start_node.d.ts.map +1 -1
  43. package/dest/cli/cmds/start_node.js +79 -29
  44. package/dest/cli/cmds/start_p2p_bootstrap.d.ts +2 -2
  45. package/dest/cli/cmds/start_p2p_bootstrap.d.ts.map +1 -1
  46. package/dest/cli/cmds/start_p2p_bootstrap.js +2 -3
  47. package/dest/cli/cmds/start_prover_agent.d.ts +1 -1
  48. package/dest/cli/cmds/start_prover_agent.d.ts.map +1 -1
  49. package/dest/cli/cmds/start_prover_agent.js +4 -4
  50. package/dest/cli/cmds/start_prover_broker.d.ts +1 -1
  51. package/dest/cli/cmds/start_prover_broker.d.ts.map +1 -1
  52. package/dest/cli/cmds/start_prover_broker.js +9 -9
  53. package/dest/cli/cmds/utils/artifacts.d.ts +21 -0
  54. package/dest/cli/cmds/utils/artifacts.d.ts.map +1 -0
  55. package/dest/cli/cmds/utils/artifacts.js +24 -0
  56. package/dest/cli/cmds/utils/spawn.d.ts +3 -0
  57. package/dest/cli/cmds/utils/spawn.d.ts.map +1 -0
  58. package/dest/cli/cmds/utils/spawn.js +16 -0
  59. package/dest/cli/util.d.ts +9 -20
  60. package/dest/cli/util.d.ts.map +1 -1
  61. package/dest/cli/util.js +51 -87
  62. package/dest/examples/token.js +9 -9
  63. package/dest/examples/util.d.ts +2 -2
  64. package/dest/examples/util.d.ts.map +1 -1
  65. package/dest/local-network/banana_fpc.d.ts +1 -1
  66. package/dest/local-network/banana_fpc.d.ts.map +1 -1
  67. package/dest/local-network/banana_fpc.js +4 -4
  68. package/dest/local-network/local-network.d.ts +13 -14
  69. package/dest/local-network/local-network.d.ts.map +1 -1
  70. package/dest/local-network/local-network.js +86 -43
  71. package/dest/testing/anvil_test_watcher.d.ts +10 -2
  72. package/dest/testing/anvil_test_watcher.d.ts.map +1 -1
  73. package/dest/testing/anvil_test_watcher.js +53 -16
  74. package/dest/testing/cheat_codes.d.ts +3 -1
  75. package/dest/testing/cheat_codes.d.ts.map +1 -1
  76. package/dest/testing/epoch_test_settler.d.ts +19 -0
  77. package/dest/testing/epoch_test_settler.d.ts.map +1 -0
  78. package/dest/testing/epoch_test_settler.js +62 -0
  79. package/dest/testing/index.d.ts +3 -1
  80. package/dest/testing/index.d.ts.map +1 -1
  81. package/dest/testing/index.js +2 -0
  82. package/dest/testing/token_allowed_setup.d.ts +7 -0
  83. package/dest/testing/token_allowed_setup.d.ts.map +1 -0
  84. package/dest/testing/token_allowed_setup.js +20 -0
  85. package/package.json +37 -35
  86. package/scripts/add_crate.sh +102 -0
  87. package/scripts/aztec.sh +19 -9
  88. package/scripts/init.sh +23 -19
  89. package/scripts/new.sh +48 -24
  90. package/scripts/setup_workspace.sh +68 -0
  91. package/src/bin/index.ts +13 -5
  92. package/src/cli/admin_api_key_store.ts +128 -0
  93. package/src/cli/aztec_start_action.ts +58 -11
  94. package/src/cli/aztec_start_options.ts +42 -35
  95. package/src/cli/cli.ts +4 -37
  96. package/src/cli/cmds/compile.ts +184 -0
  97. package/src/cli/cmds/migrate_ha_db.ts +43 -0
  98. package/src/cli/cmds/profile.ts +25 -0
  99. package/src/cli/cmds/profile_flamegraph.ts +63 -0
  100. package/src/cli/cmds/profile_gates.ts +67 -0
  101. package/src/cli/cmds/profile_utils.ts +58 -0
  102. package/src/cli/cmds/standby.ts +111 -0
  103. package/src/cli/cmds/start_archiver.ts +8 -19
  104. package/src/cli/cmds/start_bot.ts +9 -6
  105. package/src/cli/cmds/start_node.ts +78 -35
  106. package/src/cli/cmds/start_p2p_bootstrap.ts +3 -3
  107. package/src/cli/cmds/start_prover_agent.ts +4 -12
  108. package/src/cli/cmds/start_prover_broker.ts +13 -16
  109. package/src/cli/cmds/utils/artifacts.ts +44 -0
  110. package/src/cli/cmds/utils/spawn.ts +16 -0
  111. package/src/cli/util.ts +60 -98
  112. package/src/examples/token.ts +10 -10
  113. package/src/examples/util.ts +1 -1
  114. package/src/local-network/banana_fpc.ts +12 -8
  115. package/src/local-network/local-network.ts +120 -85
  116. package/src/testing/anvil_test_watcher.ts +61 -17
  117. package/src/testing/cheat_codes.ts +3 -2
  118. package/src/testing/epoch_test_settler.ts +71 -0
  119. package/src/testing/index.ts +2 -0
  120. package/src/testing/token_allowed_setup.ts +19 -0
  121. package/dest/cli/cmds/start_blob_sink.d.ts +0 -3
  122. package/dest/cli/cmds/start_blob_sink.d.ts.map +0 -1
  123. package/dest/cli/cmds/start_blob_sink.js +0 -33
  124. package/dest/cli/cmds/start_prover_node.d.ts +0 -7
  125. package/dest/cli/cmds/start_prover_node.d.ts.map +0 -1
  126. package/dest/cli/cmds/start_prover_node.js +0 -108
  127. package/dest/cli/release_version.d.ts +0 -2
  128. package/dest/cli/release_version.d.ts.map +0 -1
  129. package/dest/cli/release_version.js +0 -14
  130. package/scripts/compile.sh +0 -44
  131. package/scripts/extract_function.js +0 -47
  132. package/scripts/flamegraph.sh +0 -59
  133. package/scripts/setup_project.sh +0 -31
  134. package/src/cli/cmds/start_blob_sink.ts +0 -57
  135. package/src/cli/cmds/start_prover_node.ts +0 -124
  136. 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 { EthAddress } from '@aztec/aztec.js/addresses';
3
- import { Fr } from '@aztec/aztec.js/fields';
4
- import { AccountManager } from '@aztec/aztec.js/wallet';
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 { UpdateChecker } from '@aztec/stdlib/update-checker';
11
- import { getTelemetryClient } from '@aztec/telemetry-client';
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 TestWallet instance to get the registered accounts
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 accountWithSecretKey of accountsWithSecretKeys) {
91
- const completeAddress = await accountWithSecretKey.account.getCompleteAddress();
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: ${accountWithSecretKey.secretKey.toString()}\n`);
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 + 1, undefined, log)]);
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 + 1, undefined, log), GrumpkinCrs.new(2 ** 18 + 1, undefined, log)]);
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 setupUpdateMonitor(
306
- autoUpdateMode: SharedNodeConfig['autoUpdate'],
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
- updateNodeConfig?: (config: object) => Promise<void>,
313
- ) {
314
- const logger = createLogger('update-check');
315
- const checker = await UpdateChecker.new({
316
- baseURL: updatesLocation,
317
- publicClient,
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
- // eslint-disable-next-line @typescript-eslint/no-misused-promises
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
- // if node follows canonical rollup then this is equivalent to a config update
328
- if (!followsCanonicalRollup) {
329
- return;
330
- }
308
+ const logger = createLogger('version_check');
309
+ const registry = new RegistryContract(publicClient, networkConfig.registryAddress as Hex);
331
310
 
332
- if (autoUpdateMode === 'config' || autoUpdateMode === 'config-and-version') {
333
- logger.info(`New rollup version detected. Please restart the node`, { latestVersion, currentVersion });
334
- await shutdown(logger.info, ExitCode.ROLLUP_UPGRADE, signalHandlers);
335
- } else if (autoUpdateMode === 'notify') {
336
- logger.warn(`New rollup detected. Please restart the node`, { latestVersion, currentVersion });
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
- // eslint-disable-next-line @typescript-eslint/no-misused-promises
341
- checker.on('newNodeVersion', async ({ latestVersion, currentVersion }) => {
342
- if (isShuttingDown()) {
343
- return;
344
- }
345
- if (autoUpdateMode === 'config-and-version') {
346
- logger.info(`New node version detected. Please update and restart the node`, { latestVersion, currentVersion });
347
- await shutdown(logger.info, ExitCode.VERSION_UPGRADE, signalHandlers);
348
- } else if (autoUpdateMode === 'notify') {
349
- logger.info(`New node version detected. Please update and restart the node`, { latestVersion, currentVersion });
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
- // eslint-disable-next-line @typescript-eslint/no-misused-promises
354
- checker.on('updateNodeConfig', async config => {
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
- if ((autoUpdateMode === 'config' || autoUpdateMode === 'config-and-version') && updateNodeConfig) {
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
  }
@@ -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 { TestWallet } from '@aztec/test-wallet/server';
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 TestWallet.create(node);
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
- .send({ from: alice })
37
- .deployed();
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 }).wait();
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 }).wait();
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
 
@@ -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/fields';
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
- .send({ from: admin, contractAddressSalt: BANANA_COIN_SALT, universalDeploy: true })
54
- .deployed(),
55
- FPCContract.deploy(wallet, bananaCoinAddress, admin)
56
- .send({ from: admin, contractAddressSalt: BANANA_FPC_SALT, universalDeploy: true })
57
- .deployed(),
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 { type AztecNodeConfig, AztecNodeService, getConfigEnvVars } from '@aztec/aztec-node';
4
- import { EthAddress } from '@aztec/aztec.js/addresses';
5
- import { type BlobSinkClientInterface, createBlobSinkClient } from '@aztec/blob-sink/client';
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
- NULL_KEY,
9
- createEthereumChain,
10
- deployL1Contracts,
11
- deployMulticall3,
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 { Fr } from '@aztec/foundation/fields';
18
- import { type LogFn, createLogger } from '@aztec/foundation/log';
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 { TestWallet, deployFundedSchnorrAccounts } from '@aztec/test-wallet/server';
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 HDAccount, type PrivateKeyAccount, createPublicClient, fallback, http as httpViemTransport } from 'viem';
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
- hdAccount: HDAccount | PrivateKeyAccount,
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 deployL1Contracts(
69
- aztecNodeConfig.l1RpcUrls,
70
- hdAccount,
71
- chain.chainInfo,
72
- contractDeployLogger,
73
- {
74
- ...getL1ContractsConfigEnvVars(), // TODO: We should not need to be loading config from env again, caller should handle this
75
- ...aztecNodeConfig,
76
- vkTreeRoot: getVKTreeRoot(),
77
- protocolContractsHash,
78
- genesisArchiveRoot: opts.genesisArchiveRoot ?? new Fr(GENESIS_ARCHIVE_ROOT),
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
- const aztecNodeConfig: AztecNodeConfig = { ...getConfigEnvVars(), ...config };
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.publisherPrivateKeys == undefined ||
123
- !aztecNodeConfig.publisherPrivateKeys.length ||
124
- aztecNodeConfig.publisherPrivateKeys[0].getValue() === NULL_KEY
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.publisherPrivateKeys = [new SecretValue(`0x${Buffer.from(privKey!).toString('hex')}` as const)];
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 fundedAddresses = initialAccounts.length
152
- ? [...initialAccounts.map(a => a.address), bananaFPC, sponsoredFPC]
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
- const l1ContractAddresses = await deployContractsToL1(aztecNodeConfig, hdAccount, undefined, {
160
- assumeProvenThroughBlockNumber: Number.MAX_SAFE_INTEGER,
161
- genesisArchiveRoot,
162
- salt: config.deployAztecContractsSalt ? parseInt(config.deployAztecContractsSalt) : undefined,
163
- feeJuicePortalInitialBalance: fundingNeeded,
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
- watcher = new AnvilTestWatcher(
177
- new EthCheatCodes([l1RpcUrl], dateProvider),
178
- l1ContractAddresses.rollupAddress,
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 sink client inside the local network, no http connectivity
188
- const blobSinkClient = createBlobSinkClient();
189
- const node = await createAztecNode(
190
- aztecNodeConfig,
191
- { telemetry, blobSinkClient, dateProvider },
192
- { prefilledPublicData },
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 PXEConfig = { proverEnabled: aztecNodeConfig.realProofs };
197
- const wallet = await TestWallet.create(node, PXEConfig);
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, node, initialAccounts);
201
- const accountsWithSecrets = accountManagers.map((manager, i) => ({
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: { telemetry?: TelemetryClient; blobSinkClient?: BlobSinkClientInterface; dateProvider?: DateProvider } = {},
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(aztecNodeConfig, deps, options);
271
+ const node = await AztecNodeService.createAndSync(
272
+ aztecNodeConfig,
273
+ { ...deps, proverNodeDeps: { broker: deps.proverBroker } },
274
+ options,
275
+ );
241
276
  return node;
242
277
  }