@aztec/aztec 5.0.0-private.20260319 → 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.
- package/dest/bin/index.js +1 -1
- package/dest/cli/aztec_start_action.d.ts +1 -1
- package/dest/cli/aztec_start_action.d.ts.map +1 -1
- package/dest/cli/aztec_start_action.js +16 -24
- package/dest/cli/aztec_start_options.d.ts +2 -2
- package/dest/cli/aztec_start_options.d.ts.map +1 -1
- package/dest/cli/aztec_start_options.js +14 -14
- package/dest/cli/cmds/compile.d.ts +1 -1
- package/dest/cli/cmds/compile.d.ts.map +1 -1
- package/dest/cli/cmds/compile.js +8 -8
- package/dest/cli/cmds/profile.d.ts +1 -1
- package/dest/cli/cmds/profile.d.ts.map +1 -1
- package/dest/cli/cmds/profile.js +1 -1
- package/dest/cli/cmds/profile_gates.d.ts +2 -2
- package/dest/cli/cmds/profile_gates.d.ts.map +1 -1
- package/dest/cli/cmds/profile_gates.js +21 -3
- package/dest/cli/cmds/standby.d.ts +3 -5
- package/dest/cli/cmds/standby.d.ts.map +1 -1
- package/dest/cli/cmds/standby.js +3 -3
- package/dest/cli/cmds/start_bot.d.ts +1 -1
- package/dest/cli/cmds/start_bot.d.ts.map +1 -1
- package/dest/cli/cmds/start_bot.js +8 -4
- package/dest/cli/cmds/start_node.d.ts +1 -1
- package/dest/cli/cmds/start_node.d.ts.map +1 -1
- package/dest/cli/cmds/start_node.js +13 -40
- package/dest/cli/cmds/start_prover_agent.d.ts +1 -1
- package/dest/cli/cmds/start_prover_agent.d.ts.map +1 -1
- package/dest/cli/cmds/start_prover_agent.js +5 -17
- package/dest/cli/cmds/start_prover_broker.d.ts +1 -1
- package/dest/cli/cmds/start_prover_broker.d.ts.map +1 -1
- package/dest/cli/cmds/start_prover_broker.js +11 -8
- package/dest/cli/cmds/start_txe.d.ts +2 -2
- package/dest/cli/cmds/start_txe.d.ts.map +1 -1
- package/dest/cli/cmds/start_txe.js +6 -5
- package/dest/cli/cmds/utils/collect_crate_dirs.d.ts +21 -0
- package/dest/cli/cmds/utils/collect_crate_dirs.d.ts.map +1 -0
- package/dest/cli/cmds/utils/collect_crate_dirs.js +114 -0
- package/dest/cli/cmds/utils/needs_recompile.d.ts +1 -1
- package/dest/cli/cmds/utils/needs_recompile.d.ts.map +1 -1
- package/dest/cli/cmds/utils/needs_recompile.js +9 -53
- package/dest/cli/cmds/utils/warn_if_aztec_version_mismatch.d.ts +4 -0
- package/dest/cli/cmds/utils/warn_if_aztec_version_mismatch.d.ts.map +1 -0
- package/dest/cli/cmds/utils/warn_if_aztec_version_mismatch.js +61 -0
- package/dest/cli/util.js +7 -5
- package/dest/examples/token.js +3 -3
- package/dest/local-network/auth_registry.d.ts +5 -0
- package/dest/local-network/auth_registry.d.ts.map +1 -0
- package/dest/local-network/auth_registry.js +17 -0
- package/dest/local-network/banana_fpc.d.ts +3 -2
- package/dest/local-network/banana_fpc.d.ts.map +1 -1
- package/dest/local-network/banana_fpc.js +11 -7
- package/dest/local-network/local-network.d.ts +6 -29
- package/dest/local-network/local-network.d.ts.map +1 -1
- package/dest/local-network/local-network.js +45 -70
- package/dest/testing/cheat_codes.d.ts +18 -17
- package/dest/testing/cheat_codes.d.ts.map +1 -1
- package/dest/testing/cheat_codes.js +70 -36
- package/dest/testing/epoch_test_settler.d.ts +2 -2
- package/dest/testing/epoch_test_settler.d.ts.map +1 -1
- package/dest/testing/epoch_test_settler.js +6 -25
- package/dest/testing/index.d.ts +1 -2
- package/dest/testing/index.d.ts.map +1 -1
- package/dest/testing/index.js +0 -1
- package/package.json +34 -33
- package/scripts/add_crate.sh +11 -60
- package/scripts/aztec.sh +6 -2
- package/scripts/init.sh +5 -5
- package/scripts/new.sh +2 -2
- package/scripts/setup_workspace.sh +3 -2
- package/scripts/templates/blank/contract/Nargo.toml +6 -0
- package/scripts/templates/blank/contract/src/main.nr +10 -0
- package/scripts/templates/blank/test/Nargo.toml +7 -0
- package/scripts/templates/blank/test/src/lib.nr +11 -0
- package/scripts/templates/counter/contract/Nargo.toml +7 -0
- package/scripts/templates/counter/contract/src/main.nr +48 -0
- package/scripts/templates/counter/test/Nargo.toml +7 -0
- package/scripts/templates/counter/test/src/lib.nr +32 -0
- package/src/bin/index.ts +1 -1
- package/src/cli/aztec_start_action.ts +14 -17
- package/src/cli/aztec_start_options.ts +21 -22
- package/src/cli/cmds/compile.ts +10 -9
- package/src/cli/cmds/profile.ts +2 -1
- package/src/cli/cmds/profile_gates.ts +20 -4
- package/src/cli/cmds/standby.ts +4 -4
- package/src/cli/cmds/start_bot.ts +9 -6
- package/src/cli/cmds/start_node.ts +20 -23
- package/src/cli/cmds/start_prover_agent.ts +5 -8
- package/src/cli/cmds/start_prover_broker.ts +10 -11
- package/src/cli/cmds/start_txe.ts +7 -5
- package/src/cli/cmds/utils/collect_crate_dirs.ts +118 -0
- package/src/cli/cmds/utils/needs_recompile.ts +8 -61
- package/src/cli/cmds/utils/warn_if_aztec_version_mismatch.ts +76 -0
- package/src/cli/util.ts +7 -7
- package/src/examples/token.ts +3 -3
- package/src/local-network/auth_registry.ts +19 -0
- package/src/local-network/banana_fpc.ts +12 -8
- package/src/local-network/local-network.ts +49 -80
- package/src/testing/cheat_codes.ts +89 -39
- package/src/testing/epoch_test_settler.ts +8 -31
- package/src/testing/index.ts +0 -1
- package/dest/cli/cmds/start_archiver.d.ts +0 -9
- package/dest/cli/cmds/start_archiver.d.ts.map +0 -1
- package/dest/cli/cmds/start_archiver.js +0 -48
- package/dest/testing/anvil_test_watcher.d.ts +0 -42
- package/dest/testing/anvil_test_watcher.d.ts.map +0 -1
- package/dest/testing/anvil_test_watcher.js +0 -181
- package/src/cli/cmds/start_archiver.ts +0 -50
- 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-
|
|
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-
|
|
32
|
-
"@aztec/archiver": "5.0.0-
|
|
33
|
-
"@aztec/aztec-node": "5.0.0-
|
|
34
|
-
"@aztec/aztec.js": "5.0.0-
|
|
35
|
-
"@aztec/bb-prover": "5.0.0-
|
|
36
|
-
"@aztec/bb.js": "5.0.0-
|
|
37
|
-
"@aztec/blob-client": "5.0.0-
|
|
38
|
-
"@aztec/bot": "5.0.0-
|
|
39
|
-
"@aztec/builder": "5.0.0-
|
|
40
|
-
"@aztec/cli": "5.0.0-
|
|
41
|
-
"@aztec/constants": "5.0.0-
|
|
42
|
-
"@aztec/entrypoints": "5.0.0-
|
|
43
|
-
"@aztec/ethereum": "5.0.0-
|
|
44
|
-
"@aztec/foundation": "5.0.0-
|
|
45
|
-
"@aztec/kv-store": "5.0.0-
|
|
46
|
-
"@aztec/l1-artifacts": "5.0.0-
|
|
47
|
-
"@aztec/node-lib": "5.0.0-
|
|
48
|
-
"@aztec/noir-contracts.js": "5.0.0-
|
|
49
|
-
"@aztec/noir-protocol-circuits-types": "5.0.0-
|
|
50
|
-
"@aztec/p2p": "5.0.0-
|
|
51
|
-
"@aztec/p2p-bootstrap": "5.0.0-
|
|
52
|
-
"@aztec/protocol-contracts": "5.0.0-
|
|
53
|
-
"@aztec/prover-client": "5.0.0-
|
|
54
|
-
"@aztec/prover-node": "5.0.0-
|
|
55
|
-
"@aztec/pxe": "5.0.0-
|
|
56
|
-
"@aztec/sequencer-client": "5.0.0-
|
|
57
|
-
"@aztec/
|
|
58
|
-
"@aztec/
|
|
59
|
-
"@aztec/
|
|
60
|
-
"@aztec/
|
|
61
|
-
"@aztec/
|
|
62
|
-
"@aztec/
|
|
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",
|
package/scripts/add_crate.sh
CHANGED
|
@@ -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
|
-
#
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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:
|
|
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
|
|
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
|
|
20
|
-
|
|
19
|
+
a workspace containing a Counter contract example with tests. The Counter
|
|
20
|
+
demonstrates private state, private functions, and utility reads.
|
|
21
21
|
|
|
22
|
-
|
|
23
|
-
|
|
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,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,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()
|
|
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, '
|
|
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
|
|
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
|
-
|
|
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 = (
|
|
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',
|
package/src/cli/cmds/compile.ts
CHANGED
|
@@ -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
|
-
/**
|
|
28
|
-
async function
|
|
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
|
-
|
|
32
|
-
|
|
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
|
-
|
|
163
|
-
await stripInternalPrefixes(artifacts);
|
|
164
|
+
await stampAztecVersion(artifacts);
|
|
164
165
|
}
|
|
165
166
|
|
|
166
167
|
log('Compilation complete!');
|