@aztec/aztec 0.0.1-fake-ceab37513c → 0.0.6-commit.a2d1860fe9

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 (142) hide show
  1. package/README.md +1 -1
  2. package/dest/bin/index.d.ts +1 -1
  3. package/dest/bin/index.js +14 -9
  4. package/dest/cli/admin_api_key_store.d.ts +45 -0
  5. package/dest/cli/admin_api_key_store.d.ts.map +1 -0
  6. package/dest/cli/admin_api_key_store.js +98 -0
  7. package/dest/cli/aztec_start_action.d.ts +1 -1
  8. package/dest/cli/aztec_start_action.d.ts.map +1 -1
  9. package/dest/cli/aztec_start_action.js +59 -34
  10. package/dest/cli/aztec_start_options.d.ts +1 -1
  11. package/dest/cli/aztec_start_options.d.ts.map +1 -1
  12. package/dest/cli/aztec_start_options.js +46 -45
  13. package/dest/cli/cli.d.ts +1 -1
  14. package/dest/cli/cli.js +7 -7
  15. package/dest/cli/cmds/compile.d.ts +4 -0
  16. package/dest/cli/cmds/compile.d.ts.map +1 -0
  17. package/dest/cli/cmds/compile.js +95 -0
  18. package/dest/cli/cmds/migrate_ha_db.d.ts +3 -0
  19. package/dest/cli/cmds/migrate_ha_db.d.ts.map +1 -0
  20. package/dest/cli/cmds/migrate_ha_db.js +27 -0
  21. package/dest/cli/cmds/start_archiver.d.ts +1 -1
  22. package/dest/cli/cmds/start_archiver.d.ts.map +1 -1
  23. package/dest/cli/cmds/start_archiver.js +12 -14
  24. package/dest/cli/cmds/start_bot.d.ts +4 -7
  25. package/dest/cli/cmds/start_bot.d.ts.map +1 -1
  26. package/dest/cli/cmds/start_bot.js +18 -18
  27. package/dest/cli/cmds/start_node.d.ts +1 -1
  28. package/dest/cli/cmds/start_node.d.ts.map +1 -1
  29. package/dest/cli/cmds/start_node.js +71 -27
  30. package/dest/cli/cmds/start_p2p_bootstrap.d.ts +2 -2
  31. package/dest/cli/cmds/start_p2p_bootstrap.d.ts.map +1 -1
  32. package/dest/cli/cmds/start_p2p_bootstrap.js +2 -3
  33. package/dest/cli/cmds/start_prover_agent.d.ts +1 -1
  34. package/dest/cli/cmds/start_prover_agent.d.ts.map +1 -1
  35. package/dest/cli/cmds/start_prover_agent.js +4 -4
  36. package/dest/cli/cmds/start_prover_broker.d.ts +1 -1
  37. package/dest/cli/cmds/start_prover_broker.d.ts.map +1 -1
  38. package/dest/cli/cmds/start_prover_broker.js +4 -4
  39. package/dest/cli/cmds/start_txe.d.ts +1 -1
  40. package/dest/cli/index.d.ts +1 -1
  41. package/dest/cli/preload_crs.d.ts +1 -1
  42. package/dest/cli/release_version.d.ts +1 -1
  43. package/dest/cli/util.d.ts +12 -19
  44. package/dest/cli/util.d.ts.map +1 -1
  45. package/dest/cli/util.js +16 -11
  46. package/dest/cli/versioning.d.ts +1 -1
  47. package/dest/cli/versioning.js +3 -3
  48. package/dest/examples/token.d.ts +1 -1
  49. package/dest/examples/token.js +21 -19
  50. package/dest/examples/util.d.ts +3 -3
  51. package/dest/examples/util.d.ts.map +1 -1
  52. package/dest/examples/util.js +1 -1
  53. package/dest/index.d.ts +2 -2
  54. package/dest/index.d.ts.map +1 -1
  55. package/dest/index.js +1 -1
  56. package/dest/local-network/banana_fpc.d.ts +10 -0
  57. package/dest/local-network/banana_fpc.d.ts.map +1 -0
  58. package/dest/{sandbox → local-network}/banana_fpc.js +17 -21
  59. package/dest/local-network/index.d.ts +4 -0
  60. package/dest/local-network/index.d.ts.map +1 -0
  61. package/dest/local-network/index.js +3 -0
  62. package/dest/local-network/local-network.d.ts +73 -0
  63. package/dest/local-network/local-network.d.ts.map +1 -0
  64. package/dest/{sandbox/sandbox.js → local-network/local-network.js} +83 -66
  65. package/dest/local-network/sponsored_fpc.d.ts +5 -0
  66. package/dest/local-network/sponsored_fpc.d.ts.map +1 -0
  67. package/dest/{sandbox → local-network}/sponsored_fpc.js +7 -8
  68. package/dest/mnemonic.d.ts +1 -1
  69. package/dest/splash.d.ts +1 -1
  70. package/dest/testing/anvil_test_watcher.d.ts +12 -4
  71. package/dest/testing/anvil_test_watcher.d.ts.map +1 -1
  72. package/dest/testing/anvil_test_watcher.js +69 -31
  73. package/dest/testing/cheat_codes.d.ts +7 -8
  74. package/dest/testing/cheat_codes.d.ts.map +1 -1
  75. package/dest/testing/cheat_codes.js +9 -10
  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 +2 -2
  80. package/dest/testing/index.d.ts.map +1 -1
  81. package/dest/testing/index.js +1 -1
  82. package/package.json +41 -37
  83. package/scripts/aztec.sh +62 -0
  84. package/scripts/extract_function.js +47 -0
  85. package/scripts/flamegraph.sh +59 -0
  86. package/scripts/init.sh +35 -0
  87. package/scripts/new.sh +59 -0
  88. package/scripts/setup_project.sh +31 -0
  89. package/src/bin/index.ts +15 -9
  90. package/src/cli/admin_api_key_store.ts +128 -0
  91. package/src/cli/aztec_start_action.ts +62 -26
  92. package/src/cli/aztec_start_options.ts +47 -43
  93. package/src/cli/cli.ts +11 -11
  94. package/src/cli/cmds/compile.ts +107 -0
  95. package/src/cli/cmds/migrate_ha_db.ts +43 -0
  96. package/src/cli/cmds/start_archiver.ts +8 -19
  97. package/src/cli/cmds/start_bot.ts +27 -15
  98. package/src/cli/cmds/start_node.ts +64 -23
  99. package/src/cli/cmds/start_p2p_bootstrap.ts +3 -3
  100. package/src/cli/cmds/start_prover_agent.ts +4 -12
  101. package/src/cli/cmds/start_prover_broker.ts +7 -3
  102. package/src/cli/util.ts +23 -26
  103. package/src/cli/versioning.ts +3 -3
  104. package/src/examples/token.ts +20 -19
  105. package/src/examples/util.ts +2 -2
  106. package/src/index.ts +5 -5
  107. package/src/{sandbox → local-network}/banana_fpc.ts +24 -25
  108. package/src/local-network/index.ts +7 -0
  109. package/src/local-network/local-network.ts +267 -0
  110. package/src/local-network/sponsored_fpc.ts +26 -0
  111. package/src/testing/anvil_test_watcher.ts +77 -34
  112. package/src/testing/cheat_codes.ts +13 -13
  113. package/src/testing/epoch_test_settler.ts +71 -0
  114. package/src/testing/index.ts +1 -1
  115. package/dest/cli/cmds/start_blob_sink.d.ts +0 -3
  116. package/dest/cli/cmds/start_blob_sink.d.ts.map +0 -1
  117. package/dest/cli/cmds/start_blob_sink.js +0 -33
  118. package/dest/cli/cmds/start_prover_node.d.ts +0 -7
  119. package/dest/cli/cmds/start_prover_node.d.ts.map +0 -1
  120. package/dest/cli/cmds/start_prover_node.js +0 -108
  121. package/dest/cli/cmds/start_pxe.d.ts +0 -16
  122. package/dest/cli/cmds/start_pxe.d.ts.map +0 -1
  123. package/dest/cli/cmds/start_pxe.js +0 -31
  124. package/dest/sandbox/banana_fpc.d.ts +0 -11
  125. package/dest/sandbox/banana_fpc.d.ts.map +0 -1
  126. package/dest/sandbox/index.d.ts +0 -4
  127. package/dest/sandbox/index.d.ts.map +0 -1
  128. package/dest/sandbox/index.js +0 -3
  129. package/dest/sandbox/sandbox.d.ts +0 -84
  130. package/dest/sandbox/sandbox.d.ts.map +0 -1
  131. package/dest/sandbox/sponsored_fpc.d.ts +0 -4
  132. package/dest/sandbox/sponsored_fpc.d.ts.map +0 -1
  133. package/dest/testing/aztec_cheat_codes.d.ts +0 -59
  134. package/dest/testing/aztec_cheat_codes.d.ts.map +0 -1
  135. package/dest/testing/aztec_cheat_codes.js +0 -62
  136. package/src/cli/cmds/start_blob_sink.ts +0 -57
  137. package/src/cli/cmds/start_prover_node.ts +0 -124
  138. package/src/cli/cmds/start_pxe.ts +0 -49
  139. package/src/sandbox/index.ts +0 -4
  140. package/src/sandbox/sandbox.ts +0 -253
  141. package/src/sandbox/sponsored_fpc.ts +0 -27
  142. package/src/testing/aztec_cheat_codes.ts +0 -77
