@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
|
@@ -1,15 +1,47 @@
|
|
|
1
1
|
import { FunctionSelector } from '@aztec/aztec.js/abi';
|
|
2
|
-
import { AztecAddress } from '@aztec/aztec.js/
|
|
2
|
+
import { AztecAddress } from '@aztec/aztec.js/addresses';
|
|
3
3
|
import { EthAddress } from '@aztec/aztec.js/eth_address';
|
|
4
|
-
import { Fr
|
|
4
|
+
import { Fr } from '@aztec/aztec.js/fields';
|
|
5
5
|
import { LogId } from '@aztec/aztec.js/log_id';
|
|
6
6
|
import { TxHash } from '@aztec/aztec.js/tx_hash';
|
|
7
|
+
import type { LogFn } from '@aztec/foundation/log';
|
|
8
|
+
import type { PXE } from '@aztec/stdlib/interfaces/client';
|
|
9
|
+
import { PublicKeys } from '@aztec/stdlib/keys';
|
|
10
|
+
import { type Command, Option } from 'commander';
|
|
7
11
|
/**
|
|
8
|
-
*
|
|
12
|
+
* If we can successfully resolve 'host.docker.internal', then we are running in a container, and we should treat
|
|
13
|
+
* localhost as being host.docker.internal.
|
|
14
|
+
*/
|
|
15
|
+
export declare const getLocalhost: () => Promise<string>;
|
|
16
|
+
export declare const LOCALHOST: string;
|
|
17
|
+
export declare const ETHEREUM_HOSTS: string, PRIVATE_KEY: string | undefined, API_KEY: string | undefined, CLI_VERSION: string | undefined;
|
|
18
|
+
export declare function addOptions(program: Command, options: Option[]): Command;
|
|
19
|
+
export declare const makePxeOption: (mandatory: boolean) => Option;
|
|
20
|
+
export declare const pxeOption: Option;
|
|
21
|
+
export declare const l1ChainIdOption: Option;
|
|
22
|
+
export declare const createSecretKeyOption: (description: string, mandatory: boolean, argsParser?: (value: string, previous: Fr) => Fr) => Option;
|
|
23
|
+
export declare const logJson: (log: LogFn) => (obj: object) => void;
|
|
24
|
+
/**
|
|
25
|
+
* Updates a file in place atomically.
|
|
26
|
+
* @param filePath - Path to file
|
|
27
|
+
* @param contents - New contents to write
|
|
28
|
+
*/
|
|
29
|
+
export declare function atomicUpdateFile(filePath: string, contents: string): Promise<void>;
|
|
30
|
+
/**
|
|
31
|
+
* Utility to select a TX sender either from user input
|
|
32
|
+
* or from the first account that is found in a PXE instance.
|
|
33
|
+
* @param pxe - The PXE instance that will be checked for an account.
|
|
34
|
+
* @param _from - The user input.
|
|
35
|
+
* @returns An Aztec address. Will throw if one can't be found in either options.
|
|
36
|
+
*/
|
|
37
|
+
export declare function getTxSender(pxe: PXE, _from?: string): Promise<AztecAddress>;
|
|
38
|
+
export declare function parseBigint(bigint: string): bigint | undefined;
|
|
39
|
+
/**
|
|
40
|
+
* Parses a hex encoded string to an Fr integer
|
|
9
41
|
* @param str - Hex encoded string
|
|
10
|
-
* @returns A integer
|
|
42
|
+
* @returns A integer
|
|
11
43
|
*/
|
|
12
|
-
export declare function
|
|
44
|
+
export declare function parseFieldFromHexString(str: string): Fr;
|
|
13
45
|
/**
|
|
14
46
|
* Parses an AztecAddress from a string.
|
|
15
47
|
* @param address - A serialized Aztec address
|
|
@@ -70,11 +102,11 @@ export declare function parseTxHash(txHash: string): TxHash;
|
|
|
70
102
|
export declare function parseOptionalTxHash(txHash: string): TxHash | undefined;
|
|
71
103
|
/**
|
|
72
104
|
* Parses a public key from a string.
|
|
73
|
-
* @param publicKey - A public
|
|
74
|
-
* @returns A
|
|
105
|
+
* @param publicKey - A public keys object serialised as a string
|
|
106
|
+
* @returns A PublicKeys instance
|
|
75
107
|
* @throws InvalidArgumentError if the input string is not valid.
|
|
76
108
|
*/
|
|
77
|
-
export declare function parsePublicKey(publicKey: string):
|
|
109
|
+
export declare function parsePublicKey(publicKey: string): PublicKeys | undefined;
|
|
78
110
|
/**
|
|
79
111
|
* Parses a partial address from a string.
|
|
80
112
|
* @param address - A partial address
|
|
@@ -83,12 +115,12 @@ export declare function parsePublicKey(publicKey: string): Point;
|
|
|
83
115
|
*/
|
|
84
116
|
export declare function parsePartialAddress(address: string): Fr;
|
|
85
117
|
/**
|
|
86
|
-
* Parses a
|
|
118
|
+
* Parses a secret key from a string.
|
|
87
119
|
* @param privateKey - A string
|
|
88
|
-
* @returns A
|
|
120
|
+
* @returns A secret key
|
|
89
121
|
* @throws InvalidArgumentError if the input string is not valid.
|
|
90
122
|
*/
|
|
91
|
-
export declare function
|
|
123
|
+
export declare function parseSecretKey(secretKey: string): Fr;
|
|
92
124
|
/**
|
|
93
125
|
* Parses a field from a string.
|
|
94
126
|
* @param field - A string representing the field.
|
|
@@ -102,4 +134,10 @@ export declare function parseField(field: string): Fr;
|
|
|
102
134
|
* @returns An array of Frs.
|
|
103
135
|
*/
|
|
104
136
|
export declare function parseFields(fields: string[]): Fr[];
|
|
105
|
-
|
|
137
|
+
/**
|
|
138
|
+
* Pretty prints an object as JSON
|
|
139
|
+
* @param data - The object to stringify
|
|
140
|
+
* @returns A JSON string
|
|
141
|
+
*/
|
|
142
|
+
export declare function prettyPrintJSON(data: Record<string, any>): string;
|
|
143
|
+
//# sourceMappingURL=commands.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"commands.d.ts","sourceRoot":"","sources":["../../src/utils/commands.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,303 @@
|
|
|
1
|
+
import { FunctionSelector } from '@aztec/aztec.js/abi';
|
|
2
|
+
import { AztecAddress } from '@aztec/aztec.js/addresses';
|
|
3
|
+
import { EthAddress } from '@aztec/aztec.js/eth_address';
|
|
4
|
+
import { Fr } from '@aztec/aztec.js/fields';
|
|
5
|
+
import { LogId } from '@aztec/aztec.js/log_id';
|
|
6
|
+
import { TxHash } from '@aztec/aztec.js/tx_hash';
|
|
7
|
+
import { PublicKeys } from '@aztec/stdlib/keys';
|
|
8
|
+
import { CommanderError, InvalidArgumentError, Option } from 'commander';
|
|
9
|
+
import { lookup } from 'dns/promises';
|
|
10
|
+
import { rename, writeFile } from 'fs/promises';
|
|
11
|
+
/**
|
|
12
|
+
* If we can successfully resolve 'host.docker.internal', then we are running in a container, and we should treat
|
|
13
|
+
* localhost as being host.docker.internal.
|
|
14
|
+
*/ export const getLocalhost = ()=>lookup('host.docker.internal').then(()=>'host.docker.internal').catch(()=>'localhost');
|
|
15
|
+
export const LOCALHOST = await getLocalhost();
|
|
16
|
+
export const { ETHEREUM_HOSTS = `http://${LOCALHOST}:8545`, PRIVATE_KEY, API_KEY, CLI_VERSION } = process.env;
|
|
17
|
+
export function addOptions(program, options) {
|
|
18
|
+
options.forEach((option)=>program.addOption(option));
|
|
19
|
+
return program;
|
|
20
|
+
}
|
|
21
|
+
export const makePxeOption = (mandatory)=>new Option('-u, --rpc-url <string>', 'URL of the PXE').env('PXE_URL').default(`http://${LOCALHOST}:8080`).conflicts('remote-pxe').makeOptionMandatory(mandatory);
|
|
22
|
+
export const pxeOption = makePxeOption(true);
|
|
23
|
+
export const l1ChainIdOption = new Option('-c, --l1-chain-id <number>', 'Chain ID of the ethereum host').env('L1_CHAIN_ID').default(31337).argParser((value)=>{
|
|
24
|
+
const parsedValue = Number(value);
|
|
25
|
+
if (isNaN(parsedValue)) {
|
|
26
|
+
throw new Error('Chain ID must be a number.');
|
|
27
|
+
}
|
|
28
|
+
return parsedValue;
|
|
29
|
+
});
|
|
30
|
+
export const createSecretKeyOption = (description, mandatory, argsParser)=>new Option('-sk, --secret-key <string>', description).env('SECRET_KEY').argParser(argsParser ?? parseSecretKey).makeOptionMandatory(mandatory);
|
|
31
|
+
export const logJson = (log)=>(obj)=>log(JSON.stringify(obj, null, 2));
|
|
32
|
+
/**
|
|
33
|
+
* Updates a file in place atomically.
|
|
34
|
+
* @param filePath - Path to file
|
|
35
|
+
* @param contents - New contents to write
|
|
36
|
+
*/ export async function atomicUpdateFile(filePath, contents) {
|
|
37
|
+
const tmpFilepath = filePath + '.tmp';
|
|
38
|
+
try {
|
|
39
|
+
await writeFile(tmpFilepath, contents, {
|
|
40
|
+
// let's crash if the tmp file already exists
|
|
41
|
+
flag: 'wx'
|
|
42
|
+
});
|
|
43
|
+
await rename(tmpFilepath, filePath);
|
|
44
|
+
} catch (e) {
|
|
45
|
+
if (e instanceof Error && 'code' in e && e.code === 'EEXIST') {
|
|
46
|
+
const commanderError = new CommanderError(1, e.code, `Temporary file already exists: ${tmpFilepath}. Delete this file and try again.`);
|
|
47
|
+
commanderError.nestedError = e.message;
|
|
48
|
+
throw commanderError;
|
|
49
|
+
} else {
|
|
50
|
+
throw e;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
/**
|
|
55
|
+
* Utility to select a TX sender either from user input
|
|
56
|
+
* or from the first account that is found in a PXE instance.
|
|
57
|
+
* @param pxe - The PXE instance that will be checked for an account.
|
|
58
|
+
* @param _from - The user input.
|
|
59
|
+
* @returns An Aztec address. Will throw if one can't be found in either options.
|
|
60
|
+
*/ export async function getTxSender(pxe, _from) {
|
|
61
|
+
let from;
|
|
62
|
+
if (_from) {
|
|
63
|
+
try {
|
|
64
|
+
from = AztecAddress.fromString(_from);
|
|
65
|
+
} catch {
|
|
66
|
+
throw new InvalidArgumentError(`Invalid option 'from' passed: ${_from}`);
|
|
67
|
+
}
|
|
68
|
+
} else {
|
|
69
|
+
const accounts = await pxe.getRegisteredAccounts();
|
|
70
|
+
if (!accounts.length) {
|
|
71
|
+
throw new Error('No accounts found in PXE instance.');
|
|
72
|
+
}
|
|
73
|
+
from = accounts[0].address;
|
|
74
|
+
}
|
|
75
|
+
return from;
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Removes the leading 0x from a hex string. If no leading 0x is found the string is returned unchanged.
|
|
79
|
+
* @param hex - A hex string
|
|
80
|
+
* @returns A new string with leading 0x removed
|
|
81
|
+
*/ const stripLeadingHex = (hex)=>{
|
|
82
|
+
if (hex.length > 2 && hex.startsWith('0x')) {
|
|
83
|
+
return hex.substring(2);
|
|
84
|
+
}
|
|
85
|
+
return hex;
|
|
86
|
+
};
|
|
87
|
+
export function parseBigint(bigint) {
|
|
88
|
+
return bigint ? BigInt(bigint) : undefined;
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Parses a hex encoded string to an Fr integer
|
|
92
|
+
* @param str - Hex encoded string
|
|
93
|
+
* @returns A integer
|
|
94
|
+
*/ export function parseFieldFromHexString(str) {
|
|
95
|
+
const hex = stripLeadingHex(str);
|
|
96
|
+
// ensure it's a hex string
|
|
97
|
+
if (!hex.match(/^[0-9a-f]+$/i)) {
|
|
98
|
+
throw new InvalidArgumentError('Invalid hex string');
|
|
99
|
+
}
|
|
100
|
+
// pad it so that we may read it as a buffer.
|
|
101
|
+
// Buffer needs _exactly_ two hex characters per byte
|
|
102
|
+
const padded = hex.length % 2 === 1 ? '0' + hex : hex;
|
|
103
|
+
let buf = Buffer.from(padded, 'hex');
|
|
104
|
+
if (buf.length > Fr.SIZE_IN_BYTES) {
|
|
105
|
+
buf = buf.subarray(buf.length - Fr.SIZE_IN_BYTES);
|
|
106
|
+
}
|
|
107
|
+
const fr = Buffer.alloc(Fr.SIZE_IN_BYTES, 0);
|
|
108
|
+
fr.set(buf, Fr.SIZE_IN_BYTES - buf.length);
|
|
109
|
+
// finally, turn it into an integer
|
|
110
|
+
return Fr.fromBuffer(fr);
|
|
111
|
+
}
|
|
112
|
+
/**
|
|
113
|
+
* Parses an AztecAddress from a string.
|
|
114
|
+
* @param address - A serialized Aztec address
|
|
115
|
+
* @returns An Aztec address
|
|
116
|
+
* @throws InvalidArgumentError if the input string is not valid.
|
|
117
|
+
*/ export function parseAztecAddress(address) {
|
|
118
|
+
try {
|
|
119
|
+
return AztecAddress.fromString(address);
|
|
120
|
+
} catch {
|
|
121
|
+
throw new InvalidArgumentError(`Invalid address: ${address}`);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
* Parses an Ethereum address from a string.
|
|
126
|
+
* @param address - A serialized Ethereum address
|
|
127
|
+
* @returns An Ethereum address
|
|
128
|
+
* @throws InvalidArgumentError if the input string is not valid.
|
|
129
|
+
*/ export function parseEthereumAddress(address) {
|
|
130
|
+
try {
|
|
131
|
+
return EthAddress.fromString(address);
|
|
132
|
+
} catch {
|
|
133
|
+
throw new InvalidArgumentError(`Invalid address: ${address}`);
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
/**
|
|
137
|
+
* Parses an AztecAddress from a string.
|
|
138
|
+
* @param address - A serialized Aztec address
|
|
139
|
+
* @returns An Aztec address
|
|
140
|
+
* @throws InvalidArgumentError if the input string is not valid.
|
|
141
|
+
*/ export function parseOptionalAztecAddress(address) {
|
|
142
|
+
if (!address) {
|
|
143
|
+
return undefined;
|
|
144
|
+
}
|
|
145
|
+
return parseAztecAddress(address);
|
|
146
|
+
}
|
|
147
|
+
/**
|
|
148
|
+
* Parses an optional log ID string into a LogId object.
|
|
149
|
+
*
|
|
150
|
+
* @param logId - The log ID string to parse.
|
|
151
|
+
* @returns The parsed LogId object, or undefined if the log ID is missing or empty.
|
|
152
|
+
*/ export function parseOptionalLogId(logId) {
|
|
153
|
+
if (!logId) {
|
|
154
|
+
return undefined;
|
|
155
|
+
}
|
|
156
|
+
return LogId.fromString(logId);
|
|
157
|
+
}
|
|
158
|
+
/**
|
|
159
|
+
* Parses a selector from a string.
|
|
160
|
+
* @param selector - A serialized selector.
|
|
161
|
+
* @returns A selector.
|
|
162
|
+
* @throws InvalidArgumentError if the input string is not valid.
|
|
163
|
+
*/ export function parseOptionalSelector(selector) {
|
|
164
|
+
if (!selector) {
|
|
165
|
+
return undefined;
|
|
166
|
+
}
|
|
167
|
+
try {
|
|
168
|
+
return FunctionSelector.fromString(selector);
|
|
169
|
+
} catch {
|
|
170
|
+
throw new InvalidArgumentError(`Invalid selector: ${selector}`);
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
/**
|
|
174
|
+
* Parses a string into an integer or returns undefined if the input is falsy.
|
|
175
|
+
*
|
|
176
|
+
* @param value - The string to parse into an integer.
|
|
177
|
+
* @returns The parsed integer, or undefined if the input string is falsy.
|
|
178
|
+
* @throws If the input is not a valid integer.
|
|
179
|
+
*/ export function parseOptionalInteger(value) {
|
|
180
|
+
if (!value) {
|
|
181
|
+
return undefined;
|
|
182
|
+
}
|
|
183
|
+
const parsed = Number(value);
|
|
184
|
+
if (!Number.isInteger(parsed)) {
|
|
185
|
+
throw new InvalidArgumentError('Invalid integer.');
|
|
186
|
+
}
|
|
187
|
+
return parsed;
|
|
188
|
+
}
|
|
189
|
+
/**
|
|
190
|
+
* Parses a TxHash from a string.
|
|
191
|
+
* @param txHash - A transaction hash
|
|
192
|
+
* @returns A TxHash instance
|
|
193
|
+
* @throws InvalidArgumentError if the input string is not valid.
|
|
194
|
+
*/ export function parseTxHash(txHash) {
|
|
195
|
+
try {
|
|
196
|
+
return TxHash.fromString(txHash);
|
|
197
|
+
} catch {
|
|
198
|
+
throw new InvalidArgumentError(`Invalid transaction hash: ${txHash}`);
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
/**
|
|
202
|
+
* Parses an optional TxHash from a string.
|
|
203
|
+
* Calls parseTxHash internally.
|
|
204
|
+
* @param txHash - A transaction hash
|
|
205
|
+
* @returns A TxHash instance, or undefined if the input string is falsy.
|
|
206
|
+
* @throws InvalidArgumentError if the input string is not valid.
|
|
207
|
+
*/ export function parseOptionalTxHash(txHash) {
|
|
208
|
+
if (!txHash) {
|
|
209
|
+
return undefined;
|
|
210
|
+
}
|
|
211
|
+
return parseTxHash(txHash);
|
|
212
|
+
}
|
|
213
|
+
/**
|
|
214
|
+
* Parses a public key from a string.
|
|
215
|
+
* @param publicKey - A public keys object serialised as a string
|
|
216
|
+
* @returns A PublicKeys instance
|
|
217
|
+
* @throws InvalidArgumentError if the input string is not valid.
|
|
218
|
+
*/ export function parsePublicKey(publicKey) {
|
|
219
|
+
if (!publicKey) {
|
|
220
|
+
return undefined;
|
|
221
|
+
}
|
|
222
|
+
try {
|
|
223
|
+
return PublicKeys.fromString(publicKey);
|
|
224
|
+
} catch (err) {
|
|
225
|
+
throw new InvalidArgumentError(`Invalid public key: ${publicKey}`);
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
/**
|
|
229
|
+
* Parses a partial address from a string.
|
|
230
|
+
* @param address - A partial address
|
|
231
|
+
* @returns A Fr instance
|
|
232
|
+
* @throws InvalidArgumentError if the input string is not valid.
|
|
233
|
+
*/ export function parsePartialAddress(address) {
|
|
234
|
+
try {
|
|
235
|
+
return Fr.fromHexString(address);
|
|
236
|
+
} catch (err) {
|
|
237
|
+
throw new InvalidArgumentError(`Invalid partial address: ${address}`);
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
/**
|
|
241
|
+
* Parses a secret key from a string.
|
|
242
|
+
* @param privateKey - A string
|
|
243
|
+
* @returns A secret key
|
|
244
|
+
* @throws InvalidArgumentError if the input string is not valid.
|
|
245
|
+
*/ export function parseSecretKey(secretKey) {
|
|
246
|
+
try {
|
|
247
|
+
return Fr.fromHexString(secretKey);
|
|
248
|
+
} catch (err) {
|
|
249
|
+
throw new InvalidArgumentError(`Invalid encryption secret key: ${secretKey}`);
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
/**
|
|
253
|
+
* Parses a field from a string.
|
|
254
|
+
* @param field - A string representing the field.
|
|
255
|
+
* @returns A field.
|
|
256
|
+
* @throws InvalidArgumentError if the input string is not valid.
|
|
257
|
+
*/ export function parseField(field) {
|
|
258
|
+
try {
|
|
259
|
+
const isHex = field.startsWith('0x') || field.match(new RegExp(`^[0-9a-f]{${Fr.SIZE_IN_BYTES * 2}}$`, 'i'));
|
|
260
|
+
if (isHex) {
|
|
261
|
+
return Fr.fromHexString(field);
|
|
262
|
+
}
|
|
263
|
+
if ([
|
|
264
|
+
'true',
|
|
265
|
+
'false'
|
|
266
|
+
].includes(field)) {
|
|
267
|
+
return new Fr(field === 'true');
|
|
268
|
+
}
|
|
269
|
+
const isNumber = +field || field === '0';
|
|
270
|
+
if (isNumber) {
|
|
271
|
+
return new Fr(BigInt(field));
|
|
272
|
+
}
|
|
273
|
+
const isBigInt = field.endsWith('n');
|
|
274
|
+
if (isBigInt) {
|
|
275
|
+
return new Fr(BigInt(field.replace(/n$/, '')));
|
|
276
|
+
}
|
|
277
|
+
return new Fr(BigInt(field));
|
|
278
|
+
} catch (err) {
|
|
279
|
+
throw new InvalidArgumentError(`Invalid field: ${field}`);
|
|
280
|
+
}
|
|
281
|
+
}
|
|
282
|
+
/**
|
|
283
|
+
* Parses an array of strings to Frs.
|
|
284
|
+
* @param fields - An array of strings representing the fields.
|
|
285
|
+
* @returns An array of Frs.
|
|
286
|
+
*/ export function parseFields(fields) {
|
|
287
|
+
return fields.map(parseField);
|
|
288
|
+
}
|
|
289
|
+
/**
|
|
290
|
+
* Pretty prints an object as JSON
|
|
291
|
+
* @param data - The object to stringify
|
|
292
|
+
* @returns A JSON string
|
|
293
|
+
*/ export function prettyPrintJSON(data) {
|
|
294
|
+
return JSON.stringify(data, (_key, val)=>{
|
|
295
|
+
if (typeof val === 'bigint') {
|
|
296
|
+
return String(val);
|
|
297
|
+
} else if (val && typeof val === 'object' && 'toBuffer' in val) {
|
|
298
|
+
return '0x' + val.toBuffer().toString('hex');
|
|
299
|
+
} else {
|
|
300
|
+
return val;
|
|
301
|
+
}
|
|
302
|
+
}, 2);
|
|
303
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"encoding.d.ts","sourceRoot":"","sources":["../../src/utils/encoding.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,YAAY,EAAW,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAE3E;;;;;GAKG;AACH,wBAAgB,iBAAiB,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,EAAE,UAAU,OAcjE;AA4ED;;;;GAIG;AACH,wBAAgB,UAAU,CAAC,IAAI,EAAE,GAAG,EAAE,EAAE,MAAM,EAAE,YAAY,EAAE,SAY7D"}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import { Fr } from '@aztec/foundation/fields';
|
|
2
|
+
/**
|
|
3
|
+
* Parses a hex string into an ABI struct type.
|
|
4
|
+
* @param str - The encoded hex string.
|
|
5
|
+
* @param abiType - The ABI Struct type.
|
|
6
|
+
* @returns An object in the ABI struct type's format.
|
|
7
|
+
*/ export function parseStructString(str, abiType) {
|
|
8
|
+
// Assign string bytes to struct fields.
|
|
9
|
+
const buf = Buffer.from(str.replace(/^0x/i, ''), 'hex');
|
|
10
|
+
const struct = {};
|
|
11
|
+
let byteIndex = 0;
|
|
12
|
+
let argIndex = 0;
|
|
13
|
+
while(byteIndex < buf.length){
|
|
14
|
+
const { name } = abiType.fields[argIndex];
|
|
15
|
+
struct[name] = Fr.fromBuffer(buf.subarray(byteIndex, byteIndex + 32));
|
|
16
|
+
byteIndex += 32;
|
|
17
|
+
argIndex += 1;
|
|
18
|
+
}
|
|
19
|
+
return struct;
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Helper function to encode CLI string args to an appropriate JS type.
|
|
23
|
+
* @param arg - The CLI argument.
|
|
24
|
+
* @param abiType - The type as described by the contract's ABI.
|
|
25
|
+
* @returns The encoded argument.
|
|
26
|
+
*/ function encodeArg(arg, abiType, name) {
|
|
27
|
+
const { kind } = abiType;
|
|
28
|
+
if (kind === 'field' || kind === 'integer') {
|
|
29
|
+
let res;
|
|
30
|
+
try {
|
|
31
|
+
res = BigInt(arg);
|
|
32
|
+
} catch (err) {
|
|
33
|
+
throw new Error(`Invalid value passed for ${name}. Could not parse ${arg} as a${kind === 'integer' ? 'n' : ''} ${kind}.`);
|
|
34
|
+
}
|
|
35
|
+
return res;
|
|
36
|
+
} else if (kind === 'boolean') {
|
|
37
|
+
if (arg === 'true') {
|
|
38
|
+
return true;
|
|
39
|
+
}
|
|
40
|
+
if (arg === 'false') {
|
|
41
|
+
return false;
|
|
42
|
+
} else {
|
|
43
|
+
throw Error(`Invalid boolean value passed for ${name}: ${arg}.`);
|
|
44
|
+
}
|
|
45
|
+
} else if (kind === 'string') {
|
|
46
|
+
return arg;
|
|
47
|
+
} else if (kind === 'array') {
|
|
48
|
+
let arr;
|
|
49
|
+
const res = [];
|
|
50
|
+
try {
|
|
51
|
+
arr = JSON.parse(arg);
|
|
52
|
+
} catch {
|
|
53
|
+
throw new Error(`Unable to parse arg ${arg} as array for ${name} parameter`);
|
|
54
|
+
}
|
|
55
|
+
if (!Array.isArray(arr)) {
|
|
56
|
+
throw Error(`Invalid argument ${arg} passed for array parameter ${name}.`);
|
|
57
|
+
}
|
|
58
|
+
if (arr.length !== abiType.length) {
|
|
59
|
+
throw Error(`Invalid array length passed for ${name}. Expected ${abiType.length}, received ${arr.length}.`);
|
|
60
|
+
}
|
|
61
|
+
for(let i = 0; i < abiType.length; i += 1){
|
|
62
|
+
res.push(encodeArg(arr[i], abiType.type, name));
|
|
63
|
+
}
|
|
64
|
+
return res;
|
|
65
|
+
} else if (kind === 'struct') {
|
|
66
|
+
// check if input is encoded long string
|
|
67
|
+
if (arg.startsWith('0x')) {
|
|
68
|
+
return parseStructString(arg, abiType);
|
|
69
|
+
}
|
|
70
|
+
let obj;
|
|
71
|
+
try {
|
|
72
|
+
obj = JSON.parse(arg);
|
|
73
|
+
} catch {
|
|
74
|
+
throw new Error(`Unable to parse arg ${arg} as struct`);
|
|
75
|
+
}
|
|
76
|
+
if (Array.isArray(obj)) {
|
|
77
|
+
throw Error(`Array passed for arg ${name}. Expected a struct.`);
|
|
78
|
+
}
|
|
79
|
+
const res = {};
|
|
80
|
+
for (const field of abiType.fields){
|
|
81
|
+
// Remove field name from list as it's present
|
|
82
|
+
const arg = obj[field.name];
|
|
83
|
+
if (!arg) {
|
|
84
|
+
throw Error(`Expected field ${field.name} not found in struct ${name}.`);
|
|
85
|
+
}
|
|
86
|
+
res[field.name] = encodeArg(obj[field.name], field.type, field.name);
|
|
87
|
+
}
|
|
88
|
+
return res;
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
/**
|
|
92
|
+
* Tries to encode function args to their equivalent TS type.
|
|
93
|
+
* @param args - An array of function's / constructor's args.
|
|
94
|
+
* @returns The encoded array.
|
|
95
|
+
*/ export function encodeArgs(args, params) {
|
|
96
|
+
if (args.length !== params.length) {
|
|
97
|
+
throw new Error(`Invalid args provided.\nExpected args: [${params.map((param)=>param.name + ': ' + param.type.kind).join(', ')}]\nReceived args: ${args.join(', ')}`);
|
|
98
|
+
}
|
|
99
|
+
return args.map((arg, index)=>{
|
|
100
|
+
const { type, name } = params[index];
|
|
101
|
+
return encodeArg(arg, type, name);
|
|
102
|
+
});
|
|
103
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"github.d.ts","sourceRoot":"","sources":["../../src/utils/github.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,YAAY,kBAAkB,CAAC;AAC5C,eAAO,MAAM,WAAW,mBAAmB,CAAC;AAC5C,eAAO,MAAM,iBAAiB,mBAAmB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,eAAe,CAAC;AAC9B,cAAc,YAAY,CAAC;AAC3B,cAAc,eAAe,CAAC;AAC9B,cAAc,aAAa,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { ContractArtifact, Fr } from '@aztec/aztec.js';
|
|
2
|
+
import type { LogFn } from '@aztec/foundation/log';
|
|
3
|
+
import type { PXE } from '@aztec/stdlib/interfaces/client';
|
|
4
|
+
import type { TxHash } from '@aztec/stdlib/tx';
|
|
5
|
+
export declare function inspectBlock(pxe: PXE, blockNumber: number, log: LogFn, opts?: {
|
|
6
|
+
showTxs?: boolean;
|
|
7
|
+
}): Promise<void>;
|
|
8
|
+
export declare function inspectTx(pxe: PXE, txHash: TxHash, log: LogFn, opts?: {
|
|
9
|
+
includeBlockInfo?: boolean;
|
|
10
|
+
artifactMap?: ArtifactMap;
|
|
11
|
+
}): Promise<void>;
|
|
12
|
+
type ArtifactMap = Record<string, ContractArtifactWithClassId>;
|
|
13
|
+
type ContractArtifactWithClassId = ContractArtifact & {
|
|
14
|
+
classId: Fr;
|
|
15
|
+
};
|
|
16
|
+
export {};
|
|
17
|
+
//# sourceMappingURL=inspect.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"inspect.d.ts","sourceRoot":"","sources":["../../src/utils/inspect.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAgB,gBAAgB,EAAE,EAAE,EAAE,MAAM,iBAAiB,CAAC;AAC1E,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,uBAAuB,CAAC;AAGnD,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,iCAAiC,CAAC;AAE3D,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAE/C,wBAAsB,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,WAAW,EAAE,MAAM,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,GAAE;IAAE,OAAO,CAAC,EAAE,OAAO,CAAA;CAAO,iBA0B7G;AAED,wBAAsB,SAAS,CAC7B,GAAG,EAAE,GAAG,EACR,MAAM,EAAE,MAAM,EACd,GAAG,EAAE,KAAK,EACV,IAAI,GAAE;IAAE,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAAC,WAAW,CAAC,EAAE,WAAW,CAAA;CAAO,iBAmGrE;AAyCD,KAAK,WAAW,GAAG,MAAM,CAAC,MAAM,EAAE,2BAA2B,CAAC,CAAC;AAC/D,KAAK,2BAA2B,GAAG,gBAAgB,GAAG;IAAE,OAAO,EAAE,EAAE,CAAA;CAAE,CAAC"}
|