@aztec/aztec 5.0.0-private.20260318 → 5.0.0-rc.1

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 (108) hide show
  1. package/dest/bin/index.js +1 -1
  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 +16 -24
  5. package/dest/cli/aztec_start_options.d.ts +2 -2
  6. package/dest/cli/aztec_start_options.d.ts.map +1 -1
  7. package/dest/cli/aztec_start_options.js +14 -14
  8. package/dest/cli/cmds/compile.d.ts +1 -1
  9. package/dest/cli/cmds/compile.d.ts.map +1 -1
  10. package/dest/cli/cmds/compile.js +8 -8
  11. package/dest/cli/cmds/profile.d.ts +1 -1
  12. package/dest/cli/cmds/profile.d.ts.map +1 -1
  13. package/dest/cli/cmds/profile.js +1 -1
  14. package/dest/cli/cmds/profile_gates.d.ts +2 -2
  15. package/dest/cli/cmds/profile_gates.d.ts.map +1 -1
  16. package/dest/cli/cmds/profile_gates.js +21 -3
  17. package/dest/cli/cmds/standby.d.ts +3 -5
  18. package/dest/cli/cmds/standby.d.ts.map +1 -1
  19. package/dest/cli/cmds/standby.js +3 -3
  20. package/dest/cli/cmds/start_bot.d.ts +1 -1
  21. package/dest/cli/cmds/start_bot.d.ts.map +1 -1
  22. package/dest/cli/cmds/start_bot.js +8 -4
  23. package/dest/cli/cmds/start_node.d.ts +1 -1
  24. package/dest/cli/cmds/start_node.d.ts.map +1 -1
  25. package/dest/cli/cmds/start_node.js +13 -40
  26. package/dest/cli/cmds/start_prover_agent.d.ts +1 -1
  27. package/dest/cli/cmds/start_prover_agent.d.ts.map +1 -1
  28. package/dest/cli/cmds/start_prover_agent.js +5 -17
  29. package/dest/cli/cmds/start_prover_broker.d.ts +1 -1
  30. package/dest/cli/cmds/start_prover_broker.d.ts.map +1 -1
  31. package/dest/cli/cmds/start_prover_broker.js +11 -8
  32. package/dest/cli/cmds/start_txe.d.ts +2 -2
  33. package/dest/cli/cmds/start_txe.d.ts.map +1 -1
  34. package/dest/cli/cmds/start_txe.js +6 -5
  35. package/dest/cli/cmds/utils/collect_crate_dirs.d.ts +21 -0
  36. package/dest/cli/cmds/utils/collect_crate_dirs.d.ts.map +1 -0
  37. package/dest/cli/cmds/utils/collect_crate_dirs.js +114 -0
  38. package/dest/cli/cmds/utils/needs_recompile.d.ts +1 -1
  39. package/dest/cli/cmds/utils/needs_recompile.d.ts.map +1 -1
  40. package/dest/cli/cmds/utils/needs_recompile.js +9 -53
  41. package/dest/cli/cmds/utils/warn_if_aztec_version_mismatch.d.ts +4 -0
  42. package/dest/cli/cmds/utils/warn_if_aztec_version_mismatch.d.ts.map +1 -0
  43. package/dest/cli/cmds/utils/warn_if_aztec_version_mismatch.js +61 -0
  44. package/dest/cli/util.js +7 -5
  45. package/dest/examples/token.js +3 -3
  46. package/dest/local-network/auth_registry.d.ts +5 -0
  47. package/dest/local-network/auth_registry.d.ts.map +1 -0
  48. package/dest/local-network/auth_registry.js +17 -0
  49. package/dest/local-network/banana_fpc.d.ts +3 -2
  50. package/dest/local-network/banana_fpc.d.ts.map +1 -1
  51. package/dest/local-network/banana_fpc.js +11 -7
  52. package/dest/local-network/local-network.d.ts +6 -29
  53. package/dest/local-network/local-network.d.ts.map +1 -1
  54. package/dest/local-network/local-network.js +45 -70
  55. package/dest/testing/cheat_codes.d.ts +18 -17
  56. package/dest/testing/cheat_codes.d.ts.map +1 -1
  57. package/dest/testing/cheat_codes.js +70 -36
  58. package/dest/testing/epoch_test_settler.d.ts +2 -2
  59. package/dest/testing/epoch_test_settler.d.ts.map +1 -1
  60. package/dest/testing/epoch_test_settler.js +6 -25
  61. package/dest/testing/index.d.ts +1 -2
  62. package/dest/testing/index.d.ts.map +1 -1
  63. package/dest/testing/index.js +0 -1
  64. package/package.json +34 -33
  65. package/scripts/add_crate.sh +11 -60
  66. package/scripts/aztec.sh +6 -2
  67. package/scripts/init.sh +5 -5
  68. package/scripts/new.sh +2 -2
  69. package/scripts/setup_workspace.sh +3 -2
  70. package/scripts/templates/blank/contract/Nargo.toml +6 -0
  71. package/scripts/templates/blank/contract/src/main.nr +10 -0
  72. package/scripts/templates/blank/test/Nargo.toml +7 -0
  73. package/scripts/templates/blank/test/src/lib.nr +11 -0
  74. package/scripts/templates/counter/contract/Nargo.toml +7 -0
  75. package/scripts/templates/counter/contract/src/main.nr +48 -0
  76. package/scripts/templates/counter/test/Nargo.toml +7 -0
  77. package/scripts/templates/counter/test/src/lib.nr +32 -0
  78. package/src/bin/index.ts +1 -1
  79. package/src/cli/aztec_start_action.ts +14 -17
  80. package/src/cli/aztec_start_options.ts +21 -22
  81. package/src/cli/cmds/compile.ts +10 -9
  82. package/src/cli/cmds/profile.ts +2 -1
  83. package/src/cli/cmds/profile_gates.ts +20 -4
  84. package/src/cli/cmds/standby.ts +4 -4
  85. package/src/cli/cmds/start_bot.ts +9 -6
  86. package/src/cli/cmds/start_node.ts +20 -23
  87. package/src/cli/cmds/start_prover_agent.ts +5 -8
  88. package/src/cli/cmds/start_prover_broker.ts +10 -11
  89. package/src/cli/cmds/start_txe.ts +7 -5
  90. package/src/cli/cmds/utils/collect_crate_dirs.ts +118 -0
  91. package/src/cli/cmds/utils/needs_recompile.ts +8 -61
  92. package/src/cli/cmds/utils/warn_if_aztec_version_mismatch.ts +76 -0
  93. package/src/cli/util.ts +7 -7
  94. package/src/examples/token.ts +3 -3
  95. package/src/local-network/auth_registry.ts +19 -0
  96. package/src/local-network/banana_fpc.ts +12 -8
  97. package/src/local-network/local-network.ts +49 -80
  98. package/src/testing/cheat_codes.ts +89 -39
  99. package/src/testing/epoch_test_settler.ts +8 -31
  100. package/src/testing/index.ts +0 -1
  101. package/dest/cli/cmds/start_archiver.d.ts +0 -9
  102. package/dest/cli/cmds/start_archiver.d.ts.map +0 -1
  103. package/dest/cli/cmds/start_archiver.js +0 -48
  104. package/dest/testing/anvil_test_watcher.d.ts +0 -42
  105. package/dest/testing/anvil_test_watcher.d.ts.map +0 -1
  106. package/dest/testing/anvil_test_watcher.js +0 -181
  107. package/src/cli/cmds/start_archiver.ts +0 -50
  108. package/src/testing/anvil_test_watcher.ts +0 -210
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aztec/aztec",
3
- "version": "5.0.0-private.20260318",
3
+ "version": "5.0.0-rc.1",
4
4
  "type": "module",
