@aztec/aztec 3.0.3 → 4.0.0-devnet.1-patch.0

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 (68) hide show
  1. package/dest/bin/index.js +2 -0
  2. package/dest/cli/aztec_start_action.d.ts +1 -1
  3. package/dest/cli/aztec_start_action.d.ts.map +1 -1
  4. package/dest/cli/aztec_start_action.js +6 -4
  5. package/dest/cli/aztec_start_options.d.ts +1 -1
  6. package/dest/cli/aztec_start_options.d.ts.map +1 -1
  7. package/dest/cli/aztec_start_options.js +9 -15
  8. package/dest/cli/cli.d.ts +1 -1
  9. package/dest/cli/cli.d.ts.map +1 -1
  10. package/dest/cli/cli.js +9 -53
  11. package/dest/cli/cmds/migrate_ha_db.d.ts +3 -0
  12. package/dest/cli/cmds/migrate_ha_db.d.ts.map +1 -0
  13. package/dest/cli/cmds/migrate_ha_db.js +27 -0
  14. package/dest/cli/cmds/start_archiver.d.ts +1 -1
  15. package/dest/cli/cmds/start_archiver.d.ts.map +1 -1
  16. package/dest/cli/cmds/start_archiver.js +10 -12
  17. package/dest/cli/cmds/start_p2p_bootstrap.d.ts +2 -2
  18. package/dest/cli/cmds/start_p2p_bootstrap.d.ts.map +1 -1
  19. package/dest/cli/cmds/start_p2p_bootstrap.js +1 -2
  20. package/dest/cli/cmds/start_prover_agent.d.ts +1 -1
  21. package/dest/cli/cmds/start_prover_agent.d.ts.map +1 -1
  22. package/dest/cli/cmds/start_prover_agent.js +3 -3
  23. package/dest/cli/cmds/start_prover_broker.d.ts +1 -1
  24. package/dest/cli/cmds/start_prover_broker.d.ts.map +1 -1
  25. package/dest/cli/cmds/start_prover_broker.js +2 -2
  26. package/dest/cli/util.js +1 -1
  27. package/dest/examples/token.js +3 -3
  28. package/dest/local-network/banana_fpc.d.ts +1 -1
  29. package/dest/local-network/banana_fpc.d.ts.map +1 -1
  30. package/dest/local-network/banana_fpc.js +2 -2
  31. package/dest/local-network/local-network.d.ts +4 -5
  32. package/dest/local-network/local-network.d.ts.map +1 -1
  33. package/dest/local-network/local-network.js +24 -12
  34. package/dest/testing/cheat_codes.d.ts +3 -1
  35. package/dest/testing/cheat_codes.d.ts.map +1 -1
  36. package/dest/testing/epoch_test_settler.d.ts +19 -0
  37. package/dest/testing/epoch_test_settler.d.ts.map +1 -0
  38. package/dest/testing/epoch_test_settler.js +62 -0
  39. package/dest/testing/index.d.ts +2 -1
  40. package/dest/testing/index.d.ts.map +1 -1
  41. package/dest/testing/index.js +1 -0
  42. package/package.json +37 -35
  43. package/scripts/aztec.sh +63 -0
  44. package/scripts/compile.sh +44 -0
  45. package/scripts/extract_function.js +47 -0
  46. package/scripts/flamegraph.sh +59 -0
  47. package/scripts/init.sh +35 -0
  48. package/scripts/new.sh +59 -0
  49. package/scripts/setup_project.sh +31 -0
  50. package/src/bin/index.ts +2 -0
  51. package/src/cli/aztec_start_action.ts +5 -3
  52. package/src/cli/aztec_start_options.ts +8 -14
  53. package/src/cli/cli.ts +12 -56
  54. package/src/cli/cmds/migrate_ha_db.ts +43 -0
  55. package/src/cli/cmds/start_archiver.ts +6 -17
  56. package/src/cli/cmds/start_p2p_bootstrap.ts +2 -2
  57. package/src/cli/cmds/start_prover_agent.ts +3 -11
  58. package/src/cli/cmds/start_prover_broker.ts +5 -1
  59. package/src/cli/util.ts +1 -1
  60. package/src/examples/token.ts +3 -5
  61. package/src/local-network/banana_fpc.ts +10 -6
  62. package/src/local-network/local-network.ts +37 -23
  63. package/src/testing/epoch_test_settler.ts +71 -0
  64. package/src/testing/index.ts +1 -0
  65. package/dest/cli/cmds/start_blob_sink.d.ts +0 -3
  66. package/dest/cli/cmds/start_blob_sink.d.ts.map +0 -1
  67. package/dest/cli/cmds/start_blob_sink.js +0 -33
  68. package/src/cli/cmds/start_blob_sink.ts +0 -57
@@ -1,10 +1,10 @@
1
1
  #!/usr/bin/env -S node --no-warnings
2
- import { getInitialTestAccountsData } from '@aztec/accounts/testing/lazy';
2
+ import { getInitialTestAccountsData } from '@aztec/accounts/testing';
3
3
  import { AztecNodeService } from '@aztec/aztec-node';
4
4
  import { getConfigEnvVars } from '@aztec/aztec-node/config';
5
5
  import { Fr } from '@aztec/aztec.js/fields';
6
6
  import { createLogger } from '@aztec/aztec.js/log';
7
- import { createBlobSinkClient } from '@aztec/blob-sink/client';
7
+ import { createBlobClient } from '@aztec/blob-client/client';
8
8
  import { GENESIS_ARCHIVE_ROOT } from '@aztec/constants';