@@ -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,5 +1,5 @@
1
1
  export { AnvilTestWatcher } from './anvil_test_watcher.js';
2
2
  export { EthCheatCodes, RollupCheatCodes } from '@aztec/ethereum/test';
3
- export { AztecCheatCodes } from './aztec_cheat_codes.js';
4
3
  export { CheatCodes } from './cheat_codes.js';
5
- //# sourceMappingURL=index.d.ts.map
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,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACzD,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,4 +1,4 @@
1
1
  export { AnvilTestWatcher } from './anvil_test_watcher.js';
2
2
  export { EthCheatCodes, RollupCheatCodes } from '@aztec/ethereum/test';
3
- export { AztecCheatCodes } from './aztec_cheat_codes.js';
4
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": "0.0.1-fake-ceab37513c",
3
+ "version": "0.0.6-commit.a2d1860fe9",
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"
@@ -15,12 +15,12 @@
15
15
  "tsconfig": "./tsconfig.json"
16
16
  },
17
17
  "scripts": {
18
- "build": "yarn clean && tsc -b",
18
+ "build": "yarn clean && ../scripts/tsc.sh",
19
19
  "start": "node --no-warnings ./dest/bin",
20
20
  "start:debug": "node --inspect=0.0.0.0:9221 --no-warnings ./dest/bin",
21
- "start:sandbox": "ETHEREUM_HOSTS=http://0.0.0.0:8545/ && yarn start start --sandbox",
21
+ "start:local-network": "ETHEREUM_HOSTS=http://0.0.0.0:8545/ && yarn start start --local-network",
22
22
  "clean": "rm -rf ./dest .tsbuildinfo",
23
- "build:dev": "tsc -b --watch",
23
+ "build:dev": "../scripts/tsc.sh --watch",
24
24
  "test": "NODE_NO_WARNINGS=1 node --experimental-vm-modules ../node_modules/.bin/jest --passWithNoTests --maxWorkers=${JEST_MAX_WORKERS:-8}",
25
25
  "run:example:token": "LOG_LEVEL='verbose' node ./dest/examples/token.js"
26
26
  },