5
5
  "exports": {
6
6
  ".": "./dest/index.js",
@@ -28,38 +28,39 @@
28
28
  "../package.common.json"
29
29
  ],
30
30
  "dependencies": {
31
- "@aztec/accounts": "5.0.0-private.20260318",
32
- "@aztec/archiver": "5.0.0-private.20260318",
33
- "@aztec/aztec-node": "5.0.0-private.20260318",
34
- "@aztec/aztec.js": "5.0.0-private.20260318",
35
- "@aztec/bb-prover": "5.0.0-private.20260318",
36
- "@aztec/bb.js": "5.0.0-private.20260318",
37
- "@aztec/blob-client": "5.0.0-private.20260318",
38
- "@aztec/bot": "5.0.0-private.20260318",
39
- "@aztec/builder": "5.0.0-private.20260318",
40
- "@aztec/cli": "5.0.0-private.20260318",
41
- "@aztec/constants": "5.0.0-private.20260318",
42
- "@aztec/entrypoints": "5.0.0-private.20260318",
43
- "@aztec/ethereum": "5.0.0-private.20260318",
44
- "@aztec/foundation": "5.0.0-private.20260318",
45
- "@aztec/kv-store": "5.0.0-private.20260318",
46
- "@aztec/l1-artifacts": "5.0.0-private.20260318",
47
- "@aztec/node-lib": "5.0.0-private.20260318",
48
- "@aztec/noir-contracts.js": "5.0.0-private.20260318",
49
- "@aztec/noir-protocol-circuits-types": "5.0.0-private.20260318",
50
- "@aztec/p2p": "5.0.0-private.20260318",
51
- "@aztec/p2p-bootstrap": "5.0.0-private.20260318",
52
- "@aztec/protocol-contracts": "5.0.0-private.20260318",
53
- "@aztec/prover-client": "5.0.0-private.20260318",
54
- "@aztec/prover-node": "5.0.0-private.20260318",
55
- "@aztec/pxe": "5.0.0-private.20260318",
56
- "@aztec/sequencer-client": "5.0.0-private.20260318",
57
- "@aztec/stdlib": "5.0.0-private.20260318",
58
- "@aztec/telemetry-client": "5.0.0-private.20260318",
59
- "@aztec/txe": "5.0.0-private.20260318",
60
- "@aztec/validator-ha-signer": "5.0.0-private.20260318",
61
- "@aztec/wallets": "5.0.0-private.20260318",
62
- "@aztec/world-state": "5.0.0-private.20260318",
31
+ "@aztec/accounts": "5.0.0-rc.1",
32
+ "@aztec/archiver": "5.0.0-rc.1",
33
+ "@aztec/aztec-node": "5.0.0-rc.1",
34
+ "@aztec/aztec.js": "5.0.0-rc.1",
35
+ "@aztec/bb-prover": "5.0.0-rc.1",
36
+ "@aztec/bb.js": "5.0.0-rc.1",
37
+ "@aztec/blob-client": "5.0.0-rc.1",
38
+ "@aztec/bot": "5.0.0-rc.1",
39
+ "@aztec/builder": "5.0.0-rc.1",
40
+ "@aztec/cli": "5.0.0-rc.1",
41
+ "@aztec/constants": "5.0.0-rc.1",
42
+ "@aztec/entrypoints": "5.0.0-rc.1",
43
+ "@aztec/ethereum": "5.0.0-rc.1",
44
+ "@aztec/foundation": "5.0.0-rc.1",
45
+ "@aztec/kv-store": "5.0.0-rc.1",
46
+ "@aztec/l1-artifacts": "5.0.0-rc.1",
47
+ "@aztec/node-lib": "5.0.0-rc.1",
48
+ "@aztec/noir-contracts.js": "5.0.0-rc.1",
49
+ "@aztec/noir-protocol-circuits-types": "5.0.0-rc.1",
50
+ "@aztec/p2p": "5.0.0-rc.1",
51
+ "@aztec/p2p-bootstrap": "5.0.0-rc.1",
52
+ "@aztec/protocol-contracts": "5.0.0-rc.1",
53
+ "@aztec/prover-client": "5.0.0-rc.1",
54
+ "@aztec/prover-node": "5.0.0-rc.1",
55
+ "@aztec/pxe": "5.0.0-rc.1",
56
+ "@aztec/sequencer-client": "5.0.0-rc.1",
57
+ "@aztec/standard-contracts": "5.0.0-rc.1",
58
+ "@aztec/stdlib": "5.0.0-rc.1",
59
+ "@aztec/telemetry-client": "5.0.0-rc.1",
60
+ "@aztec/txe": "5.0.0-rc.1",
61
+ "@aztec/validator-ha-signer": "5.0.0-rc.1",
62
+ "@aztec/wallets": "5.0.0-rc.1",
63
+ "@aztec/world-state": "5.0.0-rc.1",
63
64
  "@iarna/toml": "^2.2.5",
64
65
  "@types/chalk": "^2.2.0",
65
66
  "abitype": "^0.8.11",
@@ -2,10 +2,11 @@
2
2
  set -euo pipefail
3
3
 
4
4
  # Creates a contract+test crate pair and adds them to an existing workspace.
5
- # Usage: add_crate.sh <crate_name>
5
+ # Usage: add_crate.sh <crate_name> <template>
6
6
  # Must be called from a workspace root that already has Nargo.toml with [workspace].
7
7
 
8
8
  crate_name=$1
9
+ template=$2
9
10
 
10
11
  if [ -z "$crate_name" ]; then
11
12
  echo "Error: crate name is required"
@@ -31,72 +32,22 @@ fi
31
32
 
32
33
  # Get the actual aztec version for the git tag.
33
34
  AZTEC_VERSION=$(jq -r '.version' $(dirname $0)/../package.json)
35
+ TEMPLATE_DIR="$(dirname $0)/templates/$template"
34
36
 
35
- # Create contract crate
36
- mkdir -p "$contract_dir/src"
37
- cat > "$contract_dir/Nargo.toml" << CEOF
38
- [package]
39
- name = "${crate_name}_contract"
40
- type = "contract"
41
-
42
- [dependencies]
43
- aztec = { git="https://github.com/AztecProtocol/aztec-nr", tag="v${AZTEC_VERSION}", directory="aztec" }
44
- CEOF
45
-
46
- cat > "$contract_dir/src/main.nr" << 'EOF'
47
- use aztec::macros::aztec;
48
-
49
- #[aztec]
50
- pub contract Main {
51
- use aztec::macros::functions::{external, initializer};
52
-
53
- #[initializer]
54
- #[external("private")]
55
- fn constructor() {}
56
- }
57
- EOF
58
-
59
- # Create test crate
60
- mkdir -p "$test_dir/src"
61
- cat > "$test_dir/Nargo.toml" << TEOF
62
- [package]
63
- name = "${crate_name}_test"
64
- type = "lib"
65
-
66
- [dependencies]
67
- aztec = { git="https://github.com/AztecProtocol/aztec-nr", tag="v${AZTEC_VERSION}", directory="aztec" }
68
- ${crate_name}_contract = { path = "../${contract_dir}" }
69
- TEOF
70
-
71
- cat > "$test_dir/src/lib.nr" << 'NOIR'
72
- use aztec::test::helpers::test_environment::TestEnvironment;
73
- use __CRATE_NAME___contract::Main;
74
-
75
- #[test]
76
- unconstrained fn test_constructor() {
77
- let mut env = TestEnvironment::new();
78
- let deployer = env.create_light_account();
79
-
80
- // Deploy the contract with the default constructor:
81
- let contract_address = env.deploy("@__CRATE_NAME___contract/Main").with_private_initializer(
82
- deployer,
83
- Main::interface().constructor(),
84
- );
85
-
86
- // Deploy without an initializer:
87
- let contract_address = env.deploy("@__CRATE_NAME___contract/Main").without_initializer();
88
- }
89
- NOIR
90
-
91
- sed -i "s/__CRATE_NAME__/${crate_name}/g" "$test_dir/src/lib.nr"
37
+ # Copy template crates and substitute placeholders
38
+ cp -r "$TEMPLATE_DIR/contract" "$contract_dir"
39
+ cp -r "$TEMPLATE_DIR/test" "$test_dir"
40
+ # Use perl -i for portability across os.
41
+ find "$contract_dir" "$test_dir" -type f -exec \
42
+ perl -i -pe "s/__CRATE_NAME__/${crate_name}/g; s/__AZTEC_VERSION__/${AZTEC_VERSION}/g" {} +
92
43
 
93
44
  # Add members to workspace Nargo.toml
94
45
  if grep -q 'members\s*=\s*\[\s*\]' Nargo.toml; then
95
46
  # Empty array: members = []
96
- sed -i "s|members\s*=\s*\[\s*\]|members = [\"${contract_dir}\", \"${test_dir}\"]|" Nargo.toml
47
+ perl -i -pe "s|members\s*=\s*\[\s*\]|members = [\"${contract_dir}\", \"${test_dir}\"]|" Nargo.toml
97
48
  else
98
49
  # Non-empty array: add before closing ]
99
- sed -i "s|\(members\s*=\s*\[.*\)\]|\1, \"${contract_dir}\", \"${test_dir}\"]|" Nargo.toml
50
+ perl -i -pe "s|(members\s*=\s*\[.*)\]|\1, \"${contract_dir}\", \"${test_dir}\"]|" Nargo.toml
100
51
  fi
101
52
 
102
53
  echo "Created crates '${contract_dir}' and '${test_dir}'"
package/scripts/aztec.sh CHANGED
@@ -23,13 +23,17 @@ case $cmd in
23
23
  # Attempt to compile, no-op if there are no changes
24
24
  node --no-warnings "$script_dir/../dest/bin/index.js" compile
25
25
 
26
- export LOG_LEVEL="${LOG_LEVEL:-"error;trace:contract_log"}"
26
+ export LOG_LEVEL="${LOG_LEVEL:-"error;trace:^contract:"}"
27
27
  aztec start --txe --port 8081 &
28
28
  server_pid=$!
29
29
  trap 'kill $server_pid &>/dev/null || true' EXIT
30
+ if ! command -v nc &>/dev/null; then
31
+ echo "Error: 'nc' (netcat) is required but not installed." >&2
32
+ exit 1
33
+ fi
30
34
  while ! nc -z 127.0.0.1 8081 &>/dev/null; do sleep 0.2; done
31
35
  export NARGO_FOREIGN_CALL_TIMEOUT=300000
32
- nargo test --silence-warnings --oracle-resolver http://127.0.0.1:8081 --test-threads 16 "$@"
36
+ nargo test --silence-warnings --oracle-resolver http://127.0.0.1:8081 "$@"
33
37
  ;;
34
38
  start)