9
9
  import { createEthereumChain } from '@aztec/ethereum/chain';
10
10
  import { waitForPublicClient } from '@aztec/ethereum/client';
@@ -26,6 +26,7 @@ import { foundry } from 'viem/chains';
26
26
  import { createAccountLogs } from '../cli/util.js';
27
27
  import { DefaultMnemonic } from '../mnemonic.js';
28
28
  import { AnvilTestWatcher } from '../testing/anvil_test_watcher.js';
29
+ import { EpochTestSettler } from '../testing/epoch_test_settler.js';
29
30
  import { getBananaFPCAddress, setupBananaFPC } from './banana_fpc.js';
30
31
  import { getSponsoredFPCAddress } from './sponsored_fpc.js';
31
32
  const logger = createLogger('local-network');
@@ -101,14 +102,15 @@ const localAnvil = foundry;
101
102
  sponsoredFPC
102
103
  ] : [];
103
104
  const { genesisArchiveRoot, prefilledPublicData, fundingNeeded } = await getGenesisValues(fundedAddresses);
104
- let watcher = undefined;
105
105
  const dateProvider = new TestDateProvider();
106
+ let cheatcodes;
107
+ let rollupAddress;
108
+ let watcher;
106
109
  if (!aztecNodeConfig.p2pEnabled) {
107
- const l1ContractAddresses = await deployContractsToL1(aztecNodeConfig, aztecNodeConfig.validatorPrivateKeys.getValue()[0], {
108
- assumeProvenThroughBlockNumber: Number.MAX_SAFE_INTEGER,
110
+ ({ rollupAddress } = await deployContractsToL1(aztecNodeConfig, aztecNodeConfig.validatorPrivateKeys.getValue()[0], {
109
111
  genesisArchiveRoot,
110
112
  feeJuicePortalInitialBalance: fundingNeeded
111
- });
113
+ }));
112
114
  const chain = aztecNodeConfig.l1RpcUrls.length > 0 ? createEthereumChain([
113
115
  l1RpcUrl
114
116
  ], aztecNodeConfig.l1ChainId) : {
@@ -120,29 +122,38 @@ const localAnvil = foundry;
120
122
  httpViemTransport(l1RpcUrl)
121
123
  ])
122
124
  });
123
- watcher = new AnvilTestWatcher(new EthCheatCodes([
125
+ cheatcodes = new EthCheatCodes([
124
126
  l1RpcUrl
125
- ], dateProvider), l1ContractAddresses.rollupAddress, publicClient, dateProvider);
127
+ ], dateProvider);
128
+ watcher = new AnvilTestWatcher(cheatcodes, rollupAddress, publicClient, dateProvider);
126
129
  watcher.setisLocalNetwork(true);
130
+ watcher.setIsMarkingAsProven(false); // Do not mark as proven in the watcher. It's marked in the epochTestSettler after the out hash is set.
127
131
  await watcher.start();
128
132
  }
129
133
  const telemetry = await initTelemetryClient(getTelemetryClientConfig());
130
- // Create a local blob sink client inside the local network, no http connectivity
131
- const blobSinkClient = createBlobSinkClient();
134
+ // Create a local blob client client inside the local network, no http connectivity
135
+ const blobClient = createBlobClient();
132
136
  const node = await createAztecNode(aztecNodeConfig, {
133
137
  telemetry,
134
- blobSinkClient,
138
+ blobClient,
135
139
  dateProvider
136
140
  }, {
137
141
  prefilledPublicData
138
142
  });