@@ -28,47 +28,50 @@
28
28
  "../package.common.json"
29
29
  ],
30
30
  "dependencies": {
31
- "@aztec/accounts": "0.0.1-fake-ceab37513c",
32
- "@aztec/archiver": "0.0.1-fake-ceab37513c",
33
- "@aztec/aztec-faucet": "0.0.1-fake-ceab37513c",
34
- "@aztec/aztec-node": "0.0.1-fake-ceab37513c",
35
- "@aztec/aztec.js": "0.0.1-fake-ceab37513c",
36
- "@aztec/bb-prover": "0.0.1-fake-ceab37513c",
37
- "@aztec/bb.js": "0.0.1-fake-ceab37513c",
38
- "@aztec/blob-sink": "0.0.1-fake-ceab37513c",
39
- "@aztec/bot": "0.0.1-fake-ceab37513c",
40
- "@aztec/builder": "0.0.1-fake-ceab37513c",
41
- "@aztec/cli": "0.0.1-fake-ceab37513c",
42
- "@aztec/cli-wallet": "0.0.1-fake-ceab37513c",
43
- "@aztec/constants": "0.0.1-fake-ceab37513c",
44
- "@aztec/entrypoints": "0.0.1-fake-ceab37513c",
45
- "@aztec/ethereum": "0.0.1-fake-ceab37513c",
46
- "@aztec/foundation": "0.0.1-fake-ceab37513c",
47
- "@aztec/kv-store": "0.0.1-fake-ceab37513c",
48
- "@aztec/l1-artifacts": "0.0.1-fake-ceab37513c",
49
- "@aztec/node-lib": "0.0.1-fake-ceab37513c",
50
- "@aztec/noir-contracts.js": "0.0.1-fake-ceab37513c",
51
- "@aztec/noir-protocol-circuits-types": "0.0.1-fake-ceab37513c",
52
- "@aztec/p2p": "0.0.1-fake-ceab37513c",
53
- "@aztec/p2p-bootstrap": "0.0.1-fake-ceab37513c",
54
- "@aztec/protocol-contracts": "0.0.1-fake-ceab37513c",
55
- "@aztec/prover-client": "0.0.1-fake-ceab37513c",
56
- "@aztec/prover-node": "0.0.1-fake-ceab37513c",
57
- "@aztec/pxe": "0.0.1-fake-ceab37513c",
58
- "@aztec/stdlib": "0.0.1-fake-ceab37513c",
59
- "@aztec/telemetry-client": "0.0.1-fake-ceab37513c",
60
- "@aztec/txe": "0.0.1-fake-ceab37513c",
61
- "@aztec/world-state": "0.0.1-fake-ceab37513c",
31
+ "@aztec/accounts": "0.0.6-commit.a2d1860fe9",
32
+ "@aztec/archiver": "0.0.6-commit.a2d1860fe9",
33
+ "@aztec/aztec-faucet": "0.0.6-commit.a2d1860fe9",
34
+ "@aztec/aztec-node": "0.0.6-commit.a2d1860fe9",
35
+ "@aztec/aztec.js": "0.0.6-commit.a2d1860fe9",
36
+ "@aztec/bb-prover": "0.0.6-commit.a2d1860fe9",
37
+ "@aztec/bb.js": "0.0.6-commit.a2d1860fe9",
38
+ "@aztec/blob-client": "0.0.6-commit.a2d1860fe9",
39
+ "@aztec/bot": "0.0.6-commit.a2d1860fe9",
40
+ "@aztec/builder": "0.0.6-commit.a2d1860fe9",
41
+ "@aztec/cli": "0.0.6-commit.a2d1860fe9",
42
+ "@aztec/constants": "0.0.6-commit.a2d1860fe9",
43
+ "@aztec/entrypoints": "0.0.6-commit.a2d1860fe9",
44
+ "@aztec/ethereum": "0.0.6-commit.a2d1860fe9",
45
+ "@aztec/foundation": "0.0.6-commit.a2d1860fe9",
46
+ "@aztec/kv-store": "0.0.6-commit.a2d1860fe9",
47
+ "@aztec/l1-artifacts": "0.0.6-commit.a2d1860fe9",
48
+ "@aztec/node-lib": "0.0.6-commit.a2d1860fe9",
49
+ "@aztec/noir-contracts.js": "0.0.6-commit.a2d1860fe9",
50
+ "@aztec/noir-protocol-circuits-types": "0.0.6-commit.a2d1860fe9",
51
+ "@aztec/p2p": "0.0.6-commit.a2d1860fe9",
52
+ "@aztec/p2p-bootstrap": "0.0.6-commit.a2d1860fe9",
53
+ "@aztec/protocol-contracts": "0.0.6-commit.a2d1860fe9",
54
+ "@aztec/prover-client": "0.0.6-commit.a2d1860fe9",
55
+ "@aztec/prover-node": "0.0.6-commit.a2d1860fe9",
56
+ "@aztec/pxe": "0.0.6-commit.a2d1860fe9",
57
+ "@aztec/sequencer-client": "0.0.6-commit.a2d1860fe9",
58
+ "@aztec/stdlib": "0.0.6-commit.a2d1860fe9",
59
+ "@aztec/telemetry-client": "0.0.6-commit.a2d1860fe9",
60
+ "@aztec/txe": "0.0.6-commit.a2d1860fe9",
61
+ "@aztec/validator-ha-signer": "0.0.6-commit.a2d1860fe9",
62
+ "@aztec/wallets": "0.0.6-commit.a2d1860fe9",
63
+ "@aztec/world-state": "0.0.6-commit.a2d1860fe9",
62
64
  "@types/chalk": "^2.2.0",
63
65
  "abitype": "^0.8.11",
64
66
  "chalk": "^5.3.0",
65
67
  "commander": "^12.1.0",
66
68
  "koa": "^2.16.1",
67
69
  "koa-router": "^13.1.1",
68
- "viem": "npm:@spalladino/viem@2.38.2-eip7594.0"
70
+ "viem": "npm:@aztec/viem@2.38.2"
69
71
  },
