@aztec/cli 0.17.0 → 0.77.0-testnet-ignition.17
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/README.md +10 -16
- package/dest/cmds/contracts/index.d.ts +4 -0
- package/dest/cmds/contracts/index.d.ts.map +1 -0
- package/dest/cmds/contracts/index.js +12 -0
- package/dest/cmds/contracts/inspect_contract.d.ts +3 -0
- package/dest/cmds/contracts/inspect_contract.d.ts.map +1 -0
- package/dest/cmds/contracts/inspect_contract.js +37 -0
- package/dest/cmds/{parse_parameter_struct.d.ts → contracts/parse_parameter_struct.d.ts} +1 -4
- package/dest/cmds/contracts/parse_parameter_struct.d.ts.map +1 -0
- package/dest/cmds/contracts/parse_parameter_struct.js +13 -0
- package/dest/cmds/devnet/bootstrap_network.d.ts +3 -0
- package/dest/cmds/devnet/bootstrap_network.d.ts.map +1 -0
- package/dest/cmds/devnet/bootstrap_network.js +196 -0
- package/dest/cmds/devnet/faucet.d.ts +4 -0
- package/dest/cmds/devnet/faucet.d.ts.map +1 -0
- package/dest/cmds/devnet/faucet.js +26 -0
- package/dest/cmds/devnet/index.d.ts +4 -0
- package/dest/cmds/devnet/index.d.ts.map +1 -0
- package/dest/cmds/devnet/index.js +14 -0
- package/dest/cmds/infrastructure/index.d.ts +4 -0
- package/dest/cmds/infrastructure/index.d.ts.map +1 -0
- package/dest/cmds/infrastructure/index.js +24 -0
- package/dest/cmds/infrastructure/sequencers.d.ts +13 -0
- package/dest/cmds/infrastructure/sequencers.d.ts.map +1 -0
- package/dest/cmds/infrastructure/sequencers.js +93 -0
- package/dest/cmds/infrastructure/setup_l2_contract.d.ts +3 -0
- package/dest/cmds/infrastructure/setup_l2_contract.d.ts.map +1 -0
- package/dest/cmds/infrastructure/setup_l2_contract.js +43 -0
- package/dest/cmds/l1/advance_epoch.d.ts +3 -0
- package/dest/cmds/l1/advance_epoch.d.ts.map +1 -0
- package/dest/cmds/l1/advance_epoch.js +10 -0
- package/dest/cmds/l1/assume_proven_through.d.ts +3 -0
- package/dest/cmds/l1/assume_proven_through.d.ts.map +1 -0
- package/dest/cmds/l1/assume_proven_through.js +12 -0
- package/dest/cmds/l1/bridge_erc20.d.ts +4 -0
- package/dest/cmds/l1/bridge_erc20.d.ts.map +1 -0
- package/dest/cmds/l1/bridge_erc20.js +31 -0
- package/dest/cmds/l1/create_l1_account.d.ts +3 -0
- package/dest/cmds/l1/create_l1_account.d.ts.map +1 -0
- package/dest/cmds/l1/create_l1_account.js +15 -0
- package/dest/cmds/l1/deploy_l1_contracts.d.ts +4 -0
- package/dest/cmds/l1/deploy_l1_contracts.d.ts.map +1 -0
- package/dest/cmds/l1/deploy_l1_contracts.js +29 -0
- package/dest/cmds/l1/deploy_l1_verifier.d.ts +5 -0
- package/dest/cmds/l1/deploy_l1_verifier.d.ts.map +1 -0
- package/dest/cmds/l1/deploy_l1_verifier.js +54 -0
- package/dest/cmds/l1/deploy_new_rollup.d.ts +4 -0
- package/dest/cmds/l1/deploy_new_rollup.d.ts.map +1 -0
- package/dest/cmds/l1/deploy_new_rollup.js +19 -0
- package/dest/cmds/l1/get_l1_addresses.d.ts +4 -0
- package/dest/cmds/l1/get_l1_addresses.d.ts.map +1 -0
- package/dest/cmds/l1/get_l1_addresses.js +18 -0
- package/dest/cmds/l1/get_l1_balance.d.ts +4 -0
- package/dest/cmds/l1/get_l1_balance.d.ts.map +1 -0
- package/dest/cmds/l1/get_l1_balance.js +33 -0
- package/dest/cmds/l1/governance_utils.d.ts +50 -0
- package/dest/cmds/l1/governance_utils.d.ts.map +1 -0
- package/dest/cmds/l1/governance_utils.js +85 -0
- package/dest/cmds/l1/index.d.ts +4 -0
- package/dest/cmds/l1/index.d.ts.map +1 -0
- package/dest/cmds/l1/index.js +208 -0
- package/dest/cmds/l1/prover_stats.d.ts +14 -0
- package/dest/cmds/l1/prover_stats.d.ts.map +1 -0
- package/dest/cmds/l1/prover_stats.js +145 -0
- package/dest/cmds/l1/update_l1_validators.d.ts +30 -0
- package/dest/cmds/l1/update_l1_validators.d.ts.map +1 -0
- package/dest/cmds/l1/update_l1_validators.js +186 -0
- package/dest/cmds/misc/compute_selector.d.ts +3 -0
- package/dest/cmds/misc/compute_selector.d.ts.map +1 -0
- package/dest/cmds/misc/compute_selector.js +5 -0
- package/dest/cmds/misc/example_contracts.d.ts +3 -0
- package/dest/cmds/misc/example_contracts.d.ts.map +1 -0
- package/dest/cmds/misc/example_contracts.js +6 -0
- package/dest/cmds/misc/generate_bootnode_enr.d.ts +3 -0
- package/dest/cmds/misc/generate_bootnode_enr.d.ts.map +1 -0
- package/dest/cmds/misc/generate_bootnode_enr.js +5 -0
- package/dest/cmds/misc/generate_p2p_private_key.d.ts +3 -0
- package/dest/cmds/misc/generate_p2p_private_key.d.ts.map +1 -0
- package/dest/cmds/misc/generate_p2p_private_key.js +7 -0
- package/dest/cmds/misc/generate_secret_and_hash.d.ts +3 -0
- package/dest/cmds/misc/generate_secret_and_hash.d.ts.map +1 -0
- package/dest/cmds/misc/generate_secret_and_hash.js +11 -0
- package/dest/cmds/misc/generate_secret_key.d.ts +5 -0
- package/dest/cmds/misc/generate_secret_key.d.ts.map +1 -0
- package/dest/cmds/misc/generate_secret_key.js +6 -0
- package/dest/cmds/misc/index.d.ts +4 -0
- package/dest/cmds/misc/index.d.ts.map +1 -0
- package/dest/cmds/misc/index.js +44 -0
- package/dest/cmds/misc/setup_contracts.d.ts +7 -0
- package/dest/cmds/misc/setup_contracts.d.ts.map +1 -0
- package/dest/cmds/misc/setup_contracts.js +27 -0
- package/dest/cmds/misc/update/common.d.ts.map +1 -0
- package/dest/cmds/misc/update/common.js +3 -0
- package/dest/cmds/misc/update/github.d.ts.map +1 -0
- package/dest/cmds/misc/update/github.js +3 -0
- package/dest/{update → cmds/misc/update}/noir.d.ts +2 -2
- package/dest/cmds/misc/update/noir.d.ts.map +1 -0
- package/dest/cmds/misc/update/noir.js +45 -0
- package/dest/{update → cmds/misc/update}/npm.d.ts +3 -3
- package/dest/cmds/misc/update/npm.d.ts.map +1 -0
- package/dest/cmds/misc/update/npm.js +127 -0
- package/dest/cmds/misc/update/utils.d.ts +14 -0
- package/dest/cmds/misc/update/utils.d.ts.map +1 -0
- package/dest/cmds/misc/update/utils.js +38 -0
- package/dest/cmds/misc/update.d.ts +3 -0
- package/dest/cmds/misc/update.d.ts.map +1 -0
- package/dest/cmds/misc/update.js +52 -0
- package/dest/cmds/pxe/add_contract.d.ts +5 -0
- package/dest/cmds/pxe/add_contract.d.ts.map +1 -0
- package/dest/cmds/pxe/add_contract.js +29 -0
- package/dest/cmds/pxe/block_number.d.ts +3 -0
- package/dest/cmds/pxe/block_number.d.ts.map +1 -0
- package/dest/cmds/pxe/block_number.js +10 -0
- package/dest/cmds/pxe/get_account.d.ts +4 -0
- package/dest/cmds/pxe/get_account.d.ts.map +1 -0
- package/dest/cmds/pxe/get_account.js +10 -0
- package/dest/cmds/pxe/get_accounts.d.ts +3 -0
- package/dest/cmds/pxe/get_accounts.d.ts.map +1 -0
- package/dest/cmds/pxe/get_accounts.js +25 -0
- package/dest/cmds/pxe/get_block.d.ts +3 -0
- package/dest/cmds/pxe/get_block.d.ts.map +1 -0
- package/dest/cmds/pxe/get_block.js +9 -0
- package/dest/cmds/pxe/get_contract_data.d.ts +4 -0
- package/dest/cmds/pxe/get_contract_data.d.ts.map +1 -0
- package/dest/cmds/pxe/get_contract_data.js +31 -0
- package/dest/cmds/pxe/get_current_base_fee.d.ts +3 -0
- package/dest/cmds/pxe/get_current_base_fee.d.ts.map +1 -0
- package/dest/cmds/pxe/get_current_base_fee.js +7 -0
- package/dest/cmds/pxe/get_l1_to_l2_message_witness.d.ts +4 -0
- package/dest/cmds/pxe/get_l1_to_l2_message_witness.d.ts.map +1 -0
- package/dest/cmds/pxe/get_l1_to_l2_message_witness.js +11 -0
- package/dest/cmds/pxe/get_logs.d.ts +4 -0
- package/dest/cmds/pxe/get_logs.d.ts.map +1 -0
- package/dest/cmds/pxe/get_logs.js +51 -0
- package/dest/cmds/pxe/get_node_info.d.ts +3 -0
- package/dest/cmds/pxe/get_node_info.d.ts.map +1 -0
- package/dest/cmds/pxe/get_node_info.js +61 -0
- package/dest/cmds/pxe/get_pxe_info.d.ts +3 -0
- package/dest/cmds/pxe/get_pxe_info.d.ts.map +1 -0
- package/dest/cmds/pxe/get_pxe_info.js +11 -0
- package/dest/cmds/pxe/index.d.ts +4 -0
- package/dest/cmds/pxe/index.d.ts.map +1 -0
- package/dest/cmds/pxe/index.js +55 -0
- package/dest/utils/aztec.d.ts +68 -0
- package/dest/utils/aztec.d.ts.map +1 -0
- package/dest/utils/aztec.js +173 -0
- package/dest/{parse_args.d.ts → utils/commands.d.ts} +50 -12
- package/dest/utils/commands.d.ts.map +1 -0
- package/dest/utils/commands.js +303 -0
- package/dest/{encoding.d.ts → utils/encoding.d.ts} +1 -1
- package/dest/utils/encoding.d.ts.map +1 -0
- package/dest/utils/encoding.js +103 -0
- package/dest/utils/github.d.ts +4 -0
- package/dest/utils/github.d.ts.map +1 -0
- package/dest/utils/github.js +3 -0
- package/dest/utils/index.d.ts +5 -0
- package/dest/utils/index.d.ts.map +1 -0
- package/dest/utils/index.js +4 -0
- package/dest/utils/inspect.d.ts +17 -0
- package/dest/utils/inspect.d.ts.map +1 -0
- package/dest/utils/inspect.js +177 -0
- package/package.json +68 -22
- package/src/cmds/contracts/index.ts +34 -0
- package/src/cmds/contracts/inspect_contract.ts +51 -0
- package/src/cmds/contracts/parse_parameter_struct.ts +27 -0
- package/src/cmds/devnet/bootstrap_network.ts +318 -0
- package/src/cmds/devnet/faucet.ts +33 -0
- package/src/cmds/devnet/index.ts +60 -0
- package/src/cmds/infrastructure/index.ts +55 -0
- package/src/cmds/infrastructure/sequencers.ts +103 -0
- package/src/cmds/infrastructure/setup_l2_contract.ts +47 -0
- package/src/cmds/l1/advance_epoch.ts +12 -0
- package/src/cmds/l1/assume_proven_through.ts +19 -0
- package/src/cmds/l1/bridge_erc20.ts +52 -0
- package/src/cmds/l1/create_l1_account.ts +17 -0
- package/src/cmds/l1/deploy_l1_contracts.ts +63 -0
- package/src/cmds/l1/deploy_l1_verifier.ts +105 -0
- package/src/cmds/l1/deploy_new_rollup.ts +58 -0
- package/src/cmds/l1/get_l1_addresses.ts +30 -0
- package/src/cmds/l1/get_l1_balance.ts +44 -0
- package/src/cmds/l1/governance_utils.ts +187 -0
- package/src/cmds/l1/index.ts +556 -0
- package/src/cmds/l1/prover_stats.ts +202 -0
- package/src/cmds/l1/update_l1_validators.ts +238 -0
- package/src/cmds/misc/compute_selector.ts +7 -0
- package/src/cmds/misc/example_contracts.ts +12 -0
- package/src/cmds/misc/generate_bootnode_enr.ts +12 -0
- package/src/cmds/misc/generate_p2p_private_key.ts +10 -0
- package/src/cmds/misc/generate_secret_and_hash.ts +15 -0
- package/src/cmds/misc/generate_secret_key.ts +5 -0
- package/src/cmds/misc/index.ts +92 -0
- package/src/cmds/misc/setup_contracts.ts +40 -0
- package/src/cmds/misc/update/common.ts +16 -0
- package/src/cmds/misc/update/github.ts +3 -0
- package/src/cmds/misc/update/noir.ts +57 -0
- package/src/cmds/misc/update/npm.ts +154 -0
- package/src/cmds/misc/update/utils.ts +50 -0
- package/src/cmds/misc/update.ts +78 -0
- package/src/cmds/pxe/add_contract.ts +41 -0
- package/src/cmds/pxe/block_number.ts +9 -0
- package/src/cmds/pxe/get_account.ts +16 -0
- package/src/cmds/pxe/get_accounts.ts +35 -0
- package/src/cmds/pxe/get_block.ts +10 -0
- package/src/cmds/pxe/get_contract_data.ts +51 -0
- package/src/cmds/pxe/get_current_base_fee.ts +9 -0
- package/src/cmds/pxe/get_l1_to_l2_message_witness.ts +25 -0
- package/src/cmds/pxe/get_logs.ts +66 -0
- package/src/cmds/pxe/get_node_info.ts +71 -0
- package/src/cmds/pxe/get_pxe_info.ts +13 -0
- package/src/cmds/pxe/index.ts +170 -0
- package/src/utils/aztec.ts +248 -0
- package/src/utils/commands.ts +384 -0
- package/src/utils/encoding.ts +117 -0
- package/src/utils/github.ts +3 -0
- package/src/utils/index.ts +4 -0
- package/src/utils/inspect.ts +208 -0
- package/dest/bin/index.d.ts +0 -3
- package/dest/bin/index.d.ts.map +0 -1
- package/dest/bin/index.js +0 -19
- package/dest/client.d.ts +0 -17
- package/dest/client.d.ts.map +0 -1
- package/dest/client.js +0 -60
- package/dest/cmds/add_contract.d.ts +0 -7
- package/dest/cmds/add_contract.d.ts.map +0 -1
- package/dest/cmds/add_contract.js +0 -15
- package/dest/cmds/add_note.d.ts +0 -8
- package/dest/cmds/add_note.d.ts.map +0 -1
- package/dest/cmds/add_note.js +0 -13
- package/dest/cmds/block_number.d.ts +0 -6
- package/dest/cmds/block_number.d.ts.map +0 -1
- package/dest/cmds/block_number.js +0 -10
- package/dest/cmds/call.d.ts +0 -7
- package/dest/cmds/call.d.ts.map +0 -1
- package/dest/cmds/call.js +0 -18
- package/dest/cmds/check_deploy.d.ts +0 -7
- package/dest/cmds/check_deploy.d.ts.map +0 -1
- package/dest/cmds/check_deploy.js +0 -16
- package/dest/cmds/compute_selector.d.ts +0 -6
- package/dest/cmds/compute_selector.d.ts.map +0 -1
- package/dest/cmds/compute_selector.js +0 -9
- package/dest/cmds/create_account.d.ts +0 -7
- package/dest/cmds/create_account.d.ts.map +0 -1
- package/dest/cmds/create_account.js +0 -31
- package/dest/cmds/deploy.d.ts +0 -7
- package/dest/cmds/deploy.d.ts.map +0 -1
- package/dest/cmds/deploy.js +0 -58
- package/dest/cmds/deploy_l1_contracts.d.ts +0 -6
- package/dest/cmds/deploy_l1_contracts.d.ts.map +0 -1
- package/dest/cmds/deploy_l1_contracts.js +0 -15
- package/dest/cmds/example_contracts.d.ts +0 -6
- package/dest/cmds/example_contracts.d.ts.map +0 -1
- package/dest/cmds/example_contracts.js +0 -10
- package/dest/cmds/generate_p2p_private_key.d.ts +0 -6
- package/dest/cmds/generate_p2p_private_key.d.ts.map +0 -1
- package/dest/cmds/generate_p2p_private_key.js +0 -11
- package/dest/cmds/generate_private_key.d.ts +0 -6
- package/dest/cmds/generate_private_key.d.ts.map +0 -1
- package/dest/cmds/generate_private_key.js +0 -22
- package/dest/cmds/get_account.d.ts +0 -7
- package/dest/cmds/get_account.d.ts.map +0 -1
- package/dest/cmds/get_account.js +0 -15
- package/dest/cmds/get_accounts.d.ts +0 -6
- package/dest/cmds/get_accounts.d.ts.map +0 -1
- package/dest/cmds/get_accounts.js +0 -18
- package/dest/cmds/get_contract_data.d.ts +0 -7
- package/dest/cmds/get_contract_data.d.ts.map +0 -1
- package/dest/cmds/get_contract_data.js +0 -28
- package/dest/cmds/get_logs.d.ts +0 -7
- package/dest/cmds/get_logs.d.ts.map +0 -1
- package/dest/cmds/get_logs.js +0 -54
- package/dest/cmds/get_node_info.d.ts +0 -6
- package/dest/cmds/get_node_info.d.ts.map +0 -1
- package/dest/cmds/get_node_info.js +0 -15
- package/dest/cmds/get_recipient.d.ts +0 -7
- package/dest/cmds/get_recipient.d.ts.map +0 -1
- package/dest/cmds/get_recipient.js +0 -15
- package/dest/cmds/get_recipients.d.ts +0 -6
- package/dest/cmds/get_recipients.d.ts.map +0 -1
- package/dest/cmds/get_recipients.js +0 -18
- package/dest/cmds/get_tx_receipt.d.ts +0 -7
- package/dest/cmds/get_tx_receipt.d.ts.map +0 -1
- package/dest/cmds/get_tx_receipt.js +0 -16
- package/dest/cmds/inspect_contract.d.ts +0 -6
- package/dest/cmds/inspect_contract.d.ts.map +0 -1
- package/dest/cmds/inspect_contract.js +0 -19
- package/dest/cmds/parse_parameter_struct.d.ts.map +0 -1
- package/dest/cmds/parse_parameter_struct.js +0 -20
- package/dest/cmds/register_account.d.ts +0 -7
- package/dest/cmds/register_account.d.ts.map +0 -1
- package/dest/cmds/register_account.js +0 -13
- package/dest/cmds/register_recipient.d.ts +0 -7
- package/dest/cmds/register_recipient.d.ts.map +0 -1
- package/dest/cmds/register_recipient.js +0 -11
- package/dest/cmds/send.d.ts +0 -7
- package/dest/cmds/send.d.ts.map +0 -1
- package/dest/cmds/send.js +0 -27
- package/dest/cmds/unbox.d.ts +0 -7
- package/dest/cmds/unbox.d.ts.map +0 -1
- package/dest/cmds/unbox.js +0 -133
- package/dest/encoding.d.ts.map +0 -1
- package/dest/encoding.js +0 -114
- package/dest/github.d.ts.map +0 -1
- package/dest/github.js +0 -4
- package/dest/index.d.ts +0 -10
- package/dest/index.d.ts.map +0 -1
- package/dest/index.js +0 -321
- package/dest/parse_args.d.ts.map +0 -1
- package/dest/parse_args.js +0 -233
- package/dest/test/mocks.d.ts +0 -3
- package/dest/test/mocks.d.ts.map +0 -1
- package/dest/test/mocks.js +0 -65
- package/dest/update/common.d.ts.map +0 -1
- package/dest/update/common.js +0 -2
- package/dest/update/noir.d.ts.map +0 -1
- package/dest/update/noir.js +0 -63
- package/dest/update/npm.d.ts.map +0 -1
- package/dest/update/npm.js +0 -125
- package/dest/update/update.d.ts +0 -3
- package/dest/update/update.d.ts.map +0 -1
- package/dest/update/update.js +0 -58
- package/dest/utils.d.ts +0 -70
- package/dest/utils.d.ts.map +0 -1
- package/dest/utils.js +0 -168
- /package/dest/{update → cmds/misc/update}/common.d.ts +0 -0
- /package/dest/{github.d.ts → cmds/misc/update/github.d.ts} +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generate_bootnode_enr.d.ts","sourceRoot":"","sources":["../../../src/cmds/misc/generate_bootnode_enr.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAGnD,wBAAsB,0BAA0B,CAC9C,UAAU,EAAE,MAAM,EAClB,kBAAkB,EAAE,MAAM,EAC1B,SAAS,EAAE,MAAM,EACjB,GAAG,EAAE,KAAK,iBAIX"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { createBootnodeENRandPeerId } from '@aztec/p2p/enr';
|
|
2
|
+
export async function generateEncodedBootnodeENR(privateKey, udpAnnounceAddress, l1ChainId, log) {
|
|
3
|
+
const { enr } = await createBootnodeENRandPeerId(privateKey, udpAnnounceAddress, l1ChainId);
|
|
4
|
+
log(`ENR: ${enr.encodeTxt()}`);
|
|
5
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generate_p2p_private_key.d.ts","sourceRoot":"","sources":["../../../src/cmds/misc/generate_p2p_private_key.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAInD,wBAAsB,qBAAqB,CAAC,GAAG,EAAE,KAAK,iBAKrD"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { createSecp256k1PeerId } from '@libp2p/peer-id-factory';
|
|
2
|
+
export async function generateP2PPrivateKey(log) {
|
|
3
|
+
const peerId = await createSecp256k1PeerId();
|
|
4
|
+
const exportedPeerId = Buffer.from(peerId.privateKey).toString('hex');
|
|
5
|
+
log(`Private key: ${exportedPeerId}`);
|
|
6
|
+
log(`Peer Id: ${peerId}`);
|
|
7
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generate_secret_and_hash.d.ts","sourceRoot":"","sources":["../../../src/cmds/misc/generate_secret_and_hash.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAEnD,wBAAgB,qBAAqB,CAAC,GAAG,EAAE,KAAK,QAU/C"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { computeSecretHash } from '@aztec/aztec.js';
|
|
2
|
+
import { Fr } from '@aztec/foundation/fields';
|
|
3
|
+
export function generateSecretAndHash(log) {
|
|
4
|
+
const secret = Fr.random();
|
|
5
|
+
// We hash this the same way that aztec nr hash does.
|
|
6
|
+
const secretHash = computeSecretHash(secret);
|
|
7
|
+
log(`
|
|
8
|
+
Secret: ${secret}
|
|
9
|
+
Secret hash: ${secretHash}
|
|
10
|
+
`);
|
|
11
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generate_secret_key.d.ts","sourceRoot":"","sources":["../../../src/cmds/misc/generate_secret_key.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,iBAAiB,CAAC;AAErC,wBAAgB,iBAAiB;;EAEhC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/cmds/misc/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAGnD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAIzC,wBAAgB,cAAc,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,EAAE,KAAK,WAoF1D"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { printENR } from '@aztec/p2p/enr';
|
|
2
|
+
import { l1ChainIdOption, prettyPrintJSON } from '../../utils/commands.js';
|
|
3
|
+
export function injectCommands(program, log) {
|
|
4
|
+
program.command('generate-keys').summary('Generates encryption and signing private keys.').description('Generates and encryption and signing private key pair.').option('--json', 'Output the keys in JSON format').action(async ({ json })=>{
|
|
5
|
+
const { generateSecretKey } = await import('./generate_secret_key.js');
|
|
6
|
+
const { secretKey } = generateSecretKey();
|
|
7
|
+
if (json) {
|
|
8
|
+
log(prettyPrintJSON({
|
|
9
|
+
secretKey: secretKey.toString()
|
|
10
|
+
}));
|
|
11
|
+
} else {
|
|
12
|
+
log(`Secret Key: ${secretKey}`);
|
|
13
|
+
}
|
|
14
|
+
});
|
|
15
|
+
program.command('generate-p2p-private-key').summary('Generates a LibP2P peer private key.').description('Generates a private key that can be used for running a node on a LibP2P network.').action(async ()=>{
|
|
16
|
+
const { generateP2PPrivateKey } = await import('./generate_p2p_private_key.js');
|
|
17
|
+
await generateP2PPrivateKey(log);
|
|
18
|
+
});
|
|
19
|
+
program.command('generate-bootnode-enr').summary('Generates the encoded ENR record for a bootnode.').description('Generates the encoded ENR record for a bootnode.').argument('<privateKey>', 'The peer id private key of the bootnode').argument('<udpAnnounceAddress>', 'The bootnode UDP announce address').addOption(l1ChainIdOption).action(async (privateKey, udpAnnounceAddress, options)=>{
|
|
20
|
+
const { generateEncodedBootnodeENR } = await import('./generate_bootnode_enr.js');
|
|
21
|
+
await generateEncodedBootnodeENR(privateKey, udpAnnounceAddress, options.l1ChainId, log);
|
|
22
|
+
});
|
|
23
|
+
program.command('decode-enr').summary('Decodes an ENR record').description('Decodes and ENR record').argument('<enr>', 'The encoded ENR string').action(async (enr)=>{
|
|
24
|
+
await printENR(enr, log);
|
|
25
|
+
});
|
|
26
|
+
program.command('example-contracts').description('Lists the example contracts available to deploy from @aztec/noir-contracts.js').action(async ()=>{
|
|
27
|
+
const { exampleContracts } = await import('./example_contracts.js');
|
|
28
|
+
await exampleContracts(log);
|
|
29
|
+
});
|
|
30
|
+
program.command('compute-selector').description('Given a function signature, it computes a selector').argument('<functionSignature>', 'Function signature to compute selector for e.g. foo(Field)').action(async (functionSignature)=>{
|
|
31
|
+
const { computeSelector } = await import('./compute_selector.js');
|
|
32
|
+
await computeSelector(functionSignature, log);
|
|
33
|
+
});
|
|
34
|
+
program.command('generate-secret-and-hash').description('Generates an arbitrary secret (Fr), and its hash (using aztec-nr defaults)').action(async ()=>{
|
|
35
|
+
const { generateSecretAndHash } = await import('./generate_secret_and_hash.js');
|
|
36
|
+
generateSecretAndHash(log);
|
|
37
|
+
});
|
|
38
|
+
program.command('update').description('Updates Nodejs and Noir dependencies').argument('[projectPath]', 'Path to the project directory', process.cwd()).option('--contract [paths...]', 'Paths to contracts to update dependencies', []).option('--aztec-version <semver>', 'The version to update Aztec packages to. Defaults to latest', 'latest').action(async (projectPath, options)=>{
|
|
39
|
+
const { updateProject } = await import('./update.js');
|
|
40
|
+
const { contract, aztecVersion } = options;
|
|
41
|
+
await updateProject(projectPath, contract, aztecVersion, log);
|
|
42
|
+
});
|
|
43
|
+
return program;
|
|
44
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { type EthAddress, type Wallet } from '@aztec/aztec.js';
|
|
2
|
+
import type { LogFn } from '@aztec/foundation/log';
|
|
3
|
+
/**
|
|
4
|
+
* Deploys the contract to pay for gas on L2.
|
|
5
|
+
*/
|
|
6
|
+
export declare function setupCanonicalL2FeeJuice(deployer: Wallet, feeJuicePortalAddress: EthAddress, waitOpts: import("@aztec/aztec.js").WaitOpts | undefined, log: LogFn): Promise<void>;
|
|
7
|
+
//# sourceMappingURL=setup_contracts.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"setup_contracts.d.ts","sourceRoot":"","sources":["../../../src/cmds/misc/setup_contracts.ts"],"names":[],"mappings":"AAAA,OAAO,EAAmB,KAAK,UAAU,EAAyB,KAAK,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAEvG,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAInD;;GAEG;AACH,wBAAsB,wBAAwB,CAC5C,QAAQ,EAAE,MAAM,EAChB,qBAAqB,EAAE,UAAU,EACjC,QAAQ,gDAAkB,EAC1B,GAAG,EAAE,KAAK,iBA0BX"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { DefaultWaitOpts, FeeJuicePaymentMethod } from '@aztec/aztec.js';
|
|
2
|
+
import { FEE_JUICE_INITIAL_MINT } from '@aztec/constants';
|
|
3
|
+
import { ProtocolContractAddress } from '@aztec/protocol-contracts';
|
|
4
|
+
import { Gas } from '@aztec/stdlib/gas';
|
|
5
|
+
/**
|
|
6
|
+
* Deploys the contract to pay for gas on L2.
|
|
7
|
+
*/ export async function setupCanonicalL2FeeJuice(deployer, feeJuicePortalAddress, waitOpts = DefaultWaitOpts, log) {
|
|
8
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
9
|
+
// @ts-ignore - Importing noir-contracts.js even in devDeps results in a circular dependency error. Need to ignore because this line doesn't cause an error in a dev environment
|
|
10
|
+
const { FeeJuiceContract } = await import('@aztec/noir-contracts.js/FeeJuice');
|
|
11
|
+
const feeJuiceContract = await FeeJuiceContract.at(ProtocolContractAddress.FeeJuice, deployer);
|
|
12
|
+
const portalAddress = await deployer.getPublicStorageAt(feeJuiceContract.address, feeJuiceContract.artifact.storageLayout.portal_address.slot);
|
|
13
|
+
if (portalAddress.isZero()) {
|
|
14
|
+
log('setupCanonicalL2FeeJuice: Calling initialize on fee juice contract...');
|
|
15
|
+
const paymentMethod = new FeeJuicePaymentMethod(ProtocolContractAddress.FeeJuice);
|
|
16
|
+
await feeJuiceContract.methods.initialize(feeJuicePortalAddress, FEE_JUICE_INITIAL_MINT).send({
|
|
17
|
+
fee: {
|
|
18
|
+
paymentMethod,
|
|
19
|
+
gasSettings: {
|
|
20
|
+
teardownGasLimits: Gas.empty()
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
}).wait(waitOpts);
|
|
24
|
+
} else {
|
|
25
|
+
log('setupCanonicalL2FeeJuice: Fee juice contract already initialized. Fee Juice Portal address: ' + portalAddress.toString());
|
|
26
|
+
}
|
|
27
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"common.d.ts","sourceRoot":"","sources":["../../../../src/cmds/misc/update/common.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,MAAM,MAAM,iBAAiB,GAAG;IAC9B,6BAA6B;IAC7B,IAAI,EAAE,MAAM,CAAC;IACb,+BAA+B;IAC/B,YAAY,EAAE,KAAK,CAAC;QAClB,2CAA2C;QAC3C,IAAI,EAAE,MAAM,CAAC;QACb,yCAAyC;QACzC,IAAI,EAAE,MAAM,CAAC;QACb,uDAAuD;QACvD,EAAE,EAAE,MAAM,CAAC;KACZ,CAAC,CAAC;CACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"github.d.ts","sourceRoot":"","sources":["../../../../src/cmds/misc/update/github.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,YAAY,kBAAkB,CAAC;AAC5C,eAAO,MAAM,WAAW,mBAAmB,CAAC;AAC5C,eAAO,MAAM,iBAAiB,mBAAmB,CAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { LogFn } from '@aztec/foundation/log';
|
|
2
|
-
import { DependencyChanges } from './common.js';
|
|
1
|
+
import type { LogFn } from '@aztec/foundation/log';
|
|
2
|
+
import type { DependencyChanges } from './common.js';
|
|
3
3
|
/**
|
|
4
4
|
* Updates Aztec.nr dependencies
|
|
5
5
|
* @param contractPath - Path to the contract to be updated
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"noir.d.ts","sourceRoot":"","sources":["../../../../src/cmds/misc/update/noir.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAOnD,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAGrD;;;;;GAKG;AACH,wBAAsB,aAAa,CAAC,YAAY,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,KAAK,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAwC7G"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { parseNoirPackageConfig } from '@aztec/foundation/noir';
|
|
2
|
+
import TOML from '@iarna/toml';
|
|
3
|
+
import { readFile } from 'fs/promises';
|
|
4
|
+
import { join, relative, resolve } from 'path';
|
|
5
|
+
import { atomicUpdateFile, prettyPrintNargoToml } from './utils.js';
|
|
6
|
+
/**
|
|
7
|
+
* Updates Aztec.nr dependencies
|
|
8
|
+
* @param contractPath - Path to the contract to be updated
|
|
9
|
+
* @param tag - The tag to update to
|
|
10
|
+
* @param log - Logging function
|
|
11
|
+
*/ export async function updateAztecNr(contractPath, tag, log) {
|
|
12
|
+
const configFilepath = resolve(join(contractPath, 'Nargo.toml'));
|
|
13
|
+
const packageConfig = parseNoirPackageConfig(TOML.parse(await readFile(configFilepath, 'utf-8')));
|
|
14
|
+
const changes = {
|
|
15
|
+
dependencies: [],
|
|
16
|
+
file: configFilepath
|
|
17
|
+
};
|
|
18
|
+
log(`Updating Aztec.nr libraries to ${tag} in ${relative(process.cwd(), changes.file)}`);
|
|
19
|
+
for (const dep of Object.values(packageConfig.dependencies)){
|
|
20
|
+
if (!('git' in dep)) {
|
|
21
|
+
continue;
|
|
22
|
+
}
|
|
23
|
+
// remove trailing slash
|
|
24
|
+
const gitUrl = dep.git.toLowerCase().replace(/\/$/, '');
|
|
25
|
+
if (gitUrl !== 'https://github.com/aztecprotocol/aztec-packages') {
|
|
26
|
+
continue;
|
|
27
|
+
}
|
|
28
|
+
if (dep.tag !== tag) {
|
|
29
|
+
// show the Aztec.nr package name rather than the lib name
|
|
30
|
+
const dirParts = dep.directory?.split('/') ?? [];
|
|
31
|
+
changes.dependencies.push({
|
|
32
|
+
name: dirParts.slice(-2).join('/'),
|
|
33
|
+
from: dep.tag,
|
|
34
|
+
to: tag
|
|
35
|
+
});
|
|
36
|
+
dep.tag = tag;
|
|
37
|
+
dep.directory = dep.directory?.replace('yarn-project/', 'noir-projects/');
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
if (changes.dependencies.length > 0) {
|
|
41
|
+
const contents = prettyPrintNargoToml(packageConfig);
|
|
42
|
+
await atomicUpdateFile(configFilepath, contents);
|
|
43
|
+
}
|
|
44
|
+
return changes;
|
|
45
|
+
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { LogFn } from '@aztec/foundation/log';
|
|
2
|
-
import { SemVer } from 'semver';
|
|
3
|
-
import { DependencyChanges } from './common.js';
|
|
1
|
+
import type { LogFn } from '@aztec/foundation/log';
|
|
2
|
+
import { type SemVer } from 'semver';
|
|
3
|
+
import type { DependencyChanges } from './common.js';
|
|
4
4
|
/**
|
|
5
5
|
* Looks up a package.json file and returns its contents
|
|
6
6
|
* @param projectPath - Path to Nodejs project
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"npm.d.ts","sourceRoot":"","sources":["../../../../src/cmds/misc/update/npm.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAMnD,OAAO,EAAE,KAAK,MAAM,EAAS,MAAM,QAAQ,CAAC;AAE5C,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAYrD;;;;GAIG;AACH,wBAAsB,eAAe,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC;IAClE,mBAAmB;IACnB,YAAY,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACtC,sBAAsB;IACtB,eAAe,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CAC1C,CAAC,CAKD;AAED;;;;;GAKG;AACH,wBAAsB,gBAAgB,CAAC,WAAW,EAAE,MAAM,EAAE,OAAO,SAAW,GAAG,OAAO,CAAC,MAAM,CAAC,CAc/F;AAED;;;;;GAKG;AACH,wBAAsB,eAAe,CACnC,WAAW,EAAE,MAAM,EACnB,YAAY,EAAE,MAAM,EACpB,GAAG,EAAE,KAAK,GACT,OAAO,CAAC,iBAAiB,CAAC,CAuD5B;AAED;;;GAGG;AACH,wBAAgB,cAAc,CAAC,WAAW,EAAE,MAAM,EAAE,GAAG,EAAE,KAAK,GAAG,IAAI,CAuBpE"}
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import { spawnSync } from 'child_process';
|
|
2
|
+
import { existsSync } from 'fs';
|
|
3
|
+
import { readFile } from 'fs/promises';
|
|
4
|
+
import { join, relative, resolve } from 'path';
|
|
5
|
+
import { parse } from 'semver';
|
|
6
|
+
import { atomicUpdateFile } from './utils.js';
|
|
7
|
+
const deprecatedNpmPackages = new Set([
|
|
8
|
+
'@aztec/cli',
|
|
9
|
+
'@aztec/aztec-sandbox'
|
|
10
|
+
]);
|
|
11
|
+
const npmDeprecationMessage = `
|
|
12
|
+
The following packages have been deprecated and will no longer be updated on the npm registry:
|
|
13
|
+
${Array.from(deprecatedNpmPackages).map((pkg)=>` - ${pkg}`).join('\n')}
|
|
14
|
+
Remove them from package.json
|
|
15
|
+
`;
|
|
16
|
+
/**
|
|
17
|
+
* Looks up a package.json file and returns its contents
|
|
18
|
+
* @param projectPath - Path to Nodejs project
|
|
19
|
+
* @returns The parsed package.json
|
|
20
|
+
*/ export async function readPackageJson(projectPath) {
|
|
21
|
+
const configFilepath = resolve(join(projectPath, 'package.json'));
|
|
22
|
+
const pkg = JSON.parse(await readFile(configFilepath, 'utf-8'));
|
|
23
|
+
return pkg;
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Queries the npm registry for the latest version of a package
|
|
27
|
+
* @param packageName - The package to query
|
|
28
|
+
* @param distTag - The distribution tag
|
|
29
|
+
* @returns The latest version of the package on that distribution tag
|
|
30
|
+
*/ export async function getNewestVersion(packageName, distTag = 'latest') {
|
|
31
|
+
const url = new URL(packageName, 'https://registry.npmjs.org/');
|
|
32
|
+
const response = await fetch(url);
|
|
33
|
+
if (!response.ok) {
|
|
34
|
+
throw new Error(`Failed to fetch ${url}`);
|
|
35
|
+
}
|
|
36
|
+
const body = await response.json();
|
|
37
|
+
const latestVersion = parse(body['dist-tags'][distTag]);
|
|
38
|
+
if (!latestVersion) {
|
|
39
|
+
throw new Error(`Failed to get latest version from registry`);
|
|
40
|
+
}
|
|
41
|
+
return latestVersion;
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Updates a project's \@aztec/* dependencies to the specific version
|
|
45
|
+
* @param projectPath - Path to Nodejs project
|
|
46
|
+
* @param aztecVersion - The version to update to
|
|
47
|
+
* @returns True if the project was updated
|
|
48
|
+
*/ export async function updateAztecDeps(projectPath, aztecVersion, log) {
|
|
49
|
+
const pkg = await readPackageJson(projectPath);
|
|
50
|
+
const changes = {
|
|
51
|
+
file: resolve(join(projectPath, 'package.json')),
|
|
52
|
+
dependencies: []
|
|
53
|
+
};
|
|
54
|
+
log(`Updating @aztec packages to ${aztecVersion} in ${relative(process.cwd(), changes.file)}`);
|
|
55
|
+
const version = aztecVersion.version;
|
|
56
|
+
let detectedDeprecatedPackages = false;
|
|
57
|
+
for (const depType of [
|
|
58
|
+
'dependencies',
|
|
59
|
+
'devDependencies'
|
|
60
|
+
]){
|
|
61
|
+
const dependencies = pkg[depType];
|
|
62
|
+
if (!dependencies) {
|
|
63
|
+
continue;
|
|
64
|
+
}
|
|
65
|
+
for (const name of Object.keys(dependencies)){
|
|
66
|
+
if (!name.startsWith('@aztec/')) {
|
|
67
|
+
continue;
|
|
68
|
+
}
|
|
69
|
+
// different release schedule
|
|
70
|
+
if (name === '@aztec/aztec-ui') {
|
|
71
|
+
continue;
|
|
72
|
+
}
|
|
73
|
+
if (deprecatedNpmPackages.has(name)) {
|
|
74
|
+
detectedDeprecatedPackages = true;
|
|
75
|
+
continue;
|
|
76
|
+
}
|
|
77
|
+
if (dependencies[name] !== version) {
|
|
78
|
+
changes.dependencies.push({
|
|
79
|
+
name,
|
|
80
|
+
from: dependencies[name],
|
|
81
|
+
to: version
|
|
82
|
+
});
|
|
83
|
+
dependencies[name] = version;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
if (detectedDeprecatedPackages) {
|
|
88
|
+
log(npmDeprecationMessage);
|
|
89
|
+
}
|
|
90
|
+
if (changes.dependencies.length > 0) {
|
|
91
|
+
const contents = JSON.stringify(pkg, null, 2) + '\n';
|
|
92
|
+
await atomicUpdateFile(resolve(join(projectPath, 'package.json')), contents);
|
|
93
|
+
}
|
|
94
|
+
return changes;
|
|
95
|
+
}
|
|
96
|
+
/**
|
|
97
|
+
* Updates a project's yarn.lock or package-lock.json
|
|
98
|
+
* @param projectPath - Path to Nodejs project
|
|
99
|
+
*/ export function updateLockfile(projectPath, log) {
|
|
100
|
+
const isNpm = existsSync(resolve(join(projectPath, 'package-lock.json')));
|
|
101
|
+
const isYarn = existsSync(resolve(join(projectPath, 'yarn.lock')));
|
|
102
|
+
const isPnpm = existsSync(resolve(join(projectPath, 'pnpm-lock.yaml')));
|
|
103
|
+
if (isPnpm) {
|
|
104
|
+
spawnSync('pnpm', [
|
|
105
|
+
'install'
|
|
106
|
+
], {
|
|
107
|
+
cwd: projectPath,
|
|
108
|
+
stdio: 'inherit'
|
|
109
|
+
});
|
|
110
|
+
} else if (isYarn) {
|
|
111
|
+
spawnSync('yarn', [
|
|
112
|
+
'install'
|
|
113
|
+
], {
|
|
114
|
+
cwd: projectPath,
|
|
115
|
+
stdio: 'inherit'
|
|
116
|
+
});
|
|
117
|
+
} else if (isNpm) {
|
|
118
|
+
spawnSync('npm', [
|
|
119
|
+
'install'
|
|
120
|
+
], {
|
|
121
|
+
cwd: projectPath,
|
|
122
|
+
stdio: 'inherit'
|
|
123
|
+
});
|
|
124
|
+
} else {
|
|
125
|
+
log(`No lockfile found in ${projectPath}. Skipping lockfile update...`);
|
|
126
|
+
}
|
|
127
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { NoirPackageConfig } from '@aztec/foundation/noir';
|
|
2
|
+
/**
|
|
3
|
+
* Updates a file in place atomically.
|
|
4
|
+
* @param filePath - Path to file
|
|
5
|
+
* @param contents - New contents to write
|
|
6
|
+
*/
|
|
7
|
+
export declare function atomicUpdateFile(filePath: string, contents: string): Promise<void>;
|
|
8
|
+
/**
|
|
9
|
+
* Pretty prints Nargo.toml contents to a string
|
|
10
|
+
* @param config - Nargo.toml contents
|
|
11
|
+
* @returns The Nargo.toml contents as a string
|
|
12
|
+
*/
|
|
13
|
+
export declare function prettyPrintNargoToml(config: NoirPackageConfig): string;
|
|
14
|
+
//# sourceMappingURL=utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../../src/cmds/misc/update/utils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAMhE;;;;GAIG;AACH,wBAAsB,gBAAgB,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,iBAqBxE;AAED;;;;GAIG;AACH,wBAAgB,oBAAoB,CAAC,MAAM,EAAE,iBAAiB,GAAG,MAAM,CAUtE"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import TOML from '@iarna/toml';
|
|
2
|
+
import { CommanderError } from 'commander';
|
|
3
|
+
import { rename, writeFile } from 'fs/promises';
|
|
4
|
+
/**
|
|
5
|
+
* Updates a file in place atomically.
|
|
6
|
+
* @param filePath - Path to file
|
|
7
|
+
* @param contents - New contents to write
|
|
8
|
+
*/ export async function atomicUpdateFile(filePath, contents) {
|
|
9
|
+
const tmpFilepath = filePath + '.tmp';
|
|
10
|
+
try {
|
|
11
|
+
await writeFile(tmpFilepath, contents, {
|
|
12
|
+
// let's crash if the tmp file already exists
|
|
13
|
+
flag: 'wx'
|
|
14
|
+
});
|
|
15
|
+
await rename(tmpFilepath, filePath);
|
|
16
|
+
} catch (e) {
|
|
17
|
+
if (e instanceof Error && 'code' in e && e.code === 'EEXIST') {
|
|
18
|
+
const commanderError = new CommanderError(1, e.code, `Temporary file already exists: ${tmpFilepath}. Delete this file and try again.`);
|
|
19
|
+
commanderError.nestedError = e.message;
|
|
20
|
+
throw commanderError;
|
|
21
|
+
} else {
|
|
22
|
+
throw e;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Pretty prints Nargo.toml contents to a string
|
|
28
|
+
* @param config - Nargo.toml contents
|
|
29
|
+
* @returns The Nargo.toml contents as a string
|
|
30
|
+
*/ export function prettyPrintNargoToml(config) {
|
|
31
|
+
const withoutDependencies = Object.fromEntries(Object.entries(config).filter(([key])=>key !== 'dependencies'));
|
|
32
|
+
const partialToml = TOML.stringify(withoutDependencies);
|
|
33
|
+
const dependenciesToml = Object.entries(config.dependencies).map(([name, dep])=>{
|
|
34
|
+
const depToml = TOML.stringify.value(dep);
|
|
35
|
+
return `${name} = ${depToml}`;
|
|
36
|
+
});
|
|
37
|
+
return partialToml + '\n[dependencies]\n' + dependenciesToml.join('\n') + '\n';
|
|
38
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"update.d.ts","sourceRoot":"","sources":["../../../src/cmds/misc/update.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAanD,wBAAsB,aAAa,CACjC,WAAW,EAAE,MAAM,EACnB,SAAS,EAAE,MAAM,EAAE,EACnB,YAAY,EAAE,MAAM,EACpB,GAAG,EAAE,KAAK,GACT,OAAO,CAAC,IAAI,CAAC,CA+Cf"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
/* eslint-disable jsdoc/require-jsdoc */ import { relative, resolve } from 'path';
|
|
2
|
+
import { parse } from 'semver';
|
|
3
|
+
import { GITHUB_TAG_PREFIX } from './update/github.js';
|
|
4
|
+
import { updateAztecNr } from './update/noir.js';
|
|
5
|
+
import { getNewestVersion, updateAztecDeps, updateLockfile } from './update/npm.js';
|
|
6
|
+
const AZTECJS_PACKAGE = '@aztec/aztec.js';
|
|
7
|
+
const UPDATE_DOCS_URL = 'https://docs.aztec.network/developers/guides/local_env/versions-updating';
|
|
8
|
+
export async function updateProject(projectPath, contracts, aztecVersion, log) {
|
|
9
|
+
const targetAztecVersion = aztecVersion === 'latest' ? await getNewestVersion(AZTECJS_PACKAGE, 'latest') : parse(aztecVersion);
|
|
10
|
+
if (!targetAztecVersion) {
|
|
11
|
+
throw new Error(`Invalid aztec version ${aztecVersion}`);
|
|
12
|
+
}
|
|
13
|
+
const projectDependencyChanges = [];
|
|
14
|
+
try {
|
|
15
|
+
const npmChanges = await updateAztecDeps(resolve(process.cwd(), projectPath), targetAztecVersion, log);
|
|
16
|
+
if (npmChanges.dependencies.length > 0) {
|
|
17
|
+
updateLockfile(projectPath, log);
|
|
18
|
+
}
|
|
19
|
+
projectDependencyChanges.push(npmChanges);
|
|
20
|
+
} catch (err) {
|
|
21
|
+
if (err instanceof Error && 'code' in err && err.code === 'ENOENT') {
|
|
22
|
+
log(`No package.json found in ${projectPath}. Skipping npm update...`);
|
|
23
|
+
} else {
|
|
24
|
+
throw err;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
for (const contract of contracts){
|
|
28
|
+
try {
|
|
29
|
+
projectDependencyChanges.push(await updateAztecNr(resolve(process.cwd(), projectPath, contract), `${GITHUB_TAG_PREFIX}-v${targetAztecVersion.version}`, log));
|
|
30
|
+
} catch (err) {
|
|
31
|
+
if (err instanceof Error && 'code' in err && err.code === 'ENOENT') {
|
|
32
|
+
log(`No Nargo.toml found in ${relative(process.cwd(), contract)}. Skipping...`);
|
|
33
|
+
} else {
|
|
34
|
+
throw err;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
log(`To update Docker containers follow instructions at ${UPDATE_DOCS_URL}`);
|
|
39
|
+
projectDependencyChanges.forEach((changes)=>{
|
|
40
|
+
printChanges(changes, log);
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
function printChanges(changes, log) {
|
|
44
|
+
log(`\nIn ${relative(process.cwd(), changes.file)}:`);
|
|
45
|
+
if (changes.dependencies.length === 0) {
|
|
46
|
+
log(' No changes');
|
|
47
|
+
} else {
|
|
48
|
+
changes.dependencies.forEach(({ name, from, to })=>{
|
|
49
|
+
log(` Updated ${name} from ${from} to ${to}`);
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { AztecAddress, type Fr } from '@aztec/aztec.js';
|
|
2
|
+
import type { LogFn, Logger } from '@aztec/foundation/log';
|
|
3
|
+
import { PublicKeys } from '@aztec/stdlib/keys';
|
|
4
|
+
export declare function addContract(rpcUrl: string, contractArtifactPath: string, address: AztecAddress, initializationHash: Fr, salt: Fr, publicKeys: PublicKeys, deployer: AztecAddress | undefined, debugLogger: Logger, log: LogFn): Promise<void>;
|
|
5
|
+
//# sourceMappingURL=add_contract.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"add_contract.d.ts","sourceRoot":"","sources":["../../../src/cmds/pxe/add_contract.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAoC,KAAK,EAAE,EAAgC,MAAM,iBAAiB,CAAC;AAExH,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAE3D,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAIhD,wBAAsB,WAAW,CAC/B,MAAM,EAAE,MAAM,EACd,oBAAoB,EAAE,MAAM,EAC5B,OAAO,EAAE,YAAY,EACrB,kBAAkB,EAAE,EAAE,EACtB,IAAI,EAAE,EAAE,EACR,UAAU,EAAE,UAAU,EACtB,QAAQ,EAAE,YAAY,GAAG,SAAS,EAClC,WAAW,EAAE,MAAM,EACnB,GAAG,EAAE,KAAK,iBAuBX"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { AztecAddress, getContractClassFromArtifact } from '@aztec/aztec.js';
|
|
2
|
+
import { createCompatibleClient } from '@aztec/aztec.js';
|
|
3
|
+
import { computeContractAddressFromInstance } from '@aztec/stdlib/contract';
|
|
4
|
+
import { PublicKeys } from '@aztec/stdlib/keys';
|
|
5
|
+
import { getContractArtifact } from '../../utils/aztec.js';
|
|
6
|
+
export async function addContract(rpcUrl, contractArtifactPath, address, initializationHash, salt, publicKeys, deployer, debugLogger, log) {
|
|
7
|
+
const artifact = await getContractArtifact(contractArtifactPath, log);
|
|
8
|
+
const contractClass = await getContractClassFromArtifact(artifact);
|
|
9
|
+
const instance = {
|
|
10
|
+
version: 1,
|
|
11
|
+
salt,
|
|
12
|
+
initializationHash,
|
|
13
|
+
currentContractClassId: contractClass.id,
|
|
14
|
+
originalContractClassId: contractClass.id,
|
|
15
|
+
publicKeys: publicKeys ?? PublicKeys.default(),
|
|
16
|
+
address,
|
|
17
|
+
deployer: deployer ?? AztecAddress.ZERO
|
|
18
|
+
};
|
|
19
|
+
const computed = await computeContractAddressFromInstance(instance);
|
|
20
|
+
if (!computed.equals(address)) {
|
|
21
|
+
throw new Error(`Contract address ${address.toString()} does not match computed address ${computed.toString()}`);
|
|
22
|
+
}
|
|
23
|
+
const client = await createCompatibleClient(rpcUrl, debugLogger);
|
|
24
|
+
await client.registerContract({
|
|
25
|
+
artifact,
|
|
26
|
+
instance
|
|
27
|
+
});
|
|
28
|
+
log(`\nContract added to PXE at ${address.toString()} with class ${instance.currentContractClassId.toString()}\n`);
|
|
29
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"block_number.d.ts","sourceRoot":"","sources":["../../../src/cmds/pxe/block_number.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAE3D,wBAAsB,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,GAAG,EAAE,KAAK,iBAKhF"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { createCompatibleClient } from '@aztec/aztec.js';
|
|
2
|
+
export async function blockNumber(rpcUrl, debugLogger, log) {
|
|
3
|
+
const client = await createCompatibleClient(rpcUrl, debugLogger);
|
|
4
|
+
const [latestNum, provenNum] = await Promise.all([
|
|
5
|
+
client.getBlockNumber(),
|
|
6
|
+
client.getProvenBlockNumber()
|
|
7
|
+
]);
|
|
8
|
+
log(`Latest block: ${latestNum}`);
|
|
9
|
+
log(`Proven block: ${provenNum}`);
|
|
10
|
+
}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { AztecAddress } from '@aztec/aztec.js';
|
|
2
|
+
import type { LogFn, Logger } from '@aztec/foundation/log';
|
|
3
|
+
export declare function getAccount(aztecAddress: AztecAddress, rpcUrl: string, debugLogger: Logger, log: LogFn): Promise<void>;
|
|
4
|
+
//# sourceMappingURL=get_account.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get_account.d.ts","sourceRoot":"","sources":["../../../src/cmds/pxe/get_account.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAEpD,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAE3D,wBAAsB,UAAU,CAAC,YAAY,EAAE,YAAY,EAAE,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,GAAG,EAAE,KAAK,iBAW3G"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { createCompatibleClient } from '@aztec/aztec.js';
|
|
2
|
+
export async function getAccount(aztecAddress, rpcUrl, debugLogger, log) {
|
|
3
|
+
const client = await createCompatibleClient(rpcUrl, debugLogger);
|
|
4
|
+
const account = (await client.getRegisteredAccounts()).find((completeAddress)=>completeAddress.address.equals(aztecAddress));
|
|
5
|
+
if (!account) {
|
|
6
|
+
log(`Unknown account ${aztecAddress.toString()}`);
|
|
7
|
+
} else {
|
|
8
|
+
log(account.toReadableString());
|
|
9
|
+
}
|
|
10
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get_accounts.d.ts","sourceRoot":"","sources":["../../../src/cmds/pxe/get_accounts.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAE3D,wBAAsB,WAAW,CAC/B,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,OAAO,EACb,WAAW,EAAE,MAAM,EACnB,GAAG,EAAE,KAAK,EACV,OAAO,EAAE,CAAC,MAAM,EAAE,GAAG,KAAK,IAAI,iBA0B/B"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { createCompatibleClient } from '@aztec/aztec.js';
|
|
2
|
+
export async function getAccounts(rpcUrl, json, debugLogger, log, logJson) {
|
|
3
|
+
const client = await createCompatibleClient(rpcUrl, debugLogger);
|
|
4
|
+
const accounts = await client.getRegisteredAccounts();
|
|
5
|
+
if (!accounts.length) {
|
|
6
|
+
if (json) {
|
|
7
|
+
logJson([]);
|
|
8
|
+
} else {
|
|
9
|
+
log('No accounts found.');
|
|
10
|
+
}
|
|
11
|
+
return;
|
|
12
|
+
}
|
|
13
|
+
if (json) {
|
|
14
|
+
logJson(accounts.map((a)=>({
|
|
15
|
+
address: a.address.toString(),
|
|
16
|
+
publicKeys: a.publicKeys.toString(),
|
|
17
|
+
partialAddress: a.partialAddress.toString()
|
|
18
|
+
})));
|
|
19
|
+
} else {
|
|
20
|
+
log(`Accounts found: \n`);
|
|
21
|
+
for (const account of accounts){
|
|
22
|
+
log(account.toReadableString());
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
}
|