35
39
  if [ "${1:-}" == "--local-network" ]; then
package/scripts/init.sh CHANGED
@@ -16,11 +16,11 @@ Options:
16
16
  -h, --help Print help
17
17
 
18
18
  This command creates a new Aztec Noir project in the current directory with
19
- a workspace containing a contract crate and a test crate, and automatically
20
- adds the Aztec.nr dependency to both.
19
+ a workspace containing a Counter contract example with tests. The Counter
20
+ demonstrates private state, private functions, and utility reads.
21
21
 
22
- If a workspace already exists in the current directory, use
23
- 'aztec new <name>' instead to add another contract.
22
+ Use 'aztec new <name>' to create a blank contract project, or to add another
23
+ contract to an existing workspace.
24
24
  EOF
25
25
  exit 0
26
26
  ;;
@@ -36,4 +36,4 @@ done
36
36
  package_name="$(basename $(pwd))"
37
37
 
38
38
  echo "Initializing Aztec contract project..."
39
- $script_path/setup_workspace.sh "$package_name"
39
+ $script_path/setup_workspace.sh "$package_name" counter
package/scripts/new.sh CHANGED
@@ -68,7 +68,7 @@ fi
68
68
  if [ -f "Nargo.toml" ] && grep -q '\[workspace\]' Nargo.toml; then