70
72
  "files": [
71
73
  "dest",
74
+ "scripts",
72
75
  "src",
73
76
  "!*.test.*"
74
77
  ],
@@ -77,6 +80,7 @@
77
80
  "@jest/globals": "^30.0.0",
78
81
  "@types/jest": "^30.0.0",
79
82
  "@types/koa": "^2.15.0",
83
+ "@typescript/native-preview": "7.0.0-dev.20260113.1",
80
84
  "jest": "^30.0.0",
81
85
  "ts-node": "^10.9.1",
82
86
  "typescript": "^5.3.3"
@@ -0,0 +1,62 @@
1
+ #!/usr/bin/env bash
2
+ set -euo pipefail
3
+
4
+ # Re-execute using correct version if we have an .aztecrc file.
5
+ if [ "${AZTEC_VERSIONED:-0}" -eq 0 ] && [ -f .aztecrc ] && command -v aztec-up &>/dev/null; then
6
+ env_setup=$(aztec-up env)
7
+ eval "$env_setup"
8
+ AZTEC_VERSIONED=1 exec aztec "$@"
9
+ fi
10
+
11
+ cmd=${1:-}
12
+ [ -n "$cmd" ] && shift
13
+
14
+ script_dir="$(dirname "$(realpath "$0")")"
15
+
16
+ function aztec {
17
+ export AZTEC_SHELL_WRAPPER=1
18
+ exec node --no-warnings $script_dir/../dest/bin/index.js "$@"
19
+ }
20
+
21
+ case $cmd in
22
+ test)
23
+ export LOG_LEVEL="${LOG_LEVEL:-"error;trace:contract_log"}"
24
+ aztec start --txe --port 8081 &
25
+ server_pid=$!
26
+ trap 'kill $server_pid &>/dev/null || true' EXIT
27
+ while ! nc -z 127.0.0.1 8081 &>/dev/null; do sleep 0.2; done
28
+ export NARGO_FOREIGN_CALL_TIMEOUT=300000
29
+ nargo test --silence-warnings --oracle-resolver http://127.0.0.1:8081 --test-threads 16 "$@"
30
+ ;;
31
+ start)
32
+ if [ "${1:-}" == "--local-network" ]; then
33
+ # TODO: Can these just be set in TS?
34
+ export ARCHIVER_POLLING_INTERVAL_MS=500
35
+ export P2P_BLOCK_CHECK_INTERVAL_MS=500
36
+ export SEQ_TX_POLLING_INTERVAL_MS=500
37
+ export WS_BLOCK_CHECK_INTERVAL_MS=500
38
+ export ARCHIVER_VIEM_POLLING_INTERVAL_MS=500
39
+ export TEST_ACCOUNTS=${TEST_ACCOUNTS:-true}
40
+ export LOG_LEVEL=${LOG_LEVEL:-info;silent:sequencer;verbose:debug_log}
41
+ export DEPLOY_AZTEC_CONTRACTS_SALT=${DEPLOY_AZTEC_CONTRACTS_SALT:-$RANDOM}
42
+
43
+ ANVIL_PORT=${ANVIL_PORT:-8545}
44
+
45
+ export L1_CHAIN_ID=${L1_CHAIN_ID:-31337}
46
+ export ETHEREUM_HOSTS=${ETHEREUM_HOSTS:-"http://127.0.0.1:${ANVIL_PORT}"}
47
+
48
+ anvil --version
49
+ anvil --silent &
50
+ anvil_pid=$!
51
+ trap 'kill $anvil_pid &>/dev/null' EXIT
52
+ fi
53
+
54
+ aztec start "$@"
55
+ ;;
56
+ new|init|flamegraph)
57
+ $script_dir/${cmd}.sh "$@"
58
+ ;;
59
+ *)
60
+ aztec $cmd "$@"
61
+ ;;
62
+ esac
@@ -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
@@ -0,0 +1,31 @@
1
+ #!/usr/bin/env bash
2
+ set -euo pipefail
3
+
4
+ # Get the actual aztec version for the git tag.
5
+ AZTEC_VERSION=$(jq -r '.version' $(dirname $0)/../package.json)
6
+ NARGO_TOML_PATH="Nargo.toml"
7
+ MAIN_NR_PATH="src/main.nr"
8
+
9
+ if [ ! -f "$NARGO_TOML_PATH" ]; then
10
+ >&2 echo "Warning: Could not find Nargo.toml at $NARGO_TOML_PATH to add aztec dependency"
11
+ exit 1
12
+ fi
13
+
14
+ if [ ! -f "$MAIN_NR_PATH" ]; then
15
+ >&2 echo "Warning: Could not find main.nr at $MAIN_NR_PATH"
16
+ exit 1
17
+ fi
18
+
19
+ # Add aztec dependency to Nargo.toml
20
+ echo "" >> "$NARGO_TOML_PATH"
21
+ echo "aztec = { git=\"https://github.com/AztecProtocol/aztec-nr\", tag=\"v${AZTEC_VERSION}\", directory=\"aztec\" }" >> "$NARGO_TOML_PATH"
22
+ echo "Added aztec dependency (v${AZTEC_VERSION}) to Nargo.toml"
23
+
24
+ # Replace the contents of main.nr with the Aztec contract template
25
+ cat > "$MAIN_NR_PATH" << 'EOF'
26
+ use aztec::macros::aztec;
27
+
28
+ #[aztec]
29
+ contract Main {}
30
+ EOF
31
+ echo "Created main.nr with Aztec contract template"
package/src/bin/index.ts CHANGED
@@ -1,22 +1,26 @@
1
1
  #!/usr/bin/env node