143
+ let epochTestSettler;
144
+ if (!aztecNodeConfig.p2pEnabled) {
145
+ epochTestSettler = new EpochTestSettler(cheatcodes, rollupAddress, node.getBlockSource(), logger.createChild('epoch-settler'), {
146
+ pollingIntervalMs: 200
147
+ });
148
+ await epochTestSettler.start();
149
+ }
139
150
  if (initialAccounts.length) {
140
151
  const PXEConfig = {
141
152
  proverEnabled: aztecNodeConfig.realProofs
142
153
  };
143
154
  const wallet = await TestWallet.create(node, PXEConfig);
144
155
  userLog('Setting up funded test accounts...');
145
- const accountManagers = await deployFundedSchnorrAccounts(wallet, node, initialAccounts);
156
+ const accountManagers = await deployFundedSchnorrAccounts(wallet, initialAccounts);
146
157
  const accountsWithSecrets = accountManagers.map((manager, i)=>({
147
158
  account: manager,
148
159
  secretKey: initialAccounts[i].secret
@@ -157,6 +168,7 @@ const localAnvil = foundry;
157
168
  const stop = async ()=>{
158
169
  await node.stop();
159
170
  await watcher?.stop();
171
+ await epochTestSettler?.stop();
160
172
  };
161
173
  return {
162
174
  node,
@@ -9,7 +9,9 @@ import type { AztecNode } from '@aztec/stdlib/interfaces/client';
9
9
  * codes, please consider whether it makes sense to just introduce new utils in your tests instead.
10
10
  */
11
11
  export declare class CheatCodes {
12
+ /** Cheat codes for L1.*/
12
13
  eth: EthCheatCodes;
14
+ /** Cheat codes for the Aztec Rollup contract on L1. */
13
15
  rollup: RollupCheatCodes;
14
16
  constructor(
15
17
  /** Cheat codes for L1.*/
@@ -38,4 +40,4 @@ export declare class CheatCodes {
38
40
  */
39
41
  warpL2TimeAtLeastBy(sequencerClient: SequencerClient, node: AztecNode, duration: bigint | number): Promise<void>;
40
42
  }
41
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlYXRfY29kZXMuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90ZXN0aW5nL2NoZWF0X2NvZGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxhQUFhLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUd2RSxPQUFPLEtBQUssRUFBRSxZQUFZLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM1RCxPQUFPLEtBQUssRUFBRSxlQUFlLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUMvRCxPQUFPLEtBQUssRUFBRSxTQUFTLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUVqRTs7Ozs7R0FLRztBQUNILHFCQUFhLFVBQVU7SUFHWixHQUFHLEVBQUUsYUFBYTtJQUVsQixNQUFNLEVBQUUsZ0JBQWdCO0lBSmpDO0lBQ0UseUJBQXlCO0lBQ2xCLEdBQUcsRUFBRSxhQUFhO0lBQ3pCLHVEQUF1RDtJQUNoRCxNQUFNLEVBQUUsZ0JBQWdCLEVBQzdCO0lBRUosT0FBYSxNQUFNLENBQUMsT0FBTyxFQUFFLE1BQU0sRUFBRSxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLFlBQVksR0FBRyxPQUFPLENBQUMsVUFBVSxDQUFDLENBT3ZHO0lBRUQ7Ozs7Ozs7O09BUUc7SUFDRyxtQkFBbUIsQ0FBQyxlQUFlLEVBQUUsZUFBZSxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsZUFBZSxFQUFFLE1BQU0sR0FBRyxNQUFNLGlCQXVCNUc7SUFFRDs7Ozs7Ozs7T0FRRztJQUNHLG1CQUFtQixDQUFDLGVBQWUsRUFBRSxlQUFlLEVBQUUsSUFBSSxFQUFFLFNBQVMsRUFBRSxRQUFRLEVBQUUsTUFBTSxHQUFHLE1BQU0saUJBSXJHO0NBQ0YifQ==
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlYXRfY29kZXMuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90ZXN0aW5nL2NoZWF0X2NvZGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxhQUFhLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUd2RSxPQUFPLEtBQUssRUFBRSxZQUFZLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM1RCxPQUFPLEtBQUssRUFBRSxlQUFlLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUMvRCxPQUFPLEtBQUssRUFBRSxTQUFTLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUVqRTs7Ozs7R0FLRztBQUNILHFCQUFhLFVBQVU7SUFFbkIseUJBQXlCO0lBQ2xCLEdBQUcsRUFBRSxhQUFhO0lBQ3pCLHVEQUF1RDtJQUNoRCxNQUFNLEVBQUUsZ0JBQWdCO0lBSmpDO0lBQ0UseUJBQXlCO0lBQ2xCLEdBQUcsRUFBRSxhQUFhO0lBQ3pCLHVEQUF1RDtJQUNoRCxNQUFNLEVBQUUsZ0JBQWdCLEVBQzdCO0lBRUosT0FBYSxNQUFNLENBQUMsT0FBTyxFQUFFLE1BQU0sRUFBRSxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLFlBQVksR0FBRyxPQUFPLENBQUMsVUFBVSxDQUFDLENBT3ZHO0lBRUQ7Ozs7Ozs7O09BUUc7SUFDRyxtQkFBbUIsQ0FBQyxlQUFlLEVBQUUsZUFBZSxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsZUFBZSxFQUFFLE1BQU0sR0FBRyxNQUFNLGlCQXVCNUc7SUFFRDs7Ozs7Ozs7T0FRRztJQUNHLG1CQUFtQixDQUFDLGVBQWUsRUFBRSxlQUFlLEVBQUUsSUFBSSxFQUFFLFNBQVMsRUFBRSxRQUFRLEVBQUUsTUFBTSxHQUFHLE1BQU0saUJBSXJHO0NBQ0YifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"cheat_codes.d.ts","sourceRoot":"","sources":["../../src/testing/cheat_codes.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAGvE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAC5D,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC/D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iCAAiC,CAAC;AAEjE;;;;;GAKG;AACH,qBAAa,UAAU;IAGZ,GAAG,EAAE,aAAa;IAElB,MAAM,EAAE,gBAAgB;IAJjC;IACE,yBAAyB;IAClB,GAAG,EAAE,aAAa;IACzB,uDAAuD;IAChD,MAAM,EAAE,gBAAgB,EAC7B;IAEJ,OAAa,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,YAAY,EAAE,YAAY,GAAG,OAAO,CAAC,UAAU,CAAC,CAOvG;IAED;;;;;;;;OAQG;IACG,mBAAmB,CAAC,eAAe,EAAE,eAAe,EAAE,IAAI,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,GAAG,MAAM,iBAuB5G;IAED;;;;;;;;OAQG;IACG,mBAAmB,CAAC,eAAe,EAAE,eAAe,EAAE,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,GAAG,MAAM,iBAIrG;CACF"}
1
+ {"version":3,"file":"cheat_codes.d.ts","sourceRoot":"","sources":["../../src/testing/cheat_codes.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAGvE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAC5D,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC/D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iCAAiC,CAAC;AAEjE;;;;;GAKG;AACH,qBAAa,UAAU;IAEnB,yBAAyB;IAClB,GAAG,EAAE,aAAa;IACzB,uDAAuD;IAChD,MAAM,EAAE,gBAAgB;IAJjC;IACE,yBAAyB;IAClB,GAAG,EAAE,aAAa;IACzB,uDAAuD;IAChD,MAAM,EAAE,gBAAgB,EAC7B;IAEJ,OAAa,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,YAAY,EAAE,YAAY,GAAG,OAAO,CAAC,UAAU,CAAC,CAOvG;IAED;;;;;;;;OAQG;IACG,mBAAmB,CAAC,eAAe,EAAE,eAAe,EAAE,IAAI,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,GAAG,MAAM,iBAuB5G;IAED;;;;;;;;OAQG;IACG,mBAAmB,CAAC,eAAe,EAAE,eAAe,EAAE,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,GAAG,MAAM,iBAIrG;CACF"}
@@ -0,0 +1,19 @@
1
+ import { type EthCheatCodes } from '@aztec/ethereum/test';
2
+ import { type EpochNumber } from '@aztec/foundation/branded-types';
3
+ import type { Logger } from '@aztec/foundation/log';
4
+ import type { EthAddress, L2BlockSource } from '@aztec/stdlib/block';
5
+ export declare class EpochTestSettler {
6
+ private l2BlockSource;
7
+ private log;
8
+ private options;
9
+ private rollupCheatCodes;
10
+ private epochMonitor?;
11
+ constructor(cheatcodes: EthCheatCodes, rollupAddress: EthAddress, l2BlockSource: L2BlockSource, log: Logger, options: {
12
+ pollingIntervalMs: number;
13
+ provingDelayMs?: number;
14
+ });
15
+ start(): Promise<void>;
16
+ stop(): Promise<void>;
17
+ handleEpochReadyToProve(epoch: EpochNumber): Promise<boolean>;
18
+ }
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXBvY2hfdGVzdF9zZXR0bGVyLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdGVzdGluZy9lcG9jaF90ZXN0X3NldHRsZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLEtBQUssYUFBYSxFQUFvQixNQUFNLHNCQUFzQixDQUFDO0FBQzVFLE9BQU8sRUFBRSxLQUFLLFdBQVcsRUFBYyxNQUFNLGlDQUFpQyxDQUFDO0FBQy9FLE9BQU8sS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBRXBELE9BQU8sS0FBSyxFQUFFLFVBQVUsRUFBRSxhQUFhLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUdyRSxxQkFBYSxnQkFBZ0I7SUFPekIsT0FBTyxDQUFDLGFBQWE7SUFDckIsT0FBTyxDQUFDLEdBQUc7SUFDWCxPQUFPLENBQUMsT0FBTztJQVJqQixPQUFPLENBQUMsZ0JBQWdCLENBQW1CO0lBQzNDLE9BQU8sQ0FBQyxZQUFZLENBQUMsQ0FBZTtJQUVwQyxZQUNFLFVBQVUsRUFBRSxhQUFhLEVBQ3pCLGFBQWEsRUFBRSxVQUFVLEVBQ2pCLGFBQWEsRUFBRSxhQUFhLEVBQzVCLEdBQUcsRUFBRSxNQUFNLEVBQ1gsT0FBTyxFQUFFO1FBQUUsaUJBQWlCLEVBQUUsTUFBTSxDQUFDO1FBQUMsY0FBYyxDQUFDLEVBQUUsTUFBTSxDQUFBO0tBQUUsRUFHeEU7SUFFSyxLQUFLLGtCQUlWO0lBRUssSUFBSSxrQkFFVDtJQUVLLHVCQUF1QixDQUFDLEtBQUssRUFBRSxXQUFXLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQXFDbEU7Q0FDRiJ9
@@ -0,0 +1 @@
1
+ {"version":3,"file":"epoch_test_settler.d.ts","sourceRoot":"","sources":["../../src/testing/epoch_test_settler.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,aAAa,EAAoB,MAAM,sBAAsB,CAAC;AAC5E,OAAO,EAAE,KAAK,WAAW,EAAc,MAAM,iCAAiC,CAAC;AAC/E,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAEpD,OAAO,KAAK,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAGrE,qBAAa,gBAAgB;IAOzB,OAAO,CAAC,aAAa;IACrB,OAAO,CAAC,GAAG;IACX,OAAO,CAAC,OAAO;IARjB,OAAO,CAAC,gBAAgB,CAAmB;IAC3C,OAAO,CAAC,YAAY,CAAC,CAAe;IAEpC,YACE,UAAU,EAAE,aAAa,EACzB,aAAa,EAAE,UAAU,EACjB,aAAa,EAAE,aAAa,EAC5B,GAAG,EAAE,MAAM,EACX,OAAO,EAAE;QAAE,iBAAiB,EAAE,MAAM,CAAC;QAAC,cAAc,CAAC,EAAE,MAAM,CAAA;KAAE,EAGxE;IAEK,KAAK,kBAIV;IAEK,IAAI,kBAET;IAEK,uBAAuB,CAAC,KAAK,EAAE,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC,CAqClE;CACF"}
@@ -0,0 +1,62 @@
1
+ import { RollupCheatCodes } from '@aztec/ethereum/test';
2
+ import { SlotNumber } from '@aztec/foundation/branded-types';
3
+ import { EpochMonitor } from '@aztec/prover-node';
4
+ import { computeL2ToL1MembershipWitnessFromMessagesInEpoch } from '@aztec/stdlib/messaging';
5
+ export class EpochTestSettler {
6
+ l2BlockSource;
7
+ log;
8
+ options;
9
+ rollupCheatCodes;
10
+ epochMonitor;
11
+ constructor(cheatcodes, rollupAddress, l2BlockSource, log, options){
12
+ this.l2BlockSource = l2BlockSource;
13
+ this.log = log;
14
+ this.options = options;
15
+ this.rollupCheatCodes = new RollupCheatCodes(cheatcodes, {
16
+ rollupAddress
17
+ });
18
+ }
19
+ async start() {
20
+ const { epochDuration } = await this.rollupCheatCodes.getConfig();
21
+ this.epochMonitor = new EpochMonitor(this.l2BlockSource, {
22
+ epochDuration: Number(epochDuration)
23
+ }, this.options);
24
+ this.epochMonitor.start(this);
25
+ }
26
+ async stop() {
27
+ await this.epochMonitor?.stop();
28
+ }
29
+ async handleEpochReadyToProve(epoch) {
30
+ const checkpointedBlocks = await this.l2BlockSource.getCheckpointedBlocksForEpoch(epoch);
31
+ const blocks = checkpointedBlocks.map((b)=>b.block);
32
+ this.log.info(`Settling epoch ${epoch} with blocks ${blocks[0]?.header.getBlockNumber()} to ${blocks.at(-1)?.header.getBlockNumber()}`, {
33
+ blocks: blocks.map((b)=>b.toBlockInfo())
34
+ });
35
+ const messagesInEpoch = [];
36
+ let previousSlotNumber = SlotNumber.ZERO;
37
+ let checkpointIndex = -1;
38
+ for (const block of blocks){
39
+ const slotNumber = block.header.globalVariables.slotNumber;
40
+ if (slotNumber !== previousSlotNumber) {
41
+ checkpointIndex++;
42
+ messagesInEpoch[checkpointIndex] = [];
43
+ previousSlotNumber = slotNumber;
44
+ }
45
+ messagesInEpoch[checkpointIndex].push(block.body.txEffects.map((txEffect)=>txEffect.l2ToL1Msgs));
46
+ }
47
+ const [firstMessage] = messagesInEpoch.flat(3);
48
+ if (firstMessage) {
49
+ const { root: outHash } = computeL2ToL1MembershipWitnessFromMessagesInEpoch(messagesInEpoch, firstMessage);
50
+ await this.rollupCheatCodes.insertOutbox(epoch, outHash.toBigInt());
51
+ } else {
52
+ this.log.info(`No L2 to L1 messages in epoch ${epoch}`);
53
+ }
54
+ const lastCheckpoint = checkpointedBlocks.at(-1)?.checkpointNumber;
55
+ if (lastCheckpoint !== undefined) {
56
+ await this.rollupCheatCodes.markAsProven(lastCheckpoint);
57
+ } else {
58
+ this.log.warn(`No checkpoint found for epoch ${epoch}`);
59
+ }
60
+ return true;
61
+ }
62
+ }
@@ -1,4 +1,5 @@
1
1
  export { AnvilTestWatcher } from './anvil_test_watcher.js';
2
2
  export { EthCheatCodes, RollupCheatCodes } from '@aztec/ethereum/test';
3
3
  export { CheatCodes } from './cheat_codes.js';
4
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90ZXN0aW5nL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzNELE9BQU8sRUFBRSxhQUFhLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN2RSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sa0JBQWtCLENBQUMifQ==
4
+ export { EpochTestSettler } from './epoch_test_settler.js';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90ZXN0aW5nL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzNELE9BQU8sRUFBRSxhQUFhLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN2RSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDOUMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0seUJBQXlCLENBQUMifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/testing/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAC3D,OAAO,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AACvE,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/testing/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAC3D,OAAO,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AACvE,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC"}
@@ -1,3 +1,4 @@
1
1
  export { AnvilTestWatcher } from './anvil_test_watcher.js';
2
2
  export { EthCheatCodes, RollupCheatCodes } from '@aztec/ethereum/test';
3
3
  export { CheatCodes } from './cheat_codes.js';
4
+ export { EpochTestSettler } from './epoch_test_settler.js';
package/package.json CHANGED
@@ -1,12 +1,12 @@
1
1
  {
2
2
  "name": "@aztec/aztec",
3
- "version": "3.0.3",
3
+ "version": "4.0.0-devnet.1-patch.0",
4
4
  "type": "module",
5
5
  "exports": {
6
6
  ".": "./dest/index.js",
7
7
  "./testing": "./dest/testing/index.js"
8
8
  },
9
- "bin": "./dest/bin/index.js",
9
+ "bin": "./scripts/aztec.sh",
10
10
  "typedocOptions": {
11
11
  "entryPoints": [
12
12
  "./src/index.ts"
@@ -28,38 +28,39 @@
28
28
  "../package.common.json"
29
29
  ],
30
30
  "dependencies": {
31
- "@aztec/accounts": "3.0.3",
32
- "@aztec/archiver": "3.0.3",
33
- "@aztec/aztec-faucet": "3.0.3",
34
- "@aztec/aztec-node": "3.0.3",
35
- "@aztec/aztec.js": "3.0.3",
36
- "@aztec/bb-prover": "3.0.3",
37
- "@aztec/bb.js": "3.0.3",
38
- "@aztec/blob-sink": "3.0.3",
39
- "@aztec/bot": "3.0.3",
40
- "@aztec/builder": "3.0.3",
41
- "@aztec/cli": "3.0.3",
42
- "@aztec/constants": "3.0.3",
43
- "@aztec/entrypoints": "3.0.3",
44
- "@aztec/ethereum": "3.0.3",
45
- "@aztec/foundation": "3.0.3",
46
- "@aztec/kv-store": "3.0.3",
47
- "@aztec/l1-artifacts": "3.0.3",
48
- "@aztec/node-lib": "3.0.3",
49
- "@aztec/noir-contracts.js": "3.0.3",
50
- "@aztec/noir-protocol-circuits-types": "3.0.3",
51
- "@aztec/p2p": "3.0.3",
52
- "@aztec/p2p-bootstrap": "3.0.3",
53
- "@aztec/protocol-contracts": "3.0.3",
54
- "@aztec/prover-client": "3.0.3",
55
- "@aztec/prover-node": "3.0.3",
56
- "@aztec/pxe": "3.0.3",
57
- "@aztec/sequencer-client": "3.0.3",
58
- "@aztec/stdlib": "3.0.3",
59
- "@aztec/telemetry-client": "3.0.3",
60
- "@aztec/test-wallet": "3.0.3",
61
- "@aztec/txe": "3.0.3",
62
- "@aztec/world-state": "3.0.3",
31
+ "@aztec/accounts": "4.0.0-devnet.1-patch.0",
32
+ "@aztec/archiver": "4.0.0-devnet.1-patch.0",
33
+ "@aztec/aztec-faucet": "4.0.0-devnet.1-patch.0",
34
+ "@aztec/aztec-node": "4.0.0-devnet.1-patch.0",
35
+ "@aztec/aztec.js": "4.0.0-devnet.1-patch.0",
36
+ "@aztec/bb-prover": "4.0.0-devnet.1-patch.0",
37
+ "@aztec/bb.js": "4.0.0-devnet.1-patch.0",
38
+ "@aztec/blob-client": "4.0.0-devnet.1-patch.0",
39
+ "@aztec/bot": "4.0.0-devnet.1-patch.0",
40
+ "@aztec/builder": "4.0.0-devnet.1-patch.0",
41
+ "@aztec/cli": "4.0.0-devnet.1-patch.0",
42
+ "@aztec/constants": "4.0.0-devnet.1-patch.0",
43
+ "@aztec/entrypoints": "4.0.0-devnet.1-patch.0",
44
+ "@aztec/ethereum": "4.0.0-devnet.1-patch.0",
45
+ "@aztec/foundation": "4.0.0-devnet.1-patch.0",
46
+ "@aztec/kv-store": "4.0.0-devnet.1-patch.0",
47
+ "@aztec/l1-artifacts": "4.0.0-devnet.1-patch.0",
48
+ "@aztec/node-lib": "4.0.0-devnet.1-patch.0",
49
+ "@aztec/noir-contracts.js": "4.0.0-devnet.1-patch.0",
50
+ "@aztec/noir-protocol-circuits-types": "4.0.0-devnet.1-patch.0",
51
+ "@aztec/p2p": "4.0.0-devnet.1-patch.0",
52
+ "@aztec/p2p-bootstrap": "4.0.0-devnet.1-patch.0",
53
+ "@aztec/protocol-contracts": "4.0.0-devnet.1-patch.0",
54
+ "@aztec/prover-client": "4.0.0-devnet.1-patch.0",
55
+ "@aztec/prover-node": "4.0.0-devnet.1-patch.0",
56
+ "@aztec/pxe": "4.0.0-devnet.1-patch.0",
57
+ "@aztec/sequencer-client": "4.0.0-devnet.1-patch.0",
58
+ "@aztec/stdlib": "4.0.0-devnet.1-patch.0",
59
+ "@aztec/telemetry-client": "4.0.0-devnet.1-patch.0",
60
+ "@aztec/test-wallet": "4.0.0-devnet.1-patch.0",
61
+ "@aztec/txe": "4.0.0-devnet.1-patch.0",
62
+ "@aztec/validator-ha-signer": "4.0.0-devnet.1-patch.0",
63
+ "@aztec/world-state": "4.0.0-devnet.1-patch.0",
63
64
  "@types/chalk": "^2.2.0",
64
65
  "abitype": "^0.8.11",
65
66
  "chalk": "^5.3.0",
@@ -70,6 +71,7 @@
70
71
  },
71
72
  "files": [
72
73
  "dest",
74
+ "scripts",
73
75
  "src",
74
76
  "!*.test.*"
75
77
  ],
@@ -78,7 +80,7 @@
78
80
  "@jest/globals": "^30.0.0",
79
81
  "@types/jest": "^30.0.0",
80
82
  "@types/koa": "^2.15.0",
81
- "@typescript/native-preview": "7.0.0-dev.20251126.1",
83
+ "@typescript/native-preview": "7.0.0-dev.20260113.1",
82
84
  "jest": "^30.0.0",
83
85
  "ts-node": "^10.9.1",
84
86
  "typescript": "^5.3.3"
@@ -0,0 +1,63 @@
1
+ #!/usr/bin/env bash
2
+ set -euo pipefail
3
+ shopt -s inherit_errexit
4
+
5
+ # Re-execute using correct version if we have an .aztecrc file.
6
+ if [ "${AZTEC_VERSIONED:-0}" -eq 0 ] && [ -f .aztecrc ] && command -v aztec-up &>/dev/null; then
7
+ env_setup=$(aztec-up env)
8
+ eval "$env_setup"
9
+ AZTEC_VERSIONED=1 exec aztec "$@"
10
+ fi
11
+
12
+ cmd=${1:-}
13
+ [ -n "$cmd" ] && shift
14
+
15
+ script_dir="$(dirname "$(realpath "$0")")"
16
+
17
+ function aztec {
18
+ export AZTEC_SHELL_WRAPPER=1
19
+ exec node --no-warnings $script_dir/../dest/bin/index.js "$@"
20
+ }
21
+
22
+ case $cmd in
23
+ test)
24
+ export LOG_LEVEL="${LOG_LEVEL:-error}"
25
+ aztec start --txe --port 8081 &
26
+ server_pid=$!
27
+ trap 'kill $server_pid &>/dev/null || true' EXIT
28
+ while ! nc -z 127.0.0.1 8081 &>/dev/null; do sleep 0.2; done
29
+ export NARGO_FOREIGN_CALL_TIMEOUT=300000
30
+ nargo test --silence-warnings --oracle-resolver http://127.0.0.1:8081 "$@"
31
+ ;;
32
+ start)
33
+ if [ "${1:-}" == "--local-network" ]; then
34
+ # TODO: Can these just be set in TS?
35
+ export ARCHIVER_POLLING_INTERVAL_MS=500
36
+ export P2P_BLOCK_CHECK_INTERVAL_MS=500
37
+ export SEQ_TX_POLLING_INTERVAL_MS=500
38
+ export WS_BLOCK_CHECK_INTERVAL_MS=500
39
+ export ARCHIVER_VIEM_POLLING_INTERVAL_MS=500
40
+ export TEST_ACCOUNTS=${TEST_ACCOUNTS:-true}
41
+ export LOG_LEVEL=${LOG_LEVEL:-info;silent:sequencer;verbose:debug_log}
42
+ export DEPLOY_AZTEC_CONTRACTS_SALT=${DEPLOY_AZTEC_CONTRACTS_SALT:-$RANDOM}
43
+
44
+ ANVIL_PORT=${ANVIL_PORT:-8545}
45
+
46
+ export L1_CHAIN_ID=${L1_CHAIN_ID:-31337}
47
+ export ETHEREUM_HOSTS=${ETHEREUM_HOSTS:-"http://127.0.0.1:${ANVIL_PORT}"}
48
+
49
+ anvil --version
50
+ anvil --silent &
51
+ anvil_pid=$!
52
+ trap 'kill $anvil_pid &>/dev/null' EXIT
53
+ fi
54
+
55
+ aztec start "$@"
56
+ ;;
57
+ compile|new|init|flamegraph)
58
+ $script_dir/${cmd}.sh "$@"
59
+ ;;
60
+ *)
61
+ aztec $cmd "$@"
62
+ ;;
63
+ esac
@@ -0,0 +1,44 @@
1
+ #!/usr/bin/env bash
2
+ set -euo pipefail
3
+
4
+ NARGO=${NARGO:-nargo}
5
+ BB=${BB:-bb}
6
+
7
+ # If help is requested, show Aztec-specific info then run nargo compile help and then exit in order to not trigger
8
+ # transpilation
9
+ for arg in "$@"; do
10
+ if [ "$arg" == "--help" ] || [ "$arg" == "-h" ]; then
11
+ cat << 'EOF'
12
+ Aztec Compile - Compile Aztec Noir contracts
13
+
14
+ This command compiles Aztec Noir contracts using nargo and then automatically
15
+ postprocesses them to generate Aztec specific artifacts including:
16
+ - Transpiled contract artifacts
17
+ - Verification keys
18
+
19
+ The compiled contracts will be placed in the target/ directory by default.
20
+
21
+ ---
22
+ Underlying nargo compile options:
23
+
24
+ EOF
25
+ nargo compile --help
26
+ exit 0
27
+ fi
28
+ done
29
+
30
+ # Run nargo compile.
31
+ $NARGO compile "$@"
32
+
33
+ echo "Postprocessing contract..."
34
+ $BB aztec_process
35
+
36
+ # Strip internal prefixes from all compiled contract JSONs in target directory
37
+ # TODO: This should be part of bb aztec_process!
38
+ for json in target/*.json; do
39
+ temp_file="${json}.tmp"
40
+ jq '.functions |= map(.name |= sub("^__aztec_nr_internals__"; ""))' "$json" > "$temp_file"
41
+ mv "$temp_file" "$json"
42
+ done
43
+
44
+ echo "Compilation complete!"
@@ -0,0 +1,47 @@
1
+ #!/usr/bin/env node
2
+ import fs from 'fs/promises';
3
+ import path from 'path';
4
+
5
+ // Simple script to extract a contract function as a separate Noir artifact.
6
+ // We need to use this since the transpiling that we do on public functions make the contract artifacts
7
+ // unreadable by noir tooling, since they are no longer following the noir artifact format.
8
+ async function main() {
9
+ let [contractArtifactPath, functionName] = process.argv.slice(2);
10
+ if (!contractArtifactPath || !functionName) {
11
+ console.log('Usage: node extractFunctionAsNoirArtifact.js <contractArtifactPath> <functionName>');
12
+ return;
13
+ }
14
+
15
+ const contractArtifact = JSON.parse(await fs.readFile(contractArtifactPath, 'utf8'));
16
+ const func = contractArtifact.functions.find(f => f.name === functionName);
17
+ if (!func) {
18
+ console.error(`Function ${functionName} not found in ${contractArtifactPath}`);
19
+ return;
20
+ }
21
+
22
+ const artifact = {
23
+ noir_version: contractArtifact.noir_version,
24
+ hash: 0,
25
+ abi: func.abi,
26
+ bytecode: func.bytecode,
27
+ debug_symbols: func.debug_symbols,
28
+ file_map: contractArtifact.file_map,
29
+ expression_width: {
30
+ Bounded: {
31
+ width: 4,
32
+ },
33
+ },
34
+ };
35
+
36
+ const outputDir = path.dirname(contractArtifactPath);
37
+ const outputName = path.basename(contractArtifactPath, '.json') + `-${functionName}.json`;
38
+
39
+ const outPath = path.join(outputDir, outputName);
40
+
41
+ await fs.writeFile(outPath, JSON.stringify(artifact, null, 2));
42
+ }
43
+
44
+ main().catch(err => {
45
+ console.error(err);
46
+ process.exit(1);
47
+ });
@@ -0,0 +1,59 @@
1
+ #!/usr/bin/env bash
2
+ set -eu
3
+
4
+ # If first arg is -h or --help, print usage.
5
+ if [ $# -lt 2 ] || [ "$1" == "-h" ] || [ "$1" == "--help" ]; then
6
+ cat << 'EOF'
7
+ Aztec Flamegraph - Generate a gate count flamegraph for an aztec contract function.
8
+
9
+ Usage: aztec flamegraph <contract_artifact> <function>
10
+
11
+ Options:
12
+ -h, --help Print help
13
+
14
+ Will output an svg at <artifact_path>/<contract>-<function>-flamegraph.svg.
15
+ You can open it in your browser to view it.
16
+
17
+ EOF
18
+ exit 0
19
+ fi
20
+
21
+ cleanup() {
22
+ set +e
23
+ if [ -f "$function_artifact" ]; then
24
+ rm -f "$function_artifact"
25
+ fi
26
+ }
27
+
28
+ trap cleanup EXIT
29
+
30
+ # Get the directory of the script
31
+ script_dir=$(realpath $(dirname $0))
32
+
33
+ PROFILER=${PROFILER_PATH:-noir-profiler}
34
+ BB=${BB:-bb}
35
+
36
+ # first console arg is contract name in camel case or path to contract artifact
37
+ contract=$1
38
+
39
+ # second console arg is the contract function
40
+ function=$2
41
+
42
+ if [ ! -f "$contract" ]; then
43
+ echo "Error: Contract artifact not found at: $contract"
44
+ exit 1
45
+ fi
46
+ artifact_path=$contract
47
+ function_artifact="${artifact_path%%.json}-${function}.json"
48
+ output_dir=$(dirname "$artifact_path")
49
+
50
+ # Extract artifact for the specific function.
51
+ node $script_dir/extract_function.js "$artifact_path" $function
52
+
53
+ # Generate the flamegraph
54
+ $PROFILER gates --artifact-path "$function_artifact" --backend-path "$BB" --backend-gates-command "gates" --output "$output_dir" --scheme chonk --include_gates_per_opcode
55
+
56
+ # Save as $artifact_name-$function-flamegraph.svg
57
+ output_file="${function_artifact%%.json}-flamegraph.svg"
58
+ mv "$output_dir/__aztec_nr_internals__${function}_gates.svg" "$output_file"
59
+ echo "Flamegraph generated at: $output_file"
@@ -0,0 +1,35 @@
1
+ #!/usr/bin/env bash
2
+ set -euo pipefail
3
+
4
+ NARGO=${NARGO:-nargo}
5
+ script_path=$(realpath $(dirname "$0"))
6
+
7
+ for arg in "$@"; do
8
+ if [ "$arg" == "--help" ] || [ "$arg" == "-h" ]; then
9
+ cat << 'EOF'
10
+ Aztec Init - Create a new Aztec Noir project in the current directory
11
+
12
+ Usage: aztec init [OPTIONS]
13
+
14
+ Options:
15
+ --name <NAME> Name of the package [default: current directory name]
16
+ --lib Use a library template
17
+ -h, --help Print help
18
+
19
+ This command creates a new Aztec Noir project in the current directory using nargo
20
+ and automatically adds the Aztec.nr dependency to your Nargo.toml file.
21
+
22
+ EOF
23
+ exit 0
24
+ fi
25
+ if [ "$arg" == "--lib" ]; then
26
+ is_contract=0
27
+ fi
28
+ done
29
+
30
+ echo "Initializing Noir project..."
31
+ $NARGO init "$@"
32
+
33
+ if [ "${is_contract:-1}" -eq 1 ]; then
34
+ $script_path/setup_project.sh
35
+ fi
package/scripts/new.sh ADDED
@@ -0,0 +1,59 @@
1
+ #!/usr/bin/env bash
2
+ set -euo pipefail
3
+
4
+ NARGO=${NARGO:-nargo}
5
+ script_path=$(realpath $(dirname "$0"))
6
+
7
+ type_arg="--contract"
8
+
9
+ while [[ $# -gt 0 ]]; do
10
+ case $1 in
11
+ --help|-h)
12
+ cat << 'EOF'
13
+ Aztec New - Create a new Aztec Noir project in a new directory
14
+
15
+ Usage: aztec new [OPTIONS] <PATH>
16
+
17
+ Arguments:
18
+ <PATH> The path to save the new project
19
+
20
+ Options:
21
+ --name <NAME> Name of the package [default: package directory name]
22
+ --lib Create a library template instead of a contract
23
+ -h, --help Print help
24
+
25
+ This command creates a new Aztec Noir project using nargo and automatically
26
+ adds the Aztec.nr dependency to your Nargo.toml file.
27
+ EOF
28
+ exit 0
29
+ ;;
30
+ --lib)
31
+ type_arg="--lib"
32
+ shift
33
+ ;;
34
+ --name)
35
+ name_arg="--name $2"
36
+ shift 2
37
+ ;;
38
+ *)
39
+ project_path=$1
40
+ shift
41
+ break
42
+ ;;
43
+ esac
44
+ done
45
+
46
+ if [ -z "$project_path" ]; then
47
+ echo "Error: PATH argument is required"
48
+ echo "Usage: aztec new [OPTIONS] <PATH>"
49
+ echo "Run 'aztec new --help' for more information"
50
+ exit 1
51
+ fi
52
+
53
+ echo "Creating new Noir project at $project_path..."
54
+ $NARGO new $type_arg ${name_arg:-} $project_path
55
+
56
+ if [ "$type_arg" == "--contract" ]; then
57
+ cd $project_path
58
+ $script_path/setup_project.sh
59
+ fi