69
69
  # Add crate pair to existing workspace
70
70
  echo "Adding contract '$package_name' to existing workspace..."
71
- $script_path/add_crate.sh "$package_name"
71
+ $script_path/add_crate.sh "$package_name" blank
72
72
  else
73
73
  # Create new workspace
74
74
  if [ -d "$project_path" ] && [ "$(ls -A $project_path 2>/dev/null)" ]; then
@@ -79,5 +79,5 @@ else
79
79
  echo "Creating new Aztec contract project at $project_path..."
80
80
  mkdir -p "$project_path"
81
81
  cd "$project_path"
82
- $script_path/setup_workspace.sh "$package_name"
82
+ $script_path/setup_workspace.sh "$package_name" blank
83
83
  fi
@@ -2,10 +2,11 @@
2
2
  set -euo pipefail
3
3
 
4
4
  # Creates an Aztec contract workspace with a contract crate and a test crate.
5
- # Usage: setup_workspace.sh <package_name>
5
+ # Usage: setup_workspace.sh <package_name> <template>
6
6
  # Must be called from the workspace root directory.
7
7
 
8
8
  package_name=$1
9
+ template=$2
9
10
  script_path=$(realpath $(dirname "$0"))
10
11
 
11
12
  if [ -z "$package_name" ]; then