2
2
  //
3
3
  import { injectCommands as injectBuilderCommands } from '@aztec/builder';
4
- import { injectCommands as injectWalletCommands } from '@aztec/cli-wallet';
5
- import { enrichEnvironmentWithChainConfig, enrichEnvironmentWithNetworkConfig } from '@aztec/cli/config';
4
+ import { injectCommands as injectAztecNodeCommands } from '@aztec/cli/aztec_node';
5
+ import { enrichEnvironmentWithChainName } from '@aztec/cli/config/chain';
6
+ import { enrichEnvironmentWithNetworkConfig } from '@aztec/cli/config/network';
6
7
  import { injectCommands as injectContractCommands } from '@aztec/cli/contracts';
7
8
  import { injectCommands as injectInfrastructureCommands } from '@aztec/cli/infrastructure';
8
9
  import { injectCommands as injectL1Commands } from '@aztec/cli/l1';
9
10
  import { injectCommands as injectMiscCommands } from '@aztec/cli/misc';
10
- import { injectCommands as injectPXECommands } from '@aztec/cli/pxe';
11
+ import { injectCommands as injectValidatorKeysCommands } from '@aztec/cli/validator_keys';
11
12
  import { getActiveNetworkName } from '@aztec/foundation/config';
12
13
  import { createConsoleLogger, createLogger } from '@aztec/foundation/log';
