diff --git a/docs/docs/dev_docs/cli/main.md b/docs/docs/dev_docs/cli/main.md index 8abcec843d53..092321e0c8ab 100644 --- a/docs/docs/dev_docs/cli/main.md +++ b/docs/docs/dev_docs/cli/main.md @@ -87,7 +87,8 @@ export ADDRESS2= ## Deploying a Token Contract -We will now deploy the private token contract using the `deploy` command, minting 1000000 initial tokens to address `0x175310d40cd3412477db1c2a2188efd586b63d6830115fbb46c592a6303dbf6c`. Make sure to replace this address with one of the two you created earlier. +We will now deploy a token contract using the `deploy` command, and set and an address of admin via a constructor argument. +Make sure to replace this address with one of the two you created earlier. #include_code deploy yarn-project/end-to-end/src/cli_docs_sandbox.test.ts bash @@ -97,42 +98,19 @@ Save the contract address as an environment variable. We will use it later. export CONTRACT_ADDRESS= ``` -:::info -If you use a different address in the constructor above, you will get an error when running the deployment. This is because you need to register an account in the sandbox before it can receive private notes. When you create a new account, it gets automatically registered. Alternatively, you can register an account you do not own along with its public key using the `register-recipient` command. -::: - -This command takes 1 mandatory positional argument which is the path to the contract artifact file in a JSON format (e.g. `contracts/target/PrivateToken.json`). -Alternatively you can pass the name of an example contract as exported by `@aztec/noir-contracts` (run `aztec-cli example-contracts` to see the full list of contracts available). - -The command takes a few optional arguments while the most important one is: - -- `--args` - Arguments to the constructor of the contract. In this case we have minted 1000000 initial tokens to the aztec address 0x20d3321707d53cebb168568e25c5c62a853ae1f0766d965e00d6f6c4eb05d599. +- `--args` - Arguments to the constructor of the contract. In this case we have set an address as admin. The CLI tells us that the contract was successfully deployed. We can use the `check-deploy` command to verify that a contract has been successfully deployed to that address: #include_code check-deploy yarn-project/end-to-end/src/cli_docs_sandbox.test.ts bash -## Calling a View Method - -When we deployed the token contract, an initial supply of tokens was minted to the address provided in the constructor. We can now query the `getBalance()` method on the contract to retrieve the balance of that address. Make sure to replace the `contract-address` with the deployment address you got from the previous command, and the `args` with the account you used in the constructor. - -#include_code call yarn-project/end-to-end/src/cli_docs_sandbox.test.ts bash - -The `call` command calls a read-only method on a contract, one that will not generate a transaction to be sent to the network. The arguments here are: - -- `--args` - The address for which we want to retrieve the balance. -- `--contract-artifact` - The artifact of the contract we are calling. -- `--contract-address` - The address of the deployed contract - -As you can see from the result, this address has a balance of 1000000, as expected. When using the Sandbox, you are able to query the balance of any account that has been created in the system, even the accounts created by default. You may wonder why this is, as you haven't provided the private keys for these accounts. The Sandbox contains a component known as the Private Execution Environment (PXE). When an account is created, this component stores the provided encryption private key and is able to read the account's private state meaning that the Sandbox can report the balance of any of it's accounts. More information about the account model can be found [here](../../concepts/foundation/accounts/main.md). - ## Sending a Transaction -We can now send a transaction to the network. We will transfer funds from the owner of the initial minted tokens to our other account. For this we will use the `send` command, which expects as arguments the quantity of tokens to be transferred, the sender's address, and the recipient's address. Make sure to replace all addresses in this command with the ones for your run. +We can now send a transaction to the network. We will mint funds. For this we will use the `send` command, which expects as arguments the recipient's address and the amount to be minted. Make sure to replace all addresses in this command with yours. #include_code send yarn-project/end-to-end/src/cli_docs_sandbox.test.ts bash -We called the `transfer` function of the contract and provided these arguments: +We called the `mint_public` function of the contract and provided these arguments: - `--args` - The list of arguments to the function call. - `--contract-artifact` - The artifact of the contract to call. @@ -143,6 +121,16 @@ The command output tells us the details of the transaction such as its hash and #include_code get-tx-receipt yarn-project/end-to-end/src/cli_docs_sandbox.test.ts bash -Let's now call `getBalance()` on each of our accounts and we should see updated values: +## Calling an Unconstrained (View) Function + +Now that the `mint_public` tx has been settled we can call the `balance_of_public` unconstrained function: + +#include_code call yarn-project/end-to-end/src/cli_docs_sandbox.test.ts bash + +The `call` command calls a read-only method on a contract, one that will not generate a transaction to be sent to the network. The arguments here are: + +- `--args` - The address for which we want to retrieve the balance. +- `--contract-artifact` - The artifact of the contract we are calling. +- `--contract-address` - The address of the deployed contract -#include_code calls yarn-project/end-to-end/src/cli_docs_sandbox.test.ts bash +As you can see from the result, this address has a public balance of 543n, as expected. \ No newline at end of file diff --git a/yarn-project/end-to-end/src/cli_docs_sandbox.test.ts b/yarn-project/end-to-end/src/cli_docs_sandbox.test.ts index 87e7f0d0c694..cfa14445de54 100644 --- a/yarn-project/end-to-end/src/cli_docs_sandbox.test.ts +++ b/yarn-project/end-to-end/src/cli_docs_sandbox.test.ts @@ -349,11 +349,11 @@ Transaction receipt: // Test call docs = ` -// docs:start:calls +// docs:start:call % aztec-cli call balance_of_public -a $ADDRESS -c TokenContractArtifact -ca $CONTRACT_ADDRESS View result: 543n -// docs:end:calls +// docs:end:call `; command = docs .split('\n')[2]