@@ -26,7 +27,7 @@ members = []
26
27
  EOF
27
28
 
28
29
  # Create the first crate pair
29
- $script_path/add_crate.sh "$package_name"
30
+ $script_path/add_crate.sh "$package_name" "$template"
30
31
 
31
32
  # Create README
32
33
  cat > README.md << REOF
@@ -0,0 +1,6 @@
1
+ [package]
2
+ name = "__CRATE_NAME___contract"
3
+ type = "contract"
4
+
5
+ [dependencies]
6
+ aztec = { git="https://github.com/AztecProtocol/aztec-nr", tag="v__AZTEC_VERSION__", directory="aztec" }
@@ -0,0 +1,10 @@
1
+ use aztec::macros::aztec;
2
+
3
+ #[aztec]
4
+ pub contract Main {
5
+ use aztec::macros::functions::{external, initializer};
6
+
7
+ #[initializer]
8
+ #[external("private")]
9
+ fn constructor() {}
10
+ }
@@ -0,0 +1,7 @@
1
+ [package]
2
+ name = "__CRATE_NAME___test"
3
+ type = "lib"
4
+
5
+ [dependencies]
6
+ aztec = { git="https://github.com/AztecProtocol/aztec-nr", tag="v__AZTEC_VERSION__", directory="aztec" }
7
+ __CRATE_NAME___contract = { path = "../__CRATE_NAME___contract" }
@@ -0,0 +1,11 @@
1
+ use aztec::test::helpers::test_environment::TestEnvironment;
2
+ use __CRATE_NAME___contract::Main;
3
+
4
+ #[test]
5
+ unconstrained fn test_constructor() {
6
+ let mut env = TestEnvironment::new();
7
+ let deployer = env.create_light_account();
8
+
9
+ let _contract_address = env.deploy("@__CRATE_NAME___contract/Main")
10
+ .with_private_initializer(deployer, Main::interface().constructor());
11
+ }
@@ -0,0 +1,7 @@
1
+ [package]
2
+ name = "__CRATE_NAME___contract"
3
+ type = "contract"
4
+
5
+ [dependencies]
6
+ aztec = { git="https://github.com/AztecProtocol/aztec-nr", tag="v__AZTEC_VERSION__", directory="aztec" }
7
+ balance_set = { git="https://github.com/AztecProtocol/aztec-nr", tag="v__AZTEC_VERSION__", directory="balance-set" }
@@ -0,0 +1,48 @@
1
+ use aztec::macros::aztec;
2
+
3
+ #[aztec]
4
+ pub contract Counter {
5
+ use aztec::{
6
+ macros::{functions::{external, initializer}, storage::storage},
7
+ messages::delivery::MessageDelivery,
8
+ protocol::address::AztecAddress,
9
+ state_vars::Owned,
10
+ };
11
+ use balance_set::BalanceSet;
12
+
13
+ #[storage]
14
+ struct Storage<Context> {
15
+ // Each owner has their own counter, stored as private encrypted notes.
16
+ // Owned: dictates who will receive the encrypted notes.
17
+ // BalanceSet: manages the underlying notes, providing add/sub/balance_of.
18
+ counters: Owned<BalanceSet<Context>, Context>,
19
+ }
20
+
21
+ // Sets the owner's counter to an initial value.
22
+ //
23
+ // #[external("private")]: executes on the user's device, inputs are hidden from everyone.
24
+ #[initializer]
25
+ #[external("private")]
26
+ fn constructor(initial_value: u128, owner: AztecAddress) {
27
+ // Delivers the note to the recipient onchain with provable correctness.
28
+ // Without delivery, the recipient can't find or decrypt the note.
29
+ self.storage.counters.at(owner).add(initial_value).deliver(
30
+ MessageDelivery::onchain_constrained(),
31
+ );
32
+ }
33
+
34
+ // Adds 1 to the owner's counter.
35
+ #[external("private")]
36
+ fn increment(owner: AztecAddress) {
37
+ self.storage.counters.at(owner).add(1).deliver(MessageDelivery::onchain_constrained());
38
+ }
39
+
40
+ // Returns the current value of the owner's counter.
41
+ //
42
+ // #[external("utility")]: runs off-chain, no transaction created, no cost.
43
+ // Only the owner can decrypt and read their own counter.
44
+ #[external("utility")]
45
+ unconstrained fn get_counter(owner: AztecAddress) -> u128 {
46
+ self.storage.counters.at(owner).balance_of()
47
+ }
48
+ }
@@ -0,0 +1,7 @@
1
+ [package]
2
+ name = "__CRATE_NAME___test"
3
+ type = "lib"
4
+
5
+ [dependencies]
6
+ aztec = { git="https://github.com/AztecProtocol/aztec-nr", tag="v__AZTEC_VERSION__", directory="aztec" }
7
+ __CRATE_NAME___contract = { path = "../__CRATE_NAME___contract" }
@@ -0,0 +1,32 @@
1
+ use aztec::{protocol::address::AztecAddress, test::helpers::test_environment::TestEnvironment};
2
+ use __CRATE_NAME___contract::Counter;
3
+
4
+ unconstrained fn setup(initial_value: u128) -> (TestEnvironment, AztecAddress, AztecAddress) {
5
+ let mut env = TestEnvironment::new();
6
+ let owner = env.create_light_account();
7
+
8
+ let contract_address = env.deploy("@__CRATE_NAME___contract/Counter")
9
+ .with_private_initializer(owner, Counter::interface().constructor(initial_value, owner));
10
+
11
+ (env, contract_address, owner)
12
+ }
13
+
14
+ #[test]
15
+ unconstrained fn test_constructor() {
16
+ let initial_value = 5;
17
+ let (env, contract_address, owner) = setup(initial_value);
18
+
19
+ let counter = env.execute_utility(Counter::at(contract_address).get_counter(owner));
20
+ assert_eq(counter, initial_value);
21
+ }
22
+
23
+ #[test]
24
+ unconstrained fn test_increment() {
25
+ let initial_value = 5;
26
+ let (mut env, contract_address, owner) = setup(initial_value);
27
+
28
+ env.call_private(owner, Counter::at(contract_address).increment(owner));
29
+
30
+ let counter = env.execute_utility(Counter::at(contract_address).get_counter(owner));
31
+ assert_eq(counter, initial_value + 1);
32
+ }
package/src/bin/index.ts CHANGED
@@ -47,7 +47,7 @@ async function main() {
47
47
  await enrichEnvironmentWithNetworkConfig(networkName);
48
48
  enrichEnvironmentWithChainName(networkName);
49
49
 
50
- const cliVersion = getPackageVersion() ?? 'unknown';
50
+ const cliVersion = getPackageVersion();
51
51
  let program = new Command('aztec');
52
52
  program.description('Aztec command line interface').version(cliVersion).enablePositionalOptions();
53
53
  program = injectAztecCommands(program, userLog, debugLogger);
@@ -1,3 +1,4 @@
1
+ import { registerAztecNodeRpcHandlers } from '@aztec/aztec-node';
1
2
  import { getActiveNetworkName } from '@aztec/foundation/config';
2
3
  import {
3
4
  type NamespacedApiHandlers,
@@ -7,10 +8,9 @@ import {
7
8
  } from '@aztec/foundation/json-rpc/server';
8
9
  import type { LogFn, Logger } from '@aztec/foundation/log';
9
10
  import type { ChainConfig } from '@aztec/stdlib/config';
10
- import { AztecNodeAdminApiSchema, AztecNodeApiSchema } from '@aztec/stdlib/interfaces/client';
11
11
  import { getPackageVersion } from '@aztec/stdlib/update-checker';
12
12
  import { getVersioningMiddleware } from '@aztec/stdlib/versioning';
13
- import { getOtelJsonRpcPropagationMiddleware } from '@aztec/telemetry-client';
13
+ import { getOtelJsonRpcDiagnosticsMiddleware, getOtelJsonRpcPropagationMiddleware } from '@aztec/telemetry-client';
14
14
 
15
15
  import { createLocalNetwork } from '../local-network/index.js';
16
16
  import { github, splash } from '../splash.js';
@@ -27,30 +27,22 @@ export async function aztecStart(options: any, userLog: LogFn, debugLogger: Logg
27
27
  let config: ChainConfig | undefined = undefined;
28
28
 
29
29
  if (options.localNetwork) {
30
- const localNetwork = extractNamespacedOptions(options, 'local-network');
31
- localNetwork.testAccounts = true;
30
+ const localNetwork = extractNamespacedOptions(options, 'localNetwork');
32
31
  userLog(`${splash}\n${github}\n\n`);
33
- userLog(`Setting up Aztec local network ${packageVersion ?? 'unknown'}, please stand by...`);
32
+ userLog(`Setting up Aztec local network ${packageVersion}, please stand by...`);
34
33
 
35
34
  const { node, stop } = await createLocalNetwork(
36
35
  {
37
36
  l1Mnemonic: localNetwork.l1Mnemonic,
38
37
  l1RpcUrls: options.l1RpcUrls,
39
38
  testAccounts: localNetwork.testAccounts,
40
- realProofs: false,
41
- // Setting the epoch duration to 2 by default for local network. This allows the epoch to be "proven" faster, so
42
- // the users can consume out hash without having to wait for a long time.
43
- // Note: We are not proving anything in the local network (realProofs == false). But in `createLocalNetwork`,
44
- // the EpochTestSettler will set the out hash to the outbox when an epoch is complete.
45
- aztecEpochDuration: 2,
46
39
  },
47
40
  userLog,
48
41
  );
49
42
 
50
43
  // Start Node and PXE JSON-RPC server
51
44
  signalHandlers.push(stop);
52
- services.node = [node, AztecNodeApiSchema];
53
- adminServices.node = [node, AztecNodeAdminApiSchema];
45
+ registerAztecNodeRpcHandlers(node, services, adminServices, { debug: true });
54
46
  } else {
55
47
  // Route --prover-node through startNode
56
48
  if (options.proverNode && !options.node) {
@@ -64,9 +56,6 @@ export async function aztecStart(options: any, userLog: LogFn, debugLogger: Logg
64
56
  } else if (options.bot) {
65
57
  const { startBot } = await import('./cmds/start_bot.js');
66
58
  await startBot(options, signalHandlers, services, userLog);
67
- } else if (options.archiver) {
68
- const { startArchiver } = await import('./cmds/start_archiver.js');
69
- ({ config } = await startArchiver(options, signalHandlers, services));
70
59
  } else if (options.p2pBootstrap) {
71
60
  const { startP2PBootstrap } = await import('./cmds/start_p2p_bootstrap.js');
72
61
  ({ config } = await startP2PBootstrap(options, signalHandlers, services, userLog));
@@ -78,7 +67,7 @@ export async function aztecStart(options: any, userLog: LogFn, debugLogger: Logg
78
67
  await startProverBroker(options, signalHandlers, services, userLog);
79
68
  } else if (options.txe) {
80
69
  const { startTXE } = await import('./cmds/start_txe.js');
81
- await startTXE(options, debugLogger);
70
+ await startTXE(options, signalHandlers, debugLogger);
82
71
  } else if (options.sequencer) {
83
72
  userLog(`Cannot run a standalone sequencer without a node`);
84
73
  process.exit(1);
@@ -94,7 +83,14 @@ export async function aztecStart(options: any, userLog: LogFn, debugLogger: Logg
94
83
 
95
84
  // Start the main JSON-RPC server
96
85
  if (Object.entries(services).length > 0) {
86
+ if (services.aztec) {
87
+ const { BarretenbergSync } = await import('@aztec/bb.js');
88
+ // JSON-RPC schema parsing may decompress compressed Chonk proofs before the node handler runs.
89
+ await BarretenbergSync.initSingleton();
90
+ }
91
+
97
92
  const rpcServer = createNamespacedSafeJsonRpcServer(services, {
93
+ diagnostic: getOtelJsonRpcDiagnosticsMiddleware(),
98
94
  http200OnError: false,
99
95
  log: debugLogger,
100
96
  middlewares: [getOtelJsonRpcPropagationMiddleware(), getVersioningMiddleware(versions, versioningOpts)],
@@ -126,6 +122,7 @@ export async function aztecStart(options: any, userLog: LogFn, debugLogger: Logg
126
122
  }
127
123
 
128
124
  const rpcServer = createNamespacedSafeJsonRpcServer(adminServices, {
125
+ diagnostic: getOtelJsonRpcDiagnosticsMiddleware(),
129
126
  http200OnError: false,
130
127
  log: debugLogger,
131
128
  middlewares: adminMiddlewares,
@@ -36,7 +36,7 @@ export interface AztecStartOption {
36
36
  parseVal?: (val: string) => any;
37
37
  }
38
38
 
39
- export const getOptions = (namespace: string, configMappings: Record<string, ConfigMapping>) => {
39
+ export const getOptions = (namespace: string, configMappings: Record<string, ConfigMapping<unknown>>) => {
40
40
  const options: AztecStartOption[] = [];
41
41
  for (const [key, { env, defaultValue: def, parseEnv, description, printDefault, fallback }] of Object.entries(
42
42
  configMappings,
@@ -58,7 +58,11 @@ export const getOptions = (namespace: string, configMappings: Record<string, Con
58
58
  return options;
59
59
  };
60
60
 
61
- const configToFlag = (flag: string, configMapping: ConfigMapping, overrideDefaultValue?: any): AztecStartOption => {
61
+ const configToFlag = (
62
+ flag: string,
63
+ configMapping: ConfigMapping<unknown>,
64
+ overrideDefaultValue?: any,
65
+ ): AztecStartOption => {
62
66
  if (!configMapping.isBoolean) {
63
67
  flag += ' <value>';
64
68
  }
@@ -125,6 +129,12 @@ export const aztecStartOptions: { [key: string]: AztecStartOption[] } = {
125
129
  defaultValue: DefaultMnemonic,
126
130
  env: 'MNEMONIC',
127
131
  },
132
+ {
133
+ flag: '--local-network.testAccounts',
134
+ description: 'Deploy test accounts on local network start',
135
+ env: 'TEST_ACCOUNTS',
136
+ ...booleanConfigHelper(true),
137
+ },
128
138
  ],
129
139
  API: [
130
140
  {
@@ -165,6 +175,13 @@ export const aztecStartOptions: { [key: string]: AztecStartOption[] } = {
165
175
  env: 'AZTEC_RESET_ADMIN_API_KEY',
166
176
  parseVal: val => val === 'true' || val === '1',
167
177
  },
178
+ {
179
+ flag: '--node-debug',
180
+ description: 'Expose debug endpoints (e.g. mineBlock) on the main RPC port',
181
+ defaultValue: false,
182
+ env: 'AZTEC_NODE_DEBUG',
183
+ parseVal: val => val === undefined || val === 'true' || val === '1',
184
+ },
168
185
  {
169
186
  flag: '--api-prefix <value>',
170
187
  description: 'Prefix for API routes on any service that is started',
@@ -205,12 +222,6 @@ export const aztecStartOptions: { [key: string]: AztecStartOption[] } = {
205
222
  },
206
223
  ],
207
224
  ARCHIVER: [
208
- {
209
- flag: '--archiver',
210
- description: 'Starts Aztec Archiver with options',
211
- defaultValue: undefined,
212
- env: undefined,
213
- },
214
225
  ...getOptions(
215
226
  'archiver',
216
227
  omitConfigMappings(archiverConfigMappings, Object.keys(l1ContractsConfigMappings) as (keyof ArchiverConfig)[]),
@@ -257,11 +268,7 @@ export const aztecStartOptions: { [key: string]: AztecStartOption[] } = {
257
268
  defaultValue: undefined,
258
269
  env: undefined,
259
270
  },
260
- ...getOptions(
261
- 'proverBroker',
262
- // filter out archiver options from prover node options as they're passed separately in --archiver
263
- proverBrokerConfigMappings,
264
- ),
271
+ ...getOptions('proverBroker', proverBrokerConfigMappings),
265
272
  ],
266
273
  'PROVER AGENT': [
267
274
  {
@@ -309,15 +316,7 @@ export const aztecStartOptions: { [key: string]: AztecStartOption[] } = {
309
316
  },
310
317
  ...getOptions('bot', botConfigMappings),
311
318
  ],
312
- PXE: [
313
- {
314
- flag: '--pxe',
315
- description: 'Starts Aztec PXE with options',
316
- defaultValue: undefined,
317
- env: undefined,
318
- },
319
- ...getOptions('pxe', allPxeConfigMappings),
320
- ],
319
+ PXE: [...getOptions('pxe', allPxeConfigMappings)],
321
320
  TXE: [
322
321
  {
323
322
  flag: '--txe',
@@ -1,5 +1,6 @@
1
1
  import { findBbBinary } from '@aztec/bb.js';
2
2
  import type { LogFn } from '@aztec/foundation/log';
3
+ import { getPackageVersion } from '@aztec/stdlib/update-checker';
3
4
 
4
5
  import { execFileSync } from 'child_process';
5
6
  import type { Command } from 'commander';
@@ -9,6 +10,7 @@ import { join } from 'path';
9
10
  import { readArtifactFiles } from './utils/artifacts.js';
10
11
  import { needsRecompile } from './utils/needs_recompile.js';
11
12
  import { run } from './utils/spawn.js';
13
+ import { warnIfAztecVersionMismatch } from './utils/warn_if_aztec_version_mismatch.js';
12
14
 
13
15
  /** Returns paths to contract artifacts in the target directory. */
14
16
  async function collectContractArtifacts(): Promise<string[]> {
@@ -24,15 +26,13 @@ async function collectContractArtifacts(): Promise<string[]> {
24
26
  return files.filter(f => Array.isArray(f.content.functions)).map(f => f.filePath);
25
27
  }
26
28
 
27
- /** Strips the `__aztec_nr_internals__` prefix from function names in contract artifacts. */
28
- async function stripInternalPrefixes(artifactPaths: string[]): Promise<void> {
29
+ /** Stamps the Aztec stack version into the contract artifacts. */
30
+ async function stampAztecVersion(artifactPaths: string[]): Promise<void> {
31
+ const version = getPackageVersion();
29
32
  for (const path of artifactPaths) {
30
33
  const artifact = JSON.parse(await readFile(path, 'utf-8'));
31
- for (const fn of artifact.functions) {
32
- if (typeof fn.name === 'string') {
33
- fn.name = fn.name.replace(/^__aztec_nr_internals__/, '');
34
- }
35
- }
34
+ // eslint-disable-next-line camelcase
35
+ artifact.aztec_version = version;
36
36
  await writeFile(path, JSON.stringify(artifact, null, 2) + '\n');
37
37
  }
38
38
  }
@@ -139,6 +139,8 @@ async function checkNoTestsInContracts(nargo: string, log: LogFn): Promise<void>
139
139
 
140
140
  /** Compiles Aztec Noir contracts and postprocesses artifacts. */
141
141
  async function compileAztecContract(nargoArgs: string[], log: LogFn): Promise<void> {
142
+ await warnIfAztecVersionMismatch(log);
143
+
142
144
  if (!(await needsRecompile())) {
143
145
  log('No source changes detected, skipping compilation.');
144
146
  return;
@@ -159,8 +161,7 @@ async function compileAztecContract(nargoArgs: string[], log: LogFn): Promise<vo
159
161
  const bbArgs = artifacts.flatMap(a => ['-i', a]);
160
162
  await run(bb, ['aztec_process', ...bbArgs]);
161
163
 
162
- // TODO: This should be part of bb aztec_process!
163
- await stripInternalPrefixes(artifacts);
164
+ await stampAztecVersion(artifacts);
164
165
  }
165
166
 
166
167
  log('Compilation complete!');