13
14
 
14
15
  import { Command } from 'commander';
15
16
 
16
- import { NETWORK_FLAG } from '../cli/aztec_start_options.js';
17
+ import { injectCompileCommand } from '../cli/cmds/compile.js';
18
+ import { injectMigrateCommand } from '../cli/cmds/migrate_ha_db.js';
17
19
  import { injectAztecCommands } from '../cli/index.js';
18
20
  import { getCliVersion } from '../cli/release_version.js';
19
21
 
22
+ const NETWORK_FLAG = 'network';
23
+
20
24
  const userLog = createConsoleLogger();
21
25
  const debugLogger = createLogger('cli');
22
26
 
@@ -40,19 +44,21 @@ async function main() {
40
44
 
41
45
  const networkName = getActiveNetworkName(networkValue);
42
46
  await enrichEnvironmentWithNetworkConfig(networkName);
43
- enrichEnvironmentWithChainConfig(networkName);
47
+ enrichEnvironmentWithChainName(networkName);
44
48
 
45
49
  const cliVersion = getCliVersion();
46
50
  let program = new Command('aztec');
47
- program.description('Aztec command line interface').version(cliVersion);
51
+ program.description('Aztec command line interface').version(cliVersion).enablePositionalOptions();
48
52
  program = injectAztecCommands(program, userLog, debugLogger);
49
53
  program = injectBuilderCommands(program);
50
54
  program = injectContractCommands(program, userLog, debugLogger);
51
- program = injectInfrastructureCommands(program, userLog, debugLogger);
55
+ program = injectInfrastructureCommands(program, userLog);
52
56
  program = injectL1Commands(program, userLog, debugLogger);
53
- program = injectPXECommands(program, userLog, debugLogger);
57
+ program = injectAztecNodeCommands(program, userLog, debugLogger);
54
58
  program = injectMiscCommands(program, userLog);
55
- program = injectWalletCommands(program, userLog, debugLogger);
59
+ program = injectValidatorKeysCommands(program, userLog);
60
+ program = injectCompileCommand(program, userLog);
61
+ program = injectMigrateCommand(program, userLog);
56
62
 
57
63
  await program.parseAsync(process.argv);
58
64
  }