From 44b67848551a5bc6421676727003cc2cd9d4980a Mon Sep 17 00:00:00 2001 From: benesjan Date: Wed, 27 Sep 2023 10:23:17 +0000 Subject: [PATCH 01/23] WIP --- .circleci/config.yml | 10 ++--- CHANGELOG.md | 10 ++--- README.md | 2 +- .../roadmap/features_initial_ldt.md | 2 +- .../docs/concepts/foundation/accounts/keys.md | 2 +- docs/docs/dev_docs/cli/main.md | 2 +- docs/docs/dev_docs/contracts/common_errors.md | 16 ++++---- docs/docs/dev_docs/contracts/compiling.md | 2 +- docs/docs/dev_docs/contracts/deploying.md | 8 ++-- docs/docs/dev_docs/contracts/syntax/events.md | 18 ++++----- .../dev_docs/contracts/syntax/functions.md | 2 +- .../dev_docs/getting_started/quickstart.md | 8 ++-- docs/docs/dev_docs/tutorials/testing.md | 28 +++++++------- .../tutorials/writing_dapp/project_setup.md | 2 +- .../{rpc_server.md => pxe_service.md} | 2 +- .../tutorials/writing_token_contract.md | 2 +- docs/docs/dev_docs/wallets/architecture.md | 4 +- .../wallets/writing_an_account_contract.md | 2 +- docs/docusaurus.config.js | 2 +- docs/internal_notes/api.md | 2 +- docs/sidebars.js | 4 +- yarn-project/aztec-node/src/bin/index.ts | 2 +- yarn-project/aztec-rpc/src/bin/index.ts | 8 ++-- yarn-project/aztec-sandbox/README.md | 2 +- yarn-project/aztec-sandbox/docker-compose.yml | 2 +- yarn-project/aztec-sandbox/src/bin/index.ts | 4 +- .../src/examples/private_token_contract.ts | 4 +- .../examples/uniswap_trade_on_l1_from_l2.ts | 12 +++--- .../aztec-sandbox/src/examples/util.ts | 2 +- yarn-project/aztec-sandbox/src/routes.ts | 2 +- yarn-project/aztec-sandbox/src/sandbox.ts | 4 +- yarn-project/aztec-sandbox/src/server.ts | 8 ++-- yarn-project/aztec.js/README.md | 2 +- yarn-project/aztec.js/src/account/index.ts | 22 +++++------ .../aztec.js/src/account/manager/index.ts | 4 +- yarn-project/aztec.js/src/account/utils.ts | 8 ++-- .../src/contract/base_contract_interaction.ts | 4 +- .../aztec.js/src/contract/contract.test.ts | 2 +- .../aztec.js/src/contract/contract.ts | 2 +- .../aztec.js/src/contract/contract_base.ts | 4 +- .../aztec.js/src/contract/sent_tx.test.ts | 4 +- yarn-project/aztec.js/src/contract/sent_tx.ts | 8 ++-- .../contract_deployer.test.ts | 6 +-- .../contract_deployer/contract_deployer.ts | 6 +-- .../src/contract_deployer/deploy_method.ts | 4 +- .../src/contract_deployer/deploy_sent_tx.ts | 6 +-- yarn-project/aztec.js/src/index.ts | 4 +- .../{aztec_rpc_client.ts => pxe_client.ts} | 6 +-- yarn-project/aztec.js/src/sandbox/index.ts | 14 +++---- .../aztec.js/src/utils/cheat_codes.ts | 6 +-- .../aztec.js/src/utils/l2_contracts.ts | 6 +-- .../aztec.js/src/wallet/account_wallet.ts | 4 +- .../aztec.js/src/wallet/base_wallet.ts | 4 +- yarn-project/aztec.js/src/wallet/index.ts | 4 +- .../boxes/blank-react/docker-compose.yml | 2 +- .../boxes/blank-react/src/artifacts/blank.ts | 6 +-- yarn-project/boxes/blank-react/src/config.ts | 4 +- .../src/scripts/call_contract_function.ts | 4 +- .../src/scripts/deploy_contract.ts | 4 +- .../boxes/blank-react/src/scripts/util.ts | 4 +- .../src/scripts/view_contract_function.ts | 4 +- .../src/tests/blank.contract.test.ts | 10 ++--- yarn-project/boxes/blank/docker-compose.yml | 2 +- .../boxes/blank/src/artifacts/blank.ts | 6 +-- yarn-project/boxes/blank/src/index.ts | 12 +++--- .../blank/src/tests/blank.contract.test.ts | 10 ++--- .../boxes/private-token/docker-compose.yml | 2 +- .../src/artifacts/private_token.ts | 6 +-- .../boxes/private-token/src/config.ts | 4 +- .../src/scripts/call_contract_function.ts | 4 +- .../src/scripts/deploy_contract.ts | 4 +- .../boxes/private-token/src/scripts/util.ts | 4 +- .../src/scripts/view_contract_function.ts | 4 +- .../src/tests/privatetoken.sandbox.test.ts | 10 ++--- .../canary/scripts/docker-compose-browser.yml | 2 +- .../scripts/docker-compose-e2e-sandbox.yml | 2 +- .../canary/scripts/docker-compose.yml | 2 +- yarn-project/canary/src/cli.test.ts | 4 +- .../src/uniswap_trade_on_l1_from_l2.test.ts | 4 +- yarn-project/canary/src/utils.ts | 2 +- yarn-project/cli/README.md | 36 +++++++++--------- yarn-project/cli/src/client.test.ts | 6 +-- yarn-project/cli/src/client.ts | 26 ++++++------- yarn-project/cli/src/index.ts | 38 +++++++++---------- yarn-project/cli/src/test/utils.test.ts | 8 ++-- yarn-project/cli/src/utils.ts | 10 ++--- .../docker-compose-e2e-sandbox-browser.yml | 2 +- .../scripts/docker-compose-e2e-sandbox.yml | 2 +- .../end-to-end/scripts/docker-compose.yml | 2 +- .../end-to-end/src/aztec_rpc_sandbox.test.ts | 12 ------ yarn-project/end-to-end/src/canary/browser.ts | 12 +++--- yarn-project/end-to-end/src/canary/cli.ts | 6 +-- ...rpc_servers.test.ts => e2e_2_pxes.test.ts} | 20 +++++----- .../src/e2e_account_contracts.test.ts | 6 +-- .../end-to-end/src/e2e_block_building.test.ts | 4 +- .../end-to-end/src/e2e_card_game.test.ts | 4 +- .../end-to-end/src/e2e_cheat_codes.test.ts | 4 +- yarn-project/end-to-end/src/e2e_cli.test.ts | 8 ++-- .../src/e2e_deploy_contract.test.ts | 4 +- .../src/e2e_escrow_contract.test.ts | 4 +- .../e2e_multiple_accounts_1_enc_key.test.ts | 6 +-- .../src/e2e_nested_contract.test.ts | 4 +- .../src/e2e_non_contract_account.test.ts | 4 +- .../end-to-end/src/e2e_ordering.test.ts | 4 +- .../end-to-end/src/e2e_p2p_network.test.ts | 12 +++--- .../src/e2e_public_token_contract.test.ts | 4 +- .../src/e2e_sandbox_example.test.ts | 14 +++---- .../src/fixtures/cross_chain_test_harness.ts | 10 ++--- yarn-project/end-to-end/src/fixtures/utils.ts | 34 ++++++++--------- .../src/guides/dapp_testing.test.ts | 24 ++++++------ .../src/guides/up_quick_start.test.ts | 2 +- .../end-to-end/src/pxe_sandbox.test.ts | 12 ++++++ .../src/uniswap_trade_on_l1_from_l2.test.ts | 4 +- yarn-project/key-store/README.md | 2 +- .../src/__snapshots__/index.test.ts.snap | 6 +-- .../src/contract-interface-gen/typescript.ts | 6 +-- yarn-project/pxe/README.md | 8 ++-- yarn-project/pxe/src/aztec_rpc_http/index.ts | 1 - .../pxe/src/aztec_rpc_server/index.ts | 3 -- yarn-project/pxe/src/config/index.ts | 8 ++-- yarn-project/pxe/src/index.ts | 4 +- yarn-project/pxe/src/pxe_http/index.ts | 1 + .../pxe_http_server.ts} | 13 +++---- .../create_pxe_service.ts} | 26 ++++++------- yarn-project/pxe/src/pxe_service/index.ts | 3 ++ .../pxe_service.ts} | 18 ++++----- .../test/pxe_service.test.ts} | 22 +++++------ .../test/pxe_test_suite.ts} | 14 ++----- .../pxe/src/simulator_oracle/index.ts | 2 +- yarn-project/types/src/interfaces/index.ts | 2 +- .../src/interfaces/{aztec_rpc.ts => pxe.ts} | 8 ++-- 131 files changed, 460 insertions(+), 467 deletions(-) rename docs/docs/dev_docs/tutorials/writing_dapp/{rpc_server.md => pxe_service.md} (84%) rename yarn-project/aztec.js/src/{aztec_rpc_client.ts => pxe_client.ts} (84%) delete mode 100644 yarn-project/end-to-end/src/aztec_rpc_sandbox.test.ts rename yarn-project/end-to-end/src/{e2e_2_rpc_servers.test.ts => e2e_2_pxes.test.ts} (93%) create mode 100644 yarn-project/end-to-end/src/pxe_sandbox.test.ts delete mode 100644 yarn-project/pxe/src/aztec_rpc_http/index.ts delete mode 100644 yarn-project/pxe/src/aztec_rpc_server/index.ts create mode 100644 yarn-project/pxe/src/pxe_http/index.ts rename yarn-project/pxe/src/{aztec_rpc_http/aztec_rpc_http_server.ts => pxe_http/pxe_http_server.ts} (77%) rename yarn-project/pxe/src/{aztec_rpc_server/create_aztec_rpc_server.ts => pxe_service/create_pxe_service.ts} (59%) create mode 100644 yarn-project/pxe/src/pxe_service/index.ts rename yarn-project/pxe/src/{aztec_rpc_server/aztec_rpc_server.ts => pxe_service/pxe_service.ts} (97%) rename yarn-project/pxe/src/{aztec_rpc_server/test/aztec_rpc_server.test.ts => pxe_service/test/pxe_service.test.ts} (74%) rename yarn-project/pxe/src/{aztec_rpc_server/test/aztec_rpc_test_suite.ts => pxe_service/test/pxe_test_suite.ts} (95%) rename yarn-project/types/src/interfaces/{aztec_rpc.ts => pxe.ts} (97%) diff --git a/.circleci/config.yml b/.circleci/config.yml index fb5fc534ad2..b05b90cf172 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -520,7 +520,7 @@ jobs: name: "Build" command: build end-to-end - e2e-2-rpc-servers: + e2e-2-pxes: machine: image: ubuntu-2204:2023.07.2 resource_class: large @@ -529,7 +529,7 @@ jobs: - *setup_env - run: name: "Test" - command: cond_run_script end-to-end ./scripts/run_tests_local e2e_2_rpc_servers.test.ts + command: cond_run_script end-to-end ./scripts/run_tests_local e2e_2_pxes.test.ts e2e-multiple-accounts-1-enc-key: machine: @@ -826,7 +826,7 @@ jobs: - *setup_env - run: name: "Test" - command: cond_run_script end-to-end ./scripts/run_tests_local aztec_rpc_sandbox.test.ts ./scripts/docker-compose-e2e-sandbox.yml + command: cond_run_script end-to-end ./scripts/run_tests_local pxe_sandbox.test.ts ./scripts/docker-compose-e2e-sandbox.yml cli-docs-sandbox: machine: @@ -1186,7 +1186,7 @@ workflows: - canary <<: *defaults - - e2e-2-rpc-servers: *e2e_test + - e2e-2-pxes: *e2e_test - e2e-deploy-contract: *e2e_test - e2e-lending-contract: *e2e_test - e2e-token-contract: *e2e_test @@ -1223,7 +1223,7 @@ workflows: - e2e-end: requires: - - e2e-2-rpc-servers + - e2e-2-pxes - e2e-deploy-contract - e2e-lending-contract - e2e-token-contract diff --git a/CHANGELOG.md b/CHANGELOG.md index 8ecf411908f..67a4f0a1757 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -7,7 +7,7 @@ * Aztec-cli unbox "really empty box" ([#2388](https://github.com/AztecProtocol/aztec-packages/issues/2388)) ([b57182d](https://github.com/AztecProtocol/aztec-packages/commit/b57182d6dff9fc27d5fb555a4c4cb948d9e5cc55)) * **docs:** Document noir macros ([#2016](https://github.com/AztecProtocol/aztec-packages/issues/2016)) ([1f1a17f](https://github.com/AztecProtocol/aztec-packages/commit/1f1a17fe056d8898c4c065fb6244e53da04800cb)) -* **docs:** Include aztec rpc interface typedoc output in docs ([#2255](https://github.com/AztecProtocol/aztec-packages/issues/2255)) ([62c9e9b](https://github.com/AztecProtocol/aztec-packages/commit/62c9e9bfdc9535ccfc6bd76782971e22478a7784)) +* **docs:** Include PXE interface typedoc output in docs ([#2255](https://github.com/AztecProtocol/aztec-packages/issues/2255)) ([62c9e9b](https://github.com/AztecProtocol/aztec-packages/commit/62c9e9bfdc9535ccfc6bd76782971e22478a7784)) * **token portal standard:** Create a token portal standard ([#2351](https://github.com/AztecProtocol/aztec-packages/issues/2351)) ([426a3ea](https://github.com/AztecProtocol/aztec-packages/commit/426a3ea6a5c3529b4edaea94affaece97d39a35b)) @@ -16,7 +16,7 @@ * **build:** Fix build system post deployment tests ([#2420](https://github.com/AztecProtocol/aztec-packages/issues/2420)) ([d509dc3](https://github.com/AztecProtocol/aztec-packages/commit/d509dc359c4cd9dc37492a434a1eb3813c002839)) * CLI encoding for arrays and structs ([#2407](https://github.com/AztecProtocol/aztec-packages/issues/2407)) ([85283bd](https://github.com/AztecProtocol/aztec-packages/commit/85283bdd5b0916c207dca11ad17338f524ae18f6)) * Correct sandbox addresses in up-quick-start test ([#2412](https://github.com/AztecProtocol/aztec-packages/issues/2412)) ([974d859](https://github.com/AztecProtocol/aztec-packages/commit/974d85922fc11734c543e7ce9fe7edaad527bd69)) -* **docs:** Revert include aztec rpc interface typedoc output in docs ([#2255](https://github.com/AztecProtocol/aztec-packages/issues/2255)) ([f852432](https://github.com/AztecProtocol/aztec-packages/commit/f85243298ef2a5c01764e592c6f6ea50d835bf07)) +* **docs:** Revert include PXE interface typedoc output in docs ([#2255](https://github.com/AztecProtocol/aztec-packages/issues/2255)) ([f852432](https://github.com/AztecProtocol/aztec-packages/commit/f85243298ef2a5c01764e592c6f6ea50d835bf07)) * Handle falsy bigints in json-rpc ([#2403](https://github.com/AztecProtocol/aztec-packages/issues/2403)) ([d100650](https://github.com/AztecProtocol/aztec-packages/commit/d100650d107b6685e17fcdbbf68363505c5ed0ed)), closes [#2402](https://github.com/AztecProtocol/aztec-packages/issues/2402) * **nargo_check.sh:** UNIX standard grep ([#2396](https://github.com/AztecProtocol/aztec-packages/issues/2396)) ([02e788a](https://github.com/AztecProtocol/aztec-packages/commit/02e788a8e39c7fcb5c75a6aaf4ceb705a8ebaa4a)) @@ -385,7 +385,7 @@ ### Features -* `CompleteAddress` type and overall AztecRPC refactor ([#1524](https://github.com/AztecProtocol/aztec-packages/issues/1524)) ([aa2c74c](https://github.com/AztecProtocol/aztec-packages/commit/aa2c74c8503469630611b7004c4052b80b5fe815)) +* `CompleteAddress` type and overall PXE refactor ([#1524](https://github.com/AztecProtocol/aztec-packages/issues/1524)) ([aa2c74c](https://github.com/AztecProtocol/aztec-packages/commit/aa2c74c8503469630611b7004c4052b80b5fe815)) * `FunctionSelector` type ([#1518](https://github.com/AztecProtocol/aztec-packages/issues/1518)) ([942f705](https://github.com/AztecProtocol/aztec-packages/commit/942f7058adc706924ff26d2490bec7f7d57d7149)), closes [#1424](https://github.com/AztecProtocol/aztec-packages/issues/1424) * `GrumpkinScalar` type ([#1919](https://github.com/AztecProtocol/aztec-packages/issues/1919)) ([3a9238a](https://github.com/AztecProtocol/aztec-packages/commit/3a9238a99a32259d8d6b85df6335a002c7bab354)) * **892:** Add hints for matching transient read requests with correspondiā€¦ ([#1995](https://github.com/AztecProtocol/aztec-packages/issues/1995)) ([0955bb7](https://github.com/AztecProtocol/aztec-packages/commit/0955bb7b0903b12c4f041096d51a1dbb48f6359d)) @@ -568,7 +568,7 @@ ### Miscellaneous -* `AztecRPC` API using sandbox ([#1568](https://github.com/AztecProtocol/aztec-packages/issues/1568)) ([b2662db](https://github.com/AztecProtocol/aztec-packages/commit/b2662dbc45b0149b380ae3c88d058b70174266cb)) +* `PXE` API using sandbox ([#1568](https://github.com/AztecProtocol/aztec-packages/issues/1568)) ([b2662db](https://github.com/AztecProtocol/aztec-packages/commit/b2662dbc45b0149b380ae3c88d058b70174266cb)) * **1074:** Remove read request data from final private kernel circuit public inputs ([#1840](https://github.com/AztecProtocol/aztec-packages/issues/1840)) ([c61557a](https://github.com/AztecProtocol/aztec-packages/commit/c61557ae926f89cead7306368197fdbe8f23dd6d)) * **1407:** Remove forwarding witnesses ([#1930](https://github.com/AztecProtocol/aztec-packages/issues/1930)) ([cc8bc8f](https://github.com/AztecProtocol/aztec-packages/commit/cc8bc8f48b175479e1c4dfbcf9b92159f096c2cf)), closes [#1407](https://github.com/AztecProtocol/aztec-packages/issues/1407) * **1879:** Add use of PrivateKernelPublicInputs in TS whenever relevant ([#1911](https://github.com/AztecProtocol/aztec-packages/issues/1911)) ([8d5f548](https://github.com/AztecProtocol/aztec-packages/commit/8d5f548e42d627da1685820f99fc28ff5f47abbe)) @@ -582,7 +582,7 @@ * Add tests that check ordering of public state updates ([#1661](https://github.com/AztecProtocol/aztec-packages/issues/1661)) ([5b9aedd](https://github.com/AztecProtocol/aztec-packages/commit/5b9aeddd4a1bffcf9015786819dd3f6c1ff66fb4)) * Add todo for using generator indices in note commitment and nullifier computation. ([#1762](https://github.com/AztecProtocol/aztec-packages/issues/1762)) ([2db6728](https://github.com/AztecProtocol/aztec-packages/commit/2db6728fcaf75ce8c98d821b65695543bb0c82a2)) * Another pedantic change to public state naming ([#1359](https://github.com/AztecProtocol/aztec-packages/issues/1359)) ([cb77440](https://github.com/AztecProtocol/aztec-packages/commit/cb774405e89c71a622e32b51032aa761cd767959)) -* Aztec RPC interface cleanup ([#1423](https://github.com/AztecProtocol/aztec-packages/issues/1423)) ([1a6168a](https://github.com/AztecProtocol/aztec-packages/commit/1a6168abc9cdc092cf7c9843191194c9b90adae7)) +* PXE interface cleanup ([#1423](https://github.com/AztecProtocol/aztec-packages/issues/1423)) ([1a6168a](https://github.com/AztecProtocol/aztec-packages/commit/1a6168abc9cdc092cf7c9843191194c9b90adae7)) * **Aztec.nr:** Remove implicit imports ([#1901](https://github.com/AztecProtocol/aztec-packages/issues/1901)) ([c7d5190](https://github.com/AztecProtocol/aztec-packages/commit/c7d5190e48771c334bfa7062c361bcd623faa318)) * **Aztec.nr:** Remove the open keyword from public functions ([#1917](https://github.com/AztecProtocol/aztec-packages/issues/1917)) ([4db8603](https://github.com/AztecProtocol/aztec-packages/commit/4db8603a4ee293c64a67be5ba74072bd654c7ec5)) * **bb:** Refactor bb CLI interface ([#1672](https://github.com/AztecProtocol/aztec-packages/issues/1672)) ([a5bf6e0](https://github.com/AztecProtocol/aztec-packages/commit/a5bf6e008b19127bf15c8b12a5a699182b7ff4e7)), closes [#1671](https://github.com/AztecProtocol/aztec-packages/issues/1671) diff --git a/README.md b/README.md index c6ce2670977..bf141bfea78 100644 --- a/README.md +++ b/README.md @@ -11,7 +11,7 @@ All the packages that make up [Aztec](https://docs.aztec.network). - [Aztec.nr](./yarn-project/aztec-nr/): A [Noir](https://noir-lang.org) framework for smart contracts on Aztec. - [Aztec Sandbox](./yarn-project/aztec-sandbox/): A package for setting up a local dev net, including a local Ethereum network, deployed rollup contracts and Aztec execution environment. -- [Aztec.js](./yarn-project/aztec.js/): A tool for interacting with the Aztec network. It communicates via the [Aztec RPC Server](./yarn-project/pxe/). +- [Aztec.js](./yarn-project/aztec.js/): A tool for interacting with the Aztec network. It communicates via the [Private Execution Environment (PXE)](./yarn-project/pxe/). - [Aztec Boxes](./yarn-project/boxes/): A minimal framework for building full stack applications for Aztec (using React). - [Example contracts](./yarn-project/noir-contracts/): Example contracts for the Aztec network, written in Noir. - [End to end tests](./yarn-project/end-to-end/): Integration tests writted in Typescript--a good reference for how to use the packages for specific tasks. diff --git a/docs/docs/about_aztec/roadmap/features_initial_ldt.md b/docs/docs/about_aztec/roadmap/features_initial_ldt.md index 73c4ac3ee91..34b86912cba 100644 --- a/docs/docs/about_aztec/roadmap/features_initial_ldt.md +++ b/docs/docs/about_aztec/roadmap/features_initial_ldt.md @@ -64,7 +64,7 @@ A typescript wrapper for making RPC calls to an Aztec Sandbox node. See the sour A bundle of packages which emulate the actions of all eventual Aztec network participants. The goal is for developer experience to be akin to Ganache / Anvil. -- Aztec RPC Client +- PXE client - Simulate and/or execute private functions locally. - Aztec Public Node - Broadcasts a user's txs to the tx pool. diff --git a/docs/docs/concepts/foundation/accounts/keys.md b/docs/docs/concepts/foundation/accounts/keys.md index 2fb19d87860..71c77d1336d 100644 --- a/docs/docs/concepts/foundation/accounts/keys.md +++ b/docs/docs/concepts/foundation/accounts/keys.md @@ -74,7 +74,7 @@ An application in Aztec.nr can access the encryption public key for a given addr #include_code encrypted /yarn-project/aztec-nr/value-note/src/utils.nr rust :::info -In order to be able to provide the public encryption key for a given address, that public key needs to have been registered in advance. At the moment, there is no broadcasting mechanism for public keys, which means that you will need to manually register all addresses you intend to send encrypted notes to. You can do this via the `registerRecipient` method of the Aztec RPC server, callable either via aztec.js or the CLI. Note that any accounts you own that have been added to the RPC server are automatically registered. +In order to be able to provide the public encryption key for a given address, that public key needs to have been registered in advance. At the moment, there is no broadcasting mechanism for public keys, which means that you will need to manually register all addresses you intend to send encrypted notes to. You can do this via the `registerRecipient` method of the Private Execution Environment (PXE), callable either via aztec.js or the CLI. Note that any accounts you own that have been added to the RPC server are automatically registered. ::: ### Nullifier secrets diff --git a/docs/docs/dev_docs/cli/main.md b/docs/docs/dev_docs/cli/main.md index 363677b4c2e..35ca8c9307c 100644 --- a/docs/docs/dev_docs/cli/main.md +++ b/docs/docs/dev_docs/cli/main.md @@ -36,7 +36,7 @@ Once installed it is invoked via: ## I have the Sandbox running, now what? -Lets first establish that we are able to communicate with the Sandbox. Most commands will require the url to the Sandbox, which defaults in the CLI to `http://localhost:8080`. You can override this as an option with each command or by setting `AZTEC_RPC_HOST` environment variable. +Lets first establish that we are able to communicate with the Sandbox. Most commands will require the url to the Sandbox, which defaults in the CLI to `http://localhost:8080`. You can override this as an option with each command or by setting `PXE_HOST` environment variable. To test communication with the Sandbox, let's run the command: diff --git a/docs/docs/dev_docs/contracts/common_errors.md b/docs/docs/dev_docs/contracts/common_errors.md index cefaa8535fb..c73607e8107 100644 --- a/docs/docs/dev_docs/contracts/common_errors.md +++ b/docs/docs/dev_docs/contracts/common_errors.md @@ -15,34 +15,34 @@ Simulation error: Assertion failed: Balance too low 'sum == amount' To address the error. find the line in the contract that is throwing the error and investigate why the condition is not met. ### Unknown Contract Error -This error occurs when you are trying to interact with a smart contract via an Aztec RPC Server that does not have the necessary information to execute a transaction. +This error occurs when you are trying to interact with a smart contract via an Private Execution Environment (PXE) that does not have the necessary information to execute a transaction. This is what the error typically looks like: ``` -Unknown contract 0x1d206be10b873b78b875259e1a8c39e2212e2f181d2fd0b0407446487deba522: add it to Aztec RPC server by calling server.addContracts(...) +Unknown contract 0x1d206be10b873b78b875259e1a8c39e2212e2f181d2fd0b0407446487deba522: add it to PXE by calling server.addContracts(...) ``` -To execute a transaction, the Aztec RPC Server needs to know the complete address of a contract, portal address (if portal is used) and contract artifacts. +To execute a transaction, the PXE needs to know the complete address of a contract, portal address (if portal is used) and contract artifacts. -To address the error, add the contract to the Aztec RPC Server by calling `server.addContracts(...)`. +To address the error, add the contract to the PXE by calling `server.addContracts(...)`. ### Unknown Complete Address Error -This error occurs when your contract is trying to get a public key via the `get_public_key` oracle call, but the Aztec RPC Server does not have the Complete Address (Complete Address contains the public key). +This error occurs when your contract is trying to get a public key via the `get_public_key` oracle call, but the PXE does not have the Complete Address (Complete Address contains the public key). This is what the error typically looks like: ``` -Simulation error: Unknown complete address for address 0x0d179a5f9bd4505f7dfb8ca37d64e0bd0cd31b5cb018e252fd647bdf88959b95. Add the information to Aztec RPC server by calling server.registerRecipient(...) or server.registerAccount(...) +Simulation error: Unknown complete address for address 0x0d179a5f9bd4505f7dfb8ca37d64e0bd0cd31b5cb018e252fd647bdf88959b95. Add the information to PXE by calling pxe.registerRecipient(...) or pxe.registerAccount(...) ``` Your contract typically needs a public key when it wants to send a note to a recipient because the public key is used to encrypt notes. :::info -Manually adding the recipient to the Aztec RPC Server should not be required in case the recipient contract has already been deployed and the Aztec RPC Server is fully synced. +Manually adding the recipient to the PXE should not be required in case the recipient contract has already been deployed and the PXE is fully synced. This is because this information is submitted on-chain when the recipient contract is deployed. ::: ### Unknown account -This error occurs when your contract is trying to get a secret via the `get_secret` oracle call, but the Aztec RPC Server does not have the secret for the public key. +This error occurs when your contract is trying to get a secret via the `get_secret` oracle call, but the PXE does not have the secret for the public key. This is what the error typically looks like: ``` diff --git a/docs/docs/dev_docs/contracts/compiling.md b/docs/docs/dev_docs/contracts/compiling.md index ac14588acfb..090cae9b788 100644 --- a/docs/docs/dev_docs/contracts/compiling.md +++ b/docs/docs/dev_docs/contracts/compiling.md @@ -54,7 +54,7 @@ export class PrivateTokenContract extends ContractBase { public static async at(address: AztecAddress, wallet: Wallet) { ... } /** Creates a tx to deploy a new instance of this contract. */ - public static deploy(rpc: AztecRPC, initial_supply: FieldLike, owner: FieldLike) { ... } + public static deploy(rpc: PXE, initial_supply: FieldLike, owner: FieldLike) { ... } /** Type-safe wrappers for the public methods exposed by the contract. */ public methods!: { diff --git a/docs/docs/dev_docs/contracts/deploying.md b/docs/docs/dev_docs/contracts/deploying.md index a2e5795a8f9..8431d0154e8 100644 --- a/docs/docs/dev_docs/contracts/deploying.md +++ b/docs/docs/dev_docs/contracts/deploying.md @@ -58,7 +58,7 @@ There are several optional arguments that can be passed: The command also takes the following optional arguments: - `-args ` (default: `[]`): Arguments to pass to the contract constructor. -- `--rpc-url ` (default: `http://localhost:8080`): URL of the Aztec node to connect to. +- `--rpc-url ` (default: `http://localhost:8080`): URL of the PXE to connect to. - `--public-key ` (default: `undefined`): Optional encryption public key for this contract. Set this only if this contract is expected to receive private notes (in such a case the public key is used during the note encryption). - `--salt ` (default: random value): Hexadecimal string used when computing the contract address of the contract being deployed. @@ -69,7 +69,7 @@ Set it, if you need a deterministic contract address (same functionality as Ethe The `deploy(...)` method is generated automatically with the typescript class representing your contract. -Its arguments are `AztecRPC` client and contract constructor arguments. +Its arguments are `PXE` client and contract constructor arguments. Additionally the `.send()` method can have a few optional arguments too, which are specified in an optional object: - `portalContract?: EthAddress`: The L1 portal address to link the contract to. See the section on [Portals to learn more about them](./portals/main.md). @@ -91,7 +91,7 @@ const tx = ExampleContract.deploy(aztecRpc).send({ To give you a more complete example we will deploy the `PrivateToken` contract whose artifacts are included in the `@aztec/noir-contracts` package. The contract has `initial_supply` and `owner` as constructor arguments. -Because the contract sends a note to the owner specified inside the constructor, we need their public key to encrypt the note with. For this, we first need to register the owner as a recipient inside the Aztec RPC with the following command: +Because the contract sends a note to the owner specified inside the constructor, we need their public key to encrypt the note with. For this, we first need to register the owner as a recipient inside the PXE with the following command: @@ -120,7 +120,7 @@ When you create a new account, it gets automatically registered. It can be verif > **NOTE 1**: If we didn't register owner as a recipient we could not encrypt a note for the owner and the contract deployment would fail because constructor execution would fail (we need owner's public key to encrypt a note). -> **NOTE 2**: If a note recipient is one of the accounts inside the Aztec RPC, we don't need to register it as a recipient because we already have the public key available. +> **NOTE 2**: If a note recipient is one of the accounts inside the PXE, we don't need to register it as a recipient because we already have the public key available. Once the recipient is registered we can deploy the contract: diff --git a/docs/docs/dev_docs/contracts/syntax/events.md b/docs/docs/dev_docs/contracts/syntax/events.md index c50526530f0..fb021e0f500 100644 --- a/docs/docs/dev_docs/contracts/syntax/events.md +++ b/docs/docs/dev_docs/contracts/syntax/events.md @@ -15,7 +15,7 @@ Unlike on Ethereum, there are 2 types of events supported by Aztec: encrypted an ## Encrypted Events Encrypted events can only be emitted by private functions and are encrypted using a public key of a recipient. -For this reason it is necessary to register a recipient in the Aztec RPC Server before encrypting the events for them. +For this reason it is necessary to register a recipient in the Private Execution Environment (PXE) before encrypting the events for them. Recipients can be registered using the Aztec CLI or Aztec.js: import Tabs from '@theme/Tabs'; @@ -54,11 +54,11 @@ await aztecRpc.registerRecipient(completeAddress); :::info -If a note recipient is one of the accounts inside the Aztec RPC Server, we don't need to register it as a recipient because we already have the public key available. You can register a recipient as shown [here](../deploying#deploying-private-token-contract) +If a note recipient is one of the accounts inside the PXE, we don't need to register it as a recipient because we already have the public key available. You can register a recipient as shown [here](../deploying#deploying-private-token-contract) At this point the Sandbox only enables the emitting of encrypted note preimages through encrypted events. In the future we will allow emitting arbitrary information. -(If you currently emit arbitrary information, Aztec RPC Server will fail to decrypt, process and store this data, so it will not be queryable). +(If you currently emit arbitrary information, PXE will fail to decrypt, process and store this data, so it will not be queryable). ::: To emit encrypted logs first import the `emit_encrypted_log` utility function which wraps an [oracle](./functions.md#oracle-functions): @@ -71,19 +71,19 @@ Then you can call the function: ### Processing Encrypted Events -One of the functions of the Aztec RPC Server is constantly loading encrypted logs from the `AztecNode` and decrypting them. -When new encrypted logs are obtained, the Aztec RPC Server will try to decrypt them using the private encryption key of all the accounts registered inside Aztec RPC Server. -If the decryption is successful, the Aztec RPC Server will store the decrypted note inside a database. +One of the functions of the PXE is constantly loading encrypted logs from the `AztecNode` and decrypting them. +When new encrypted logs are obtained, the PXE will try to decrypt them using the private encryption key of all the accounts registered inside PXE. +If the decryption is successful, the PXE will store the decrypted note inside a database. If the decryption fails, the specific log will be discarded. -For the Aztec RPC Server to successfully process the decrypted note we need to compute the note's 'note hash' and 'nullifier'. -Aztec.nr enables smart contract developers to design custom notes, meaning developers can also customize how a note's note hash and nullifier should be computed. Because of this customizability, and because there will be a potentially-unlimited number of smart contracts deployed to Aztec, an Aztec RPC Server needs to be 'taught' how to compute the custom note hashes and nullifiers for a particular contract. Therefore, developers will need to implement a `compute_note_hash_and_nullifier` function inside their contracts. +For the PXE to successfully process the decrypted note we need to compute the note's 'note hash' and 'nullifier'. +Aztec.nr enables smart contract developers to design custom notes, meaning developers can also customize how a note's note hash and nullifier should be computed. Because of this customizability, and because there will be a potentially-unlimited number of smart contracts deployed to Aztec, an PXE needs to be 'taught' how to compute the custom note hashes and nullifiers for a particular contract. Therefore, developers will need to implement a `compute_note_hash_and_nullifier` function inside their contracts. :::danger If your function has private state variables, you **MUST** include a `compute_note_hash_and_nullifier` function to allow the RPC to process encrypted events. ::: -Every time a new note is successfully decrypted, the Aztec RPC Server will expect the existence of a `compute_note_hash_and_nullifier` function, which must teach it how to correctly process the new note. +Every time a new note is successfully decrypted, the PXE will expect the existence of a `compute_note_hash_and_nullifier` function, which must teach it how to correctly process the new note. #include_code compute_note_hash_and_nullifier /yarn-project/noir-contracts/src/contracts/token_contract/src/main.nr rust diff --git a/docs/docs/dev_docs/contracts/syntax/functions.md b/docs/docs/dev_docs/contracts/syntax/functions.md index 32ef5f908ea..f6a9197a79f 100644 --- a/docs/docs/dev_docs/contracts/syntax/functions.md +++ b/docs/docs/dev_docs/contracts/syntax/functions.md @@ -114,7 +114,7 @@ Oracles introduce **non-determinism** into a circuit, and thus are `unconstraine ### Private -> Private In Aztec Private to Private function calls are handled by the [private kernel circuit](../../../concepts/advanced/circuits/kernels/private_kernel.md), and take place on the user's device. -Behind the scenes, the `Aztec RPC Server` (the beating heart of Aztec that runs in your wallet) will execute all of the functions in the desired order "simulating" them in sequence. For example, a very common use-case of Private to Private interaction is calling another private function from an `account contract` (Account contracts are a general concept, more information about them can be found [here](../../wallets/writing_an_account_contract.md)). +Behind the scenes, the `Private Execution Environment (PXE)` (the beating heart of Aztec that runs in your wallet) will execute all of the functions in the desired order "simulating" them in sequence. For example, a very common use-case of Private to Private interaction is calling another private function from an `account contract` (Account contracts are a general concept, more information about them can be found [here](../../wallets/writing_an_account_contract.md)). Take, for example, the following call stack: diff --git a/docs/docs/dev_docs/getting_started/quickstart.md b/docs/docs/dev_docs/getting_started/quickstart.md index ded6297b25e..48735d70aa0 100644 --- a/docs/docs/dev_docs/getting_started/quickstart.md +++ b/docs/docs/dev_docs/getting_started/quickstart.md @@ -15,8 +15,8 @@ This is a 1 page introduction to getting started with running the sandbox, and i Aztec's Layer 2 network is a fully programmable combined private/public ZK rollup. To achieve this, the network contains the following primary components: - Aztec Node - Aggregates all of the 'backend' services necessary for the building and publishing of rollups. This packages is currently in development and much of the functionality is mocked. -- [Aztec RPC Server](https://github.com/AztecProtocol/aztec-packages/tree/master/yarn-project/pxe) - Normally residing with the end client, this decrypts and stores a client's private state, executes simulations and submits transactions to the Aztec Node. -- [Aztec.js](https://github.com/AztecProtocol/aztec-packages/tree/master/yarn-project/aztec.js) - Aztec's client library for interacting with the Aztec RPC Server (think Ethers.js). See the getting started guide [here](./sandbox.md). +- [Private Execution Environment (PXE)](https://github.com/AztecProtocol/aztec-packages/tree/master/yarn-project/pxe) - Normally residing with the end client, this decrypts and stores a client's private state, executes simulations and submits transactions to the Aztec Node. +- [Aztec.js](https://github.com/AztecProtocol/aztec-packages/tree/master/yarn-project/aztec.js) - Aztec's client library for interacting with the PXE (think Ethers.js). See the getting started guide [here](./sandbox.md). All of this is included in the Sandbox, with the exception of Aztec.js which you can use to interact with it. @@ -114,7 +114,7 @@ Congratulations! You are all set up with the Aztec sandbox! Aztec's Layer 2 network is a fully programmable combined private/public ZK rollup. To achieve this, the network contains the following primary components: - Aztec Node - Aggregates all of the 'backend' services necessary for the building and publishing of rollups. -- Aztec RPC Server - Normally residing with the end client, this decrypts and stores a client's private state, executes simulations and submits transactions to the Aztec Node. -- [Aztec.js](./sandbox) - Aztec's client library for interacting with the Aztec RPC Server (think Ethers.js). +- Private Execution Environment (PXE) - Normally residing with the end client, this decrypts and stores a client's private state, executes simulations and submits transactions to the Aztec Node. +- [Aztec.js](./sandbox) - Aztec's client library for interacting with the PXE (think Ethers.js). - [Aztec.nr](../contracts/main.md) - Aztec's smart contract framework diff --git a/docs/docs/dev_docs/tutorials/testing.md b/docs/docs/dev_docs/tutorials/testing.md index e00bccd1a81..aa91c19fc66 100644 --- a/docs/docs/dev_docs/tutorials/testing.md +++ b/docs/docs/dev_docs/tutorials/testing.md @@ -12,7 +12,7 @@ Let's start with a simple example for a test using the [Sandbox](../getting_star #include_code sandbox-example /yarn-project/end-to-end/src/guides/dapp_testing.test.ts typescript -This test sets up the environment by creating a client to the Aztec RPC server running on the Sandbox on port 8080. It then creates two new accounts, dubbed `owner` and `recipient`. Last, it deploys an instance of the [`PrivateTokenContract`](https://github.com/AztecProtocol/aztec-packages/blob/master/yarn-project/noir-contracts/src/contracts/private_token_contract/src/main.nr), minting an initial 100 tokens to the owner. +This test sets up the environment by creating a client to the Private Execution Environment (PXE) running on the Sandbox on port 8080. It then creates two new accounts, dubbed `owner` and `recipient`. Last, it deploys an instance of the [`PrivateTokenContract`](https://github.com/AztecProtocol/aztec-packages/blob/master/yarn-project/noir-contracts/src/contracts/private_token_contract/src/main.nr), minting an initial 100 tokens to the owner. Once we have this setup, the test itself is simple. We check the balance of the `recipient` user to ensure it has no tokens, send and await a deployment transaction, and then check the balance again to ensure it was increased. Note that all numeric values are represented as [native bigints](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/BigInt) to avoid loss of precision. @@ -23,36 +23,36 @@ We are using the `PrivateTokenContract` [typescript interface](../contracts/comp To run the test, first make sure the Sandbox is running on port 8080, and then [run your tests using jest](https://jestjs.io/docs/getting-started#running-from-command-line). Your test should pass, and you should see the following output in the Sandbox logs, where each chunk corresponds to a transaction. Note how this test run has a total of four transactions: two for deploying the account contracts for the `owner` and `recipient`, another for deploying the token contract, and a last one for actually executing the transfer. ```text -rpc_server Registered account 0x2efa51d2e67581aef4578e8cc647a1af2e3f40e9872deeda0919e5f77cb8b2d2 -rpc_server Added contract SchnorrAccount at 0x2efa51d2e67581aef4578e8cc647a1af2e3f40e9872deeda0919e5f77cb8b2d2 +pxe_service Registered account 0x2efa51d2e67581aef4578e8cc647a1af2e3f40e9872deeda0919e5f77cb8b2d2 +pxe_service Added contract SchnorrAccount at 0x2efa51d2e67581aef4578e8cc647a1af2e3f40e9872deeda0919e5f77cb8b2d2 node Simulating tx 19bfe4fb2569be2168f01eefe5e5a4284d6c1678f17ab5e94c6ba9c811bcb214 node Simulated tx 19bfe4fb2569be2168f01eefe5e5a4284d6c1678f17ab5e94c6ba9c811bcb214 succeeds -rpc_server Executed local simulation for 19bfe4fb2569be2168f01eefe5e5a4284d6c1678f17ab5e94c6ba9c811bcb214 -rpc_server Sending transaction 19bfe4fb2569be2168f01eefe5e5a4284d6c1678f17ab5e94c6ba9c811bcb214 +pxe_service Executed local simulation for 19bfe4fb2569be2168f01eefe5e5a4284d6c1678f17ab5e94c6ba9c811bcb214 +pxe_service Sending transaction 19bfe4fb2569be2168f01eefe5e5a4284d6c1678f17ab5e94c6ba9c811bcb214 node Received tx 19bfe4fb2569be2168f01eefe5e5a4284d6c1678f17ab5e94c6ba9c811bcb214 sequencer Submitted rollup block 2 with 1 transactions -rpc_server Registered account 0x12ef7ceb5064da3a729f598a6a50585059794fdcf347a6fc9bb317002162e3db -rpc_server Added contract SchnorrAccount at 0x12ef7ceb5064da3a729f598a6a50585059794fdcf347a6fc9bb317002162e3db +pxe_service Registered account 0x12ef7ceb5064da3a729f598a6a50585059794fdcf347a6fc9bb317002162e3db +pxe_service Added contract SchnorrAccount at 0x12ef7ceb5064da3a729f598a6a50585059794fdcf347a6fc9bb317002162e3db node Simulating tx 0f195f8f6fb8fe29cf8159c5c664c1288788f1151a5413ec0e35cf378de74794 node Simulated tx 0f195f8f6fb8fe29cf8159c5c664c1288788f1151a5413ec0e35cf378de74794 succeeds -rpc_server Executed local simulation for 0f195f8f6fb8fe29cf8159c5c664c1288788f1151a5413ec0e35cf378de74794 -rpc_server Sending transaction 0f195f8f6fb8fe29cf8159c5c664c1288788f1151a5413ec0e35cf378de74794 +pxe_service Executed local simulation for 0f195f8f6fb8fe29cf8159c5c664c1288788f1151a5413ec0e35cf378de74794 +pxe_service Sending transaction 0f195f8f6fb8fe29cf8159c5c664c1288788f1151a5413ec0e35cf378de74794 node Received tx 0f195f8f6fb8fe29cf8159c5c664c1288788f1151a5413ec0e35cf378de74794 sequencer Submitted rollup block 3 with 1 transactions -rpc_server Added contract PrivateToken at 0x24e691d8bde970ab9e84fe669ea5ac8019c32c199a55aaa8a3e704db763af88f +pxe_service Added contract PrivateToken at 0x24e691d8bde970ab9e84fe669ea5ac8019c32c199a55aaa8a3e704db763af88f node Simulating tx 0101e1a3d73c3a112a18b7e4954edfe611d74ae0dc59e1688221ecda982ba943 node Simulated tx 0101e1a3d73c3a112a18b7e4954edfe611d74ae0dc59e1688221ecda982ba943 succeeds -rpc_server Executed local simulation for 0101e1a3d73c3a112a18b7e4954edfe611d74ae0dc59e1688221ecda982ba943 -rpc_server Sending transaction 0101e1a3d73c3a112a18b7e4954edfe611d74ae0dc59e1688221ecda982ba943 +pxe_service Executed local simulation for 0101e1a3d73c3a112a18b7e4954edfe611d74ae0dc59e1688221ecda982ba943 +pxe_service Sending transaction 0101e1a3d73c3a112a18b7e4954edfe611d74ae0dc59e1688221ecda982ba943 node Received tx 0101e1a3d73c3a112a18b7e4954edfe611d74ae0dc59e1688221ecda982ba943 sequencer Submitted rollup block 4 with 1 transactions node Simulating tx 2132767911fbbe67e24a3e51bc769ba2ae874eb1ba56e69cef8fc9e2c5eba04c node Simulated tx 2132767911fbbe67e24a3e51bc769ba2ae874eb1ba56e69cef8fc9e2c5eba04c succeeds -rpc_server Executed local simulation for 2132767911fbbe67e24a3e51bc769ba2ae874eb1ba56e69cef8fc9e2c5eba04c -rpc_server Sending transaction 2132767911fbbe67e24a3e51bc769ba2ae874eb1ba56e69cef8fc9e2c5eba04c +pxe_service Executed local simulation for 2132767911fbbe67e24a3e51bc769ba2ae874eb1ba56e69cef8fc9e2c5eba04c +pxe_service Sending transaction 2132767911fbbe67e24a3e51bc769ba2ae874eb1ba56e69cef8fc9e2c5eba04c node Received tx 2132767911fbbe67e24a3e51bc769ba2ae874eb1ba56e69cef8fc9e2c5eba04c sequencer Submitted rollup block 5 with 1 transactions ``` diff --git a/docs/docs/dev_docs/tutorials/writing_dapp/project_setup.md b/docs/docs/dev_docs/tutorials/writing_dapp/project_setup.md index 02cb3be2de5..68a0e820300 100644 --- a/docs/docs/dev_docs/tutorials/writing_dapp/project_setup.md +++ b/docs/docs/dev_docs/tutorials/writing_dapp/project_setup.md @@ -28,4 +28,4 @@ yarn add @aztec/aztec.js ## Next steps -With your project already set up, let's [connect to the Sandbox RPC Server and grab an account to interact with it](./rpc_server.md). +With your project already set up, let's [connect to the Sandbox RPC Server and grab an account to interact with it](./pxe_service.md). diff --git a/docs/docs/dev_docs/tutorials/writing_dapp/rpc_server.md b/docs/docs/dev_docs/tutorials/writing_dapp/pxe_service.md similarity index 84% rename from docs/docs/dev_docs/tutorials/writing_dapp/rpc_server.md rename to docs/docs/dev_docs/tutorials/writing_dapp/pxe_service.md index fd759beee27..91e88960170 100644 --- a/docs/docs/dev_docs/tutorials/writing_dapp/rpc_server.md +++ b/docs/docs/dev_docs/tutorials/writing_dapp/pxe_service.md @@ -1,6 +1,6 @@ # Connecting to the RPC Server -As an app developer, the [Aztec RPC Server](https://github.com/AztecProtocol/aztec-packages/tree/master/yarn-project/pxe) interface provides you with access to the user's accounts and their private state, as well as a connection to the network for accessing public global state. +As an app developer, the [Private Execution Environment (PXE)](https://github.com/AztecProtocol/aztec-packages/tree/master/yarn-project/pxe) interface provides you with access to the user's accounts and their private state, as well as a connection to the network for accessing public global state. During the Sandbox phase, this role is fulfilled by the [Aztec Sandbox](../../getting_started/sandbox.md), which runs a local RPC Server and an Aztec Node, both connected to a local Ethereum development node like Anvil. The Sandbox also includes a set of pre-initialized accounts that you can use from your app. diff --git a/docs/docs/dev_docs/tutorials/writing_token_contract.md b/docs/docs/dev_docs/tutorials/writing_token_contract.md index afac795f6cc..2f7f052549c 100644 --- a/docs/docs/dev_docs/tutorials/writing_token_contract.md +++ b/docs/docs/dev_docs/tutorials/writing_token_contract.md @@ -455,7 +455,7 @@ A getter function for checking the token `total_supply`. #### `balance_of_private` -A getter function for checking the private balance of the provided Aztec account. Note that the [Aztec RPC Server](https://github.com/AztecProtocol/aztec-packages/tree/master/yarn-project/pxe) must have access to the `owner`s decryption keys in order to decrypt their notes. +A getter function for checking the private balance of the provided Aztec account. Note that the [Private Execution Environment (PXE)](https://github.com/AztecProtocol/aztec-packages/tree/master/yarn-project/pxe) must have access to the `owner`s decryption keys in order to decrypt their notes. #include_code balance_of_private /yarn-project/noir-contracts/src/contracts/token_contract/src/main.nr rust diff --git a/docs/docs/dev_docs/wallets/architecture.md b/docs/docs/dev_docs/wallets/architecture.md index 736f9d0896f..6c533f34868 100644 --- a/docs/docs/dev_docs/wallets/architecture.md +++ b/docs/docs/dev_docs/wallets/architecture.md @@ -4,7 +4,7 @@ Wallets expose to dapps an interface that allows them to act on behalf of the us ## Overview -Architecture-wise, a wallet is an instance of an **Aztec RPC Server** which manages user keys and private state. The RPC server also communicates with an **Aztec Node** for retrieving public information or broadcasting transactions. Note that the RPC server requires a local database for keeping private state, and is also expected to be continuously syncing new blocks for trial-decryption of user notes. +Architecture-wise, a wallet is an instance of an **Private Execution Environment (PXE)** which manages user keys and private state. The RPC server also communicates with an **Aztec Node** for retrieving public information or broadcasting transactions. Note that the RPC server requires a local database for keeping private state, and is also expected to be continuously syncing new blocks for trial-decryption of user notes. Additionally, a wallet must be able to handle one or more [account contract implementations](../../concepts/foundation/accounts/main.md#account-contracts-and-wallets). When a user creates a new account, the account is represented on-chain by an account contract. The wallet is responsible for deploying and interacting with this contract. A wallet may support multiple flavours of accounts, such as an account that uses ECDSA signatures, or one that relies on WebAuthn, or one that requires multi-factor authentication. For a user, the choice of what account implementation to use is then determined by the wallet they interact with. @@ -20,7 +20,7 @@ Refer to the page on [writing an account contract](./writing_an_account_contract ## RPC interface -A wallet exposes the RPC interface to dapps by running an Aztec RPC Server instance. The Aztec RPC Server requires a keystore and a database implementation for storing keys, private state, and recipient encryption public keys. +A wallet exposes the RPC interface to dapps by running an PXE instance. The PXE requires a keystore and a database implementation for storing keys, private state, and recipient encryption public keys. #include_code rpc-interface /yarn-project/types/src/interfaces/aztec_rpc.ts typescript diff --git a/docs/docs/dev_docs/wallets/writing_an_account_contract.md b/docs/docs/dev_docs/wallets/writing_an_account_contract.md index 9916cf790cb..8f14c62f1cc 100644 --- a/docs/docs/dev_docs/wallets/writing_an_account_contract.md +++ b/docs/docs/dev_docs/wallets/writing_an_account_contract.md @@ -74,7 +74,7 @@ More signing schemes are available in case you want to experiment with other typ Let's try creating a new account backed by our account contract, and interact with a simple token contract to test it works. -To create and deploy the account, we will use the `AccountManager` class, which takes an instance of an Aztec RPC server, a [privacy private key](../../concepts/foundation/accounts/keys.md#privacy-keys), and an instance of our `AccountContract` class: +To create and deploy the account, we will use the `AccountManager` class, which takes an instance of an Private Execution Environment (PXE), a [privacy private key](../../concepts/foundation/accounts/keys.md#privacy-keys), and an instance of our `AccountContract` class: #include_code account-contract-deploy yarn-project/end-to-end/src/guides/writing_an_account_contract.test.ts typescript diff --git a/docs/docusaurus.config.js b/docs/docusaurus.config.js index 6306b3ac8b5..0c90df95875 100644 --- a/docs/docusaurus.config.js +++ b/docs/docusaurus.config.js @@ -131,7 +131,7 @@ const config = { entryPointStrategy: "expand", out: "apis/pxe", disableSources: true, - frontmatter: { sidebar_label: "Aztec RPC Server" }, + frontmatter: { sidebar_label: "Private Execution Environment (PXE)" }, }, ], [ diff --git a/docs/internal_notes/api.md b/docs/internal_notes/api.md index 113cfa1d133..d6c4767c0b6 100644 --- a/docs/internal_notes/api.md +++ b/docs/internal_notes/api.md @@ -4,6 +4,6 @@ title: API ## API Structure -- Discuss AztecRPC, it's purpose and what it's used for +- Discuss PXE, it's purpose and what it's used for - Discuss aztec.js and the generated typescript interfaces - Links to other pages within this api section diff --git a/docs/sidebars.js b/docs/sidebars.js index 71f56f29406..9f852752483 100644 --- a/docs/sidebars.js +++ b/docs/sidebars.js @@ -351,9 +351,9 @@ const sidebars = { type: "category", items: [ { - label: "Aztec RPC Server", + label: "Private Execution Environment (PXE)", type: "doc", - id: "apis/pxe/interfaces/AztecRPC", + id: "apis/pxe/interfaces/PXE", }, { label: "Aztec.js", diff --git a/yarn-project/aztec-node/src/bin/index.ts b/yarn-project/aztec-node/src/bin/index.ts index 7aac8514b81..9a793952ccc 100644 --- a/yarn-project/aztec-node/src/bin/index.ts +++ b/yarn-project/aztec-node/src/bin/index.ts @@ -21,7 +21,7 @@ async function createAndDeployAztecNode() { } /** - * Creates a router for helper API endpoints of the Aztec RPC Server. + * Creates a router for helper API endpoints of the Private Execution Environment (PXE). * @param apiPrefix - The prefix to use for all api requests * @returns - The router for handling status requests. */ diff --git a/yarn-project/aztec-rpc/src/bin/index.ts b/yarn-project/aztec-rpc/src/bin/index.ts index 80584d0a8e6..a5b87a28ba2 100644 --- a/yarn-project/aztec-rpc/src/bin/index.ts +++ b/yarn-project/aztec-rpc/src/bin/index.ts @@ -3,7 +3,7 @@ import { createDebugLogger } from '@aztec/foundation/log'; import { createAztecNodeRpcClient } from '@aztec/types'; import { startHttpRpcServer } from '../aztec_rpc_http/index.js'; -import { createAztecRPCServer } from '../aztec_rpc_server/index.js'; +import { createPXEService } from '../aztec_rpc_server/index.js'; import { getConfigEnvVars } from '../config/index.js'; const { SERVER_PORT = 8080, AZTEC_NODE_RPC_URL = '' } = process.env; @@ -14,11 +14,11 @@ const logger = createDebugLogger('aztec:rpc_server'); * Create and start a new Aztec RCP HTTP Server */ async function main() { - logger.info(`Setting up Aztec RPC Server...`); + logger.info(`Setting up PXE...`); const rpcConfig = getConfigEnvVars(); const nodeRpcClient = createAztecNodeRpcClient(AZTEC_NODE_RPC_URL); - const rpcServer = await createAztecRPCServer(nodeRpcClient, rpcConfig); + const rpcServer = await createPXEService(nodeRpcClient, rpcConfig); const shutdown = async () => { logger.info('Shutting down...'); @@ -30,7 +30,7 @@ async function main() { process.once('SIGTERM', shutdown); startHttpRpcServer(rpcServer, SERVER_PORT); - logger.info(`Aztec RPC Server listening on port ${SERVER_PORT}`); + logger.info(`PXE listening on port ${SERVER_PORT}`); } main().catch(err => { diff --git a/yarn-project/aztec-sandbox/README.md b/yarn-project/aztec-sandbox/README.md index ed50c63fee6..92bde78b1ce 100644 --- a/yarn-project/aztec-sandbox/README.md +++ b/yarn-project/aztec-sandbox/README.md @@ -1,6 +1,6 @@ # aztec-sandbox -Aztec Sandbox is a package that allows for a simple development environment on Aztec stack. It creates an Aztec RPC server that listens for HTTP requests on `localhost:8080` by default. When started, it deploys all necessary L1 Aztec contracts and then starts listening for RPC requests. +Aztec Sandbox is a package that allows for a simple development environment on Aztec stack. It creates an Private Execution Environment (PXE) that listens for HTTP requests on `localhost:8080` by default. When started, it deploys all necessary L1 Aztec contracts and then starts listening for RPC requests. ## How to run: diff --git a/yarn-project/aztec-sandbox/docker-compose.yml b/yarn-project/aztec-sandbox/docker-compose.yml index 365e0626beb..935d0da224e 100644 --- a/yarn-project/aztec-sandbox/docker-compose.yml +++ b/yarn-project/aztec-sandbox/docker-compose.yml @@ -19,7 +19,7 @@ services: P2P_BLOCK_CHECK_INTERVAL_MS: 50 SEQ_TX_POLLING_INTERVAL_MS: 50 WS_BLOCK_CHECK_INTERVAL_MS: 50 - RPC_SERVER_BLOCK_POLLING_INTERVAL_MS: 50 + PXE_SERVICE_BLOCK_POLLING_INTERVAL_MS: 50 ARCHIVER_VIEM_POLLING_INTERVAL_MS: 500 volumes: - ./log:/usr/src/yarn-project/aztec-sandbox/log:rw diff --git a/yarn-project/aztec-sandbox/src/bin/index.ts b/yarn-project/aztec-sandbox/src/bin/index.ts index 2ab3b192b59..760cbbab705 100644 --- a/yarn-project/aztec-sandbox/src/bin/index.ts +++ b/yarn-project/aztec-sandbox/src/bin/index.ts @@ -3,7 +3,7 @@ import { deployInitialSandboxAccounts } from '@aztec/aztec.js'; import { createDebugLogger } from '@aztec/foundation/log'; import { fileURLToPath } from '@aztec/foundation/url'; import NoirVersion from '@aztec/noir-compiler/noir-version'; -import { startHttpRpcServer } from '@aztec/pxe'; +import { startPxeHttpServer } from '@aztec/pxe'; import { readFileSync } from 'fs'; import { dirname, resolve } from 'path'; @@ -52,7 +52,7 @@ async function main() { process.once('SIGINT', shutdown); process.once('SIGTERM', shutdown); - startHttpRpcServer(rpcServer, SERVER_PORT); + startPxeHttpServer(rpcServer, SERVER_PORT); logger.info(`Aztec Sandbox JSON-RPC Server listening on port ${SERVER_PORT}`); logger.info(`Debug logs will be written to ${logPath}`); const accountStrings = [`Initial Accounts:\n\n`]; diff --git a/yarn-project/aztec-sandbox/src/examples/private_token_contract.ts b/yarn-project/aztec-sandbox/src/examples/private_token_contract.ts index d637d02d710..1154d96552a 100644 --- a/yarn-project/aztec-sandbox/src/examples/private_token_contract.ts +++ b/yarn-project/aztec-sandbox/src/examples/private_token_contract.ts @@ -3,7 +3,7 @@ import { AztecAddress, Contract, GrumpkinScalar, - createAztecRpcClient, + createPXEClient, createRecipient, getUnsafeSchnorrAccount, } from '@aztec/aztec.js'; @@ -16,7 +16,7 @@ export const privateKey = GrumpkinScalar.fromString('ac0974bec39a17e36ba4a6b4d23 const url = 'http://localhost:8080'; -const aztecRpcClient = createAztecRpcClient(url); +const aztecRpcClient = createPXEClient(url); let wallet: AccountWallet; const INITIAL_BALANCE = 333n; diff --git a/yarn-project/aztec-sandbox/src/examples/uniswap_trade_on_l1_from_l2.ts b/yarn-project/aztec-sandbox/src/examples/uniswap_trade_on_l1_from_l2.ts index 9feaa2d9b89..c003f9ecb6f 100644 --- a/yarn-project/aztec-sandbox/src/examples/uniswap_trade_on_l1_from_l2.ts +++ b/yarn-project/aztec-sandbox/src/examples/uniswap_trade_on_l1_from_l2.ts @@ -4,7 +4,7 @@ import { EthAddress, Fr, computeMessageSecretHash, - createAztecRpcClient, + createPXEClient, createRecipient, getL1ContractAddresses, getUnsafeSchnorrAccount, @@ -13,7 +13,7 @@ import { GrumpkinScalar } from '@aztec/circuits.js'; import { createDebugLogger } from '@aztec/foundation/log'; import { UniswapPortalAbi, UniswapPortalBytecode } from '@aztec/l1-artifacts'; import { NonNativeTokenContract, UniswapContract } from '@aztec/noir-contracts/types'; -import { AztecRPC, TxStatus } from '@aztec/types'; +import { PXE, TxStatus } from '@aztec/types'; import { createPublicClient, createWalletClient, getContract, http, parseEther } from 'viem'; import { mnemonicToAccount } from 'viem/accounts'; @@ -55,7 +55,7 @@ if (Number(await publicClient.getBlockNumber()) < EXPECTED_FORKED_BLOCK) { const ethAccount = EthAddress.fromString((await walletClient.getAddresses())[0]); -const aztecRpcClient = createAztecRpcClient(aztecRpcUrl); +const aztecRpcClient = createPXEClient(aztecRpcUrl); let wallet: AccountWallet; /** @@ -132,12 +132,12 @@ async function deployAllContracts(owner: AztecAddress) { }; } -const getL2BalanceOf = async (aztecRpcClient: AztecRPC, owner: AztecAddress, l2Contract: NonNativeTokenContract) => { +const getL2BalanceOf = async (aztecRpcClient: PXE, owner: AztecAddress, l2Contract: NonNativeTokenContract) => { return await l2Contract.methods.getBalance(owner).view({ from: owner }); }; const logExpectedBalanceOnL2 = async ( - aztecRpcClient: AztecRPC, + aztecRpcClient: PXE, owner: AztecAddress, expectedBalance: bigint, l2Contract: NonNativeTokenContract, @@ -147,7 +147,7 @@ const logExpectedBalanceOnL2 = async ( }; const transferWethOnL2 = async ( - _aztecRpcClient: AztecRPC, + _aztecRpcClient: PXE, wethL2Contract: NonNativeTokenContract, ownerAddress: AztecAddress, receiver: AztecAddress, diff --git a/yarn-project/aztec-sandbox/src/examples/util.ts b/yarn-project/aztec-sandbox/src/examples/util.ts index f6feb91507e..70c3170f416 100644 --- a/yarn-project/aztec-sandbox/src/examples/util.ts +++ b/yarn-project/aztec-sandbox/src/examples/util.ts @@ -7,7 +7,7 @@ import { Account, Chain, Hex, HttpTransport, PublicClient, WalletClient, getCont /** * Deploy L1 token and portal, initialize portal, deploy a non native l2 token contract and attach is to the portal. - * @param aztecRpcServer - the aztec rpc server instance + * @param aztecRpcServer - Private Execution Environment (PXE) instance * @param walletClient - A viem WalletClient. * @param publicClient - A viem PublicClient. * @param rollupRegistryAddress - address of rollup registry to pass to initialize the token portal diff --git a/yarn-project/aztec-sandbox/src/routes.ts b/yarn-project/aztec-sandbox/src/routes.ts index 982fd37677d..91bbec88f10 100644 --- a/yarn-project/aztec-sandbox/src/routes.ts +++ b/yarn-project/aztec-sandbox/src/routes.ts @@ -2,7 +2,7 @@ import Koa from 'koa'; import Router from 'koa-router'; /** - * Creates a router for helper API endpoints of the Aztec RPC Server. + * Creates a router for helper API endpoints of the Private Execution Environment (PXE). * @param aztecNode - An instance of the aztec node. * @param config - The aztec node's configuration variables. */ diff --git a/yarn-project/aztec-sandbox/src/sandbox.ts b/yarn-project/aztec-sandbox/src/sandbox.ts index 463bf51e85f..e798ba1a62e 100644 --- a/yarn-project/aztec-sandbox/src/sandbox.ts +++ b/yarn-project/aztec-sandbox/src/sandbox.ts @@ -20,7 +20,7 @@ import { RollupAbi, RollupBytecode, } from '@aztec/l1-artifacts'; -import { createAztecRPCServer, getConfigEnvVars as getRpcConfigEnvVars } from '@aztec/pxe'; +import { createPXEService, getConfigEnvVars as getRpcConfigEnvVars } from '@aztec/pxe'; import { createPublicClient, http as httpViemTransport } from 'viem'; import { mnemonicToAccount } from 'viem/accounts'; @@ -116,7 +116,7 @@ export async function createSandbox(config: Partial = {}) { aztecNodeConfig.l1Contracts.registryAddress = l1Contracts.l1ContractAddresses.registryAddress; const node = await AztecNodeService.createAndSync(aztecNodeConfig); - const rpcServer = await createAztecRPCServer(node, rpcConfig); + const rpcServer = await createPXEService(node, rpcConfig); const stop = async () => { await rpcServer.stop(); diff --git a/yarn-project/aztec-sandbox/src/server.ts b/yarn-project/aztec-sandbox/src/server.ts index d2e4805dd75..80a760f3b73 100644 --- a/yarn-project/aztec-sandbox/src/server.ts +++ b/yarn-project/aztec-sandbox/src/server.ts @@ -1,5 +1,5 @@ -import { getHttpRpcServer } from '@aztec/pxe'; -import { AztecRPC } from '@aztec/types'; +import { createPxeRpcServer } from '@aztec/pxe'; +import { PXE } from '@aztec/types'; import http from 'http'; @@ -11,8 +11,8 @@ import { createApiRouter } from './routes.js'; * @param port - Port to listen in. * @returns A running http server. */ -export function startHttpRpcServer(aztecRpcServer: AztecRPC, port: string | number): http.Server { - const rpcServer = getHttpRpcServer(aztecRpcServer); +export function startHttpRpcServer(aztecRpcServer: PXE, port: string | number): http.Server { + const rpcServer = createPxeRpcServer(aztecRpcServer); const app = rpcServer.getApp(); const apiRouter = createApiRouter(); diff --git a/yarn-project/aztec.js/README.md b/yarn-project/aztec.js/README.md index b678fb81216..371be3ba4ca 100644 --- a/yarn-project/aztec.js/README.md +++ b/yarn-project/aztec.js/README.md @@ -1,6 +1,6 @@ # Aztec.js -Aztec.js is a library that provides APIs for managing accounts and interacting with contracts on the Aztec network. It communicates with the [Aztec RPC Server](https://docs.aztec.network/apis/pxe/interfaces/AztecRPC) through an `AztecRPCClient` implementation, allowing developers to easily register new accounts, deploy contracts, view functions, and send transactions. +Aztec.js is a library that provides APIs for managing accounts and interacting with contracts on the Aztec network. It communicates with the [Private Execution Environment (PXE)](https://docs.aztec.network/apis/pxe/interfaces/PXE) through an `PXEClient` implementation, allowing developers to easily register new accounts, deploy contracts, view functions, and send transactions. ## Usage diff --git a/yarn-project/aztec.js/src/account/index.ts b/yarn-project/aztec.js/src/account/index.ts index 4db12237ee8..6123115aa01 100644 --- a/yarn-project/aztec.js/src/account/index.ts +++ b/yarn-project/aztec.js/src/account/index.ts @@ -19,7 +19,7 @@ * * @packageDocumentation */ -import { AztecRPC, CompleteAddress, GrumpkinPrivateKey } from '@aztec/types'; +import { CompleteAddress, GrumpkinPrivateKey, PXE } from '@aztec/types'; import { AccountContract, AccountWallet, AztecAddress, Fr } from '../index.js'; import { EcdsaAccountContract } from './contract/ecdsa_account_contract.js'; @@ -38,13 +38,13 @@ export type Salt = Fr | number | bigint; /** * Creates an Account that relies on an ECDSA signing key for authentication. - * @param rpc - An AztecRPC server instance. + * @param rpc - An PXE server instance. * @param encryptionPrivateKey - Grumpkin key used for note encryption. * @param signingPrivateKey - Secp256k1 key used for signing transactions. * @param saltOrAddress - Deployment salt or complete address if account contract is already deployed. */ export function getEcdsaAccount( - rpc: AztecRPC, + rpc: PXE, encryptionPrivateKey: GrumpkinPrivateKey, signingPrivateKey: Buffer, saltOrAddress?: Salt | CompleteAddress, @@ -54,13 +54,13 @@ export function getEcdsaAccount( /** * Creates an Account that relies on a Grumpkin signing key for authentication. - * @param rpc - An AztecRPC server instance. + * @param rpc - An PXE server instance. * @param encryptionPrivateKey - Grumpkin key used for note encryption. * @param signingPrivateKey - Grumpkin key used for signing transactions. * @param saltOrAddress - Deployment salt or complete address if account contract is already deployed. */ export function getSchnorrAccount( - rpc: AztecRPC, + rpc: PXE, encryptionPrivateKey: GrumpkinPrivateKey, signingPrivateKey: GrumpkinPrivateKey, saltOrAddress?: Salt | CompleteAddress, @@ -70,12 +70,12 @@ export function getSchnorrAccount( /** * Creates an Account that uses the same Grumpkin key for encryption and authentication. - * @param rpc - An AztecRPC server instance. + * @param rpc - An PXE server instance. * @param encryptionAndSigningPrivateKey - Grumpkin key used for note encryption and signing transactions. * @param saltOrAddress - Deployment salt or complete address if account contract is already deployed. */ export function getUnsafeSchnorrAccount( - rpc: AztecRPC, + rpc: PXE, encryptionAndSigningPrivateKey: GrumpkinPrivateKey, saltOrAddress?: Salt | CompleteAddress, ): AccountManager { @@ -89,13 +89,13 @@ export function getUnsafeSchnorrAccount( /** * Gets a wallet for an already registered account using Schnorr signatures with a single key for encryption and authentication. - * @param rpc - An AztecRPC server instance. + * @param rpc - An PXE server instance. * @param address - Address for the account. * @param signingPrivateKey - Grumpkin key used for note encryption and signing transactions. * @returns A wallet for this account that can be used to interact with a contract instance. */ export function getUnsafeSchnorrWallet( - rpc: AztecRPC, + rpc: PXE, address: AztecAddress, signingKey: GrumpkinPrivateKey, ): Promise { @@ -104,13 +104,13 @@ export function getUnsafeSchnorrWallet( /** * Gets a wallet for an already registered account. - * @param rpc - An AztecRPC server instance. + * @param rpc - An PXE server instance. * @param address - Address for the account. * @param accountContract - Account contract implementation. * @returns A wallet for this account that can be used to interact with a contract instance. */ export async function getWallet( - rpc: AztecRPC, + rpc: PXE, address: AztecAddress, accountContract: AccountContract, ): Promise { diff --git a/yarn-project/aztec.js/src/account/manager/index.ts b/yarn-project/aztec.js/src/account/manager/index.ts index 4f2f066b30b..f8260b33bd6 100644 --- a/yarn-project/aztec.js/src/account/manager/index.ts +++ b/yarn-project/aztec.js/src/account/manager/index.ts @@ -1,5 +1,5 @@ import { Fr, PublicKey, getContractDeploymentInfo } from '@aztec/circuits.js'; -import { AztecRPC, CompleteAddress, GrumpkinPrivateKey } from '@aztec/types'; +import { CompleteAddress, GrumpkinPrivateKey, PXE } from '@aztec/types'; import { AccountWallet, ContractDeployer, DeployMethod, WaitOpts, generatePublicKey } from '../../index.js'; import { AccountContract, Salt } from '../index.js'; @@ -19,7 +19,7 @@ export class AccountManager { private deployMethod?: DeployMethod; constructor( - private rpc: AztecRPC, + private rpc: PXE, private encryptionPrivateKey: GrumpkinPrivateKey, private accountContract: AccountContract, saltOrAddress?: Salt | CompleteAddress, diff --git a/yarn-project/aztec.js/src/account/utils.ts b/yarn-project/aztec.js/src/account/utils.ts index fcf63096b3a..3bf16d80070 100644 --- a/yarn-project/aztec.js/src/account/utils.ts +++ b/yarn-project/aztec.js/src/account/utils.ts @@ -1,5 +1,5 @@ import { CompleteAddress, GrumpkinScalar } from '@aztec/circuits.js'; -import { AztecRPC } from '@aztec/types'; +import { PXE } from '@aztec/types'; import { getSchnorrAccount } from '../index.js'; import { AccountWallet } from '../wallet/account_wallet.js'; @@ -9,7 +9,7 @@ import { AccountWallet } from '../wallet/account_wallet.js'; * @param rpc - RPC client. * @returns - A wallet for a fresh account. */ -export function createAccount(rpc: AztecRPC): Promise { +export function createAccount(rpc: PXE): Promise { return getSchnorrAccount(rpc, GrumpkinScalar.random(), GrumpkinScalar.random()).waitDeploy(); } @@ -18,7 +18,7 @@ export function createAccount(rpc: AztecRPC): Promise { * @param rpc - RPC client. * @returns Complete address of the registered recipient. */ -export async function createRecipient(rpc: AztecRPC): Promise { +export async function createRecipient(rpc: PXE): Promise { const completeAddress = await CompleteAddress.random(); await rpc.registerRecipient(completeAddress); return completeAddress; @@ -30,7 +30,7 @@ export async function createRecipient(rpc: AztecRPC): Promise { * @param numberOfAccounts - How many accounts to create. * @returns The created account wallets. */ -export async function createAccounts(rpc: AztecRPC, numberOfAccounts = 1): Promise { +export async function createAccounts(rpc: PXE, numberOfAccounts = 1): Promise { const accounts = []; // Prepare deployments diff --git a/yarn-project/aztec.js/src/contract/base_contract_interaction.ts b/yarn-project/aztec.js/src/contract/base_contract_interaction.ts index 6a9458f27c5..c63f6d9a96f 100644 --- a/yarn-project/aztec.js/src/contract/base_contract_interaction.ts +++ b/yarn-project/aztec.js/src/contract/base_contract_interaction.ts @@ -1,4 +1,4 @@ -import { AztecRPC, Tx, TxExecutionRequest } from '@aztec/types'; +import { PXE, Tx, TxExecutionRequest } from '@aztec/types'; import { SentTx } from './sent_tx.js'; @@ -21,7 +21,7 @@ export abstract class BaseContractInteraction { protected tx?: Tx; protected txRequest?: TxExecutionRequest; - constructor(protected rpc: AztecRPC) {} + constructor(protected rpc: PXE) {} /** * Create a transaction execution request ready to be simulated. diff --git a/yarn-project/aztec.js/src/contract/contract.test.ts b/yarn-project/aztec.js/src/contract/contract.test.ts index 6afe155e32e..3faef893055 100644 --- a/yarn-project/aztec.js/src/contract/contract.test.ts +++ b/yarn-project/aztec.js/src/contract/contract.test.ts @@ -156,7 +156,7 @@ describe('Contract Class', () => { expect(() => fooContract.methods.baz().view()).toThrow(); }); - it('should add contract and dependencies to aztec rpc', async () => { + it('should add contract and dependencies to PXE', async () => { const entry: DeployedContract = { abi: randomContractAbi(), completeAddress: resolvedExtendedContractData.getCompleteAddress(), diff --git a/yarn-project/aztec.js/src/contract/contract.ts b/yarn-project/aztec.js/src/contract/contract.ts index 640c0d47d19..a6e47552129 100644 --- a/yarn-project/aztec.js/src/contract/contract.ts +++ b/yarn-project/aztec.js/src/contract/contract.ts @@ -10,7 +10,7 @@ import { ContractBase } from './contract_base.js'; * The Contract class represents a contract and provides utility methods for interacting with it. * It enables the creation of ContractFunctionInteraction instances for each function in the contract's ABI, * allowing users to call or send transactions to these functions. Additionally, the Contract class can be used - * to attach the contract instance to a deployed contract on-chain through the AztecRPCClient, which facilitates + * to attach the contract instance to a deployed contract on-chain through the PXEClient, which facilitates * interaction with Aztec's privacy protocol. */ export class Contract extends ContractBase { diff --git a/yarn-project/aztec.js/src/contract/contract_base.ts b/yarn-project/aztec.js/src/contract/contract_base.ts index 8062d178569..451e4b47185 100644 --- a/yarn-project/aztec.js/src/contract/contract_base.ts +++ b/yarn-project/aztec.js/src/contract/contract_base.ts @@ -74,12 +74,12 @@ export class ContractBase { /** * Attach the current contract instance to a portal contract and optionally add its dependencies. - * The function will return a promise that resolves when all contracts have been added to the AztecRPCClient. + * The function will return a promise that resolves when all contracts have been added to the PXEClient. * This is useful when you need to interact with a deployed contract that has multiple nested contracts. * * @param portalContract - The Ethereum address of the portal contract. * @param dependencies - An optional array of additional DeployedContract instances to be attached. - * @returns A promise that resolves when all contracts are successfully added to the AztecRPCClient. + * @returns A promise that resolves when all contracts are successfully added to the PXEClient. */ public attach(portalContract: EthAddress, dependencies: DeployedContract[] = []) { const deployedContract: DeployedContract = { diff --git a/yarn-project/aztec.js/src/contract/sent_tx.test.ts b/yarn-project/aztec.js/src/contract/sent_tx.test.ts index e3bef6b7216..a1f4e72c192 100644 --- a/yarn-project/aztec.js/src/contract/sent_tx.test.ts +++ b/yarn-project/aztec.js/src/contract/sent_tx.test.ts @@ -1,11 +1,11 @@ -import { AztecRPC, TxHash, TxReceipt, TxStatus } from '@aztec/types'; +import { PXE, TxHash, TxReceipt, TxStatus } from '@aztec/types'; import { MockProxy, mock } from 'jest-mock-extended'; import { SentTx } from './sent_tx.js'; describe('SentTx', () => { - let rpc: MockProxy; + let rpc: MockProxy; let txHashPromise: Promise; let sentTx: SentTx; diff --git a/yarn-project/aztec.js/src/contract/sent_tx.ts b/yarn-project/aztec.js/src/contract/sent_tx.ts index 1ef7f506a3c..4e3eedcb236 100644 --- a/yarn-project/aztec.js/src/contract/sent_tx.ts +++ b/yarn-project/aztec.js/src/contract/sent_tx.ts @@ -1,6 +1,6 @@ import { FieldsOf } from '@aztec/circuits.js'; import { retryUntil } from '@aztec/foundation/retry'; -import { AztecRPC, TxHash, TxReceipt, TxStatus } from '@aztec/types'; +import { PXE, TxHash, TxReceipt, TxStatus } from '@aztec/types'; import every from 'lodash.every'; @@ -24,11 +24,11 @@ const DefaultWaitOpts: WaitOpts = { }; /** - * The SentTx class represents a sent transaction through the AztecRPCClient, providing methods to fetch + * The SentTx class represents a sent transaction through the PXEClient, providing methods to fetch * its hash, receipt, and mining status. */ export class SentTx { - constructor(protected arc: AztecRPC, protected txHashPromise: Promise) {} + constructor(protected arc: PXE, protected txHashPromise: Promise) {} /** * Retrieves the transaction hash of the SentTx instance. @@ -43,7 +43,7 @@ export class SentTx { /** * Retrieve the transaction receipt associated with the current SentTx instance. * The function fetches the transaction hash using 'getTxHash' and then queries - * the AztecRPCClient to get the corresponding transaction receipt. + * the PXEClient to get the corresponding transaction receipt. * * @returns A promise that resolves to a TxReceipt object representing the fetched transaction receipt. */ diff --git a/yarn-project/aztec.js/src/contract_deployer/contract_deployer.test.ts b/yarn-project/aztec.js/src/contract_deployer/contract_deployer.test.ts index 36e2d8b5bac..8a3b4d1be7e 100644 --- a/yarn-project/aztec.js/src/contract_deployer/contract_deployer.test.ts +++ b/yarn-project/aztec.js/src/contract_deployer/contract_deployer.test.ts @@ -1,13 +1,13 @@ import { EthAddress, Fr, Point } from '@aztec/circuits.js'; import { ContractAbi, FunctionType } from '@aztec/foundation/abi'; -import { AztecRPC, PublicKey, Tx, TxHash, TxReceipt } from '@aztec/types'; +import { PXE, PublicKey, Tx, TxHash, TxReceipt } from '@aztec/types'; import { MockProxy, mock } from 'jest-mock-extended'; import { ContractDeployer } from './contract_deployer.js'; describe.skip('Contract Deployer', () => { - let arc: MockProxy; + let arc: MockProxy; const abi: ContractAbi = { name: 'MyContract', @@ -33,7 +33,7 @@ describe.skip('Contract Deployer', () => { const mockTxReceipt = { type: 'TxReceipt' } as any as TxReceipt; beforeEach(() => { - arc = mock(); + arc = mock(); arc.sendTx.mockResolvedValue(mockTxHash); arc.getTxReceipt.mockResolvedValue(mockTxReceipt); }); diff --git a/yarn-project/aztec.js/src/contract_deployer/contract_deployer.ts b/yarn-project/aztec.js/src/contract_deployer/contract_deployer.ts index c01f4490025..b195e1da9f8 100644 --- a/yarn-project/aztec.js/src/contract_deployer/contract_deployer.ts +++ b/yarn-project/aztec.js/src/contract_deployer/contract_deployer.ts @@ -1,6 +1,6 @@ import { Point } from '@aztec/circuits.js'; import { ContractAbi } from '@aztec/foundation/abi'; -import { AztecRPC, PublicKey } from '@aztec/types'; +import { PXE, PublicKey } from '@aztec/types'; import { DeployMethod } from './deploy_method.js'; @@ -9,7 +9,7 @@ import { DeployMethod } from './deploy_method.js'; * @remarks Keeping this around even though we have Aztec.nr contract types because it can be useful for non-TS users. */ export class ContractDeployer { - constructor(private abi: ContractAbi, private arc: AztecRPC, private publicKey?: PublicKey) {} + constructor(private abi: ContractAbi, private arc: PXE, private publicKey?: PublicKey) {} /** * Deploy a contract using the provided ABI and constructor arguments. @@ -18,7 +18,7 @@ export class ContractDeployer { * be passed to the contract's constructor during deployment. * * @param args - The constructor arguments for the contract being deployed. - * @returns A DeployMethod instance configured with the ABI, AztecRPCClient, and constructor arguments. + * @returns A DeployMethod instance configured with the ABI, PXEClient, and constructor arguments. */ public deploy(...args: any[]) { return new DeployMethod(this.publicKey ?? Point.ZERO, this.arc, this.abi, args); diff --git a/yarn-project/aztec.js/src/contract_deployer/deploy_method.ts b/yarn-project/aztec.js/src/contract_deployer/deploy_method.ts index b10c6df43fc..1353d121f43 100644 --- a/yarn-project/aztec.js/src/contract_deployer/deploy_method.ts +++ b/yarn-project/aztec.js/src/contract_deployer/deploy_method.ts @@ -8,7 +8,7 @@ import { import { ContractAbi, FunctionAbi, encodeArguments } from '@aztec/foundation/abi'; import { EthAddress } from '@aztec/foundation/eth-address'; import { Fr } from '@aztec/foundation/fields'; -import { AztecRPC, PackedArguments, PublicKey, Tx, TxExecutionRequest } from '@aztec/types'; +import { PXE, PackedArguments, PublicKey, Tx, TxExecutionRequest } from '@aztec/types'; import { BaseContractInteraction } from '../contract/base_contract_interaction.js'; import { Contract, ContractBase, SendMethodOptions } from '../contract/index.js'; @@ -40,7 +40,7 @@ export class DeployMethod extends Bas /** Constructor function to call. */ private constructorAbi: FunctionAbi; - constructor(private publicKey: PublicKey, private arc: AztecRPC, private abi: ContractAbi, private args: any[] = []) { + constructor(private publicKey: PublicKey, private arc: PXE, private abi: ContractAbi, private args: any[] = []) { super(arc); const constructorAbi = abi.functions.find(f => f.name === 'constructor'); if (!constructorAbi) throw new Error('Cannot find constructor in the ABI.'); diff --git a/yarn-project/aztec.js/src/contract_deployer/deploy_sent_tx.ts b/yarn-project/aztec.js/src/contract_deployer/deploy_sent_tx.ts index d6078190258..f40cc63232f 100644 --- a/yarn-project/aztec.js/src/contract_deployer/deploy_sent_tx.ts +++ b/yarn-project/aztec.js/src/contract_deployer/deploy_sent_tx.ts @@ -2,7 +2,7 @@ import { FieldsOf } from '@aztec/circuits.js'; import { ContractAbi } from '@aztec/foundation/abi'; import { TxHash, TxReceipt } from '@aztec/types'; -import { AztecAddress, AztecRPC, Contract, ContractBase, SentTx, WaitOpts, Wallet } from '../index.js'; +import { AztecAddress, Contract, ContractBase, PXE, SentTx, WaitOpts, Wallet } from '../index.js'; /** Options related to waiting for a deployment tx. */ export type DeployedWaitOpts = WaitOpts & { @@ -20,7 +20,7 @@ export type DeployTxReceipt = FieldsO * A contract deployment transaction sent to the network, extending SentTx with methods to create a contract instance. */ export class DeploySentTx extends SentTx { - constructor(private abi: ContractAbi, wallet: AztecRPC | Wallet, txHashPromise: Promise) { + constructor(private abi: ContractAbi, wallet: PXE | Wallet, txHashPromise: Promise) { super(wallet, txHashPromise); } @@ -46,7 +46,7 @@ export class DeploySentTx extends Sen } protected getContractInstance(wallet?: Wallet, address?: AztecAddress): Promise { - const isWallet = (rpc: AztecRPC | Wallet): rpc is Wallet => !!(rpc as Wallet).createTxExecutionRequest; + const isWallet = (rpc: PXE | Wallet): rpc is Wallet => !!(rpc as Wallet).createTxExecutionRequest; const contractWallet = wallet ?? (isWallet(this.arc) && this.arc); if (!contractWallet) throw new Error(`A wallet is required for creating a contract instance`); if (!address) throw new Error(`Contract address is missing from transaction receipt`); diff --git a/yarn-project/aztec.js/src/index.ts b/yarn-project/aztec.js/src/index.ts index 85f2a9ee9af..f4706d11bfa 100644 --- a/yarn-project/aztec.js/src/index.ts +++ b/yarn-project/aztec.js/src/index.ts @@ -1,7 +1,7 @@ export * from './contract/index.js'; export * from './contract_deployer/index.js'; export * from './utils/index.js'; -export * from './aztec_rpc_client.js'; +export * from './pxe_client.js'; export * from './account/index.js'; export * from './contract_deployer/deploy_method.js'; export * from './sandbox/index.js'; @@ -9,7 +9,7 @@ export * from './wallet/index.js'; export { AztecAddress, EthAddress, Point, Fr, GrumpkinScalar } from '@aztec/circuits.js'; export { - AztecRPC, + PXE, ContractData, ExtendedContractData as ExtendedContractData, DeployedContract, diff --git a/yarn-project/aztec.js/src/aztec_rpc_client.ts b/yarn-project/aztec.js/src/pxe_client.ts similarity index 84% rename from yarn-project/aztec.js/src/aztec_rpc_client.ts rename to yarn-project/aztec.js/src/pxe_client.ts index 511ed931282..0514626c1a9 100644 --- a/yarn-project/aztec.js/src/aztec_rpc_client.ts +++ b/yarn-project/aztec.js/src/pxe_client.ts @@ -2,12 +2,12 @@ import { AztecAddress, CompleteAddress, EthAddress, Fr, GrumpkinScalar, Point } import { createJsonRpcClient, makeFetch } from '@aztec/foundation/json-rpc/client'; import { AuthWitness, - AztecRPC, ContractData, ExtendedContractData, L2BlockL2Logs, L2Tx, NotePreimage, + PXE, Tx, TxExecutionRequest, TxHash, @@ -16,8 +16,8 @@ import { export { makeFetch } from '@aztec/foundation/json-rpc/client'; -export const createAztecRpcClient = (url: string, fetch = makeFetch([1, 2, 3], true)): AztecRPC => - createJsonRpcClient( +export const createPXEClient = (url: string, fetch = makeFetch([1, 2, 3], true)): PXE => + createJsonRpcClient( url, { CompleteAddress, diff --git a/yarn-project/aztec.js/src/sandbox/index.ts b/yarn-project/aztec.js/src/sandbox/index.ts index 2dd17107819..2d9fea54564 100644 --- a/yarn-project/aztec.js/src/sandbox/index.ts +++ b/yarn-project/aztec.js/src/sandbox/index.ts @@ -4,7 +4,7 @@ import { sleep } from '@aztec/foundation/sleep'; import zip from 'lodash.zip'; import SchnorrAccountContractAbi from '../abis/schnorr_account_contract.json' assert { type: 'json' }; -import { AccountWallet, AztecRPC, createAztecRpcClient, getSchnorrAccount } from '../index.js'; +import { AccountWallet, PXE, createPXEClient, getSchnorrAccount } from '../index.js'; export const INITIAL_SANDBOX_ENCRYPTION_KEYS = [ GrumpkinScalar.fromString('2153536ff6628eee01cf4024889ff977a18d9fa61d0e414422f7681cf085c281'), @@ -22,10 +22,10 @@ export const { SANDBOX_URL = 'http://localhost:8080' } = process.env; /** * Gets a collection of wallets for the Aztec accounts that are initially stored in the sandbox. - * @param aztecRpc - An instance of the Aztec RPC interface. + * @param aztecRpc - A PXE instance.PXE * @returns A set of AccountWallet implementations for each of the initial accounts. */ -export function getSandboxAccountsWallets(aztecRpc: AztecRPC): Promise { +export function getSandboxAccountsWallets(aztecRpc: PXE): Promise { return Promise.all( zip(INITIAL_SANDBOX_ENCRYPTION_KEYS, INITIAL_SANDBOX_SIGNING_KEYS, INITIAL_SANDBOX_SALTS).map( ([encryptionKey, signingKey, salt]) => getSchnorrAccount(aztecRpc, encryptionKey!, signingKey!, salt).getWallet(), @@ -35,10 +35,10 @@ export function getSandboxAccountsWallets(aztecRpc: AztecRPC): Promise { const account = getSchnorrAccount(aztecRpc, privateKey, INITIAL_SANDBOX_SIGNING_KEYS[i], INITIAL_SANDBOX_SALTS[i]); return { @@ -72,8 +72,8 @@ export async function deployInitialSandboxAccounts(aztecRpc: AztecRPC) { * Function to wait until the sandbox becomes ready for use. * @param rpc - The rpc client connected to the sandbox. */ -export async function waitForSandbox(rpc?: AztecRPC) { - rpc = rpc ?? createAztecRpcClient(SANDBOX_URL); +export async function waitForSandbox(rpc?: PXE) { + rpc = rpc ?? createPXEClient(SANDBOX_URL); while (true) { try { await rpc.getNodeInfo(); diff --git a/yarn-project/aztec.js/src/utils/cheat_codes.ts b/yarn-project/aztec.js/src/utils/cheat_codes.ts index dc0dfee94fb..865aec75158 100644 --- a/yarn-project/aztec.js/src/utils/cheat_codes.ts +++ b/yarn-project/aztec.js/src/utils/cheat_codes.ts @@ -3,7 +3,7 @@ import { pedersenPlookupCommitInputs } from '@aztec/circuits.js/barretenberg'; import { toBigIntBE, toHex } from '@aztec/foundation/bigint-buffer'; import { keccak } from '@aztec/foundation/crypto'; import { createDebugLogger } from '@aztec/foundation/log'; -import { AztecRPC, NotePreimage } from '@aztec/types'; +import { NotePreimage, PXE } from '@aztec/types'; import fs from 'fs'; @@ -22,7 +22,7 @@ export class CheatCodes { public aztec: AztecCheatCodes, ) {} - static async create(rpcUrl: string, aztecRpc: AztecRPC): Promise { + static async create(rpcUrl: string, aztecRpc: PXE): Promise { const ethCheatCodes = new EthCheatCodes(rpcUrl); const aztecCheatCodes = new AztecCheatCodes(aztecRpc, await CircuitsWasm.get(), ethCheatCodes); return new CheatCodes(ethCheatCodes, aztecCheatCodes); @@ -211,7 +211,7 @@ export class AztecCheatCodes { /** * The RPC client to use for interacting with the chain */ - public aztecRpc: AztecRPC, + public aztecRpc: PXE, /** * The circuits wasm module used for pedersen hashing */ diff --git a/yarn-project/aztec.js/src/utils/l2_contracts.ts b/yarn-project/aztec.js/src/utils/l2_contracts.ts index b15e5dd3c06..3f570597629 100644 --- a/yarn-project/aztec.js/src/utils/l2_contracts.ts +++ b/yarn-project/aztec.js/src/utils/l2_contracts.ts @@ -1,12 +1,12 @@ import { AztecAddress } from '@aztec/foundation/aztec-address'; -import { AztecRPC } from '@aztec/types'; +import { PXE } from '@aztec/types'; /** * Checks whether a give contract is deployed on the network. - * @param aztecRpcClient - The aztec rpc client to use to obtain the information. + * @param aztecRpcClient - The PXE client to use to obtain the information. * @param contractAddress - The address of the contract to check. * @returns A flag indicating whether the contract is deployed. */ -export async function isContractDeployed(aztecRpcClient: AztecRPC, contractAddress: AztecAddress): Promise { +export async function isContractDeployed(aztecRpcClient: PXE, contractAddress: AztecAddress): Promise { return !!(await aztecRpcClient.getContractData(contractAddress)); } diff --git a/yarn-project/aztec.js/src/wallet/account_wallet.ts b/yarn-project/aztec.js/src/wallet/account_wallet.ts index de4902b1c84..d5888de9753 100644 --- a/yarn-project/aztec.js/src/wallet/account_wallet.ts +++ b/yarn-project/aztec.js/src/wallet/account_wallet.ts @@ -1,6 +1,6 @@ import { Fr } from '@aztec/circuits.js'; import { ABIParameterVisibility, FunctionAbiHeader, FunctionType } from '@aztec/foundation/abi'; -import { AuthWitness, AztecRPC, FunctionCall, TxExecutionRequest } from '@aztec/types'; +import { AuthWitness, FunctionCall, PXE, TxExecutionRequest } from '@aztec/types'; import { AccountInterface } from '../account/interface.js'; import { ContractFunctionInteraction } from '../index.js'; @@ -10,7 +10,7 @@ import { BaseWallet } from './base_wallet.js'; * A wallet implementation that forwards authentication requests to a provided account. */ export class AccountWallet extends BaseWallet { - constructor(rpc: AztecRPC, protected account: AccountInterface) { + constructor(rpc: PXE, protected account: AccountInterface) { super(rpc); } diff --git a/yarn-project/aztec.js/src/wallet/base_wallet.ts b/yarn-project/aztec.js/src/wallet/base_wallet.ts index fe17337651f..f81a99f96bb 100644 --- a/yarn-project/aztec.js/src/wallet/base_wallet.ts +++ b/yarn-project/aztec.js/src/wallet/base_wallet.ts @@ -1,7 +1,6 @@ import { AztecAddress, Fr, GrumpkinPrivateKey, PartialAddress, Point } from '@aztec/circuits.js'; import { AuthWitness, - AztecRPC, ContractData, DeployedContract, ExtendedContractData, @@ -10,6 +9,7 @@ import { L2Tx, NodeInfo, NotePreimage, + PXE, SyncStatus, Tx, TxExecutionRequest, @@ -24,7 +24,7 @@ import { Wallet } from './index.js'; * A base class for Wallet implementations */ export abstract class BaseWallet implements Wallet { - constructor(protected readonly rpc: AztecRPC) {} + constructor(protected readonly rpc: PXE) {} abstract getCompleteAddress(): CompleteAddress; diff --git a/yarn-project/aztec.js/src/wallet/index.ts b/yarn-project/aztec.js/src/wallet/index.ts index d1cab61cc62..fa43fcb1a97 100644 --- a/yarn-project/aztec.js/src/wallet/index.ts +++ b/yarn-project/aztec.js/src/wallet/index.ts @@ -1,4 +1,4 @@ -import { AccountInterface, AztecRPC } from '../index.js'; +import { AccountInterface, PXE } from '../index.js'; export * from './base_wallet.js'; export * from './account_wallet.js'; @@ -7,4 +7,4 @@ export * from './signerless_wallet.js'; /** * The wallet interface. */ -export type Wallet = AccountInterface & AztecRPC; +export type Wallet = AccountInterface & PXE; diff --git a/yarn-project/boxes/blank-react/docker-compose.yml b/yarn-project/boxes/blank-react/docker-compose.yml index 082455b5d38..2417ca77775 100644 --- a/yarn-project/boxes/blank-react/docker-compose.yml +++ b/yarn-project/boxes/blank-react/docker-compose.yml @@ -19,7 +19,7 @@ services: P2P_BLOCK_CHECK_INTERVAL_MS: 50 SEQ_TX_POLLING_INTERVAL_MS: 50 WS_BLOCK_CHECK_INTERVAL_MS: 50 - RPC_SERVER_BLOCK_POLLING_INTERVAL_MS: 50 + PXE_SERVICE_BLOCK_POLLING_INTERVAL_MS: 50 ARCHIVER_VIEM_POLLING_INTERVAL_MS: 500 volumes: - ./log:/usr/src/yarn-project/aztec-sandbox/log:rw diff --git a/yarn-project/boxes/blank-react/src/artifacts/blank.ts b/yarn-project/boxes/blank-react/src/artifacts/blank.ts index ce41cd8e217..fdf14283c3e 100644 --- a/yarn-project/boxes/blank-react/src/artifacts/blank.ts +++ b/yarn-project/boxes/blank-react/src/artifacts/blank.ts @@ -13,7 +13,7 @@ import { } from '@aztec/aztec.js'; import { ContractAbi } from '@aztec/foundation/abi'; import { Point } from '@aztec/foundation/fields'; -import { AztecRPC, PublicKey } from '@aztec/types'; +import { PXE, PublicKey } from '@aztec/types'; import BlankContractAbiJson from './blank_contract.json' assert { type: 'json' }; @@ -54,14 +54,14 @@ export class BlankContract extends ContractBase { /** * Creates a tx to deploy a new instance of this contract. */ - public static deploy(rpc: AztecRPC) { + public static deploy(rpc: PXE) { return new DeployMethod(Point.ZERO, rpc, BlankContractAbi, Array.from(arguments).slice(1)); } /** * Creates a tx to deploy a new instance of this contract using the specified public key to derive the address. */ - public static deployWithPublicKey(rpc: AztecRPC, publicKey: PublicKey) { + public static deployWithPublicKey(rpc: PXE, publicKey: PublicKey) { return new DeployMethod(publicKey, rpc, BlankContractAbi, Array.from(arguments).slice(2)); } diff --git a/yarn-project/boxes/blank-react/src/config.ts b/yarn-project/boxes/blank-react/src/config.ts index ad3ac03c902..79ce241a04b 100644 --- a/yarn-project/boxes/blank-react/src/config.ts +++ b/yarn-project/boxes/blank-react/src/config.ts @@ -1,5 +1,5 @@ import { BlankContractAbi } from './artifacts/blank.js'; -import { AztecRPC, createAztecRpcClient } from '@aztec/aztec.js'; +import { PXE, createPXEClient } from '@aztec/aztec.js'; import { ContractAbi } from '@aztec/foundation/abi'; // update this if using a different contract @@ -7,7 +7,7 @@ import { ContractAbi } from '@aztec/foundation/abi'; export const contractAbi: ContractAbi = BlankContractAbi; export const SANDBOX_URL: string = process.env.SANDBOX_URL || 'http://localhost:8080'; -export const rpcClient: AztecRPC = createAztecRpcClient(SANDBOX_URL); +export const rpcClient: PXE = createPXEClient(SANDBOX_URL); export const CONTRACT_ADDRESS_PARAM_NAMES = ['address']; export const FILTERED_FUNCTION_NAMES = []; diff --git a/yarn-project/boxes/blank-react/src/scripts/call_contract_function.ts b/yarn-project/boxes/blank-react/src/scripts/call_contract_function.ts index dbc4d87e6fd..1c324bf5a40 100644 --- a/yarn-project/boxes/blank-react/src/scripts/call_contract_function.ts +++ b/yarn-project/boxes/blank-react/src/scripts/call_contract_function.ts @@ -1,4 +1,4 @@ -import { AztecAddress, AztecRPC, CompleteAddress, Contract, TxReceipt } from '@aztec/aztec.js'; +import { AztecAddress, PXE, CompleteAddress, Contract, TxReceipt } from '@aztec/aztec.js'; import { ContractAbi } from '@aztec/foundation/abi'; import { FieldsOf } from '@aztec/foundation/types'; import { getWallet } from './util.js'; @@ -8,7 +8,7 @@ export async function callContractFunction( abi: ContractAbi, functionName: string, typedArgs: any[], // for the exposed functions, this is an array of field elements Fr[] - rpc: AztecRPC, + rpc: PXE, wallet: CompleteAddress, ): Promise> { // selectedWallet is how we specify the "sender" of the transaction diff --git a/yarn-project/boxes/blank-react/src/scripts/deploy_contract.ts b/yarn-project/boxes/blank-react/src/scripts/deploy_contract.ts index 2285937d2e1..36a9e9c300b 100644 --- a/yarn-project/boxes/blank-react/src/scripts/deploy_contract.ts +++ b/yarn-project/boxes/blank-react/src/scripts/deploy_contract.ts @@ -1,13 +1,13 @@ import { AztecAddress, CompleteAddress, DeployMethod, Fr } from '@aztec/aztec.js'; import { ContractAbi } from '@aztec/foundation/abi'; -import { AztecRPC } from '@aztec/types'; +import { PXE } from '@aztec/types'; export async function deployContract( activeWallet: CompleteAddress, contractAbi: ContractAbi, typedArgs: Fr[], // encode prior to passing in salt: Fr, - client: AztecRPC, + client: PXE, ): Promise { const tx = new DeployMethod(activeWallet.publicKey, client, contractAbi, typedArgs).send({ contractAddressSalt: salt, diff --git a/yarn-project/boxes/blank-react/src/scripts/util.ts b/yarn-project/boxes/blank-react/src/scripts/util.ts index cadf2d05afa..8c61a1d3b57 100644 --- a/yarn-project/boxes/blank-react/src/scripts/util.ts +++ b/yarn-project/boxes/blank-react/src/scripts/util.ts @@ -1,6 +1,6 @@ import { AccountWallet, Fr, getSandboxAccountsWallets } from '@aztec/aztec.js'; import { FunctionAbi, encodeArguments } from '@aztec/foundation/abi'; -import { AztecRPC, CompleteAddress } from '@aztec/types'; +import { PXE, CompleteAddress } from '@aztec/types'; export function convertArgs(functionAbi: FunctionAbi, args: any): Fr[] { const untypedArgs = functionAbi.parameters.map(param => { @@ -26,7 +26,7 @@ export function convertArgs(functionAbi: FunctionAbi, args: any): Fr[] { * @param rpc * @returns */ -export async function getWallet(account: CompleteAddress, rpc: AztecRPC): Promise { +export async function getWallet(account: CompleteAddress, rpc: PXE): Promise { const accountWallets: AccountWallet[] = await getSandboxAccountsWallets(rpc); const selectedWallet: AccountWallet = accountWallets.find(w => w.getAddress().equals(account.address))!; if (!selectedWallet) { diff --git a/yarn-project/boxes/blank-react/src/scripts/view_contract_function.ts b/yarn-project/boxes/blank-react/src/scripts/view_contract_function.ts index 8c6d966861a..aa02bc916f6 100644 --- a/yarn-project/boxes/blank-react/src/scripts/view_contract_function.ts +++ b/yarn-project/boxes/blank-react/src/scripts/view_contract_function.ts @@ -1,5 +1,5 @@ import { getWallet } from './util.js'; -import { AztecAddress, AztecRPC, CompleteAddress, Contract } from '@aztec/aztec.js'; +import { AztecAddress, PXE, CompleteAddress, Contract } from '@aztec/aztec.js'; import { ContractAbi } from '@aztec/foundation/abi'; export async function viewContractFunction( @@ -7,7 +7,7 @@ export async function viewContractFunction( abi: ContractAbi, functionName: string, typedArgs: any[], - rpc: AztecRPC, + rpc: PXE, wallet: CompleteAddress, ) { // we specify the account that is calling the view function by passing in the wallet to the Contract diff --git a/yarn-project/boxes/blank-react/src/tests/blank.contract.test.ts b/yarn-project/boxes/blank-react/src/tests/blank.contract.test.ts index fd75a97b07d..a221f195ae3 100644 --- a/yarn-project/boxes/blank-react/src/tests/blank.contract.test.ts +++ b/yarn-project/boxes/blank-react/src/tests/blank.contract.test.ts @@ -3,13 +3,13 @@ import { callContractFunction, deployContract, getWallet } from '../scripts/inde import { AccountWallet, AztecAddress, - AztecRPC, + PXE, CompleteAddress, Contract, Fr, TxStatus, Wallet, - createAztecRpcClient, + createPXEClient, waitForSandbox, } from '@aztec/aztec.js'; import { createDebugLogger } from '@aztec/foundation/log'; @@ -20,13 +20,13 @@ const logger = createDebugLogger('aztec:http-rpc-client'); // as well as anvil. anvil can be started with yarn test:integration const setupSandbox = async () => { const { SANDBOX_URL = 'http://localhost:8080' } = process.env; - const aztecRpc = createAztecRpcClient(SANDBOX_URL); + const aztecRpc = createPXEClient(SANDBOX_URL); await waitForSandbox(aztecRpc); return aztecRpc; }; -async function deployZKContract(owner: CompleteAddress, wallet: Wallet, rpcClient: AztecRPC) { +async function deployZKContract(owner: CompleteAddress, wallet: Wallet, rpcClient: PXE) { logger('Deploying Blank contract...'); const contractAddress = await deployContract(owner, BlankContract.abi, [], Fr.random(), rpcClient); @@ -41,7 +41,7 @@ describe('ZK Contract Tests', () => { let _account3: CompleteAddress; let contract: Contract; let contractAddress: AztecAddress; - let rpcClient: AztecRPC; + let rpcClient: PXE; beforeAll(async () => { rpcClient = await setupSandbox(); diff --git a/yarn-project/boxes/blank/docker-compose.yml b/yarn-project/boxes/blank/docker-compose.yml index a4a84bbb4da..923aed602d3 100644 --- a/yarn-project/boxes/blank/docker-compose.yml +++ b/yarn-project/boxes/blank/docker-compose.yml @@ -19,7 +19,7 @@ services: P2P_BLOCK_CHECK_INTERVAL_MS: 50 SEQ_TX_POLLING_INTERVAL_MS: 50 WS_BLOCK_CHECK_INTERVAL_MS: 50 - RPC_SERVER_BLOCK_POLLING_INTERVAL_MS: 50 + PXE_SERVICE_BLOCK_POLLING_INTERVAL_MS: 50 ARCHIVER_VIEM_POLLING_INTERVAL_MS: 500 volumes: - ./log:/usr/src/yarn-project/aztec-sandbox/log:rw diff --git a/yarn-project/boxes/blank/src/artifacts/blank.ts b/yarn-project/boxes/blank/src/artifacts/blank.ts index ce41cd8e217..fdf14283c3e 100644 --- a/yarn-project/boxes/blank/src/artifacts/blank.ts +++ b/yarn-project/boxes/blank/src/artifacts/blank.ts @@ -13,7 +13,7 @@ import { } from '@aztec/aztec.js'; import { ContractAbi } from '@aztec/foundation/abi'; import { Point } from '@aztec/foundation/fields'; -import { AztecRPC, PublicKey } from '@aztec/types'; +import { PXE, PublicKey } from '@aztec/types'; import BlankContractAbiJson from './blank_contract.json' assert { type: 'json' }; @@ -54,14 +54,14 @@ export class BlankContract extends ContractBase { /** * Creates a tx to deploy a new instance of this contract. */ - public static deploy(rpc: AztecRPC) { + public static deploy(rpc: PXE) { return new DeployMethod(Point.ZERO, rpc, BlankContractAbi, Array.from(arguments).slice(1)); } /** * Creates a tx to deploy a new instance of this contract using the specified public key to derive the address. */ - public static deployWithPublicKey(rpc: AztecRPC, publicKey: PublicKey) { + public static deployWithPublicKey(rpc: PXE, publicKey: PublicKey) { return new DeployMethod(publicKey, rpc, BlankContractAbi, Array.from(arguments).slice(2)); } diff --git a/yarn-project/boxes/blank/src/index.ts b/yarn-project/boxes/blank/src/index.ts index a3bde8b5c11..e90dc9cb330 100644 --- a/yarn-project/boxes/blank/src/index.ts +++ b/yarn-project/boxes/blank/src/index.ts @@ -1,13 +1,13 @@ import { AccountWallet, AztecAddress, - AztecRPC, + PXE, CompleteAddress, Contract, DeployMethod, Fr, TxReceipt, - createAztecRpcClient, + createPXEClient, getSandboxAccountsWallets, } from '@aztec/aztec.js'; import { ContractAbi, FunctionAbi, encodeArguments } from '@aztec/foundation/abi'; @@ -16,7 +16,7 @@ import { BlankContractAbi } from './artifacts/blank.js'; export const contractAbi: ContractAbi = BlankContractAbi; export const SANDBOX_URL: string = process.env.SANDBOX_URL || 'http://localhost:8080'; -export const rpcClient: AztecRPC = createAztecRpcClient(SANDBOX_URL); +export const rpcClient: PXE = createPXEClient(SANDBOX_URL); export const CONTRACT_ADDRESS_PARAM_NAMES = ['owner', 'contract_address', 'recipient']; export const FILTERED_FUNCTION_NAMES = []; @@ -81,7 +81,7 @@ export async function callContractFunction( abi: ContractAbi, functionName: string, typedArgs: any[], // for the exposed functions, this is an array of field elements Fr[] - rpc: AztecRPC, + rpc: PXE, wallet: CompleteAddress, ): Promise> { // selectedWallet is how we specify the "sender" of the transaction @@ -103,7 +103,7 @@ export async function callContractFunction( * @param rpc * @returns */ -export async function getWallet(account: CompleteAddress, rpc: AztecRPC): Promise { +export async function getWallet(account: CompleteAddress, rpc: PXE): Promise { const accountWallets: AccountWallet[] = await getSandboxAccountsWallets(rpc); const selectedWallet: AccountWallet = accountWallets.find(w => w.getAddress().equals(account.address))!; if (!selectedWallet) { @@ -117,7 +117,7 @@ export async function deployContract( contractAbi: ContractAbi, typedArgs: Fr[], // encode prior to passing in salt: Fr, - client: AztecRPC, + client: PXE, ): Promise { const tx = new DeployMethod(activeWallet.publicKey, client, contractAbi, typedArgs).send({ contractAddressSalt: salt, diff --git a/yarn-project/boxes/blank/src/tests/blank.contract.test.ts b/yarn-project/boxes/blank/src/tests/blank.contract.test.ts index 06dbe51ce95..95aae4ee183 100644 --- a/yarn-project/boxes/blank/src/tests/blank.contract.test.ts +++ b/yarn-project/boxes/blank/src/tests/blank.contract.test.ts @@ -1,13 +1,13 @@ import { AccountWallet, AztecAddress, - AztecRPC, + PXE, CompleteAddress, Contract, Fr, TxStatus, Wallet, - createAztecRpcClient, + createPXEClient, waitForSandbox, } from '@aztec/aztec.js'; import { createDebugLogger } from '@aztec/foundation/log'; @@ -19,12 +19,12 @@ const logger = createDebugLogger('aztec:blank-box-test'); // as well as anvil. anvil can be started with yarn test:integration const setupSandbox = async () => { const { SANDBOX_URL = 'http://localhost:8080' } = process.env; - const aztecRpc = createAztecRpcClient(SANDBOX_URL); + const aztecRpc = createPXEClient(SANDBOX_URL); await waitForSandbox(aztecRpc); return aztecRpc; }; -async function deployZKContract(owner: CompleteAddress, wallet: Wallet, rpcClient: AztecRPC) { +async function deployZKContract(owner: CompleteAddress, wallet: Wallet, rpcClient: PXE) { logger('Deploying Blank contract...'); const contractAddress = await deployContract(owner, BlankContract.abi, [], Fr.random(), rpcClient); @@ -39,7 +39,7 @@ describe('ZK Contract Tests', () => { let _account3: CompleteAddress; let contract: Contract; let contractAddress: AztecAddress; - let rpcClient: AztecRPC; + let rpcClient: PXE; beforeAll(async () => { rpcClient = await setupSandbox(); diff --git a/yarn-project/boxes/private-token/docker-compose.yml b/yarn-project/boxes/private-token/docker-compose.yml index 52a8d9f5814..997eed0992b 100644 --- a/yarn-project/boxes/private-token/docker-compose.yml +++ b/yarn-project/boxes/private-token/docker-compose.yml @@ -19,7 +19,7 @@ services: P2P_BLOCK_CHECK_INTERVAL_MS: 50 SEQ_TX_POLLING_INTERVAL_MS: 50 WS_BLOCK_CHECK_INTERVAL_MS: 50 - RPC_SERVER_BLOCK_POLLING_INTERVAL_MS: 50 + PXE_SERVICE_BLOCK_POLLING_INTERVAL_MS: 50 ARCHIVER_VIEM_POLLING_INTERVAL_MS: 500 volumes: - ./log:/usr/src/yarn-project/aztec-sandbox/log:rw diff --git a/yarn-project/boxes/private-token/src/artifacts/private_token.ts b/yarn-project/boxes/private-token/src/artifacts/private_token.ts index 16a0a5de990..ce103625cc1 100644 --- a/yarn-project/boxes/private-token/src/artifacts/private_token.ts +++ b/yarn-project/boxes/private-token/src/artifacts/private_token.ts @@ -13,7 +13,7 @@ import { } from '@aztec/aztec.js'; import { ContractAbi } from '@aztec/foundation/abi'; import { Point } from '@aztec/foundation/fields'; -import { AztecRPC, PublicKey } from '@aztec/types'; +import { PXE, PublicKey } from '@aztec/types'; import PrivateTokenContractAbiJson from './private_token_contract.json' assert { type: 'json' }; @@ -54,7 +54,7 @@ export class PrivateTokenContract extends ContractBase { /** * Creates a tx to deploy a new instance of this contract. */ - public static deploy(rpc: AztecRPC, initial_supply: FieldLike, owner: FieldLike) { + public static deploy(rpc: PXE, initial_supply: FieldLike, owner: FieldLike) { return new DeployMethod( Point.ZERO, rpc, @@ -66,7 +66,7 @@ export class PrivateTokenContract extends ContractBase { /** * Creates a tx to deploy a new instance of this contract using the specified public key to derive the address. */ - public static deployWithPublicKey(rpc: AztecRPC, publicKey: PublicKey, initial_supply: FieldLike, owner: FieldLike) { + public static deployWithPublicKey(rpc: PXE, publicKey: PublicKey, initial_supply: FieldLike, owner: FieldLike) { return new DeployMethod( publicKey, rpc, diff --git a/yarn-project/boxes/private-token/src/config.ts b/yarn-project/boxes/private-token/src/config.ts index d52df5238cb..7e999ea5dbd 100644 --- a/yarn-project/boxes/private-token/src/config.ts +++ b/yarn-project/boxes/private-token/src/config.ts @@ -1,11 +1,11 @@ -import { AztecRPC, createAztecRpcClient } from '@aztec/aztec.js'; +import { PXE, createPXEClient } from '@aztec/aztec.js'; import { ContractAbi } from '@aztec/foundation/abi'; import { PrivateTokenContractAbi } from './artifacts/private_token.js'; // update this if using a different contract export const contractAbi: ContractAbi = PrivateTokenContractAbi; export const SANDBOX_URL: string = process.env.SANDBOX_URL || 'http://localhost:8080'; -export const rpcClient: AztecRPC = createAztecRpcClient(SANDBOX_URL); +export const rpcClient: PXE = createPXEClient(SANDBOX_URL); export const CONTRACT_ADDRESS_PARAM_NAMES = ['owner', 'contract_address', 'recipient']; export const FILTERED_FUNCTION_NAMES = ['compute_note_hash_and_nullifier']; diff --git a/yarn-project/boxes/private-token/src/scripts/call_contract_function.ts b/yarn-project/boxes/private-token/src/scripts/call_contract_function.ts index 8b242a06456..bd0e52489c3 100644 --- a/yarn-project/boxes/private-token/src/scripts/call_contract_function.ts +++ b/yarn-project/boxes/private-token/src/scripts/call_contract_function.ts @@ -1,4 +1,4 @@ -import { AztecAddress, AztecRPC, CompleteAddress, Contract } from '@aztec/aztec.js'; +import { AztecAddress, PXE, CompleteAddress, Contract } from '@aztec/aztec.js'; import { ContractAbi } from '@aztec/foundation/abi'; import { getWallet } from './util.js'; @@ -7,7 +7,7 @@ export async function callContractFunction( abi: ContractAbi, functionName: string, typedArgs: any[], // for the exposed functions, this is an array of field elements Fr[] - rpc: AztecRPC, + rpc: PXE, wallet: CompleteAddress, ) { // selectedWallet is how we specify the "sender" of the transaction diff --git a/yarn-project/boxes/private-token/src/scripts/deploy_contract.ts b/yarn-project/boxes/private-token/src/scripts/deploy_contract.ts index 2285937d2e1..36a9e9c300b 100644 --- a/yarn-project/boxes/private-token/src/scripts/deploy_contract.ts +++ b/yarn-project/boxes/private-token/src/scripts/deploy_contract.ts @@ -1,13 +1,13 @@ import { AztecAddress, CompleteAddress, DeployMethod, Fr } from '@aztec/aztec.js'; import { ContractAbi } from '@aztec/foundation/abi'; -import { AztecRPC } from '@aztec/types'; +import { PXE } from '@aztec/types'; export async function deployContract( activeWallet: CompleteAddress, contractAbi: ContractAbi, typedArgs: Fr[], // encode prior to passing in salt: Fr, - client: AztecRPC, + client: PXE, ): Promise { const tx = new DeployMethod(activeWallet.publicKey, client, contractAbi, typedArgs).send({ contractAddressSalt: salt, diff --git a/yarn-project/boxes/private-token/src/scripts/util.ts b/yarn-project/boxes/private-token/src/scripts/util.ts index cadf2d05afa..8c61a1d3b57 100644 --- a/yarn-project/boxes/private-token/src/scripts/util.ts +++ b/yarn-project/boxes/private-token/src/scripts/util.ts @@ -1,6 +1,6 @@ import { AccountWallet, Fr, getSandboxAccountsWallets } from '@aztec/aztec.js'; import { FunctionAbi, encodeArguments } from '@aztec/foundation/abi'; -import { AztecRPC, CompleteAddress } from '@aztec/types'; +import { PXE, CompleteAddress } from '@aztec/types'; export function convertArgs(functionAbi: FunctionAbi, args: any): Fr[] { const untypedArgs = functionAbi.parameters.map(param => { @@ -26,7 +26,7 @@ export function convertArgs(functionAbi: FunctionAbi, args: any): Fr[] { * @param rpc * @returns */ -export async function getWallet(account: CompleteAddress, rpc: AztecRPC): Promise { +export async function getWallet(account: CompleteAddress, rpc: PXE): Promise { const accountWallets: AccountWallet[] = await getSandboxAccountsWallets(rpc); const selectedWallet: AccountWallet = accountWallets.find(w => w.getAddress().equals(account.address))!; if (!selectedWallet) { diff --git a/yarn-project/boxes/private-token/src/scripts/view_contract_function.ts b/yarn-project/boxes/private-token/src/scripts/view_contract_function.ts index e9adba3ecd1..b0417af71c9 100644 --- a/yarn-project/boxes/private-token/src/scripts/view_contract_function.ts +++ b/yarn-project/boxes/private-token/src/scripts/view_contract_function.ts @@ -1,4 +1,4 @@ -import { AztecAddress, AztecRPC, CompleteAddress, Contract } from '@aztec/aztec.js'; +import { AztecAddress, PXE, CompleteAddress, Contract } from '@aztec/aztec.js'; import { ContractAbi } from '@aztec/foundation/abi'; import { getWallet } from './util.js'; @@ -7,7 +7,7 @@ export async function viewContractFunction( abi: ContractAbi, functionName: string, typedArgs: any[], - rpc: AztecRPC, + rpc: PXE, wallet: CompleteAddress, ) { // we specify the account that is calling the view function by passing in the wallet to the Contract diff --git a/yarn-project/boxes/private-token/src/tests/privatetoken.sandbox.test.ts b/yarn-project/boxes/private-token/src/tests/privatetoken.sandbox.test.ts index 2e92e139dcd..7ba36aef571 100644 --- a/yarn-project/boxes/private-token/src/tests/privatetoken.sandbox.test.ts +++ b/yarn-project/boxes/private-token/src/tests/privatetoken.sandbox.test.ts @@ -1,12 +1,12 @@ import { AccountWallet, AztecAddress, - AztecRPC, + PXE, CompleteAddress, Contract, Fr, Wallet, - createAztecRpcClient, + createPXEClient, waitForSandbox, } from '@aztec/aztec.js'; import { createDebugLogger } from '@aztec/foundation/log'; @@ -24,12 +24,12 @@ const MINT_AMOUNT = 11n; // as well as anvil. anvil can be started with yarn test:integration const setupSandbox = async () => { const { SANDBOX_URL = 'http://localhost:8080' } = process.env; - const aztecRpc = createAztecRpcClient(SANDBOX_URL); + const aztecRpc = createPXEClient(SANDBOX_URL); await waitForSandbox(aztecRpc); return aztecRpc; }; -async function deployZKContract(owner: CompleteAddress, wallet: Wallet, rpcClient: AztecRPC) { +async function deployZKContract(owner: CompleteAddress, wallet: Wallet, rpcClient: PXE) { logger('Deploying PrivateToken contract...'); const typedArgs = [new Fr(INITIAL_BALANCE), owner.address.toField()]; @@ -83,7 +83,7 @@ describe('ZK Contract Tests', () => { let _account3: CompleteAddress; let privateTokenContract: Contract; let contractAddress: AztecAddress; - let rpcClient: AztecRPC; + let rpcClient: PXE; beforeAll(async () => { rpcClient = await setupSandbox(); diff --git a/yarn-project/canary/scripts/docker-compose-browser.yml b/yarn-project/canary/scripts/docker-compose-browser.yml index 04ab2d5c2fc..e7db3336acc 100644 --- a/yarn-project/canary/scripts/docker-compose-browser.yml +++ b/yarn-project/canary/scripts/docker-compose-browser.yml @@ -22,7 +22,7 @@ services: P2P_BLOCK_CHECK_INTERVAL_MS: 50 SEQ_TX_POLLING_INTERVAL_MS: 50 WS_BLOCK_CHECK_INTERVAL_MS: 50 - RPC_SERVER_BLOCK_POLLING_INTERVAL_MS: 50 + PXE_SERVICE_BLOCK_POLLING_INTERVAL_MS: 50 ARCHIVER_VIEM_POLLING_INTERVAL_MS: 500 SEARCH_START_BLOCK: ${FORK_BLOCK_NUMBER:-0} ports: diff --git a/yarn-project/canary/scripts/docker-compose-e2e-sandbox.yml b/yarn-project/canary/scripts/docker-compose-e2e-sandbox.yml index bd97f00d823..7f3d8162382 100644 --- a/yarn-project/canary/scripts/docker-compose-e2e-sandbox.yml +++ b/yarn-project/canary/scripts/docker-compose-e2e-sandbox.yml @@ -22,7 +22,7 @@ services: P2P_BLOCK_CHECK_INTERVAL_MS: 50 SEQ_TX_POLLING_INTERVAL_MS: 50 WS_BLOCK_CHECK_INTERVAL_MS: 50 - RPC_SERVER_BLOCK_POLLING_INTERVAL_MS: 50 + PXE_SERVICE_BLOCK_POLLING_INTERVAL_MS: 50 ARCHIVER_VIEM_POLLING_INTERVAL_MS: 500 SEARCH_START_BLOCK: ${FORK_BLOCK_NUMBER:-0} ports: diff --git a/yarn-project/canary/scripts/docker-compose.yml b/yarn-project/canary/scripts/docker-compose.yml index e22f63d3fb4..ccba483c3ac 100644 --- a/yarn-project/canary/scripts/docker-compose.yml +++ b/yarn-project/canary/scripts/docker-compose.yml @@ -22,7 +22,7 @@ services: P2P_BLOCK_CHECK_INTERVAL_MS: 50 SEQ_TX_POLLING_INTERVAL_MS: 50 WS_BLOCK_CHECK_INTERVAL_MS: 50 - RPC_SERVER_BLOCK_POLLING_INTERVAL_MS: 50 + PXE_SERVICE_BLOCK_POLLING_INTERVAL_MS: 50 ARCHIVER_VIEM_POLLING_INTERVAL_MS: 500 SEARCH_START_BLOCK: ${FORK_BLOCK_NUMBER:-0} ports: diff --git a/yarn-project/canary/src/cli.test.ts b/yarn-project/canary/src/cli.test.ts index 309dddca662..940df56870e 100644 --- a/yarn-project/canary/src/cli.test.ts +++ b/yarn-project/canary/src/cli.test.ts @@ -1,4 +1,4 @@ -import { createAztecRpcClient, createDebugLogger, makeFetch, waitForSandbox } from '@aztec/aztec.js'; +import { createDebugLogger, createPXEClient, makeFetch, waitForSandbox } from '@aztec/aztec.js'; import { cliTestSuite } from '@aztec/end-to-end'; const { SANDBOX_URL = 'http://localhost:8080' } = process.env; @@ -6,7 +6,7 @@ const { SANDBOX_URL = 'http://localhost:8080' } = process.env; const debug = createDebugLogger('aztec:canary_cli'); const setupRPC = async () => { - const aztecRpcClient = createAztecRpcClient(SANDBOX_URL, makeFetch([1, 2, 3, 4, 5], true)); + const aztecRpcClient = createPXEClient(SANDBOX_URL, makeFetch([1, 2, 3, 4, 5], true)); await waitForSandbox(aztecRpcClient); return aztecRpcClient; }; diff --git a/yarn-project/canary/src/uniswap_trade_on_l1_from_l2.test.ts b/yarn-project/canary/src/uniswap_trade_on_l1_from_l2.test.ts index 5bcd696168c..09e0d59dba2 100644 --- a/yarn-project/canary/src/uniswap_trade_on_l1_from_l2.test.ts +++ b/yarn-project/canary/src/uniswap_trade_on_l1_from_l2.test.ts @@ -5,8 +5,8 @@ import { TxStatus, Wallet, computeMessageSecretHash, - createAztecRpcClient, createDebugLogger, + createPXEClient, getL1ContractAddresses, getSandboxAccountsWallets, sleep, @@ -50,7 +50,7 @@ const ethRpcUrl = ETHEREUM_HOST; const hdAccount = mnemonicToAccount(MNEMONIC); -const aztecRpcClient = createAztecRpcClient(aztecRpcUrl); +const aztecRpcClient = createPXEClient(aztecRpcUrl); let wallet: Wallet; /** diff --git a/yarn-project/canary/src/utils.ts b/yarn-project/canary/src/utils.ts index 52868eee329..79a16bc8c8a 100644 --- a/yarn-project/canary/src/utils.ts +++ b/yarn-project/canary/src/utils.ts @@ -7,7 +7,7 @@ import { Account, Chain, Hex, HttpTransport, PublicClient, WalletClient, getCont /** * Deploy L1 token and portal, initialize portal, deploy a non native l2 token contract and attach is to the portal. - * @param aztecRpcServer - the aztec rpc server instance + * @param aztecRpcServer - Private Execution Environment (PXE) instance * @param walletClient - A viem WalletClient. * @param publicClient - A viem PublicClient. * @param rollupRegistryAddress - address of rollup registry to pass to initialize the token portal diff --git a/yarn-project/cli/README.md b/yarn-project/cli/README.md index 08bc07e5f0a..c9dd1adb0d3 100644 --- a/yarn-project/cli/README.md +++ b/yarn-project/cli/README.md @@ -43,14 +43,14 @@ These options are: - `PRIVATE_KEY` -> `-k, --private-key` for all commands that require a private key. - `PUBLIC_KEY` -> `-k, --public-key` for all commands that require a public key. -- `AZTEC_RPC_HOST` -> `-u, --rpc-url` for commands that require an Aztec RPC URL. +- `PXE_HOST` -> `-u, --rpc-url` for commands that require an PXE - `API_KEY` -> `a, --api-key` for `deploy-l1-contracts`. - `ETHEREUM_RPC_HOST` -> `-u, --rpc-url` for `deploy-l1-contracts`. -So if for example you are running your Aztec RPC server remotely you can do: +So if for example you are running your Private Execution Environment (PXE) remotely you can do: ```shell -export AZTEC_RPC_HOST=http://external.site/rpc:8080 +export PXE_HOST=http://external.site/rpc:8080 aztec-cli deploy my_contract.json ``` @@ -123,7 +123,7 @@ aztec-cli create-account [options] Options: - `-k, --private-key`: Private key to use for the account generation. Uses a random key by default. -- `-u, --rpc-url `: URL of the Aztec RPC. Default: `http://localhost:8080`. +- `-u, --rpc-url `: URL of the PXEult: `http://localhost:8080`. This command creates an Aztec account that can be used for transactions. It generates a new account with a private key or uses the provided private key. The command displays the account's address and public key. @@ -147,7 +147,7 @@ Options: - `-c, --contract-abi `: Path to the compiled Aztec.nr contract's ABI file in JSON format. You can also use one of Aztec's example contracts found in [@aztec/noir-contracts](https://www.npmjs.com/package/@aztec/noir-contracts), e.g. PrivateTokenContractAbi. You can get a full ist of the available contracts with `aztec-cli example-contracts` - `-a, --args ` (optional): Contract constructor arguments Default: []. -- `-u, --rpc-url `: URL of the Aztec RPC. Default: `http://localhost:8080`. +- `-u, --rpc-url `: URL of the PXEult: `http://localhost:8080`. - `-k, --public-key `: Public key of the deployer. If not provided, it will check the RPC for existing ones. This command deploys a compiled Aztec.nr contract to Aztec. It requires the path to the contract's ABI file in JSON format. Optionally, you can specify the public key of the deployer and provide constructor arguments for the contract. The command displays the address of the deployed contract. @@ -177,7 +177,7 @@ aztec-cli check-deploy [options] Options: - `-ca, --contract-address
`: An Aztec address to check if the contract has been deployed to. -- `-u, --rpc-url `: URL of the Aztec RPC. Default: `http://localhost:8080`. +- `-u, --rpc-url `: URL of the PXEult: `http://localhost:8080`. This command checks if a contract is deployed to the specified Aztec address. It verifies if the contract is present at the given address and displays the result. @@ -201,7 +201,7 @@ aztec-cli get-tx-receipt [options] Options: -- `-u, --rpc-url `: URL of the Aztec RPC. Default: `http://localhost:8080`. +- `-u, --rpc-url `: URL of the PXEult: `http://localhost:8080`. This command retrieves and displays the receipt for the specified transaction hash. It shows details such as the transaction status, block number, and block hash. @@ -225,7 +225,7 @@ aztec-cli get-contract-data [options] Options: -- `-u, --rpc-url `: URL of the Aztec RPC. Default: `http://localhost:8080`. +- `-u, --rpc-url `: URL of the PXEult: `http://localhost:8080`. - `-b, --include-bytecode`: Include the contract's public function bytecode, if any. This command retrieves and displays information about the Aztec contract deployed at the specified address. It shows the contract address, portal contract address, and optionally, the bytecode of the contract's public functions. @@ -252,7 +252,7 @@ Options: - `-a, --address `: The account's Aztec address. - `-p, --public-key `: 'The account public key.' - `-pa, --partial-address `: URL of the Aztec RPC. Default: `http://localhost:8080`. +- `-u, --rpc-url `: URL of the PXEult: `http://localhost:8080`. Example usage: @@ -262,7 +262,7 @@ aztec-cli register-recipient -p 0x20d9d93c4a9eb2b4bdb70ead07d28d1edb74bfd78443a8 ### get-accounts -Gets all the Aztec accounts stored in an Aztec RPC. +Gets all the Aztec accounts stored in an PXE Syntax: @@ -272,7 +272,7 @@ aztec-cli get-accounts [options] Options: -- `-u, --rpc-url `: URL of the Aztec RPC. Default: `http://localhost:8080`. +- `-u, --rpc-url `: URL of the PXEult: `http://localhost:8080`. This command retrieves and displays all the Aztec accounts available in the system. @@ -296,7 +296,7 @@ aztec-cli get-account
[options] Options: -- `-u, --rpc-url `: URL of the Aztec RPC. Default: `http://localhost:8080`. +- `-u, --rpc-url `: URL of the PXEult: `http://localhost:8080`. This command retrieves and displays the public key of an account given its Aztec address. @@ -324,7 +324,7 @@ Options: - `-c, --contract-abi `: The compiled contract's ABI in JSON format. You can also use one of Aztec's example contracts found in (@aztec/noir-contracts)[https://www.npmjs.com/package/@aztec/noir-contracts], e.g. PrivateTokenContractAbi. - `-ca, --contract-address
`: Address of the contract. - `-k, --private-key `: The sender's private key. -- `-u, --rpc-url `: URL of the Aztec RPC. Default: `http://localhost:8080`. +- `-u, --rpc-url `: URL of the PXEult: `http://localhost:8080`. This command calls a function on an Aztec contract. It requires the contract's ABI, address, function name, and optionally, function arguments. The command executes the function call and displays the transaction details. @@ -352,8 +352,8 @@ Options: - `'-a, --args [functionArgs...]` (optional): Function arguments. Default: []. - `-c, --contract-abi `: The compiled contract's ABI in JSON format. You can also use one of Aztec's example contracts found in (@aztec/noir-contracts)[https://www.npmjs.com/package/@aztec/noir-contracts], e.g. PrivateTokenContractAbi. - `-ca, --contract-address
`: Address of the contract. -- `-f, --from `: Address of the caller. If empty, first account in the Aztec RPC Server will be used. -- `-u, --rpc-url `: URL of the Aztec RPC. Default: `http://localhost:8080`. +- `-f, --from `: Address of the caller. If empty, first account in the Private Execution Environment (PXE) will be used. +- `-u, --rpc-url `: URL of the PXEult: `http://localhost:8080`. This command simulates the execution of a view function on a deployed contract without modifying the state. It requires the contract's ABI, address, function name, and optionally, function arguments. The command displays the result of the view function. @@ -400,7 +400,7 @@ aztec-cli get-logs --from --limit [options] Options: -- `-u, --rpc-url `: URL of the Aztec RPC. Default: `http://localhost:8080`. +- `-u, --rpc-url `: URL of the PXEult: `http://localhost:8080`. This command retrieves and displays all the unencrypted logs from L2 blocks in the specified range. It shows the logs found in the blocks and unrolls them for readability. @@ -422,7 +422,7 @@ aztec-cli block-number Options: -- `-u, --rpc-url `: URL of the Aztec RPC. Default: `http://localhost:8080`. +- `-u, --rpc-url `: URL of the PXEult: `http://localhost:8080`. This command retrieves and displays the current Aztec L2 block number. @@ -448,7 +448,7 @@ aztec-cli get-node-info Options: -- `-u, --rpc-url `: URL of the Aztec RPC. Default: `http://localhost:8080`. +- `-u, --rpc-url `: URL of the PXEult: `http://localhost:8080`. ## Conclusion diff --git a/yarn-project/cli/src/client.test.ts b/yarn-project/cli/src/client.test.ts index 10a8445acf9..d90f1487394 100644 --- a/yarn-project/cli/src/client.test.ts +++ b/yarn-project/cli/src/client.test.ts @@ -1,4 +1,4 @@ -import { AztecRPC, NodeInfo } from '@aztec/types'; +import { NodeInfo, PXE } from '@aztec/types'; import { MockProxy, mock } from 'jest-mock-extended'; @@ -6,10 +6,10 @@ import { checkServerVersion } from './client.js'; describe('client', () => { describe('checkServerVersion', () => { - let rpc: MockProxy; + let rpc: MockProxy; beforeEach(() => { - rpc = mock(); + rpc = mock(); }); it('checks versions match', async () => { diff --git a/yarn-project/cli/src/client.ts b/yarn-project/cli/src/client.ts index 05580cb90ef..19c588b5936 100644 --- a/yarn-project/cli/src/client.ts +++ b/yarn-project/cli/src/client.ts @@ -1,4 +1,4 @@ -import { AztecRPC, createAztecRpcClient } from '@aztec/aztec.js'; +import { PXE, createPXEClient } from '@aztec/aztec.js'; import { DebugLogger } from '@aztec/foundation/log'; import { fileURLToPath } from '@aztec/foundation/url'; @@ -7,20 +7,20 @@ import { dirname, resolve } from 'path'; import { gtr, ltr, satisfies, valid } from 'semver'; /** - * Creates an Aztec RPC client with a given set of retries on non-server errors. - * @param rpcUrl - URL of the RPC server. - * @returns An RPC client. + * Creates a PXE client with a given set of retries on non-server errors. + * @param rpcUrl - URL of the RPC server wrapping the PXE. + * @returns A PXE client. */ export function createClient(rpcUrl: string) { - return createAztecRpcClient(rpcUrl); + return createPXEClient(rpcUrl); } /** - * Creates an Aztec RPC client with a given set of retries on non-server errors. - * Checks that the RPC server matches the expected version, and warns if not. - * @param rpcUrl - URL of the RPC server. + * Creates a PXE client with a given set of retries on non-server errors. + * Checks that PXE matches the expected version, and warns if not. + * @param rpcUrl - URL of the RPC server wrapping the PXE. * @param logger - Debug logger to warn version incompatibilities. - * @returns An RPC client. + * @returns A PXE client. */ export async function createCompatibleClient(rpcUrl: string, logger: DebugLogger) { const client = createClient(rpcUrl); @@ -45,13 +45,13 @@ export async function createCompatibleClient(rpcUrl: string, logger: DebugLogger class VersionMismatchError extends Error {} /** - * Checks that the RPC server version matches the expected one by this CLI. Throws if not. - * @param rpc - RPC server connection. + * Checks that Private Execution Environment (PXE) version matches the expected one by this CLI. Throws if not. + * @param pxe - PXE client. * @param expectedVersionRange - Expected version by CLI. */ -export async function checkServerVersion(rpc: AztecRPC, expectedVersionRange: string) { +export async function checkServerVersion(pxe: PXE, expectedVersionRange: string) { const serverName = 'Aztec Sandbox'; - const { sandboxVersion } = await rpc.getNodeInfo(); + const { sandboxVersion } = await pxe.getNodeInfo(); if (!sandboxVersion) { throw new VersionMismatchError(`Couldn't determine ${serverName} version. You may run into issues.`); } diff --git a/yarn-project/cli/src/index.ts b/yarn-project/cli/src/index.ts index 6e048412cb7..3e4ae97fc06 100644 --- a/yarn-project/cli/src/index.ts +++ b/yarn-project/cli/src/index.ts @@ -40,7 +40,7 @@ const accountCreationSalt = Fr.ZERO; const { ETHEREUM_HOST = 'http://localhost:8545', - AZTEC_RPC_HOST = 'http://localhost:8080', + PXE_HOST = 'http://localhost:8080', PRIVATE_KEY, API_KEY, } = process.env; @@ -139,7 +139,7 @@ export function getProgram(log: LogFn, debugLogger: DebugLogger): Command { 'Private key for note encryption and transaction signing. Uses random by default.', PRIVATE_KEY, ) - .requiredOption('-u, --rpc-url ', 'URL of the Aztec RPC', AZTEC_RPC_HOST) + .requiredOption('-u, --rpc-url ', 'URL of the PXE', PXE_HOST) .action(async options => { const client = await createCompatibleClient(options.rpcUrl, debugLogger); const privateKey = options.privateKey @@ -165,7 +165,7 @@ export function getProgram(log: LogFn, debugLogger: DebugLogger): Command { "A compiled Aztec.nr contract's ABI in JSON format or name of a contract ABI exported by @aztec/noir-contracts", ) .option('-a, --args ', 'Contract constructor arguments', []) - .requiredOption('-u, --rpc-url ', 'URL of the Aztec RPC', AZTEC_RPC_HOST) + .requiredOption('-u, --rpc-url ', 'URL of the PXE', PXE_HOST) .option( '-k, --public-key ', 'Optional encryption public key for this address. Set this value only if this contract is expected to receive private notes, which will be encrypted using this public key.', @@ -208,7 +208,7 @@ export function getProgram(log: LogFn, debugLogger: DebugLogger): Command { .command('check-deploy') .description('Checks if a contract is deployed to the specified Aztec address.') .requiredOption('-ca, --contract-address
', 'An Aztec address to check if contract has been deployed to.') - .requiredOption('-u, --rpc-url ', 'URL of the Aztec RPC', AZTEC_RPC_HOST) + .requiredOption('-u, --rpc-url ', 'URL of the PXE', PXE_HOST) .action(async options => { const client = await createCompatibleClient(options.rpcUrl, debugLogger); const address = AztecAddress.fromString(options.contractAddress); @@ -221,7 +221,7 @@ export function getProgram(log: LogFn, debugLogger: DebugLogger): Command { .command('get-tx-receipt') .description('Gets the receipt for the specified transaction hash.') .argument('', 'A transaction hash to get the receipt for.') - .requiredOption('-u, --rpc-url ', 'URL of the Aztec RPC', AZTEC_RPC_HOST) + .requiredOption('-u, --rpc-url ', 'URL of the PXE', PXE_HOST) .action(async (_txHash, options) => { const client = await createCompatibleClient(options.rpcUrl, debugLogger); const txHash = TxHash.fromString(_txHash); @@ -237,7 +237,7 @@ export function getProgram(log: LogFn, debugLogger: DebugLogger): Command { .command('get-contract-data') .description('Gets information about the Aztec contract deployed at the specified address.') .argument('', 'Aztec address of the contract.') - .requiredOption('-u, --rpc-url ', 'URL of the Aztec RPC', AZTEC_RPC_HOST) + .requiredOption('-u, --rpc-url ', 'URL of the PXE', PXE_HOST) .option('-b, --include-bytecode ', "Include the contract's public function bytecode, if any.", false) .action(async (contractAddress, options) => { const client = await createCompatibleClient(options.rpcUrl, debugLogger); @@ -270,7 +270,7 @@ export function getProgram(log: LogFn, debugLogger: DebugLogger): Command { .description('Gets all the unencrypted logs from L2 blocks in the range specified.') .option('-f, --from ', 'Initial block number for getting logs (defaults to 1).') .option('-l, --limit ', 'How many blocks to fetch (defaults to 100).') - .requiredOption('-u, --rpc-url ', 'URL of the Aztec RPC', AZTEC_RPC_HOST) + .requiredOption('-u, --rpc-url ', 'URL of the PXE', PXE_HOST) .action(async options => { const { from, limit } = options; const fromBlock = from ? parseInt(from) : 1; @@ -288,11 +288,11 @@ export function getProgram(log: LogFn, debugLogger: DebugLogger): Command { program .command('register-recipient') - .description('Register a recipient in the Aztec RPC.') + .description('Register a recipient in the PXE.') .requiredOption('-a, --address ', "The account's Aztec address.") .requiredOption('-p, --public-key ', 'The account public key.') .requiredOption('-pa, --partial-address ', 'URL of the Aztec RPC', AZTEC_RPC_HOST) + .requiredOption('-u, --rpc-url ', 'URL of the PXE', PXE_HOST) .action(async options => { const client = await createCompatibleClient(options.rpcUrl, debugLogger); const address = AztecAddress.fromString(options.address); @@ -305,8 +305,8 @@ export function getProgram(log: LogFn, debugLogger: DebugLogger): Command { program .command('get-accounts') - .description('Gets all the Aztec accounts stored in the Aztec RPC.') - .requiredOption('-u, --rpc-url ', 'URL of the Aztec RPC', AZTEC_RPC_HOST) + .description('Gets all the Aztec accounts stored in the PXE.') + .requiredOption('-u, --rpc-url ', 'URL of the PXE', PXE_HOST) .action(async (options: any) => { const client = await createCompatibleClient(options.rpcUrl, debugLogger); const accounts = await client.getRegisteredAccounts(); @@ -324,7 +324,7 @@ export function getProgram(log: LogFn, debugLogger: DebugLogger): Command { .command('get-account') .description('Gets an account given its Aztec address.') .argument('
', 'The Aztec address to get account for') - .requiredOption('-u, --rpc-url ', 'URL of the Aztec RPC', AZTEC_RPC_HOST) + .requiredOption('-u, --rpc-url ', 'URL of the PXE', PXE_HOST) .action(async (_address, options) => { const client = await createCompatibleClient(options.rpcUrl, debugLogger); const address = AztecAddress.fromString(_address); @@ -339,8 +339,8 @@ export function getProgram(log: LogFn, debugLogger: DebugLogger): Command { program .command('get-recipients') - .description('Gets all the recipients stored in the Aztec RPC.') - .requiredOption('-u, --rpc-url ', 'URL of the Aztec RPC', AZTEC_RPC_HOST) + .description('Gets all the recipients stored in the PXE.') + .requiredOption('-u, --rpc-url ', 'URL of the PXE', PXE_HOST) .action(async (options: any) => { const client = await createCompatibleClient(options.rpcUrl, debugLogger); const recipients = await client.getRecipients(); @@ -358,7 +358,7 @@ export function getProgram(log: LogFn, debugLogger: DebugLogger): Command { .command('get-recipient') .description('Gets a recipient given its Aztec address.') .argument('
', 'The Aztec address to get recipient for') - .requiredOption('-u, --rpc-url ', 'URL of the Aztec RPC', AZTEC_RPC_HOST) + .requiredOption('-u, --rpc-url ', 'URL of the PXE', PXE_HOST) .action(async (_address, options) => { const client = await createCompatibleClient(options.rpcUrl, debugLogger); const address = AztecAddress.fromString(_address); @@ -382,7 +382,7 @@ export function getProgram(log: LogFn, debugLogger: DebugLogger): Command { ) .requiredOption('-ca, --contract-address
', 'Aztec address of the contract.') .requiredOption('-k, --private-key ', "The sender's private key.", PRIVATE_KEY) - .requiredOption('-u, --rpc-url ', 'URL of the Aztec RPC', AZTEC_RPC_HOST) + .requiredOption('-u, --rpc-url ', 'URL of the PXE', PXE_HOST) .option('--no-wait', 'Print transaction hash without waiting for it to be mined') .action(async (functionName, options) => { const { contractAddress, functionArgs, contractAbi } = await prepTx( @@ -427,7 +427,7 @@ export function getProgram(log: LogFn, debugLogger: DebugLogger): Command { ) .requiredOption('-ca, --contract-address
', 'Aztec address of the contract.') .option('-f, --from ', 'Aztec address of the caller. If empty, will use the first account from RPC.') - .requiredOption('-u, --rpc-url ', 'URL of the Aztec RPC', AZTEC_RPC_HOST) + .requiredOption('-u, --rpc-url ', 'URL of the PXE', PXE_HOST) .action(async (functionName, options) => { const { contractAddress, functionArgs, contractAbi } = await prepTx( options.contractAbi, @@ -475,7 +475,7 @@ export function getProgram(log: LogFn, debugLogger: DebugLogger): Command { program .command('block-number') .description('Gets the current Aztec L2 block number.') - .requiredOption('-u, --rpc-url ', 'URL of the Aztec RPC', AZTEC_RPC_HOST) + .requiredOption('-u, --rpc-url ', 'URL of the PXE', PXE_HOST) .action(async (options: any) => { const client = await createCompatibleClient(options.rpcUrl, debugLogger); const num = await client.getBlockNumber(); @@ -506,7 +506,7 @@ export function getProgram(log: LogFn, debugLogger: DebugLogger): Command { program .command('get-node-info') .description('Gets the information of an aztec node at a URL.') - .requiredOption('-u, --rpc-url ', 'URL of the Aztec RPC', AZTEC_RPC_HOST) + .requiredOption('-u, --rpc-url ', 'URL of the PXE', PXE_HOST) .action(async options => { const client = await createCompatibleClient(options.rpcUrl, debugLogger); const info = await client.getNodeInfo(); diff --git a/yarn-project/cli/src/test/utils.test.ts b/yarn-project/cli/src/test/utils.test.ts index 70e1a9c7d10..2e04691cba2 100644 --- a/yarn-project/cli/src/test/utils.test.ts +++ b/yarn-project/cli/src/test/utils.test.ts @@ -1,5 +1,5 @@ import { AztecAddress, Fr } from '@aztec/aztec.js'; -import { AztecRPC, CompleteAddress } from '@aztec/types'; +import { CompleteAddress, PXE } from '@aztec/types'; import { InvalidArgumentError } from 'commander'; import { MockProxy, mock } from 'jest-mock-extended'; @@ -9,7 +9,7 @@ import { getSaltFromHexString, getTxSender, stripLeadingHex } from '../utils.js' import { mockContractAbi } from './mocks.js'; describe('CLI Utils', () => { - let client: MockProxy; + let client: MockProxy; // test values const addr1 = AztecAddress.random(); @@ -23,7 +23,7 @@ describe('CLI Utils', () => { subField2: 'true', }; beforeEach(() => { - client = mock(); + client = mock(); }); it('Gets a txSender correctly or throw error', async () => { // returns a parsed Aztec Address @@ -53,7 +53,7 @@ describe('CLI Utils', () => { (async () => { await getTxSender(client); })(), - ).rejects.toThrow('No accounts found in Aztec RPC instance.'); + ).rejects.toThrow('No accounts found in PXE instance.'); }); it('Encodes args correctly', () => { diff --git a/yarn-project/cli/src/utils.ts b/yarn-project/cli/src/utils.ts index 7bb19a4f8db..2aec1e854c1 100644 --- a/yarn-project/cli/src/utils.ts +++ b/yarn-project/cli/src/utils.ts @@ -1,4 +1,4 @@ -import { AztecAddress, AztecRPC, Fr } from '@aztec/aztec.js'; +import { AztecAddress, Fr, PXE } from '@aztec/aztec.js'; import { L1ContractArtifactsForDeployment, createEthereumChain, deployL1Contracts } from '@aztec/ethereum'; import { ContractAbi } from '@aztec/foundation/abi'; import { DebugLogger, LogFn } from '@aztec/foundation/log'; @@ -125,12 +125,12 @@ export async function getContractAbi(fileDir: string, log: LogFn) { /** * Utility to select a TX sender either from user input - * or from the first account that is found in an Aztec RPC instance. - * @param client - The Aztec RPC instance that will be checked for an account. + * or from the first account that is found in an PXE instance. + * @param client - The PXE instance that will be checked for an account. * @param _from - The user input. * @returns An Aztec address. Will throw if one can't be found in either options. */ -export async function getTxSender(client: AztecRPC, _from?: string) { +export async function getTxSender(client: PXE, _from?: string) { let from: AztecAddress; if (_from) { try { @@ -141,7 +141,7 @@ export async function getTxSender(client: AztecRPC, _from?: string) { } else { const accounts = await client.getRegisteredAccounts(); if (!accounts.length) { - throw new Error('No accounts found in Aztec RPC instance.'); + throw new Error('No accounts found in PXE instance.'); } from = accounts[0].address; } diff --git a/yarn-project/end-to-end/scripts/docker-compose-e2e-sandbox-browser.yml b/yarn-project/end-to-end/scripts/docker-compose-e2e-sandbox-browser.yml index cbee1a7bbfd..54424e6c93e 100644 --- a/yarn-project/end-to-end/scripts/docker-compose-e2e-sandbox-browser.yml +++ b/yarn-project/end-to-end/scripts/docker-compose-e2e-sandbox-browser.yml @@ -22,7 +22,7 @@ services: P2P_BLOCK_CHECK_INTERVAL_MS: 50 SEQ_TX_POLLING_INTERVAL_MS: 50 WS_BLOCK_CHECK_INTERVAL_MS: 50 - RPC_SERVER_BLOCK_POLLING_INTERVAL_MS: 50 + PXE_SERVICE_BLOCK_POLLING_INTERVAL_MS: 50 ARCHIVER_VIEM_POLLING_INTERVAL_MS: 500 SEARCH_START_BLOCK: ${FORK_BLOCK_NUMBER:-0} ports: diff --git a/yarn-project/end-to-end/scripts/docker-compose-e2e-sandbox.yml b/yarn-project/end-to-end/scripts/docker-compose-e2e-sandbox.yml index 3ab4dc4a37b..53eb4fde6d2 100644 --- a/yarn-project/end-to-end/scripts/docker-compose-e2e-sandbox.yml +++ b/yarn-project/end-to-end/scripts/docker-compose-e2e-sandbox.yml @@ -22,7 +22,7 @@ services: P2P_BLOCK_CHECK_INTERVAL_MS: 50 SEQ_TX_POLLING_INTERVAL_MS: 50 WS_BLOCK_CHECK_INTERVAL_MS: 50 - RPC_SERVER_BLOCK_POLLING_INTERVAL_MS: 50 + PXE_SERVICE_BLOCK_POLLING_INTERVAL_MS: 50 ARCHIVER_VIEM_POLLING_INTERVAL_MS: 500 SEARCH_START_BLOCK: ${FORK_BLOCK_NUMBER:-0} ports: diff --git a/yarn-project/end-to-end/scripts/docker-compose.yml b/yarn-project/end-to-end/scripts/docker-compose.yml index cf73156c000..a20f4ffb02f 100644 --- a/yarn-project/end-to-end/scripts/docker-compose.yml +++ b/yarn-project/end-to-end/scripts/docker-compose.yml @@ -22,7 +22,7 @@ services: P2P_BLOCK_CHECK_INTERVAL_MS: 50 SEQ_TX_POLLING_INTERVAL_MS: 50 WS_BLOCK_CHECK_INTERVAL_MS: 50 - RPC_SERVER_BLOCK_POLLING_INTERVAL_MS: 50 + PXE_SERVICE_BLOCK_POLLING_INTERVAL_MS: 50 ARCHIVER_VIEM_POLLING_INTERVAL_MS: 500 SEARCH_START_BLOCK: ${FORK_BLOCK_NUMBER:-0} command: ${TEST:-./src/e2e_deploy_contract.test.ts} diff --git a/yarn-project/end-to-end/src/aztec_rpc_sandbox.test.ts b/yarn-project/end-to-end/src/aztec_rpc_sandbox.test.ts deleted file mode 100644 index c6becb31dc5..00000000000 --- a/yarn-project/end-to-end/src/aztec_rpc_sandbox.test.ts +++ /dev/null @@ -1,12 +0,0 @@ -import { createAztecRpcClient, waitForSandbox } from '@aztec/aztec.js'; -import { aztecRpcTestSuite } from '@aztec/pxe'; - -const { SANDBOX_URL = 'http://localhost:8080' } = process.env; - -const setup = async () => { - const aztecRpc = createAztecRpcClient(SANDBOX_URL); - await waitForSandbox(aztecRpc); - return aztecRpc; -}; - -aztecRpcTestSuite('aztec_rpc_sandbox', setup); diff --git a/yarn-project/end-to-end/src/canary/browser.ts b/yarn-project/end-to-end/src/canary/browser.ts index c3f16ff9861..4e3fcb8d242 100644 --- a/yarn-project/end-to-end/src/canary/browser.ts +++ b/yarn-project/end-to-end/src/canary/browser.ts @@ -38,7 +38,7 @@ export const browserTestSuite = (setup: () => Server, pageLogger: AztecJs.DebugL let contractAddress: AztecJs.AztecAddress; let app: Koa; - let testClient: AztecJs.AztecRPC; + let testClient: AztecJs.PXE; let server: Server; let browser: Browser; @@ -46,7 +46,7 @@ export const browserTestSuite = (setup: () => Server, pageLogger: AztecJs.DebugL beforeAll(async () => { server = setup(); - testClient = AztecJs.createAztecRpcClient(SANDBOX_URL!); + testClient = AztecJs.createPXEClient(SANDBOX_URL!); await AztecJs.waitForSandbox(testClient); app = new Koa(); @@ -90,7 +90,7 @@ export const browserTestSuite = (setup: () => Server, pageLogger: AztecJs.DebugL it('Creates an account', async () => { const result = await page.evaluate( async (rpcUrl, privateKeyString) => { - const { GrumpkinScalar, createAztecRpcClient, getUnsafeSchnorrAccount } = window.AztecJs; + const { GrumpkinScalar, createPXEClient: createAztecRpcClient, getUnsafeSchnorrAccount } = window.AztecJs; const client = createAztecRpcClient(rpcUrl!); const privateKey = GrumpkinScalar.fromString(privateKeyString); const account = getUnsafeSchnorrAccount(client, privateKey); @@ -115,7 +115,7 @@ export const browserTestSuite = (setup: () => Server, pageLogger: AztecJs.DebugL it("Gets the owner's balance", async () => { const result = await page.evaluate( async (rpcUrl, contractAddress, TokenContractAbi) => { - const { Contract, AztecAddress, createAztecRpcClient } = window.AztecJs; + const { Contract, AztecAddress, createPXEClient: createAztecRpcClient } = window.AztecJs; const client = createAztecRpcClient(rpcUrl!); const owner = (await client.getRegisteredAccounts())[0].address; const [wallet] = await AztecJs.getSandboxAccountsWallets(client); @@ -134,7 +134,7 @@ export const browserTestSuite = (setup: () => Server, pageLogger: AztecJs.DebugL const result = await page.evaluate( async (rpcUrl, contractAddress, transferAmount, TokenContractAbi) => { console.log(`Starting transfer tx`); - const { AztecAddress, Contract, createAztecRpcClient } = window.AztecJs; + const { AztecAddress, Contract, createPXEClient: createAztecRpcClient } = window.AztecJs; const client = createAztecRpcClient(rpcUrl!); const accounts = await client.getRegisteredAccounts(); const receiver = accounts[1].address; @@ -158,7 +158,7 @@ export const browserTestSuite = (setup: () => Server, pageLogger: AztecJs.DebugL const { GrumpkinScalar, DeployMethod, - createAztecRpcClient, + createPXEClient: createAztecRpcClient, getUnsafeSchnorrAccount, Contract, Fr, diff --git a/yarn-project/end-to-end/src/canary/cli.ts b/yarn-project/end-to-end/src/canary/cli.ts index 2cc7442ef29..d0cc198291e 100644 --- a/yarn-project/end-to-end/src/canary/cli.ts +++ b/yarn-project/end-to-end/src/canary/cli.ts @@ -1,4 +1,4 @@ -import { AztecAddress, AztecRPC, CompleteAddress, DebugLogger, Fr, computeMessageSecretHash } from '@aztec/aztec.js'; +import { AztecAddress, CompleteAddress, DebugLogger, Fr, PXE, computeMessageSecretHash } from '@aztec/aztec.js'; import { getProgram } from '@aztec/cli'; import stringArgv from 'string-argv'; @@ -9,14 +9,14 @@ const TRANSFER_BALANCE = 3000; export const cliTestSuite = ( name: string, - setup: () => Promise, + setup: () => Promise, cleanup: () => Promise, debug: DebugLogger, rpcUrl = 'http://localhost:8080', ) => describe(name, () => { let cli: ReturnType; - let aztecRpcClient: AztecRPC; + let aztecRpcClient: PXE; let existingAccounts: CompleteAddress[]; let contractAddress: AztecAddress; let log: (...args: any[]) => void; diff --git a/yarn-project/end-to-end/src/e2e_2_rpc_servers.test.ts b/yarn-project/end-to-end/src/e2e_2_pxes.test.ts similarity index 93% rename from yarn-project/end-to-end/src/e2e_2_rpc_servers.test.ts rename to yarn-project/end-to-end/src/e2e_2_pxes.test.ts index 88be20741da..086a3993443 100644 --- a/yarn-project/end-to-end/src/e2e_2_rpc_servers.test.ts +++ b/yarn-project/end-to-end/src/e2e_2_pxes.test.ts @@ -4,12 +4,12 @@ import { DebugLogger } from '@aztec/foundation/log'; import { retryUntil } from '@aztec/foundation/retry'; import { toBigInt } from '@aztec/foundation/serialize'; import { ChildContract, TokenContract } from '@aztec/noir-contracts/types'; -import { AztecRPCServer, EthAddress, Fr } from '@aztec/pxe'; -import { AztecRPC, CompleteAddress, TxStatus } from '@aztec/types'; +import { EthAddress, Fr, PXEService } from '@aztec/pxe'; +import { CompleteAddress, PXE, TxStatus } from '@aztec/types'; import { jest } from '@jest/globals'; -import { expectsNumOfEncryptedLogsInTheLastBlockToBe, setup, setupAztecRPCServer } from './fixtures/utils.js'; +import { expectsNumOfEncryptedLogsInTheLastBlockToBe, setup, setupPXEService } from './fixtures/utils.js'; const { SANDBOX_URL = '' } = process.env; @@ -19,8 +19,8 @@ describe('e2e_2_rpc_servers', () => { jest.setTimeout(TIMEOUT); let aztecNode: AztecNodeService | undefined; - let aztecRpcServerA: AztecRPC; - let aztecRpcServerB: AztecRPC; + let aztecRpcServerA: PXE; + let aztecRpcServerB: PXE; let walletA: Wallet; let walletB: Wallet; let userA: CompleteAddress; @@ -48,13 +48,13 @@ describe('e2e_2_rpc_servers', () => { aztecRpcServer: aztecRpcServerB, accounts: accounts, wallets: [walletB], - } = await setupAztecRPCServer(1, aztecNode!, undefined, true)); + } = await setupPXEService(1, aztecNode!, undefined, true)); [userB] = accounts; }, 100_000); afterEach(async () => { await teardownA(); - if (aztecRpcServerB instanceof AztecRPCServer) await aztecRpcServerB.stop(); + if (aztecRpcServerB instanceof PXEService) await aztecRpcServerB.stop(); }); const awaitUserSynchronized = async (wallet: Wallet, owner: AztecAddress) => { @@ -168,14 +168,14 @@ describe('e2e_2_rpc_servers', () => { return contract.completeAddress; }; - const awaitServerSynchronized = async (server: AztecRPC) => { + const awaitServerSynchronized = async (server: PXE) => { const isServerSynchronized = async () => { return await server.isGlobalStateSynchronized(); }; await retryUntil(isServerSynchronized, 'server sync', 10); }; - const getChildStoredValue = (child: { address: AztecAddress }, aztecRpcServer: AztecRPC) => + const getChildStoredValue = (child: { address: AztecAddress }, aztecRpcServer: PXE) => aztecRpcServer.getPublicStorageAt(child.address, new Fr(1)).then(x => toBigInt(x!)); it('user calls a public function on a contract deployed by a different user using a different RPC server', async () => { @@ -203,7 +203,7 @@ describe('e2e_2_rpc_servers', () => { expect(storedValue).toBe(newValueToSet); }); - it('private state is "zero" when Aztec RPC Server does not have the account private key', async () => { + it('private state is "zero" when Private Execution Environment (PXE) does not have the account private key', async () => { const userABalance = 100n; const userBBalance = 150n; diff --git a/yarn-project/end-to-end/src/e2e_account_contracts.test.ts b/yarn-project/end-to-end/src/e2e_account_contracts.test.ts index 51a1b1773bc..a8103b60412 100644 --- a/yarn-project/end-to-end/src/e2e_account_contracts.test.ts +++ b/yarn-project/end-to-end/src/e2e_account_contracts.test.ts @@ -1,9 +1,9 @@ import { AccountContract, AccountManager, - AztecRPC, EcdsaAccountContract, Fr, + PXE, SchnorrAccountContract, SingleKeyAccountContract, Wallet, @@ -19,7 +19,7 @@ import { setup } from './fixtures/utils.js'; function itShouldBehaveLikeAnAccountContract( getAccountContract: (encryptionKey: GrumpkinPrivateKey) => AccountContract, walletSetup: ( - rpc: AztecRPC, + rpc: PXE, encryptionPrivateKey: GrumpkinPrivateKey, accountContract: AccountContract, address?: CompleteAddress, @@ -77,7 +77,7 @@ function itShouldBehaveLikeAnAccountContract( describe('e2e_account_contracts', () => { const base = async ( - rpc: AztecRPC, + rpc: PXE, encryptionPrivateKey: GrumpkinPrivateKey, accountContract: AccountContract, address?: CompleteAddress, diff --git a/yarn-project/end-to-end/src/e2e_block_building.test.ts b/yarn-project/end-to-end/src/e2e_block_building.test.ts index 7aad5d37038..002359f2e34 100644 --- a/yarn-project/end-to-end/src/e2e_block_building.test.ts +++ b/yarn-project/end-to-end/src/e2e_block_building.test.ts @@ -4,14 +4,14 @@ import { pedersenPlookupCommitInputs } from '@aztec/circuits.js/barretenberg'; import { DebugLogger } from '@aztec/foundation/log'; import { TestContractAbi } from '@aztec/noir-contracts/artifacts'; import { TestContract } from '@aztec/noir-contracts/types'; -import { AztecRPC, TxStatus } from '@aztec/types'; +import { PXE, TxStatus } from '@aztec/types'; import times from 'lodash.times'; import { setup } from './fixtures/utils.js'; describe('e2e_block_building', () => { - let aztecRpcServer: AztecRPC; + let aztecRpcServer: PXE; let logger: DebugLogger; let wallet: Wallet; let teardown: () => Promise; diff --git a/yarn-project/end-to-end/src/e2e_card_game.test.ts b/yarn-project/end-to-end/src/e2e_card_game.test.ts index b6bdcb19d7b..0415874630f 100644 --- a/yarn-project/end-to-end/src/e2e_card_game.test.ts +++ b/yarn-project/end-to-end/src/e2e_card_game.test.ts @@ -1,7 +1,7 @@ import { AccountWallet, AztecAddress, Wallet, deployInitialSandboxAccounts } from '@aztec/aztec.js'; import { DebugLogger } from '@aztec/foundation/log'; import { CardGameContract } from '@aztec/noir-contracts/types'; -import { AztecRPC } from '@aztec/types'; +import { PXE } from '@aztec/types'; import { setup } from './fixtures/utils.js'; @@ -44,7 +44,7 @@ function unwrapOptions(options: NoirOption[]): T[] { const GAME_ID = 42; describe('e2e_card_game', () => { - let aztecRpcServer: AztecRPC; + let aztecRpcServer: PXE; let logger: DebugLogger; let teardown: () => Promise; diff --git a/yarn-project/end-to-end/src/e2e_cheat_codes.test.ts b/yarn-project/end-to-end/src/e2e_cheat_codes.test.ts index 75cf2245ee9..a17796a05bd 100644 --- a/yarn-project/end-to-end/src/e2e_cheat_codes.test.ts +++ b/yarn-project/end-to-end/src/e2e_cheat_codes.test.ts @@ -2,14 +2,14 @@ import { CheatCodes, Wallet } from '@aztec/aztec.js'; import { RollupAbi } from '@aztec/l1-artifacts'; import { TestContract } from '@aztec/noir-contracts/types'; import { EthAddress } from '@aztec/pxe'; -import { AztecRPC, TxStatus } from '@aztec/types'; +import { PXE, TxStatus } from '@aztec/types'; import { Account, Chain, HttpTransport, PublicClient, WalletClient, getAddress, getContract, parseEther } from 'viem'; import { setup } from './fixtures/utils.js'; describe('e2e_cheat_codes', () => { - let aztecRpcServer: AztecRPC; + let aztecRpcServer: PXE; let wallet: Wallet; let cc: CheatCodes; let teardown: () => Promise; diff --git a/yarn-project/end-to-end/src/e2e_cli.test.ts b/yarn-project/end-to-end/src/e2e_cli.test.ts index 36795577426..76c854a3829 100644 --- a/yarn-project/end-to-end/src/e2e_cli.test.ts +++ b/yarn-project/end-to-end/src/e2e_cli.test.ts @@ -1,7 +1,7 @@ import { AztecNodeService } from '@aztec/aztec-node'; import { startHttpRpcServer } from '@aztec/aztec-sandbox'; -import { AztecRPC, createDebugLogger } from '@aztec/aztec.js'; -import { AztecRPCServer } from '@aztec/pxe'; +import { PXE, createDebugLogger } from '@aztec/aztec.js'; +import { PXEService } from '@aztec/pxe'; import { cliTestSuite } from './canary/cli.js'; import { setup as e2eSetup } from './fixtures/utils.js'; @@ -12,7 +12,7 @@ const debug = createDebugLogger('aztec:e2e_cli'); let http: ReturnType; let aztecNode: AztecNodeService | undefined; -let aztecRpcServer: AztecRPC; +let aztecRpcServer: PXE; const testSetup = async () => { const context = await e2eSetup(2); @@ -26,7 +26,7 @@ const testSetup = async () => { const testCleanup = async () => { http.close(); await aztecNode?.stop(); - await (aztecRpcServer as AztecRPCServer).stop(); + await (aztecRpcServer as PXEService).stop(); }; cliTestSuite('E2E CLI Test', testSetup, testCleanup, createDebugLogger('aztec:e2e_cli'), RPC_URL); diff --git a/yarn-project/end-to-end/src/e2e_deploy_contract.test.ts b/yarn-project/end-to-end/src/e2e_deploy_contract.test.ts index 1317cd6fcb6..2e49c49855f 100644 --- a/yarn-project/end-to-end/src/e2e_deploy_contract.test.ts +++ b/yarn-project/end-to-end/src/e2e_deploy_contract.test.ts @@ -2,12 +2,12 @@ import { AztecAddress, Contract, ContractDeployer, Fr, Wallet, isContractDeploye import { CompleteAddress, getContractDeploymentInfo } from '@aztec/circuits.js'; import { DebugLogger } from '@aztec/foundation/log'; import { TestContractAbi } from '@aztec/noir-contracts/artifacts'; -import { AztecRPC, TxStatus } from '@aztec/types'; +import { PXE, TxStatus } from '@aztec/types'; import { setup } from './fixtures/utils.js'; describe('e2e_deploy_contract', () => { - let aztecRpcServer: AztecRPC; + let aztecRpcServer: PXE; let accounts: CompleteAddress[]; let logger: DebugLogger; let wallet: Wallet; diff --git a/yarn-project/end-to-end/src/e2e_escrow_contract.test.ts b/yarn-project/end-to-end/src/e2e_escrow_contract.test.ts index 1a661fe563d..1fa1392096c 100644 --- a/yarn-project/end-to-end/src/e2e_escrow_contract.test.ts +++ b/yarn-project/end-to-end/src/e2e_escrow_contract.test.ts @@ -3,12 +3,12 @@ import { CompleteAddress, Fr, GrumpkinPrivateKey, GrumpkinScalar, getContractDep import { DebugLogger } from '@aztec/foundation/log'; import { EscrowContractAbi } from '@aztec/noir-contracts/artifacts'; import { EscrowContract, TokenContract } from '@aztec/noir-contracts/types'; -import { AztecRPC, PublicKey, TxStatus } from '@aztec/types'; +import { PXE, PublicKey, TxStatus } from '@aztec/types'; import { setup } from './fixtures/utils.js'; describe('e2e_escrow_contract', () => { - let aztecRpcServer: AztecRPC; + let aztecRpcServer: PXE; let wallet: AccountWallet; let recipientWallet: AccountWallet; let accounts: CompleteAddress[]; diff --git a/yarn-project/end-to-end/src/e2e_multiple_accounts_1_enc_key.test.ts b/yarn-project/end-to-end/src/e2e_multiple_accounts_1_enc_key.test.ts index 688d5c4cd16..6894a65c9cd 100644 --- a/yarn-project/end-to-end/src/e2e_multiple_accounts_1_enc_key.test.ts +++ b/yarn-project/end-to-end/src/e2e_multiple_accounts_1_enc_key.test.ts @@ -3,13 +3,13 @@ import { AztecAddress, Wallet, computeMessageSecretHash, generatePublicKey, getS import { Fr, GrumpkinScalar } from '@aztec/circuits.js'; import { DebugLogger } from '@aztec/foundation/log'; import { TokenContract } from '@aztec/noir-contracts/types'; -import { AztecRPC, TxStatus } from '@aztec/types'; +import { PXE, TxStatus } from '@aztec/types'; import { expectsNumOfEncryptedLogsInTheLastBlockToBe, setup } from './fixtures/utils.js'; describe('e2e_multiple_accounts_1_enc_key', () => { let aztecNode: AztecNodeService | undefined; - let aztecRpcServer: AztecRPC; + let aztecRpcServer: PXE; const wallets: Wallet[] = []; const accounts: AztecAddress[] = []; let logger: DebugLogger; @@ -97,7 +97,7 @@ describe('e2e_multiple_accounts_1_enc_key', () => { }; /** - * Tests the ability of the Aztec RPC server to handle multiple accounts under the same encryption key. + * Tests the ability of the Private Execution Environment (PXE) to handle multiple accounts under the same encryption key. */ it('spends notes from multiple account under the same encryption key', async () => { const transferAmount1 = 654n; // account 0 -> account 1 diff --git a/yarn-project/end-to-end/src/e2e_nested_contract.test.ts b/yarn-project/end-to-end/src/e2e_nested_contract.test.ts index 0319f94fec5..47ec3016325 100644 --- a/yarn-project/end-to-end/src/e2e_nested_contract.test.ts +++ b/yarn-project/end-to-end/src/e2e_nested_contract.test.ts @@ -3,12 +3,12 @@ import { toBigIntBE } from '@aztec/foundation/bigint-buffer'; import { DebugLogger } from '@aztec/foundation/log'; import { toBigInt } from '@aztec/foundation/serialize'; import { ChildContract, ImportTestContract, ParentContract, TestContract } from '@aztec/noir-contracts/types'; -import { AztecRPC, L2BlockL2Logs } from '@aztec/types'; +import { L2BlockL2Logs, PXE } from '@aztec/types'; import { setup } from './fixtures/utils.js'; describe('e2e_nested_contract', () => { - let aztecRpcServer: AztecRPC; + let aztecRpcServer: PXE; let wallet: Wallet; let logger: DebugLogger; let teardown: () => Promise; diff --git a/yarn-project/end-to-end/src/e2e_non_contract_account.test.ts b/yarn-project/end-to-end/src/e2e_non_contract_account.test.ts index 4afce0ef322..9a092c55cc7 100644 --- a/yarn-project/end-to-end/src/e2e_non_contract_account.test.ts +++ b/yarn-project/end-to-end/src/e2e_non_contract_account.test.ts @@ -2,13 +2,13 @@ import { AztecNodeService } from '@aztec/aztec-node'; import { AztecAddress, SignerlessWallet, Wallet } from '@aztec/aztec.js'; import { DebugLogger } from '@aztec/foundation/log'; import { PokeableTokenContract } from '@aztec/noir-contracts/types'; -import { AztecRPC, CompleteAddress, TxStatus } from '@aztec/types'; +import { CompleteAddress, PXE, TxStatus } from '@aztec/types'; import { expectsNumOfEncryptedLogsInTheLastBlockToBe, setup } from './fixtures/utils.js'; describe('e2e_non_contract_account', () => { let aztecNode: AztecNodeService | undefined; - let aztecRpcServer: AztecRPC; + let aztecRpcServer: PXE; let wallet: Wallet; let sender: AztecAddress; let recipient: AztecAddress; diff --git a/yarn-project/end-to-end/src/e2e_ordering.test.ts b/yarn-project/end-to-end/src/e2e_ordering.test.ts index 046cb25da5d..17b7b800ca5 100644 --- a/yarn-project/end-to-end/src/e2e_ordering.test.ts +++ b/yarn-project/end-to-end/src/e2e_ordering.test.ts @@ -4,13 +4,13 @@ import { Fr, FunctionSelector } from '@aztec/circuits.js'; import { toBigIntBE } from '@aztec/foundation/bigint-buffer'; import { toBigInt } from '@aztec/foundation/serialize'; import { ChildContract, ParentContract } from '@aztec/noir-contracts/types'; -import { AztecRPC, L2BlockL2Logs, TxStatus } from '@aztec/types'; +import { L2BlockL2Logs, PXE, TxStatus } from '@aztec/types'; import { setup } from './fixtures/utils.js'; // See https://github.com/AztecProtocol/aztec-packages/issues/1601 describe('e2e_ordering', () => { - let aztecRpcServer: AztecRPC; + let aztecRpcServer: PXE; let wallet: Wallet; let teardown: () => Promise; diff --git a/yarn-project/end-to-end/src/e2e_p2p_network.test.ts b/yarn-project/end-to-end/src/e2e_p2p_network.test.ts index 53a285646b7..3c7b8b6178f 100644 --- a/yarn-project/end-to-end/src/e2e_p2p_network.test.ts +++ b/yarn-project/end-to-end/src/e2e_p2p_network.test.ts @@ -5,7 +5,7 @@ import { Grumpkin } from '@aztec/circuits.js/barretenberg'; import { DebugLogger } from '@aztec/foundation/log'; import { TestContractAbi } from '@aztec/noir-contracts/artifacts'; import { BootstrapNode, P2PConfig, createLibP2PPeerId } from '@aztec/p2p'; -import { AztecRPCServer, ConstantKeyPair, createAztecRPCServer, getConfigEnvVars as getRpcConfig } from '@aztec/pxe'; +import { ConstantKeyPair, PXEService, createPXEService, getConfigEnvVars as getRpcConfig } from '@aztec/pxe'; import { TxStatus } from '@aztec/types'; import { setup } from './fixtures/utils.js'; @@ -17,7 +17,7 @@ const BOOT_NODE_TCP_PORT = 40400; interface NodeContext { node: AztecNodeService; - rpcServer: AztecRPCServer; + rpcServer: PXEService; txs: SentTx[]; account: AztecAddress; } @@ -112,9 +112,9 @@ describe('e2e_p2p_network', () => { return await AztecNodeService.createAndSync(newConfig); }; - // submits a set of transactions to the provided aztec rpc server + // submits a set of transactions to the provided Private Execution Environment (PXE) const submitTxsTo = async ( - aztecRpcServer: AztecRPCServer, + aztecRpcServer: PXEService, account: AztecAddress, numTxs: number, publicKey: PublicKey, @@ -139,13 +139,13 @@ describe('e2e_p2p_network', () => { return txs; }; - // creates an instance of the aztec rpc server and submit a given number of transactions to it. + // creates an instance of the PXE and submit a given number of transactions to it. const createAztecRpcServerAndSubmitTransactions = async ( node: AztecNodeService, numTxs: number, ): Promise => { const rpcConfig = getRpcConfig(); - const aztecRpcServer = await createAztecRPCServer(node, rpcConfig, {}, true); + const aztecRpcServer = await createPXEService(node, rpcConfig, {}, true); const keyPair = ConstantKeyPair.random(await Grumpkin.new()); const completeAddress = await CompleteAddress.fromPrivateKeyAndPartialAddress( diff --git a/yarn-project/end-to-end/src/e2e_public_token_contract.test.ts b/yarn-project/end-to-end/src/e2e_public_token_contract.test.ts index fb2822c1f1e..ca058b17ce3 100644 --- a/yarn-project/end-to-end/src/e2e_public_token_contract.test.ts +++ b/yarn-project/end-to-end/src/e2e_public_token_contract.test.ts @@ -1,14 +1,14 @@ import { AztecAddress, Wallet } from '@aztec/aztec.js'; import { DebugLogger } from '@aztec/foundation/log'; import { PublicTokenContract } from '@aztec/noir-contracts/types'; -import { AztecRPC, CompleteAddress, TxStatus } from '@aztec/types'; +import { CompleteAddress, PXE, TxStatus } from '@aztec/types'; import times from 'lodash.times'; import { expectUnencryptedLogsFromLastBlockToBe, setup } from './fixtures/utils.js'; describe('e2e_public_token_contract', () => { - let aztecRpcServer: AztecRPC; + let aztecRpcServer: PXE; let wallet: Wallet; let logger: DebugLogger; let recipient: AztecAddress; diff --git a/yarn-project/end-to-end/src/e2e_sandbox_example.test.ts b/yarn-project/end-to-end/src/e2e_sandbox_example.test.ts index 84f72c805ca..5daed243d1c 100644 --- a/yarn-project/end-to-end/src/e2e_sandbox_example.test.ts +++ b/yarn-project/end-to-end/src/e2e_sandbox_example.test.ts @@ -1,10 +1,10 @@ // docs:start:imports import { - AztecRPC, Fr, + PXE, computeMessageSecretHash, - createAztecRpcClient, createDebugLogger, + createPXEClient, getSandboxAccountsWallets, getSchnorrAccount, waitForSandbox, @@ -21,8 +21,8 @@ describe('e2e_sandbox_example', () => { ////////////// CREATE THE CLIENT INTERFACE AND CONTACT THE SANDBOX ////////////// const logger = createDebugLogger('token'); - // We create AztecRPC client connected to the sandbox URL - const aztecRpc = createAztecRpcClient(SANDBOX_URL); + // We create PXE client connected to the sandbox URL + const aztecRpc = createPXEClient(SANDBOX_URL); // Wait for sandbox to be ready await waitForSandbox(aztecRpc); @@ -137,8 +137,8 @@ describe('e2e_sandbox_example', () => { it('can create accounts on the sandbox', async () => { const logger = createDebugLogger('token'); - // We create AztecRPC client connected to the sandbox URL - const aztecRpc = createAztecRpcClient(SANDBOX_URL); + // We create PXE client connected to the sandbox URL + const aztecRpc = createPXEClient(SANDBOX_URL); // Wait for sandbox to be ready await waitForSandbox(aztecRpc); @@ -146,7 +146,7 @@ describe('e2e_sandbox_example', () => { ////////////// CREATE SOME ACCOUNTS WITH SCHNORR SIGNERS ////////////// // Creates new accounts using an account contract that verifies schnorr signatures // Returns once the deployment transactions have settled - const createSchnorrAccounts = async (numAccounts: number, aztecRpc: AztecRPC) => { + const createSchnorrAccounts = async (numAccounts: number, aztecRpc: PXE) => { const accountManagers = Array(numAccounts) .fill(0) .map(() => diff --git a/yarn-project/end-to-end/src/fixtures/cross_chain_test_harness.ts b/yarn-project/end-to-end/src/fixtures/cross_chain_test_harness.ts index de813f13c5f..7c8d9dda8cf 100644 --- a/yarn-project/end-to-end/src/fixtures/cross_chain_test_harness.ts +++ b/yarn-project/end-to-end/src/fixtures/cross_chain_test_harness.ts @@ -7,8 +7,8 @@ import { sha256ToField } from '@aztec/foundation/crypto'; import { DebugLogger } from '@aztec/foundation/log'; import { OutboxAbi } from '@aztec/l1-artifacts'; import { TokenBridgeContract, TokenContract } from '@aztec/noir-contracts/types'; -import { AztecRPCServer } from '@aztec/pxe'; -import { AztecRPC, TxStatus } from '@aztec/types'; +import { PXEService } from '@aztec/pxe'; +import { PXE, TxStatus } from '@aztec/types'; import { Chain, HttpTransport, PublicClient, getContract } from 'viem'; @@ -21,7 +21,7 @@ import { deployAndInitializeStandardizedTokenAndBridgeContracts } from './utils. export class CrossChainTestHarness { static async new( aztecNode: AztecNodeService | undefined, - aztecRpcServer: AztecRPC, + aztecRpcServer: PXE, deployL1ContractsValues: DeployL1Contracts, accounts: CompleteAddress[], wallet: Wallet, @@ -91,7 +91,7 @@ export class CrossChainTestHarness { /** AztecNode. */ public aztecNode: AztecNodeService | undefined, /** AztecRpcServer. */ - public aztecRpcServer: AztecRPC, + public aztecRpcServer: PXE, /** CheatCodes. */ public cc: CheatCodes, /** Accounts. */ @@ -335,7 +335,7 @@ export class CrossChainTestHarness { async stop() { await this.aztecNode?.stop(); - if (this.aztecRpcServer instanceof AztecRPCServer) { + if (this.aztecRpcServer instanceof PXEService) { await this.aztecRpcServer?.stop(); } } diff --git a/yarn-project/end-to-end/src/fixtures/utils.ts b/yarn-project/end-to-end/src/fixtures/utils.ts index 34725dfc973..886a431ab86 100644 --- a/yarn-project/end-to-end/src/fixtures/utils.ts +++ b/yarn-project/end-to-end/src/fixtures/utils.ts @@ -8,7 +8,7 @@ import { EthCheatCodes, Wallet, createAccounts, - createAztecRpcClient as createJsonRpcClient, + createPXEClient as createJsonRpcClient, getSandboxAccountsWallets, } from '@aztec/aztec.js'; import { CircuitsWasm, GeneratorIndex } from '@aztec/circuits.js'; @@ -41,8 +41,8 @@ import { TokenPortalBytecode, } from '@aztec/l1-artifacts'; import { NonNativeTokenContract, TokenBridgeContract, TokenContract } from '@aztec/noir-contracts/types'; -import { AztecRPCServer, createAztecRPCServer, getConfigEnvVars as getRpcConfigEnvVars } from '@aztec/pxe'; -import { AztecRPC, L2BlockL2Logs, LogType, TxStatus } from '@aztec/types'; +import { PXEService, createPXEService, getConfigEnvVars as getRpcConfigEnvVars } from '@aztec/pxe'; +import { L2BlockL2Logs, LogType, PXE, TxStatus } from '@aztec/types'; import { Account, @@ -63,7 +63,7 @@ import { MNEMONIC, localAnvil } from './fixtures.js'; const { SANDBOX_URL = '' } = process.env; -export const waitForRPCServer = async (rpcServer: AztecRPC, logger: DebugLogger) => { +export const waitForRPCServer = async (rpcServer: PXE, logger: DebugLogger) => { await retryUntil(async () => { try { logger('Attempting to contact RPC Server...'); @@ -126,24 +126,24 @@ export const setupL1Contracts = async ( }; /** - * Sets up Aztec RPC Server. + * Sets up Private Execution Environment (PXE). * @param numberOfAccounts - The number of new accounts to be created once the RPC server is initiated. * @param aztecNode - The instance of an aztec node, if one is required * @param firstPrivKey - The private key of the first account to be created. * @param logger - The logger to be used. * @param useLogSuffix - Whether to add a randomly generated suffix to the RPC server debug logs. - * @returns Aztec RPC server, accounts, wallets and logger. + * @returns Private Execution Environment (PXE), accounts, wallets and logger. */ -export async function setupAztecRPCServer( +export async function setupPXEService( numberOfAccounts: number, aztecNode: AztecNodeService, logger = getLogger(), useLogSuffix = false, ): Promise<{ /** - * The Aztec RPC instance. + * The PXE instance. */ - aztecRpcServer: AztecRPC; + aztecRpcServer: PXE; /** * The accounts created by the RPC server. */ @@ -158,7 +158,7 @@ export async function setupAztecRPCServer( logger: DebugLogger; }> { const rpcConfig = getRpcConfigEnvVars(); - const rpc = await createAztecRPCServer(aztecNode, rpcConfig, {}, useLogSuffix); + const rpc = await createPXEService(aztecNode, rpcConfig, {}, useLogSuffix); const wallets = await createAccounts(rpc, numberOfAccounts); @@ -231,9 +231,9 @@ export async function setup( */ aztecNode: AztecNodeService | undefined; /** - * The Aztec RPC server. + * The Private Execution Environment (PXE). */ - aztecRpcServer: AztecRPC; + aztecRpcServer: PXE; /** * Return values from deployL1Contracts function. */ @@ -295,13 +295,13 @@ export async function setup( const aztecNode = await createAztecNode(config, logger); - const { aztecRpcServer, accounts, wallets } = await setupAztecRPCServer(numberOfAccounts, aztecNode!, logger); + const { aztecRpcServer, accounts, wallets } = await setupPXEService(numberOfAccounts, aztecNode!, logger); const cheatCodes = await CheatCodes.create(config.rpcUrl, aztecRpcServer!); const teardown = async () => { await aztecNode?.stop(); - if (aztecRpcServer instanceof AztecRPCServer) await aztecRpcServer?.stop(); + if (aztecRpcServer instanceof PXEService) await aztecRpcServer?.stop(); }; return { @@ -455,7 +455,7 @@ export async function deployAndInitializeStandardizedTokenAndBridgeContracts( /** * Deploy L1 token and portal, initialize portal, deploy a non native l2 token contract and attach is to the portal. - * @param aztecRpcServer - the aztec rpc server instance + * @param aztecRpcServer - Private Execution Environment (PXE) instance * @param walletClient - A viem WalletClient. * @param publicClient - A viem PublicClient. * @param rollupRegistryAddress - address of rollup registry to pass to initialize the token portal @@ -544,10 +544,10 @@ export const expectsNumOfEncryptedLogsInTheLastBlockToBe = async ( /** * Checks that the last block contains the given expected unencrypted log messages. - * @param rpc - The instance of AztecRPC for retrieving the logs. + * @param rpc - The instance of PXE for retrieving the logs. * @param logMessages - The set of expected log messages. */ -export const expectUnencryptedLogsFromLastBlockToBe = async (rpc: AztecRPC, logMessages: string[]) => { +export const expectUnencryptedLogsFromLastBlockToBe = async (rpc: PXE, logMessages: string[]) => { // docs:start:get_logs // Get the latest block number to retrieve logs from const l2BlockNum = await rpc.getBlockNumber(); diff --git a/yarn-project/end-to-end/src/guides/dapp_testing.test.ts b/yarn-project/end-to-end/src/guides/dapp_testing.test.ts index 161454e4afa..aeae2ca3a23 100644 --- a/yarn-project/end-to-end/src/guides/dapp_testing.test.ts +++ b/yarn-project/end-to-end/src/guides/dapp_testing.test.ts @@ -1,13 +1,13 @@ import { createSandbox } from '@aztec/aztec-sandbox'; import { AccountWallet, - AztecRPC, CheatCodes, Fr, L2BlockL2Logs, + PXE, computeMessageSecretHash, createAccount, - createAztecRpcClient, + createPXEClient, getSandboxAccountsWallets, waitForSandbox, } from '@aztec/aztec.js'; @@ -19,7 +19,7 @@ const { SANDBOX_URL = 'http://localhost:8080', ETHEREUM_HOST = 'http://localhost describe('guides/dapp/testing', () => { describe('on in-proc sandbox', () => { describe('private token contract', () => { - let rpc: AztecRPC; + let rpc: PXE; let stop: () => Promise; let owner: AccountWallet; let recipient: AccountWallet; @@ -52,19 +52,19 @@ describe('guides/dapp/testing', () => { describe('on local sandbox', () => { beforeAll(async () => { - const rpc = createAztecRpcClient(SANDBOX_URL); + const rpc = createPXEClient(SANDBOX_URL); await waitForSandbox(rpc); }); // docs:start:sandbox-example describe('private token contract', () => { - let rpc: AztecRPC; + let rpc: PXE; let owner: AccountWallet; let recipient: AccountWallet; let token: TokenContract; beforeEach(async () => { - rpc = createAztecRpcClient(SANDBOX_URL); + rpc = createPXEClient(SANDBOX_URL); owner = await createAccount(rpc); recipient = await createAccount(rpc); token = await TokenContract.deploy(owner).send().deployed(); @@ -83,14 +83,14 @@ describe('guides/dapp/testing', () => { // docs:end:sandbox-example describe('private token contract with initial accounts', () => { - let rpc: AztecRPC; + let rpc: PXE; let owner: AccountWallet; let recipient: AccountWallet; let token: TokenContract; beforeEach(async () => { // docs:start:use-existing-wallets - rpc = createAztecRpcClient(SANDBOX_URL); + rpc = createPXEClient(SANDBOX_URL); [owner, recipient] = await getSandboxAccountsWallets(rpc); token = await TokenContract.deploy(owner).send().deployed(); await token.methods._initialize(owner.getAddress()).send().wait(); @@ -108,13 +108,13 @@ describe('guides/dapp/testing', () => { }); describe('cheats', () => { - let rpc: AztecRPC; + let rpc: PXE; let owner: AccountWallet; let testContract: TestContract; let cheats: CheatCodes; beforeAll(async () => { - rpc = createAztecRpcClient(SANDBOX_URL); + rpc = createPXEClient(SANDBOX_URL); owner = await createAccount(rpc); testContract = await TestContract.deploy(owner).send().deployed(); cheats = await CheatCodes.create(ETHEREUM_HOST, rpc); @@ -130,7 +130,7 @@ describe('guides/dapp/testing', () => { }); describe('assertions', () => { - let rpc: AztecRPC; + let rpc: PXE; let owner: AccountWallet; let recipient: AccountWallet; let testContract: TestContract; @@ -139,7 +139,7 @@ describe('guides/dapp/testing', () => { let ownerSlot: Fr; beforeAll(async () => { - rpc = createAztecRpcClient(SANDBOX_URL); + rpc = createPXEClient(SANDBOX_URL); owner = await createAccount(rpc); recipient = await createAccount(rpc); testContract = await TestContract.deploy(owner).send().deployed(); diff --git a/yarn-project/end-to-end/src/guides/up_quick_start.test.ts b/yarn-project/end-to-end/src/guides/up_quick_start.test.ts index d544381b256..855dbcaf4ff 100644 --- a/yarn-project/end-to-end/src/guides/up_quick_start.test.ts +++ b/yarn-project/end-to-end/src/guides/up_quick_start.test.ts @@ -7,7 +7,7 @@ describe('guides/up_quick_start', () => { it('works', async () => { await waitForSandbox(); execSync( - `DEBUG="aztec:*" AZTEC_RPC_HOST=\${SANDBOX_URL:-http://localhost:8080} PATH=$PATH:../node_modules/.bin ./src/guides/up_quick_start.sh`, + `DEBUG="aztec:*" PXE_HOST=\${SANDBOX_URL:-http://localhost:8080} PATH=$PATH:../node_modules/.bin ./src/guides/up_quick_start.sh`, { shell: '/bin/bash', stdio: 'pipe', diff --git a/yarn-project/end-to-end/src/pxe_sandbox.test.ts b/yarn-project/end-to-end/src/pxe_sandbox.test.ts new file mode 100644 index 00000000000..bc1ea20fc49 --- /dev/null +++ b/yarn-project/end-to-end/src/pxe_sandbox.test.ts @@ -0,0 +1,12 @@ +import { createPXEClient, waitForSandbox } from '@aztec/aztec.js'; +import { pxeTestSuite } from '@aztec/pxe'; + +const { SANDBOX_URL = 'http://localhost:8080' } = process.env; + +const setup = async () => { + const aztecRpc = createPXEClient(SANDBOX_URL); + await waitForSandbox(aztecRpc); + return aztecRpc; +}; + +pxeTestSuite('pxe_sandbox', setup); diff --git a/yarn-project/end-to-end/src/uniswap_trade_on_l1_from_l2.test.ts b/yarn-project/end-to-end/src/uniswap_trade_on_l1_from_l2.test.ts index b1d220dceca..40ff939630d 100644 --- a/yarn-project/end-to-end/src/uniswap_trade_on_l1_from_l2.test.ts +++ b/yarn-project/end-to-end/src/uniswap_trade_on_l1_from_l2.test.ts @@ -5,7 +5,7 @@ import { EthAddress } from '@aztec/foundation/eth-address'; import { DebugLogger } from '@aztec/foundation/log'; import { UniswapPortalAbi, UniswapPortalBytecode } from '@aztec/l1-artifacts'; import { UniswapContract } from '@aztec/noir-contracts/types'; -import { AztecRPC, CompleteAddress, TxStatus } from '@aztec/types'; +import { CompleteAddress, PXE, TxStatus } from '@aztec/types'; import { getContract, parseEther } from 'viem'; @@ -32,7 +32,7 @@ describe.skip('uniswap_trade_on_l1_from_l2', () => { const DAI_ADDRESS: EthAddress = EthAddress.fromString('0x6B175474E89094C44Da98b954EedeAC495271d0F'); let aztecNode: AztecNodeService | undefined; - let aztecRpcServer: AztecRPC; + let aztecRpcServer: PXE; let wallet: Wallet; let accounts: CompleteAddress[]; let logger: DebugLogger; diff --git a/yarn-project/key-store/README.md b/yarn-project/key-store/README.md index 25d284f1f3a..e8dff2a84be 100644 --- a/yarn-project/key-store/README.md +++ b/yarn-project/key-store/README.md @@ -1,3 +1,3 @@ # Key Store -A key store is an input component for the [AztecRPCServer](../pxe/) to manage keys securely. It provides a secure environment and interfaces for users to manage their keys. When the AztecRPCServer requests keys and signatures from the key store, a well-designed key store should prompt users to authorize the requested action before sending any sensitive information to the AztecRPCServer. This helps to ensure that sensitive data, such as private keys, is not accessible to unauthorized parties. Additionally, the key store should provide robust protection mechanisms such as encryption, multi-factor authentication, and backup/restore functionalities to prevent data loss or theft. +A key store is an input component for the [PXEService](../pxe/) to manage keys securely. It provides a secure environment and interfaces for users to manage their keys. When the PXEService requests keys and signatures from the key store, a well-designed key store should prompt users to authorize the requested action before sending any sensitive information to the PXEService. This helps to ensure that sensitive data, such as private keys, is not accessible to unauthorized parties. Additionally, the key store should provide robust protection mechanisms such as encryption, multi-factor authentication, and backup/restore functionalities to prevent data loss or theft. diff --git a/yarn-project/noir-compiler/src/__snapshots__/index.test.ts.snap b/yarn-project/noir-compiler/src/__snapshots__/index.test.ts.snap index d3c5c08ec31..b6fdf8207ce 100644 --- a/yarn-project/noir-compiler/src/__snapshots__/index.test.ts.snap +++ b/yarn-project/noir-compiler/src/__snapshots__/index.test.ts.snap @@ -267,7 +267,7 @@ exports[`noir-compiler using nargo binary generates typescript interface 1`] = ` /* eslint-disable */ import { AztecAddress, CompleteAddress, ContractBase, ContractFunctionInteraction, ContractMethod, DeployMethod, FieldLike, Wallet } from '@aztec/aztec.js'; import { Fr, Point } from '@aztec/foundation/fields'; -import { AztecRPC, PublicKey } from '@aztec/types'; +import { PXE, PublicKey } from '@aztec/types'; import { ContractAbi } from '@aztec/foundation/abi'; import TestContractContractAbiJson from '../target/test.json' assert { type: 'json' }; export const TestContractContractAbi = TestContractContractAbiJson as ContractAbi; @@ -311,14 +311,14 @@ export class TestContractContract extends ContractBase { /** * Creates a tx to deploy a new instance of this contract. */ - public static deploy(rpc: AztecRPC, pub_param: FieldLike) { + public static deploy(rpc: PXE, pub_param: FieldLike) { return new DeployMethod(Point.ZERO, rpc, TestContractContractAbi, Array.from(arguments).slice(1)); } /** * Creates a tx to deploy a new instance of this contract using the specified public key to derive the address. */ - public static deployWithPublicKey(rpc: AztecRPC, publicKey: PublicKey, pub_param: FieldLike) { + public static deployWithPublicKey(rpc: PXE, publicKey: PublicKey, pub_param: FieldLike) { return new DeployMethod(publicKey, rpc, TestContractContractAbi, Array.from(arguments).slice(2)); } diff --git a/yarn-project/noir-compiler/src/contract-interface-gen/typescript.ts b/yarn-project/noir-compiler/src/contract-interface-gen/typescript.ts index a2fc7a94c2d..272179adf61 100644 --- a/yarn-project/noir-compiler/src/contract-interface-gen/typescript.ts +++ b/yarn-project/noir-compiler/src/contract-interface-gen/typescript.ts @@ -69,14 +69,14 @@ function generateDeploy(input: ContractAbi) { /** * Creates a tx to deploy a new instance of this contract. */ - public static deploy(rpc: AztecRPC, ${args}) { + public static deploy(rpc: PXE, ${args}) { return new DeployMethod<${input.name}Contract>(Point.ZERO, rpc, ${abiName}, Array.from(arguments).slice(1)); } /** * Creates a tx to deploy a new instance of this contract using the specified public key to derive the address. */ - public static deployWithPublicKey(rpc: AztecRPC, publicKey: PublicKey, ${args}) { + public static deployWithPublicKey(rpc: PXE, publicKey: PublicKey, ${args}) { return new DeployMethod<${input.name}Contract>(publicKey, rpc, ${abiName}, Array.from(arguments).slice(2)); } `; @@ -180,7 +180,7 @@ export function generateTypescriptContractInterface(input: ContractAbi, abiImpor /* eslint-disable */ import { AztecAddress, CompleteAddress, ContractBase, ContractFunctionInteraction, ContractMethod, DeployMethod, FieldLike, AztecAddressLike, EthAddressLike, Wallet } from '@aztec/aztec.js'; import { Fr, Point } from '@aztec/foundation/fields'; -import { AztecRPC, PublicKey } from '@aztec/types'; +import { PXE, PublicKey } from '@aztec/types'; import { ContractAbi } from '@aztec/foundation/abi'; ${abiStatement} diff --git a/yarn-project/pxe/README.md b/yarn-project/pxe/README.md index 9f50fa1cf0f..ccbe49a9032 100644 --- a/yarn-project/pxe/README.md +++ b/yarn-project/pxe/README.md @@ -1,10 +1,10 @@ -# AztecRPCServer & AztecRPCClient +# PXEService & PXEClient -`AztecRPCServer` is a server-side software that provides a set of apis for interacting with the Aztec network. It acts as a bridge between the network and client applications by exposing methods to manage accounts, deploy contracts, create transactions, and retrieve public and account-specific information. It provides a secure environment for the execution of sensitive operations, ensuring private information and decrypted data are not accessible to unauthorized applications. The AztecRPCServer is a critical component of the Aztec network, and its security and reliability are essential to the overall trustworthiness of user's data. +`PXEService` is a server-side software that provides a set of apis for interacting with the Aztec network. It acts as a bridge between the network and client applications by exposing methods to manage accounts, deploy contracts, create transactions, and retrieve public and account-specific information. It provides a secure environment for the execution of sensitive operations, ensuring private information and decrypted data are not accessible to unauthorized applications. The PXEService is a critical component of the Aztec network, and its security and reliability are essential to the overall trustworthiness of user's data. -`AztecRPCClient` is the interface the AztecRPCServer and every client-side instance implement. Various implementations of the client-side can exist, including those for different platforms such as mobile apps and web browsers. It is a relay between the dApps and the actual AztecRPCServer. +`PXEClient` is the interface the PXEService and every client-side instance implement. Various implementations of the client-side can exist, including those for different platforms such as mobile apps and web browsers. It is a relay between the dApps and the actual PXEService. -### Main Components in an AztecRPCServer +### Main Components in an PXEService - [Acir Simulator](../acir-simulator/) - [Key Store](../key-store/) diff --git a/yarn-project/pxe/src/aztec_rpc_http/index.ts b/yarn-project/pxe/src/aztec_rpc_http/index.ts deleted file mode 100644 index 939d0ac64c8..00000000000 --- a/yarn-project/pxe/src/aztec_rpc_http/index.ts +++ /dev/null @@ -1 +0,0 @@ -export * from './aztec_rpc_http_server.js'; diff --git a/yarn-project/pxe/src/aztec_rpc_server/index.ts b/yarn-project/pxe/src/aztec_rpc_server/index.ts deleted file mode 100644 index 1cc9adbe3cb..00000000000 --- a/yarn-project/pxe/src/aztec_rpc_server/index.ts +++ /dev/null @@ -1,3 +0,0 @@ -export * from './aztec_rpc_server.js'; -export * from './create_aztec_rpc_server.js'; -export { aztecRpcTestSuite } from './test/aztec_rpc_test_suite.js'; diff --git a/yarn-project/pxe/src/config/index.ts b/yarn-project/pxe/src/config/index.ts index 11a63369e05..e6f85c85e26 100644 --- a/yarn-project/pxe/src/config/index.ts +++ b/yarn-project/pxe/src/config/index.ts @@ -5,7 +5,7 @@ import { fileURLToPath } from 'url'; /** * Configuration settings for the RPC Server. */ -export interface RpcServerConfig { +export interface PXEServiceConfig { /** * The interval to wait between polling for new blocks. */ @@ -15,11 +15,11 @@ export interface RpcServerConfig { /** * Creates an instance of SequencerClientConfig out of environment variables using sensible defaults for integration testing if not set. */ -export function getConfigEnvVars(): RpcServerConfig { - const { RPC_SERVER_BLOCK_POLLING_INTERVAL_MS } = process.env; +export function getConfigEnvVars(): PXEServiceConfig { + const { PXE_SERVICE_BLOCK_POLLING_INTERVAL_MS } = process.env; return { - l2BlockPollingIntervalMS: RPC_SERVER_BLOCK_POLLING_INTERVAL_MS ? +RPC_SERVER_BLOCK_POLLING_INTERVAL_MS : 1000, + l2BlockPollingIntervalMS: PXE_SERVICE_BLOCK_POLLING_INTERVAL_MS ? +PXE_SERVICE_BLOCK_POLLING_INTERVAL_MS : 1000, }; } diff --git a/yarn-project/pxe/src/index.ts b/yarn-project/pxe/src/index.ts index 1356fae3a22..3aa2f478b0b 100644 --- a/yarn-project/pxe/src/index.ts +++ b/yarn-project/pxe/src/index.ts @@ -1,5 +1,5 @@ -export * from './aztec_rpc_server/index.js'; -export * from './aztec_rpc_http/index.js'; +export * from './pxe_service/index.js'; +export * from './pxe_http/index.js'; export * from './config/index.js'; export { Tx, TxHash } from '@aztec/types'; diff --git a/yarn-project/pxe/src/pxe_http/index.ts b/yarn-project/pxe/src/pxe_http/index.ts new file mode 100644 index 00000000000..9de03e58d4d --- /dev/null +++ b/yarn-project/pxe/src/pxe_http/index.ts @@ -0,0 +1 @@ +export * from './pxe_http_server.js'; diff --git a/yarn-project/pxe/src/aztec_rpc_http/aztec_rpc_http_server.ts b/yarn-project/pxe/src/pxe_http/pxe_http_server.ts similarity index 77% rename from yarn-project/pxe/src/aztec_rpc_http/aztec_rpc_http_server.ts rename to yarn-project/pxe/src/pxe_http/pxe_http_server.ts index 3dc5b84e44c..275de40bb85 100644 --- a/yarn-project/pxe/src/aztec_rpc_http/aztec_rpc_http_server.ts +++ b/yarn-project/pxe/src/pxe_http/pxe_http_server.ts @@ -3,7 +3,6 @@ import { Fr, GrumpkinScalar, Point } from '@aztec/foundation/fields'; import { JsonRpcServer } from '@aztec/foundation/json-rpc/server'; import { AuthWitness, - AztecRPC, CompleteAddress, ContractData, ExtendedContractData, @@ -11,6 +10,7 @@ import { L2BlockL2Logs, L2Tx, NotePreimage, + PXE, Tx, TxExecutionRequest, TxHash, @@ -25,11 +25,11 @@ import { EthAddress } from '../index.js'; export const localAnvil = foundry; /** - * Wraps an instance of the Aztec RPC Server implementation to a JSON RPC HTTP interface. + * Wraps an instance of Private Execution Environment (PXE) implementation to a JSON RPC HTTP interface. * @returns A new instance of the HTTP server. */ -export function getHttpRpcServer(aztecRpcServer: AztecRPC): JsonRpcServer { - const generatedRpcServer = new JsonRpcServer( +export function createPxeRpcServer(aztecRpcServer: PXE): JsonRpcServer { + return new JsonRpcServer( aztecRpcServer, { CompleteAddress, @@ -51,7 +51,6 @@ export function getHttpRpcServer(aztecRpcServer: AztecRPC): JsonRpcServer { false, ['start', 'stop'], ); - return generatedRpcServer; } /** @@ -60,8 +59,8 @@ export function getHttpRpcServer(aztecRpcServer: AztecRPC): JsonRpcServer { * @param port - Port to listen in. * @returns A running http server. */ -export function startHttpRpcServer(aztecRpcServer: AztecRPC, port: string | number): http.Server { - const rpcServer = getHttpRpcServer(aztecRpcServer); +export function startPxeHttpServer(aztecRpcServer: PXE, port: string | number): http.Server { + const rpcServer = createPxeRpcServer(aztecRpcServer); const app = rpcServer.getApp(); const httpServer = http.createServer(app.callback()); diff --git a/yarn-project/pxe/src/aztec_rpc_server/create_aztec_rpc_server.ts b/yarn-project/pxe/src/pxe_service/create_pxe_service.ts similarity index 59% rename from yarn-project/pxe/src/aztec_rpc_server/create_aztec_rpc_server.ts rename to yarn-project/pxe/src/pxe_service/create_pxe_service.ts index 4a4f5a7eb73..9319a880dfa 100644 --- a/yarn-project/pxe/src/aztec_rpc_server/create_aztec_rpc_server.ts +++ b/yarn-project/pxe/src/pxe_service/create_pxe_service.ts @@ -2,14 +2,14 @@ import { Grumpkin } from '@aztec/circuits.js/barretenberg'; import { TestKeyStore } from '@aztec/key-store'; import { AztecNode, KeyStore } from '@aztec/types'; -import { RpcServerConfig } from '../config/index.js'; +import { PXEServiceConfig } from '../config/index.js'; import { Database, MemoryDB } from '../database/index.js'; -import { AztecRPCServer } from './aztec_rpc_server.js'; +import { PXEService } from './pxe_service.js'; /** - * Optional information for creating an AztecRPCServer. + * Optional information for creating an PXEService. */ -interface CreateAztecRPCServerOptions { +interface CreatePXEServiceOptions { /** * A secure storage for cryptographic keys. */ @@ -21,19 +21,19 @@ interface CreateAztecRPCServerOptions { } /** - * Create and start an AztecRPCServer instance with the given AztecNode. + * Create and start an PXEService instance with the given AztecNode. * If no keyStore or database is provided, it will use TestKeyStore and MemoryDB as default values. - * Returns a Promise that resolves to the started AztecRPCServer instance. + * Returns a Promise that resolves to the started PXEService instance. * * @param aztecNode - The AztecNode instance to be used by the server. - * @param config - The Rpc Server Config to use - * @param options - (Optional) Optional information for creating an AztecRPCServer. - * @returns A Promise that resolves to the started AztecRPCServer instance. + * @param config - The PXE Service Config to use + * @param options - (Optional) Optional information for creating an PXEService. + * @returns A Promise that resolves to the started PXEService instance. */ -export async function createAztecRPCServer( +export async function createPXEService( aztecNode: AztecNode, - config: RpcServerConfig, - { keyStore, db }: CreateAztecRPCServerOptions = {}, + config: PXEServiceConfig, + { keyStore, db }: CreatePXEServiceOptions = {}, useLogSuffix: string | boolean | undefined = undefined, ) { const logSuffix = @@ -46,7 +46,7 @@ export async function createAztecRPCServer( keyStore = keyStore || new TestKeyStore(await Grumpkin.new()); db = db || new MemoryDB(logSuffix); - const server = new AztecRPCServer(keyStore, aztecNode, db, config, logSuffix); + const server = new PXEService(keyStore, aztecNode, db, config, logSuffix); await server.start(); return server; } diff --git a/yarn-project/pxe/src/pxe_service/index.ts b/yarn-project/pxe/src/pxe_service/index.ts new file mode 100644 index 00000000000..a43b331f3ad --- /dev/null +++ b/yarn-project/pxe/src/pxe_service/index.ts @@ -0,0 +1,3 @@ +export * from './pxe_service.js'; +export * from './create_pxe_service.js'; +export { pxeTestSuite } from './test/pxe_test_suite.js'; diff --git a/yarn-project/pxe/src/aztec_rpc_server/aztec_rpc_server.ts b/yarn-project/pxe/src/pxe_service/pxe_service.ts similarity index 97% rename from yarn-project/pxe/src/aztec_rpc_server/aztec_rpc_server.ts rename to yarn-project/pxe/src/pxe_service/pxe_service.ts index 85f9910414c..6a20d9b06cd 100644 --- a/yarn-project/pxe/src/aztec_rpc_server/aztec_rpc_server.ts +++ b/yarn-project/pxe/src/pxe_service/pxe_service.ts @@ -27,7 +27,6 @@ import NoirVersion from '@aztec/noir-compiler/noir-version'; import { AuthWitness, AztecNode, - AztecRPC, ContractDao, ContractData, DeployedContract, @@ -41,6 +40,7 @@ import { LogType, NodeInfo, NotePreimage, + PXE, PublicKey, SimulationError, Tx, @@ -54,7 +54,7 @@ import { toContractDao, } from '@aztec/types'; -import { RpcServerConfig, getPackageInfo } from '../config/index.js'; +import { PXEServiceConfig, getPackageInfo } from '../config/index.js'; import { ContractDataOracle } from '../contract_data_oracle/index.js'; import { Database } from '../database/index.js'; import { KernelOracle } from '../kernel_oracle/index.js'; @@ -63,9 +63,9 @@ import { getAcirSimulator } from '../simulator/index.js'; import { Synchronizer } from '../synchronizer/index.js'; /** - * A remote Aztec RPC Client implementation. + * A Private Execution Environment (PXE) implementation. */ -export class AztecRPCServer implements AztecRPC { +export class PXEService implements PXE { private synchronizer: Synchronizer; private contractDataOracle: ContractDataOracle; private simulator: AcirSimulator; @@ -76,10 +76,10 @@ export class AztecRPCServer implements AztecRPC { private keyStore: KeyStore, private node: AztecNode, private db: Database, - private config: RpcServerConfig, + private config: PXEServiceConfig, logSuffix?: string, ) { - this.log = createDebugLogger(logSuffix ? `aztec:rpc_server_${logSuffix}` : `aztec:rpc_server`); + this.log = createDebugLogger(logSuffix ? `aztec:pxe_service_${logSuffix}` : `aztec:pxe_service`); this.synchronizer = new Synchronizer(node, db, logSuffix); this.contractDataOracle = new ContractDataOracle(db, node); this.simulator = getAcirSimulator(db, node, node, node, keyStore, this.contractDataOracle); @@ -88,7 +88,7 @@ export class AztecRPCServer implements AztecRPC { } /** - * Starts the Aztec RPC server by beginning the synchronisation process between the Aztec node and the database. + * Starts the PXE Service by beginning the synchronisation process between the Aztec node and the database. * * @returns A promise that resolves when the server has started successfully. */ @@ -99,7 +99,7 @@ export class AztecRPCServer implements AztecRPC { } /** - * Stops the Aztec RPC server, halting processing of new transactions and shutting down the synchronizer. + * Stops the PXE Service, halting processing of new transactions and shutting down the synchronizer. * This function ensures that all ongoing tasks are completed before stopping the server. * It is useful for gracefully shutting down the server during maintenance or restarts. * @@ -365,7 +365,7 @@ export class AztecRPCServer implements AztecRPC { async #getFunctionCall(functionName: string, args: any[], to: AztecAddress): Promise { const contract = await this.db.getContract(to); if (!contract) { - throw new Error(`Unknown contract ${to}: add it to Aztec RPC server by calling server.addContracts(...)`); + throw new Error(`Unknown contract ${to}: add it to PXE Service by calling server.addContracts(...)`); } const functionDao = contract.functions.find(f => f.name === functionName); diff --git a/yarn-project/pxe/src/aztec_rpc_server/test/aztec_rpc_server.test.ts b/yarn-project/pxe/src/pxe_service/test/pxe_service.test.ts similarity index 74% rename from yarn-project/pxe/src/aztec_rpc_server/test/aztec_rpc_server.test.ts rename to yarn-project/pxe/src/pxe_service/test/pxe_service.test.ts index 09aabfd08ed..a6fde8a0f36 100644 --- a/yarn-project/pxe/src/aztec_rpc_server/test/aztec_rpc_server.test.ts +++ b/yarn-project/pxe/src/pxe_service/test/pxe_service.test.ts @@ -2,20 +2,20 @@ import { Grumpkin } from '@aztec/circuits.js/barretenberg'; import { L1ContractAddresses } from '@aztec/ethereum'; import { EthAddress } from '@aztec/foundation/eth-address'; import { TestKeyStore } from '@aztec/key-store'; -import { AztecNode, AztecRPC, L2Tx, mockTx } from '@aztec/types'; +import { AztecNode, L2Tx, PXE, mockTx } from '@aztec/types'; import { MockProxy, mock } from 'jest-mock-extended'; import { MemoryDB } from '../../database/memory_db.js'; -import { RpcServerConfig } from '../../index.js'; -import { AztecRPCServer } from '../aztec_rpc_server.js'; -import { aztecRpcTestSuite } from './aztec_rpc_test_suite.js'; +import { PXEServiceConfig } from '../../index.js'; +import { PXEService } from '../pxe_service.js'; +import { pxeTestSuite } from './pxe_test_suite.js'; -async function createAztecRpcServer(): Promise { +async function createPXEService(): Promise { const keyStore = new TestKeyStore(await Grumpkin.new()); const node = mock(); const db = new MemoryDB(); - const config: RpcServerConfig = { + const config: PXEServiceConfig = { l2BlockPollingIntervalMS: 100, }; @@ -33,16 +33,16 @@ async function createAztecRpcServer(): Promise { }; node.getL1ContractAddresses.mockResolvedValue(mockedContracts); - return new AztecRPCServer(keyStore, node, db, config); + return new PXEService(keyStore, node, db, config); } -aztecRpcTestSuite('AztecRPCServer', createAztecRpcServer); +pxeTestSuite('PXEService', createPXEService); -describe('AztecRPCServer', () => { +describe('PXEService', () => { let keyStore: TestKeyStore; let node: MockProxy; let db: MemoryDB; - let config: RpcServerConfig; + let config: PXEServiceConfig; beforeEach(async () => { keyStore = new TestKeyStore(await Grumpkin.new()); @@ -59,7 +59,7 @@ describe('AztecRPCServer', () => { node.getTx.mockResolvedValue(settledTx); - const rpc = new AztecRPCServer(keyStore, node, db, config); + const rpc = new PXEService(keyStore, node, db, config); await expect(rpc.sendTx(duplicateTx)).rejects.toThrowError(/A settled tx with equal hash/); }); }); diff --git a/yarn-project/pxe/src/aztec_rpc_server/test/aztec_rpc_test_suite.ts b/yarn-project/pxe/src/pxe_service/test/pxe_test_suite.ts similarity index 95% rename from yarn-project/pxe/src/aztec_rpc_server/test/aztec_rpc_test_suite.ts rename to yarn-project/pxe/src/pxe_service/test/pxe_test_suite.ts index ce612295dfd..b9ba8afa9c1 100644 --- a/yarn-project/pxe/src/aztec_rpc_server/test/aztec_rpc_test_suite.ts +++ b/yarn-project/pxe/src/pxe_service/test/pxe_test_suite.ts @@ -1,17 +1,11 @@ import { AztecAddress, CompleteAddress, Fr, FunctionData, Point, TxContext } from '@aztec/circuits.js'; import { Grumpkin } from '@aztec/circuits.js/barretenberg'; import { ConstantKeyPair } from '@aztec/key-store'; -import { - AztecRPC, - DeployedContract, - INITIAL_L2_BLOCK_NUM, - TxExecutionRequest, - randomDeployedContract, -} from '@aztec/types'; - -export const aztecRpcTestSuite = (testName: string, aztecRpcSetup: () => Promise) => { +import { DeployedContract, INITIAL_L2_BLOCK_NUM, PXE, TxExecutionRequest, randomDeployedContract } from '@aztec/types'; + +export const pxeTestSuite = (testName: string, aztecRpcSetup: () => Promise) => { describe(testName, () => { - let rpc: AztecRPC; + let rpc: PXE; beforeAll(async () => { rpc = await aztecRpcSetup(); diff --git a/yarn-project/pxe/src/simulator_oracle/index.ts b/yarn-project/pxe/src/simulator_oracle/index.ts index 68309243747..0fb1ee0ce38 100644 --- a/yarn-project/pxe/src/simulator_oracle/index.ts +++ b/yarn-project/pxe/src/simulator_oracle/index.ts @@ -34,7 +34,7 @@ export class SimulatorOracle implements DBOracle { const completeAddress = await this.db.getCompleteAddress(address); if (!completeAddress) throw new Error( - `Unknown complete address for address ${address.toString()}. Add the information to Aztec RPC server by calling server.registerRecipient(...) or server.registerAccount(...)`, + `Unknown complete address for address ${address.toString()}. Add the information to PXE Service by calling server.registerRecipient(...) or server.registerAccount(...)`, ); return completeAddress; } diff --git a/yarn-project/types/src/interfaces/index.ts b/yarn-project/types/src/interfaces/index.ts index d53098ad94c..cde71ea5604 100644 --- a/yarn-project/types/src/interfaces/index.ts +++ b/yarn-project/types/src/interfaces/index.ts @@ -3,7 +3,7 @@ export * from './hasher.js'; export * from './data_commitment_provider.js'; export * from './l1_l2_message_provider.js'; export * from './aztec-node.js'; -export * from './aztec_rpc.js'; +export * from './pxe.js'; export * from './deployed-contract.js'; export * from './node-info.js'; export * from './sync-status.js'; diff --git a/yarn-project/types/src/interfaces/aztec_rpc.ts b/yarn-project/types/src/interfaces/pxe.ts similarity index 97% rename from yarn-project/types/src/interfaces/aztec_rpc.ts rename to yarn-project/types/src/interfaces/pxe.ts index 94217c10a83..ec36db4fb40 100644 --- a/yarn-project/types/src/interfaces/aztec_rpc.ts +++ b/yarn-project/types/src/interfaces/pxe.ts @@ -20,12 +20,12 @@ import { SyncStatus } from './sync-status.js'; // docs:start:rpc-interface /** - * The Aztec RPC Server runs locally for each user, providing functionality for all the operations + * Private Execution Environment (PXE) runs locally for each user, providing functionality for all the operations * needed to interact with the Aztec network, including account management, private data management, * transaction local simulation, and access to an Aztec node. This interface, as part of a Wallet, * is exposed to dapps for interacting with the network on behalf of the user. */ -export interface AztecRPC { +export interface PXE { /** * Insert an auth witness for a given message hash. Auth witnesses are used to authorise actions on * behalf of a user. For instance, a token transfer initiated by a different address may request @@ -41,7 +41,7 @@ export interface AztecRPC { addAuthWitness(authWitness: AuthWitness): Promise; /** - * Registers a user account in the Aztec RPC server given its master encryption private key. + * Registers a user account in PXE given its master encryption private key. * Once a new account is registered, the RPC server will trial-decrypt all published notes on * the chain and store those that correspond to the registered account. * @@ -52,7 +52,7 @@ export interface AztecRPC { registerAccount(privKey: GrumpkinPrivateKey, partialAddress: PartialAddress): Promise; /** - * Registers a recipient in the Aztec RPC server. This is required when sending encrypted notes to + * Registers a recipient in PXE. This is required when sending encrypted notes to * a user who hasn't deployed their account contract yet. Since their account is not deployed, their * encryption public key has not been broadcasted, so we need to manually register it on the RPC server * in order to be able to encrypt data for this recipient. From 0a746b538ac8c79059331adaeb1ec7176821002c Mon Sep 17 00:00:00 2001 From: benesjan Date: Wed, 27 Sep 2023 10:51:01 +0000 Subject: [PATCH 02/23] WIP --- docs/docs/dev_docs/cli/main.md | 2 +- .../dev_docs/sandbox/components.md | 3 +- .../aztec-sandbox/src/examples/util.ts | 2 +- yarn-project/aztec-sandbox/src/server.ts | 8 ++--- yarn-project/canary/src/utils.ts | 2 +- .../end-to-end/src/e2e_2_pxes.test.ts | 34 +++++++++---------- .../src/e2e_account_contracts.test.ts | 8 ++--- .../end-to-end/src/e2e_block_building.test.ts | 8 ++--- .../end-to-end/src/e2e_card_game.test.ts | 6 ++-- .../end-to-end/src/e2e_cheat_codes.test.ts | 6 ++-- yarn-project/end-to-end/src/e2e_cli.test.ts | 10 +++--- .../src/e2e_cross_chain_messaging.test.ts | 4 +-- .../src/e2e_deploy_contract.test.ts | 16 ++++----- .../src/e2e_escrow_contract.test.ts | 6 ++-- .../e2e_multiple_accounts_1_enc_key.test.ts | 8 ++--- .../src/e2e_nested_contract.test.ts | 6 ++-- .../src/e2e_non_contract_account.test.ts | 8 ++--- .../end-to-end/src/e2e_ordering.test.ts | 12 +++---- .../end-to-end/src/e2e_p2p_network.test.ts | 17 ++++------ .../e2e_public_cross_chain_messaging.test.ts | 4 +-- .../e2e_public_to_private_messaging.test.ts | 4 +-- .../src/e2e_public_token_contract.test.ts | 8 ++--- .../src/fixtures/cross_chain_test_harness.ts | 14 ++++---- yarn-project/end-to-end/src/fixtures/utils.ts | 18 +++++----- .../writing_an_account_contract.test.ts | 6 ++-- .../src/uniswap_trade_on_l1_from_l2.test.ts | 14 ++++---- .../pxe/src/pxe_http/pxe_http_server.ts | 10 +++--- 27 files changed, 120 insertions(+), 124 deletions(-) diff --git a/docs/docs/dev_docs/cli/main.md b/docs/docs/dev_docs/cli/main.md index 35ca8c9307c..4836fad27a3 100644 --- a/docs/docs/dev_docs/cli/main.md +++ b/docs/docs/dev_docs/cli/main.md @@ -124,7 +124,7 @@ The `call` command calls a read-only method on a contract, one that will not gen - `--contract-abi` - The abi 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 AztecRPCServer. 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). +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 diff --git a/docs/internal_notes/dev_docs/sandbox/components.md b/docs/internal_notes/dev_docs/sandbox/components.md index 0db084b6508..698e35201bc 100644 --- a/docs/internal_notes/dev_docs/sandbox/components.md +++ b/docs/internal_notes/dev_docs/sandbox/components.md @@ -136,8 +136,7 @@ Implementation notes for this milestone: - Exposes a single account, created by a private key given in the ctor, that defaults to some test key. - Can be used as both the spending and decryption key for early development. -### AztecRpcServer (Previously Wallet/Private Client) - +### Private Execution Environment (PXE) ![](https://hackmd.io/_uploads/ryS0sOLyh.png) Implements: diff --git a/yarn-project/aztec-sandbox/src/examples/util.ts b/yarn-project/aztec-sandbox/src/examples/util.ts index 70c3170f416..d1e261a2a72 100644 --- a/yarn-project/aztec-sandbox/src/examples/util.ts +++ b/yarn-project/aztec-sandbox/src/examples/util.ts @@ -7,7 +7,7 @@ import { Account, Chain, Hex, HttpTransport, PublicClient, WalletClient, getCont /** * Deploy L1 token and portal, initialize portal, deploy a non native l2 token contract and attach is to the portal. - * @param aztecRpcServer - Private Execution Environment (PXE) instance + * @param pxeServicerivate Execution Environment (PXE) instance * @param walletClient - A viem WalletClient. * @param publicClient - A viem PublicClient. * @param rollupRegistryAddress - address of rollup registry to pass to initialize the token portal diff --git a/yarn-project/aztec-sandbox/src/server.ts b/yarn-project/aztec-sandbox/src/server.ts index 80a760f3b73..156349e64a2 100644 --- a/yarn-project/aztec-sandbox/src/server.ts +++ b/yarn-project/aztec-sandbox/src/server.ts @@ -6,13 +6,13 @@ import http from 'http'; import { createApiRouter } from './routes.js'; /** - * Creates an http server that forwards calls to the rpc server and starts it on the given port. - * @param aztecRpcServer - RPC server that answers queries to the created HTTP server. + * Creates an http server that forwards calls to the PXE and starts it on the given port. + * @param pxe - PXE that answers queries to the created HTTP server. * @param port - Port to listen in. * @returns A running http server. */ -export function startHttpRpcServer(aztecRpcServer: PXE, port: string | number): http.Server { - const rpcServer = createPxeRpcServer(aztecRpcServer); +export function startHttpRpcServer(pxe: PXE, port: string | number): http.Server { + const rpcServer = createPxeRpcServer(pxe); const app = rpcServer.getApp(); const apiRouter = createApiRouter(); diff --git a/yarn-project/canary/src/utils.ts b/yarn-project/canary/src/utils.ts index 79a16bc8c8a..58367905e0b 100644 --- a/yarn-project/canary/src/utils.ts +++ b/yarn-project/canary/src/utils.ts @@ -7,7 +7,7 @@ import { Account, Chain, Hex, HttpTransport, PublicClient, WalletClient, getCont /** * Deploy L1 token and portal, initialize portal, deploy a non native l2 token contract and attach is to the portal. - * @param aztecRpcServer - Private Execution Environment (PXE) instance + * @param pxeServicerivate Execution Environment (PXE) instance * @param walletClient - A viem WalletClient. * @param publicClient - A viem PublicClient. * @param rollupRegistryAddress - address of rollup registry to pass to initialize the token portal diff --git a/yarn-project/end-to-end/src/e2e_2_pxes.test.ts b/yarn-project/end-to-end/src/e2e_2_pxes.test.ts index 086a3993443..60ee21df181 100644 --- a/yarn-project/end-to-end/src/e2e_2_pxes.test.ts +++ b/yarn-project/end-to-end/src/e2e_2_pxes.test.ts @@ -19,8 +19,8 @@ describe('e2e_2_rpc_servers', () => { jest.setTimeout(TIMEOUT); let aztecNode: AztecNodeService | undefined; - let aztecRpcServerA: PXE; - let aztecRpcServerB: PXE; + let pxeA: PXE; + let pxeB: PXE; let walletA: Wallet; let walletB: Wallet; let userA: CompleteAddress; @@ -36,7 +36,7 @@ describe('e2e_2_rpc_servers', () => { let accounts: CompleteAddress[] = []; ({ aztecNode, - aztecRpcServer: aztecRpcServerA, + pxe: pxeA, accounts, wallets: [walletA], logger, @@ -45,7 +45,7 @@ describe('e2e_2_rpc_servers', () => { [userA] = accounts; ({ - aztecRpcServer: aztecRpcServerB, + pxe: pxeB, accounts: accounts, wallets: [walletB], } = await setupPXEService(1, aztecNode!, undefined, true)); @@ -54,7 +54,7 @@ describe('e2e_2_rpc_servers', () => { afterEach(async () => { await teardownA(); - if (aztecRpcServerB instanceof PXEService) await aztecRpcServerB.stop(); + if (pxeB instanceof PXEService) await pxeB.stop(); }); const awaitUserSynchronized = async (wallet: Wallet, owner: AztecAddress) => { @@ -116,12 +116,12 @@ describe('e2e_2_rpc_servers', () => { const tokenAddress = completeTokenAddress.address; // Add account B to wallet A - await aztecRpcServerA.registerRecipient(userB); + await pxeA.registerRecipient(userB); // Add account A to wallet B - await aztecRpcServerB.registerRecipient(userA); + await pxeB.registerRecipient(userA); // Add token to RPC server B (RPC server A already has it because it was deployed through it) - await aztecRpcServerB.addContracts([ + await pxeB.addContracts([ { abi: TokenContract.abi, completeAddress: completeTokenAddress, @@ -175,16 +175,16 @@ describe('e2e_2_rpc_servers', () => { await retryUntil(isServerSynchronized, 'server sync', 10); }; - const getChildStoredValue = (child: { address: AztecAddress }, aztecRpcServer: PXE) => - aztecRpcServer.getPublicStorageAt(child.address, new Fr(1)).then(x => toBigInt(x!)); + const getChildStoredValue = (child: { address: AztecAddress }, pxe: PXE) => + pxe.getPublicStorageAt(child.address, new Fr(1)).then(x => toBigInt(x!)); it('user calls a public function on a contract deployed by a different user using a different RPC server', async () => { const childCompleteAddress = await deployChildContractViaServerA(); - await awaitServerSynchronized(aztecRpcServerA); + await awaitServerSynchronized(pxeA); // Add Child to RPC server B - await aztecRpcServerB.addContracts([ + await pxeB.addContracts([ { abi: ChildContract.abi, completeAddress: childCompleteAddress, @@ -197,9 +197,9 @@ describe('e2e_2_rpc_servers', () => { const childContractWithWalletB = await ChildContract.at(childCompleteAddress.address, walletB); await childContractWithWalletB.methods.pubIncValue(newValueToSet).send().wait({ interval: 0.1 }); - await awaitServerSynchronized(aztecRpcServerA); + await awaitServerSynchronized(pxeA); - const storedValue = await getChildStoredValue(childCompleteAddress, aztecRpcServerB); + const storedValue = await getChildStoredValue(childCompleteAddress, pxeB); expect(storedValue).toBe(newValueToSet); }); @@ -211,12 +211,12 @@ describe('e2e_2_rpc_servers', () => { const contractWithWalletA = await TokenContract.at(completeTokenAddress.address, walletA); // Add account B to wallet A - await aztecRpcServerA.registerRecipient(userB); + await pxeA.registerRecipient(userB); // Add account A to wallet B - await aztecRpcServerB.registerRecipient(userA); + await pxeB.registerRecipient(userA); // Add token to RPC server B (RPC server A already has it because it was deployed through it) - await aztecRpcServerB.addContracts([ + await pxeB.addContracts([ { abi: TokenContract.abi, completeAddress: completeTokenAddress, diff --git a/yarn-project/end-to-end/src/e2e_account_contracts.test.ts b/yarn-project/end-to-end/src/e2e_account_contracts.test.ts index a8103b60412..c308043de8f 100644 --- a/yarn-project/end-to-end/src/e2e_account_contracts.test.ts +++ b/yarn-project/end-to-end/src/e2e_account_contracts.test.ts @@ -37,7 +37,7 @@ function itShouldBehaveLikeAnAccountContract( encryptionPrivateKey = GrumpkinScalar.random(); ({ account, wallet } = await walletSetup( - context.aztecRpcServer, + context.pxe, encryptionPrivateKey, getAccountContract(encryptionPrivateKey), )); @@ -53,16 +53,16 @@ function itShouldBehaveLikeAnAccountContract( }, 60_000); it('calls a public function', async () => { - const { logger, aztecRpcServer } = context; + const { logger, pxe } = context; logger('Calling public function...'); await child.methods.pubIncValue(42).send().wait({ interval: 0.1 }); - expect(toBigInt((await aztecRpcServer.getPublicStorageAt(child.address, new Fr(1)))!)).toEqual(42n); + expect(toBigInt((await pxe.getPublicStorageAt(child.address, new Fr(1)))!)).toEqual(42n); }, 60_000); it('fails to call a function using an invalid signature', async () => { const accountAddress = await account.getCompleteAddress(); const { wallet: invalidWallet } = await walletSetup( - context.aztecRpcServer, + context.pxe, encryptionPrivateKey, getAccountContract(GrumpkinScalar.random()), accountAddress, diff --git a/yarn-project/end-to-end/src/e2e_block_building.test.ts b/yarn-project/end-to-end/src/e2e_block_building.test.ts index 002359f2e34..a7e589d08ff 100644 --- a/yarn-project/end-to-end/src/e2e_block_building.test.ts +++ b/yarn-project/end-to-end/src/e2e_block_building.test.ts @@ -11,7 +11,7 @@ import times from 'lodash.times'; import { setup } from './fixtures/utils.js'; describe('e2e_block_building', () => { - let aztecRpcServer: PXE; + let pxe: PXE; let logger: DebugLogger; let wallet: Wallet; let teardown: () => Promise; @@ -20,7 +20,7 @@ describe('e2e_block_building', () => { const abi = TestContractAbi; beforeAll(async () => { - ({ teardown, aztecRpcServer, logger, wallet } = await setup(1)); + ({ teardown, pxe, logger, wallet } = await setup(1)); }, 100_000); afterAll(() => teardown()); @@ -48,7 +48,7 @@ describe('e2e_block_building', () => { expect(receipts.map(r => r.blockNumber)).toEqual(times(TX_COUNT, () => receipts[0].blockNumber)); // Assert all contracts got deployed - const areDeployed = await Promise.all(receipts.map(r => isContractDeployed(aztecRpcServer, r.contractAddress!))); + const areDeployed = await Promise.all(receipts.map(r => isContractDeployed(pxe, r.contractAddress!))); expect(areDeployed).toEqual(times(TX_COUNT, () => true)); }, 60_000); }); @@ -59,7 +59,7 @@ describe('e2e_block_building', () => { let teardown: () => Promise; beforeAll(async () => { - ({ teardown, aztecRpcServer, logger, wallet } = await setup(1)); + ({ teardown, pxe, logger, wallet } = await setup(1)); contract = await TestContract.deploy(wallet).send().deployed(); }, 100_000); diff --git a/yarn-project/end-to-end/src/e2e_card_game.test.ts b/yarn-project/end-to-end/src/e2e_card_game.test.ts index 0415874630f..5ff8b15c591 100644 --- a/yarn-project/end-to-end/src/e2e_card_game.test.ts +++ b/yarn-project/end-to-end/src/e2e_card_game.test.ts @@ -44,7 +44,7 @@ function unwrapOptions(options: NoirOption[]): T[] { const GAME_ID = 42; describe('e2e_card_game', () => { - let aztecRpcServer: PXE; + let pxe: PXE; let logger: DebugLogger; let teardown: () => Promise; @@ -64,8 +64,8 @@ describe('e2e_card_game', () => { beforeEach(async () => { // Card stats are derived from the users' private keys, so to get consistent values, we set up the // initial sandbox accounts that always use the same private keys, instead of random ones. - ({ aztecRpcServer, logger, teardown } = await setup(0)); - wallets = await Promise.all((await deployInitialSandboxAccounts(aztecRpcServer)).map(a => a.account.getWallet())); + ({ pxe, logger, teardown } = await setup(0)); + wallets = await Promise.all((await deployInitialSandboxAccounts(pxe)).map(a => a.account.getWallet())); [firstPlayerWallet, secondPlayerWallet, thirdPlayerWallet] = wallets; [firstPlayer, secondPlayer, thirdPlayer] = wallets.map(a => a.getAddress()); await deployContract(); diff --git a/yarn-project/end-to-end/src/e2e_cheat_codes.test.ts b/yarn-project/end-to-end/src/e2e_cheat_codes.test.ts index a17796a05bd..3cc9079d287 100644 --- a/yarn-project/end-to-end/src/e2e_cheat_codes.test.ts +++ b/yarn-project/end-to-end/src/e2e_cheat_codes.test.ts @@ -9,7 +9,7 @@ import { Account, Chain, HttpTransport, PublicClient, WalletClient, getAddress, import { setup } from './fixtures/utils.js'; describe('e2e_cheat_codes', () => { - let aztecRpcServer: PXE; + let pxe: PXE; let wallet: Wallet; let cc: CheatCodes; let teardown: () => Promise; @@ -20,7 +20,7 @@ describe('e2e_cheat_codes', () => { beforeAll(async () => { let deployL1ContractsValues; - ({ teardown, aztecRpcServer, wallet, cheatCodes: cc, deployL1ContractsValues } = await setup()); + ({ teardown, pxe, wallet, cheatCodes: cc, deployL1ContractsValues } = await setup()); walletClient = deployL1ContractsValues.walletClient; publicClient = deployL1ContractsValues.publicClient; @@ -134,7 +134,7 @@ describe('e2e_cheat_codes', () => { }); it('can modify L2 block time', async () => { - const tx = TestContract.deploy(aztecRpcServer).send(); + const tx = TestContract.deploy(pxe).send(); await tx.isMined({ interval: 0.1 }); const receipt = await tx.getReceipt(); const contract = await TestContract.at(receipt.contractAddress!, wallet); diff --git a/yarn-project/end-to-end/src/e2e_cli.test.ts b/yarn-project/end-to-end/src/e2e_cli.test.ts index 76c854a3829..37e4a3c1cda 100644 --- a/yarn-project/end-to-end/src/e2e_cli.test.ts +++ b/yarn-project/end-to-end/src/e2e_cli.test.ts @@ -12,21 +12,21 @@ const debug = createDebugLogger('aztec:e2e_cli'); let http: ReturnType; let aztecNode: AztecNodeService | undefined; -let aztecRpcServer: PXE; +let pxe: PXE; const testSetup = async () => { const context = await e2eSetup(2); debug(`Environment set up`); - ({ aztecNode, aztecRpcServer } = context); - http = startHttpRpcServer(aztecRpcServer, HTTP_PORT); + ({ aztecNode, pxe } = context); + http = startHttpRpcServer(pxe, HTTP_PORT); debug(`HTTP RPC server started in port ${HTTP_PORT}`); - return aztecRpcServer; + return pxe; }; const testCleanup = async () => { http.close(); await aztecNode?.stop(); - await (aztecRpcServer as PXEService).stop(); + await (pxe as PXEService).stop(); }; cliTestSuite('E2E CLI Test', testSetup, testCleanup, createDebugLogger('aztec:e2e_cli'), RPC_URL); diff --git a/yarn-project/end-to-end/src/e2e_cross_chain_messaging.test.ts b/yarn-project/end-to-end/src/e2e_cross_chain_messaging.test.ts index ebb44ddd98b..c9eb2d5ae42 100644 --- a/yarn-project/end-to-end/src/e2e_cross_chain_messaging.test.ts +++ b/yarn-project/end-to-end/src/e2e_cross_chain_messaging.test.ts @@ -25,7 +25,7 @@ describe('e2e_cross_chain_messaging', () => { beforeEach(async () => { const { aztecNode, - aztecRpcServer, + pxe, deployL1ContractsValues, accounts, wallets, @@ -36,7 +36,7 @@ describe('e2e_cross_chain_messaging', () => { crossChainTestHarness = await CrossChainTestHarness.new( aztecNode, - aztecRpcServer, + pxe, deployL1ContractsValues, accounts, wallets[0], diff --git a/yarn-project/end-to-end/src/e2e_deploy_contract.test.ts b/yarn-project/end-to-end/src/e2e_deploy_contract.test.ts index 2e49c49855f..b1b4196fbe8 100644 --- a/yarn-project/end-to-end/src/e2e_deploy_contract.test.ts +++ b/yarn-project/end-to-end/src/e2e_deploy_contract.test.ts @@ -7,14 +7,14 @@ import { PXE, TxStatus } from '@aztec/types'; import { setup } from './fixtures/utils.js'; describe('e2e_deploy_contract', () => { - let aztecRpcServer: PXE; + let pxe: PXE; let accounts: CompleteAddress[]; let logger: DebugLogger; let wallet: Wallet; let teardown: () => Promise; beforeEach(async () => { - ({ teardown, aztecRpcServer, accounts, logger, wallet } = await setup()); + ({ teardown, pxe, accounts, logger, wallet } = await setup()); }, 100_000); afterEach(() => teardown()); @@ -27,7 +27,7 @@ describe('e2e_deploy_contract', () => { const publicKey = accounts[0].publicKey; const salt = Fr.random(); const deploymentData = await getContractDeploymentInfo(TestContractAbi, [], salt, publicKey); - const deployer = new ContractDeployer(TestContractAbi, aztecRpcServer, publicKey); + const deployer = new ContractDeployer(TestContractAbi, pxe, publicKey); const tx = deployer.deploy().send({ contractAddressSalt: salt }); logger(`Tx sent with hash ${await tx.getTxHash()}`); const receipt = await tx.getReceipt(); @@ -50,15 +50,15 @@ describe('e2e_deploy_contract', () => { }), ); const contractAddress = receiptAfterMined.contractAddress!; - expect(await isContractDeployed(aztecRpcServer, contractAddress)).toBe(true); - expect(await isContractDeployed(aztecRpcServer, AztecAddress.random())).toBe(false); + expect(await isContractDeployed(pxe, contractAddress)).toBe(true); + expect(await isContractDeployed(pxe, AztecAddress.random())).toBe(false); }, 30_000); /** * Verify that we can produce multiple rollups. */ it('should deploy one contract after another in consecutive rollups', async () => { - const deployer = new ContractDeployer(TestContractAbi, aztecRpcServer); + const deployer = new ContractDeployer(TestContractAbi, pxe); for (let index = 0; index < 2; index++) { logger(`Deploying contract ${index + 1}...`); @@ -74,7 +74,7 @@ describe('e2e_deploy_contract', () => { * Verify that we can deploy multiple contracts and interact with all of them. */ it('should deploy multiple contracts and interact with them', async () => { - const deployer = new ContractDeployer(TestContractAbi, aztecRpcServer); + const deployer = new ContractDeployer(TestContractAbi, pxe); for (let index = 0; index < 2; index++) { logger(`Deploying contract ${index + 1}...`); @@ -92,7 +92,7 @@ describe('e2e_deploy_contract', () => { */ it('should not deploy a contract with the same salt twice', async () => { const contractAddressSalt = Fr.random(); - const deployer = new ContractDeployer(TestContractAbi, aztecRpcServer); + const deployer = new ContractDeployer(TestContractAbi, pxe); { const tx = deployer.deploy().send({ contractAddressSalt }); diff --git a/yarn-project/end-to-end/src/e2e_escrow_contract.test.ts b/yarn-project/end-to-end/src/e2e_escrow_contract.test.ts index 1fa1392096c..d54e8400790 100644 --- a/yarn-project/end-to-end/src/e2e_escrow_contract.test.ts +++ b/yarn-project/end-to-end/src/e2e_escrow_contract.test.ts @@ -8,7 +8,7 @@ import { PXE, PublicKey, TxStatus } from '@aztec/types'; import { setup } from './fixtures/utils.js'; describe('e2e_escrow_contract', () => { - let aztecRpcServer: PXE; + let pxe: PXE; let wallet: AccountWallet; let recipientWallet: AccountWallet; let accounts: CompleteAddress[]; @@ -27,7 +27,7 @@ describe('e2e_escrow_contract', () => { // Setup environment ({ teardown, - aztecRpcServer, + pxe, accounts, wallets: [wallet, recipientWallet], logger, @@ -41,7 +41,7 @@ describe('e2e_escrow_contract', () => { escrowPublicKey = await generatePublicKey(escrowPrivateKey); const salt = Fr.random(); const deployInfo = await getContractDeploymentInfo(EscrowContractAbi, [owner], salt, escrowPublicKey); - await aztecRpcServer.registerAccount(escrowPrivateKey, deployInfo.completeAddress.partialAddress); + await pxe.registerAccount(escrowPrivateKey, deployInfo.completeAddress.partialAddress); escrowContract = await EscrowContract.deployWithPublicKey(wallet, escrowPublicKey, owner) .send({ contractAddressSalt: salt }) diff --git a/yarn-project/end-to-end/src/e2e_multiple_accounts_1_enc_key.test.ts b/yarn-project/end-to-end/src/e2e_multiple_accounts_1_enc_key.test.ts index 6894a65c9cd..23263fa4edf 100644 --- a/yarn-project/end-to-end/src/e2e_multiple_accounts_1_enc_key.test.ts +++ b/yarn-project/end-to-end/src/e2e_multiple_accounts_1_enc_key.test.ts @@ -9,7 +9,7 @@ import { expectsNumOfEncryptedLogsInTheLastBlockToBe, setup } from './fixtures/u describe('e2e_multiple_accounts_1_enc_key', () => { let aztecNode: AztecNodeService | undefined; - let aztecRpcServer: PXE; + let pxe: PXE; const wallets: Wallet[] = []; const accounts: AztecAddress[] = []; let logger: DebugLogger; @@ -21,14 +21,14 @@ describe('e2e_multiple_accounts_1_enc_key', () => { const numAccounts = 3; beforeEach(async () => { - ({ teardown, aztecNode, aztecRpcServer, logger } = await setup(0)); + ({ teardown, aztecNode, pxe, logger } = await setup(0)); const encryptionPrivateKey = GrumpkinScalar.random(); for (let i = 0; i < numAccounts; i++) { logger(`Deploying account contract ${i}/3...`); const signingPrivateKey = GrumpkinScalar.random(); - const account = getSchnorrAccount(aztecRpcServer, encryptionPrivateKey, signingPrivateKey); + const account = getSchnorrAccount(pxe, encryptionPrivateKey, signingPrivateKey); const wallet = await account.waitDeploy({ interval: 0.1 }); const { address } = await account.getCompleteAddress(); wallets.push(wallet); @@ -38,7 +38,7 @@ describe('e2e_multiple_accounts_1_enc_key', () => { // Verify that all accounts use the same encryption key const encryptionPublicKey = await generatePublicKey(encryptionPrivateKey); - for (const account of await aztecRpcServer.getRegisteredAccounts()) { + for (const account of await pxe.getRegisteredAccounts()) { expect(account.publicKey).toEqual(encryptionPublicKey); } diff --git a/yarn-project/end-to-end/src/e2e_nested_contract.test.ts b/yarn-project/end-to-end/src/e2e_nested_contract.test.ts index 47ec3016325..aefb5152e1c 100644 --- a/yarn-project/end-to-end/src/e2e_nested_contract.test.ts +++ b/yarn-project/end-to-end/src/e2e_nested_contract.test.ts @@ -8,13 +8,13 @@ import { L2BlockL2Logs, PXE } from '@aztec/types'; import { setup } from './fixtures/utils.js'; describe('e2e_nested_contract', () => { - let aztecRpcServer: PXE; + let pxe: PXE; let wallet: Wallet; let logger: DebugLogger; let teardown: () => Promise; beforeEach(async () => { - ({ teardown, aztecRpcServer, wallet, logger } = await setup()); + ({ teardown, pxe, wallet, logger } = await setup()); }, 100_000); afterEach(() => teardown()); @@ -29,7 +29,7 @@ describe('e2e_nested_contract', () => { }, 100_000); const getChildStoredValue = (child: { address: AztecAddress }) => - aztecRpcServer.getPublicStorageAt(child.address, new Fr(1)).then(x => toBigInt(x!)); + pxe.getPublicStorageAt(child.address, new Fr(1)).then(x => toBigInt(x!)); it('performs nested calls', async () => { await parentContract.methods diff --git a/yarn-project/end-to-end/src/e2e_non_contract_account.test.ts b/yarn-project/end-to-end/src/e2e_non_contract_account.test.ts index 9a092c55cc7..6f4da87a779 100644 --- a/yarn-project/end-to-end/src/e2e_non_contract_account.test.ts +++ b/yarn-project/end-to-end/src/e2e_non_contract_account.test.ts @@ -8,7 +8,7 @@ import { expectsNumOfEncryptedLogsInTheLastBlockToBe, setup } from './fixtures/u describe('e2e_non_contract_account', () => { let aztecNode: AztecNodeService | undefined; - let aztecRpcServer: PXE; + let pxe: PXE; let wallet: Wallet; let sender: AztecAddress; let recipient: AztecAddress; @@ -23,13 +23,13 @@ describe('e2e_non_contract_account', () => { beforeEach(async () => { let accounts: CompleteAddress[]; - ({ teardown, aztecNode, aztecRpcServer, accounts, wallet, logger } = await setup(2)); + ({ teardown, aztecNode, pxe, accounts, wallet, logger } = await setup(2)); sender = accounts[0].address; recipient = accounts[1].address; - pokerWallet = new SignerlessWallet(aztecRpcServer); + pokerWallet = new SignerlessWallet(pxe); logger(`Deploying L2 contract...`); - const tx = PokeableTokenContract.deploy(aztecRpcServer, initialBalance, sender, recipient).send(); + const tx = PokeableTokenContract.deploy(pxe, initialBalance, sender, recipient).send(); await tx.isMined({ interval: 0.1 }); const receipt = await tx.getReceipt(); expect(receipt.status).toEqual(TxStatus.MINED); diff --git a/yarn-project/end-to-end/src/e2e_ordering.test.ts b/yarn-project/end-to-end/src/e2e_ordering.test.ts index 17b7b800ca5..7a9dc9490ea 100644 --- a/yarn-project/end-to-end/src/e2e_ordering.test.ts +++ b/yarn-project/end-to-end/src/e2e_ordering.test.ts @@ -10,13 +10,13 @@ import { setup } from './fixtures/utils.js'; // See https://github.com/AztecProtocol/aztec-packages/issues/1601 describe('e2e_ordering', () => { - let aztecRpcServer: PXE; + let pxe: PXE; let wallet: Wallet; let teardown: () => Promise; const expectLogsFromLastBlockToBe = async (logMessages: bigint[]) => { - const l2BlockNum = await aztecRpcServer.getBlockNumber(); - const unencryptedLogs = await aztecRpcServer.getUnencryptedLogs(l2BlockNum, 1); + const l2BlockNum = await pxe.getBlockNumber(); + const unencryptedLogs = await pxe.getUnencryptedLogs(l2BlockNum, 1); const unrolledLogs = L2BlockL2Logs.unrollLogs(unencryptedLogs); const bigintLogs = unrolledLogs.map((log: Buffer) => toBigIntBE(log)); @@ -24,7 +24,7 @@ describe('e2e_ordering', () => { }; beforeEach(async () => { - ({ teardown, aztecRpcServer, wallet } = await setup()); + ({ teardown, pxe, wallet } = await setup()); }, 100_000); afterEach(() => teardown()); @@ -72,7 +72,7 @@ describe('e2e_ordering', () => { await expectLogsFromLastBlockToBe(expectedOrder); // The final value of the child is the last one set - const value = await aztecRpcServer.getPublicStorageAt(child.address, new Fr(1)).then(x => toBigInt(x!)); + const value = await pxe.getPublicStorageAt(child.address, new Fr(1)).then(x => toBigInt(x!)); expect(value).toEqual(expectedOrder[1]); // final state should match last value set }, ); @@ -96,7 +96,7 @@ describe('e2e_ordering', () => { const receipt = await tx.wait(); expect(receipt.status).toBe(TxStatus.MINED); - const value = await aztecRpcServer.getPublicStorageAt(child.address, new Fr(1)).then(x => toBigInt(x!)); + const value = await pxe.getPublicStorageAt(child.address, new Fr(1)).then(x => toBigInt(x!)); expect(value).toEqual(expectedOrder[1]); // final state should match last value set }, ); diff --git a/yarn-project/end-to-end/src/e2e_p2p_network.test.ts b/yarn-project/end-to-end/src/e2e_p2p_network.test.ts index 3c7b8b6178f..3f7f0576d2f 100644 --- a/yarn-project/end-to-end/src/e2e_p2p_network.test.ts +++ b/yarn-project/end-to-end/src/e2e_p2p_network.test.ts @@ -113,17 +113,12 @@ describe('e2e_p2p_network', () => { }; // submits a set of transactions to the provided Private Execution Environment (PXE) - const submitTxsTo = async ( - aztecRpcServer: PXEService, - account: AztecAddress, - numTxs: number, - publicKey: PublicKey, - ) => { + const submitTxsTo = async (pxe: PXEService, account: AztecAddress, numTxs: number, publicKey: PublicKey) => { const txs: SentTx[] = []; for (let i = 0; i < numTxs; i++) { const salt = Fr.random(); const origin = (await getContractDeploymentInfo(TestContractAbi, [], salt, publicKey)).completeAddress.address; - const deployer = new ContractDeployer(TestContractAbi, aztecRpcServer, publicKey); + const deployer = new ContractDeployer(TestContractAbi, pxe, publicKey); const tx = deployer.deploy().send({ contractAddressSalt: salt }); logger(`Tx sent with hash ${await tx.getTxHash()}`); const receipt = await tx.getReceipt(); @@ -145,20 +140,20 @@ describe('e2e_p2p_network', () => { numTxs: number, ): Promise => { const rpcConfig = getRpcConfig(); - const aztecRpcServer = await createPXEService(node, rpcConfig, {}, true); + const pxe = await createPXEService(node, rpcConfig, {}, true); const keyPair = ConstantKeyPair.random(await Grumpkin.new()); const completeAddress = await CompleteAddress.fromPrivateKeyAndPartialAddress( await keyPair.getPrivateKey(), Fr.random(), ); - await aztecRpcServer.registerAccount(await keyPair.getPrivateKey(), completeAddress.partialAddress); + await pxe.registerAccount(await keyPair.getPrivateKey(), completeAddress.partialAddress); - const txs = await submitTxsTo(aztecRpcServer, completeAddress.address, numTxs, completeAddress.publicKey); + const txs = await submitTxsTo(pxe, completeAddress.address, numTxs, completeAddress.publicKey); return { txs, account: completeAddress.address, - rpcServer: aztecRpcServer, + rpcServer: pxe, node, }; }; diff --git a/yarn-project/end-to-end/src/e2e_public_cross_chain_messaging.test.ts b/yarn-project/end-to-end/src/e2e_public_cross_chain_messaging.test.ts index 95f0273f9ce..dab03de4fdc 100644 --- a/yarn-project/end-to-end/src/e2e_public_cross_chain_messaging.test.ts +++ b/yarn-project/end-to-end/src/e2e_public_cross_chain_messaging.test.ts @@ -25,7 +25,7 @@ describe('e2e_public_cross_chain_messaging', () => { beforeEach(async () => { const { aztecNode: aztecNode_, - aztecRpcServer: aztecRpcServer_, + pxe: pxe_, deployL1ContractsValues, accounts, wallets, @@ -35,7 +35,7 @@ describe('e2e_public_cross_chain_messaging', () => { } = await setup(2); crossChainTestHarness = await CrossChainTestHarness.new( aztecNode_, - aztecRpcServer_, + pxe_, deployL1ContractsValues, accounts, wallets[0], diff --git a/yarn-project/end-to-end/src/e2e_public_to_private_messaging.test.ts b/yarn-project/end-to-end/src/e2e_public_to_private_messaging.test.ts index 60a55068f1c..31d08635522 100644 --- a/yarn-project/end-to-end/src/e2e_public_to_private_messaging.test.ts +++ b/yarn-project/end-to-end/src/e2e_public_to_private_messaging.test.ts @@ -20,7 +20,7 @@ describe('e2e_public_to_private_messaging', () => { beforeEach(async () => { const { aztecNode: aztecNode_, - aztecRpcServer: aztecRpcServer_, + pxe: pxe_, deployL1ContractsValues, accounts, wallet, @@ -30,7 +30,7 @@ describe('e2e_public_to_private_messaging', () => { } = await setup(2); crossChainTestHarness = await CrossChainTestHarness.new( aztecNode_, - aztecRpcServer_, + pxe_, deployL1ContractsValues, accounts, wallet, diff --git a/yarn-project/end-to-end/src/e2e_public_token_contract.test.ts b/yarn-project/end-to-end/src/e2e_public_token_contract.test.ts index ca058b17ce3..32b85181195 100644 --- a/yarn-project/end-to-end/src/e2e_public_token_contract.test.ts +++ b/yarn-project/end-to-end/src/e2e_public_token_contract.test.ts @@ -8,7 +8,7 @@ import times from 'lodash.times'; import { expectUnencryptedLogsFromLastBlockToBe, setup } from './fixtures/utils.js'; describe('e2e_public_token_contract', () => { - let aztecRpcServer: PXE; + let pxe: PXE; let wallet: Wallet; let logger: DebugLogger; let recipient: AztecAddress; @@ -26,7 +26,7 @@ describe('e2e_public_token_contract', () => { beforeEach(async () => { let accounts: CompleteAddress[]; - ({ teardown, aztecRpcServer, accounts, wallet, logger } = await setup()); + ({ teardown, pxe, accounts, wallet, logger } = await setup()); recipient = accounts[0].address; }, 100_000); @@ -52,7 +52,7 @@ describe('e2e_public_token_contract', () => { const balance = await contract.methods.publicBalanceOf(recipient.toField()).view({ from: recipient }); expect(balance).toBe(mintAmount); - await expectUnencryptedLogsFromLastBlockToBe(aztecRpcServer, ['Coins minted']); + await expectUnencryptedLogsFromLastBlockToBe(pxe, ['Coins minted']); }, 45_000); // Regression for https://github.com/AztecProtocol/aztec-packages/issues/640 @@ -75,6 +75,6 @@ describe('e2e_public_token_contract', () => { const balance = await contract.methods.publicBalanceOf(recipient.toField()).view({ from: recipient }); expect(balance).toBe(mintAmount * 3n); - await expectUnencryptedLogsFromLastBlockToBe(aztecRpcServer, ['Coins minted', 'Coins minted', 'Coins minted']); + await expectUnencryptedLogsFromLastBlockToBe(pxe, ['Coins minted', 'Coins minted', 'Coins minted']); }, 60_000); }); diff --git a/yarn-project/end-to-end/src/fixtures/cross_chain_test_harness.ts b/yarn-project/end-to-end/src/fixtures/cross_chain_test_harness.ts index 7c8d9dda8cf..339fffc0380 100644 --- a/yarn-project/end-to-end/src/fixtures/cross_chain_test_harness.ts +++ b/yarn-project/end-to-end/src/fixtures/cross_chain_test_harness.ts @@ -21,7 +21,7 @@ import { deployAndInitializeStandardizedTokenAndBridgeContracts } from './utils. export class CrossChainTestHarness { static async new( aztecNode: AztecNodeService | undefined, - aztecRpcServer: PXE, + pxeService: PXE, deployL1ContractsValues: DeployL1Contracts, accounts: CompleteAddress[], wallet: Wallet, @@ -69,7 +69,7 @@ export class CrossChainTestHarness { return new CrossChainTestHarness( aztecNode, - aztecRpcServer, + pxeService, cheatCodes, accounts, logger, @@ -90,8 +90,8 @@ export class CrossChainTestHarness { constructor( /** AztecNode. */ public aztecNode: AztecNodeService | undefined, - /** AztecRpcServer. */ - public aztecRpcServer: PXE, + /** Private Execution Environment (PXE). */ + public pxeService: PXE, /** CheatCodes. */ public cc: CheatCodes, /** Accounts. */ @@ -271,7 +271,7 @@ export class CrossChainTestHarness { async checkEntryIsNotInOutbox(withdrawAmount: bigint, callerOnL1: EthAddress = EthAddress.ZERO): Promise { this.logger('Ensure that the entry is not in outbox yet'); - const contractData = await this.aztecRpcServer.getContractData(this.l2Bridge.address); + const contractData = await this.pxeService.getContractData(this.l2Bridge.address); // 0xb460af94, selector for "withdraw(uint256,address,address)" const content = sha256ToField( Buffer.concat([ @@ -335,8 +335,8 @@ export class CrossChainTestHarness { async stop() { await this.aztecNode?.stop(); - if (this.aztecRpcServer instanceof PXEService) { - await this.aztecRpcServer?.stop(); + if (this.pxeService instanceof PXEService) { + await this.pxeService?.stop(); } } } diff --git a/yarn-project/end-to-end/src/fixtures/utils.ts b/yarn-project/end-to-end/src/fixtures/utils.ts index 886a431ab86..b5ae35f1688 100644 --- a/yarn-project/end-to-end/src/fixtures/utils.ts +++ b/yarn-project/end-to-end/src/fixtures/utils.ts @@ -143,7 +143,7 @@ export async function setupPXEService( /** * The PXE instance. */ - aztecRpcServer: PXE; + pxe: PXE; /** * The accounts created by the RPC server. */ @@ -163,7 +163,7 @@ export async function setupPXEService( const wallets = await createAccounts(rpc, numberOfAccounts); return { - aztecRpcServer: rpc!, + pxe: rpc!, accounts: await rpc!.getRegisteredAccounts(), wallets, logger, @@ -206,7 +206,7 @@ async function setupWithSandbox(account: Account, config: AztecNodeConfig, logge const teardown = () => Promise.resolve(); return { aztecNode: undefined, - aztecRpcServer: jsonClient, + pxe: jsonClient, deployL1ContractsValues, accounts: await jsonClient!.getRegisteredAccounts(), config, @@ -233,7 +233,7 @@ export async function setup( /** * The Private Execution Environment (PXE). */ - aztecRpcServer: PXE; + pxe: PXE; /** * Return values from deployL1Contracts function. */ @@ -295,18 +295,18 @@ export async function setup( const aztecNode = await createAztecNode(config, logger); - const { aztecRpcServer, accounts, wallets } = await setupPXEService(numberOfAccounts, aztecNode!, logger); + const { pxe, accounts, wallets } = await setupPXEService(numberOfAccounts, aztecNode!, logger); - const cheatCodes = await CheatCodes.create(config.rpcUrl, aztecRpcServer!); + const cheatCodes = await CheatCodes.create(config.rpcUrl, pxe!); const teardown = async () => { await aztecNode?.stop(); - if (aztecRpcServer instanceof PXEService) await aztecRpcServer?.stop(); + if (pxe instanceof PXEService) await pxe?.stop(); }; return { aztecNode, - aztecRpcServer, + pxe, deployL1ContractsValues, accounts, config, @@ -455,7 +455,7 @@ export async function deployAndInitializeStandardizedTokenAndBridgeContracts( /** * Deploy L1 token and portal, initialize portal, deploy a non native l2 token contract and attach is to the portal. - * @param aztecRpcServer - Private Execution Environment (PXE) instance + * @param pxeService - Private Execution Environment (PXE) instance * @param walletClient - A viem WalletClient. * @param publicClient - A viem PublicClient. * @param rollupRegistryAddress - address of rollup registry to pass to initialize the token portal diff --git a/yarn-project/end-to-end/src/guides/writing_an_account_contract.test.ts b/yarn-project/end-to-end/src/guides/writing_an_account_contract.test.ts index 8930f604eda..eb58f3f19a6 100644 --- a/yarn-project/end-to-end/src/guides/writing_an_account_contract.test.ts +++ b/yarn-project/end-to-end/src/guides/writing_an_account_contract.test.ts @@ -50,10 +50,10 @@ describe('guides/writing_an_account_contract', () => { afterEach(() => context.teardown()); it('works', async () => { - const { aztecRpcServer: rpc, logger } = context; + const { pxe, logger } = context; // docs:start:account-contract-deploy const encryptionPrivateKey = GrumpkinScalar.random(); - const account = new AccountManager(rpc, encryptionPrivateKey, new SchnorrHardcodedKeyAccountContract()); + const account = new AccountManager(pxe, encryptionPrivateKey, new SchnorrHardcodedKeyAccountContract()); const wallet = await account.waitDeploy(); const address = wallet.getCompleteAddress().address; // docs:end:account-contract-deploy @@ -79,7 +79,7 @@ describe('guides/writing_an_account_contract', () => { const walletAddress = wallet.getCompleteAddress(); const wrongKey = GrumpkinScalar.random(); const wrongAccountContract = new SchnorrHardcodedKeyAccountContract(wrongKey); - const wrongAccount = new AccountManager(rpc, encryptionPrivateKey, wrongAccountContract, walletAddress); + const wrongAccount = new AccountManager(pxe, encryptionPrivateKey, wrongAccountContract, walletAddress); const wrongWallet = await wrongAccount.getWallet(); const tokenWithWrongWallet = token.withWallet(wrongWallet); diff --git a/yarn-project/end-to-end/src/uniswap_trade_on_l1_from_l2.test.ts b/yarn-project/end-to-end/src/uniswap_trade_on_l1_from_l2.test.ts index 40ff939630d..d3d30eee095 100644 --- a/yarn-project/end-to-end/src/uniswap_trade_on_l1_from_l2.test.ts +++ b/yarn-project/end-to-end/src/uniswap_trade_on_l1_from_l2.test.ts @@ -32,7 +32,7 @@ describe.skip('uniswap_trade_on_l1_from_l2', () => { const DAI_ADDRESS: EthAddress = EthAddress.fromString('0x6B175474E89094C44Da98b954EedeAC495271d0F'); let aztecNode: AztecNodeService | undefined; - let aztecRpcServer: PXE; + let pxe: PXE; let wallet: Wallet; let accounts: CompleteAddress[]; let logger: DebugLogger; @@ -53,8 +53,10 @@ describe.skip('uniswap_trade_on_l1_from_l2', () => { beforeEach(async () => { let deployL1ContractsValues: DeployL1Contracts; - ({ teardown, aztecNode, aztecRpcServer, deployL1ContractsValues, accounts, logger, wallet, cheatCodes } = - await setup(2, dumpedState)); + ({ teardown, aztecNode, pxe, deployL1ContractsValues, accounts, logger, wallet, cheatCodes } = await setup( + 2, + dumpedState, + )); const walletClient = deployL1ContractsValues.walletClient; const publicClient = deployL1ContractsValues.publicClient; @@ -69,7 +71,7 @@ describe.skip('uniswap_trade_on_l1_from_l2', () => { logger('Deploying DAI Portal, initializing and deploying l2 contract...'); daiCrossChainHarness = await CrossChainTestHarness.new( aztecNode, - aztecRpcServer, + pxe, deployL1ContractsValues, accounts, wallet, @@ -82,7 +84,7 @@ describe.skip('uniswap_trade_on_l1_from_l2', () => { logger('Deploying WETH Portal, initializing and deploying l2 contract...'); wethCrossChainHarness = await CrossChainTestHarness.new( aztecNode, - aztecRpcServer, + pxe, deployL1ContractsValues, accounts, wallet, @@ -101,7 +103,7 @@ describe.skip('uniswap_trade_on_l1_from_l2', () => { publicClient, }); // deploy l2 uniswap contract and attach to portal - const tx = UniswapContract.deploy(aztecRpcServer).send({ portalContract: uniswapPortalAddress }); + const tx = UniswapContract.deploy(pxe).send({ portalContract: uniswapPortalAddress }); await tx.isMined({ interval: 0.1 }); const receipt = await tx.getReceipt(); expect(receipt.status).toEqual(TxStatus.MINED); diff --git a/yarn-project/pxe/src/pxe_http/pxe_http_server.ts b/yarn-project/pxe/src/pxe_http/pxe_http_server.ts index 275de40bb85..9cf95e4bda9 100644 --- a/yarn-project/pxe/src/pxe_http/pxe_http_server.ts +++ b/yarn-project/pxe/src/pxe_http/pxe_http_server.ts @@ -28,9 +28,9 @@ export const localAnvil = foundry; * Wraps an instance of Private Execution Environment (PXE) implementation to a JSON RPC HTTP interface. * @returns A new instance of the HTTP server. */ -export function createPxeRpcServer(aztecRpcServer: PXE): JsonRpcServer { +export function createPxeRpcServer(pxeService: PXE): JsonRpcServer { return new JsonRpcServer( - aztecRpcServer, + pxeService, { CompleteAddress, AztecAddress, @@ -55,12 +55,12 @@ export function createPxeRpcServer(aztecRpcServer: PXE): JsonRpcServer { /** * Creates an http server that forwards calls to the rpc server and starts it on the given port. - * @param aztecRpcServer - RPC server that answers queries to the created HTTP server. + * @param pxeService - RPC server that answers queries to the created HTTP server. * @param port - Port to listen in. * @returns A running http server. */ -export function startPxeHttpServer(aztecRpcServer: PXE, port: string | number): http.Server { - const rpcServer = createPxeRpcServer(aztecRpcServer); +export function startPxeHttpServer(pxeService: PXE, port: string | number): http.Server { + const rpcServer = createPxeRpcServer(pxeService); const app = rpcServer.getApp(); const httpServer = http.createServer(app.callback()); From c0ac3fd7760557cd7d2d23238233a4842d8204bc Mon Sep 17 00:00:00 2001 From: benesjan Date: Wed, 27 Sep 2023 10:55:21 +0000 Subject: [PATCH 03/23] WIP --- docs/docs/dev_docs/testing/cheat_codes.md | 4 ++-- .../writing_dapp/contract_deployment.md | 2 +- .../tutorials/writing_dapp/pxe_service.md | 2 +- yarn-project/end-to-end/src/canary/browser.ts | 16 ++++++++-------- .../end-to-end/src/sample-dapp/connect.mjs | 4 ++-- .../end-to-end/src/sample-dapp/deploy.mjs | 4 ++-- .../end-to-end/src/sample-dapp/index.mjs | 4 ++-- 7 files changed, 18 insertions(+), 18 deletions(-) diff --git a/docs/docs/dev_docs/testing/cheat_codes.md b/docs/docs/dev_docs/testing/cheat_codes.md index 3fd12b18325..d3fd1036ec7 100644 --- a/docs/docs/dev_docs/testing/cheat_codes.md +++ b/docs/docs/dev_docs/testing/cheat_codes.md @@ -28,9 +28,9 @@ For this guide, the following Aztec packages are used: ### Initialisation ```ts -import { createAztecRpcClient, CheatCodes } from "@aztec/aztec.js"; +import { createPXEClient, CheatCodes } from "@aztec/aztec.js"; const aztecRpcUrl = "http://localhost:8080"; -const aztecRpcClient = createAztecRpcClient(aztecRpcUrl); +const aztecRpcClient = createPXEClient(aztecRpcUrl); const cc = await CheatCodes.create(aztecRpcUrl, aztecRpcClient); ``` diff --git a/docs/docs/dev_docs/tutorials/writing_dapp/contract_deployment.md b/docs/docs/dev_docs/tutorials/writing_dapp/contract_deployment.md index 34ce039738d..6b90304d4d3 100644 --- a/docs/docs/dev_docs/tutorials/writing_dapp/contract_deployment.md +++ b/docs/docs/dev_docs/tutorials/writing_dapp/contract_deployment.md @@ -67,7 +67,7 @@ Create a new file `src/deploy.mjs`: ```js // src/deploy.mjs import { writeFileSync } from 'fs'; -import { Contract, ContractDeployer, createAztecRpcClient, getSandboxAccountsWallets } from '@aztec/aztec.js'; +import { Contract, ContractDeployer, createPXEClient, getSandboxAccountsWallets } from '@aztec/aztec.js'; import TokenContractAbi from "../contracts/token/target/Token.json" assert { type: "json" }; #include_code dapp-deploy yarn-project/end-to-end/src/sample-dapp/deploy.mjs raw diff --git a/docs/docs/dev_docs/tutorials/writing_dapp/pxe_service.md b/docs/docs/dev_docs/tutorials/writing_dapp/pxe_service.md index 91e88960170..283a0466900 100644 --- a/docs/docs/dev_docs/tutorials/writing_dapp/pxe_service.md +++ b/docs/docs/dev_docs/tutorials/writing_dapp/pxe_service.md @@ -8,7 +8,7 @@ In this section, we'll connect to the Sandbox from our project. ## Create RPC client -We'll use the `createAztecRpcClient` function from `aztec.js` to connect to the Sandbox, which by default runs on `localhost:8080`. To test the connection works, we'll request and print the node's chain id. +We'll use the `createPXEClient` function from `aztec.js` to connect to the Sandbox, which by default runs on `localhost:8080`. To test the connection works, we'll request and print the node's chain id. Let's create our first file `src/index.mjs` with the following contents: diff --git a/yarn-project/end-to-end/src/canary/browser.ts b/yarn-project/end-to-end/src/canary/browser.ts index 4e3fcb8d242..21a2fe5115c 100644 --- a/yarn-project/end-to-end/src/canary/browser.ts +++ b/yarn-project/end-to-end/src/canary/browser.ts @@ -90,8 +90,8 @@ export const browserTestSuite = (setup: () => Server, pageLogger: AztecJs.DebugL it('Creates an account', async () => { const result = await page.evaluate( async (rpcUrl, privateKeyString) => { - const { GrumpkinScalar, createPXEClient: createAztecRpcClient, getUnsafeSchnorrAccount } = window.AztecJs; - const client = createAztecRpcClient(rpcUrl!); + const { GrumpkinScalar, createPXEClient: createPXEClient, getUnsafeSchnorrAccount } = window.AztecJs; + const client = createPXEClient(rpcUrl!); const privateKey = GrumpkinScalar.fromString(privateKeyString); const account = getUnsafeSchnorrAccount(client, privateKey); await account.waitDeploy(); @@ -115,8 +115,8 @@ export const browserTestSuite = (setup: () => Server, pageLogger: AztecJs.DebugL it("Gets the owner's balance", async () => { const result = await page.evaluate( async (rpcUrl, contractAddress, TokenContractAbi) => { - const { Contract, AztecAddress, createPXEClient: createAztecRpcClient } = window.AztecJs; - const client = createAztecRpcClient(rpcUrl!); + const { Contract, AztecAddress, createPXEClient: createPXEClient } = window.AztecJs; + const client = createPXEClient(rpcUrl!); const owner = (await client.getRegisteredAccounts())[0].address; const [wallet] = await AztecJs.getSandboxAccountsWallets(client); const contract = await Contract.at(AztecAddress.fromString(contractAddress), TokenContractAbi, wallet); @@ -134,8 +134,8 @@ export const browserTestSuite = (setup: () => Server, pageLogger: AztecJs.DebugL const result = await page.evaluate( async (rpcUrl, contractAddress, transferAmount, TokenContractAbi) => { console.log(`Starting transfer tx`); - const { AztecAddress, Contract, createPXEClient: createAztecRpcClient } = window.AztecJs; - const client = createAztecRpcClient(rpcUrl!); + const { AztecAddress, Contract, createPXEClient: createPXEClient } = window.AztecJs; + const client = createPXEClient(rpcUrl!); const accounts = await client.getRegisteredAccounts(); const receiver = accounts[1].address; const [wallet] = await AztecJs.getSandboxAccountsWallets(client); @@ -158,14 +158,14 @@ export const browserTestSuite = (setup: () => Server, pageLogger: AztecJs.DebugL const { GrumpkinScalar, DeployMethod, - createPXEClient: createAztecRpcClient, + createPXEClient: createPXEClient, getUnsafeSchnorrAccount, Contract, Fr, computeMessageSecretHash, getSandboxAccountsWallets, } = window.AztecJs; - const client = createAztecRpcClient(rpcUrl!); + const client = createPXEClient(rpcUrl!); let accounts = await client.getRegisteredAccounts(); if (accounts.length === 0) { // This test needs an account for deployment. We create one in case there is none available in the RPC server. diff --git a/yarn-project/end-to-end/src/sample-dapp/connect.mjs b/yarn-project/end-to-end/src/sample-dapp/connect.mjs index d66fbc3ba02..dfaa55e26bc 100644 --- a/yarn-project/end-to-end/src/sample-dapp/connect.mjs +++ b/yarn-project/end-to-end/src/sample-dapp/connect.mjs @@ -1,10 +1,10 @@ // docs:start:all -import { createAztecRpcClient } from '@aztec/aztec.js'; +import { createPXEClient } from '@aztec/aztec.js'; const { SANDBOX_URL = 'http://localhost:8080' } = process.env; async function main() { - const client = createAztecRpcClient(SANDBOX_URL); + const client = createPXEClient(SANDBOX_URL); const { chainId } = await client.getNodeInfo(); console.log(`Connected to chain ${chainId}`); } diff --git a/yarn-project/end-to-end/src/sample-dapp/deploy.mjs b/yarn-project/end-to-end/src/sample-dapp/deploy.mjs index b620819eb33..c3ff3a9c2f7 100644 --- a/yarn-project/end-to-end/src/sample-dapp/deploy.mjs +++ b/yarn-project/end-to-end/src/sample-dapp/deploy.mjs @@ -1,4 +1,4 @@ -import { Contract, ContractDeployer, createAztecRpcClient, getSandboxAccountsWallets } from '@aztec/aztec.js'; +import { Contract, ContractDeployer, createPXEClient, getSandboxAccountsWallets } from '@aztec/aztec.js'; import { TokenContractAbi } from '@aztec/noir-contracts/artifacts'; import { writeFileSync } from 'fs'; @@ -8,7 +8,7 @@ import { fileURLToPath } from 'url'; const { SANDBOX_URL = 'http://localhost:8080' } = process.env; async function main() { - const client = createAztecRpcClient(SANDBOX_URL); + const client = createPXEClient(SANDBOX_URL); const [owner] = await getSandboxAccountsWallets(client); const token = await Contract.deploy(client, TokenContractAbi, []).send().deployed(); diff --git a/yarn-project/end-to-end/src/sample-dapp/index.mjs b/yarn-project/end-to-end/src/sample-dapp/index.mjs index 17b6e9024eb..c0d61e1a593 100644 --- a/yarn-project/end-to-end/src/sample-dapp/index.mjs +++ b/yarn-project/end-to-end/src/sample-dapp/index.mjs @@ -2,7 +2,7 @@ import { Fr, L2BlockL2Logs, computeMessageSecretHash, - createAztecRpcClient, + createPXEClient, getSandboxAccountsWallets, } from '@aztec/aztec.js'; import { fileURLToPath } from '@aztec/foundation/url'; @@ -99,7 +99,7 @@ async function mintPublicFunds(client) { } async function main() { - const client = createAztecRpcClient(SANDBOX_URL); + const client = createPXEClient(SANDBOX_URL); const { chainId } = await client.getNodeInfo(); console.log(`Connected to chain ${chainId}`); From 4b29c7d41a5ba9a692c747b52955af2934fb7eaf Mon Sep 17 00:00:00 2001 From: benesjan Date: Wed, 27 Sep 2023 11:12:51 +0000 Subject: [PATCH 04/23] WIP --- CHANGELOG.md | 2 +- docs/docs/dev_docs/contracts/deploying.md | 8 ++-- docs/docs/dev_docs/contracts/syntax/events.md | 2 +- docs/docs/dev_docs/testing/cheat_codes.md | 6 +-- .../dev_docs/sandbox/components.md | 4 +- .../src/examples/private_token_contract.ts | 8 ++-- .../examples/uniswap_trade_on_l1_from_l2.ts | 41 ++++++++----------- .../src/tests/blank.contract.test.ts | 6 +-- .../blank/src/tests/blank.contract.test.ts | 6 +-- .../src/tests/privatetoken.sandbox.test.ts | 6 +-- yarn-project/canary/src/cli.test.ts | 6 +-- .../src/uniswap_trade_on_l1_from_l2.test.ts | 12 +++--- yarn-project/end-to-end/src/canary/cli.ts | 12 +++--- .../end-to-end/src/e2e_p2p_network.test.ts | 20 ++++----- .../src/e2e_sandbox_example.test.ts | 24 +++++------ .../end-to-end/src/pxe_sandbox.test.ts | 6 +-- .../src/pxe_service/test/pxe_test_suite.ts | 4 +- 17 files changed, 84 insertions(+), 89 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 67a4f0a1757..188f95ee5ff 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -673,7 +673,7 @@ * Rework nonces ([#1210](https://github.com/AztecProtocol/aztec-packages/issues/1210)) ([#1331](https://github.com/AztecProtocol/aztec-packages/issues/1331)) ([665cb75](https://github.com/AztecProtocol/aztec-packages/commit/665cb753f50f003ccd21935755aa1f08bfb78deb)) * Sandbox logging tweaks ([#1797](https://github.com/AztecProtocol/aztec-packages/issues/1797)) ([0e3914e](https://github.com/AztecProtocol/aztec-packages/commit/0e3914ed6ad63062add1cc08f6ea85646c068f8a)) * **scripts:** Convenience script to update local generated artifacts ([#1349](https://github.com/AztecProtocol/aztec-packages/issues/1349)) ([317981a](https://github.com/AztecProtocol/aztec-packages/commit/317981a13c9faf791a2760a07e9808a8474ecae2)) -* Simplified AztecRpc.registerAccount function ([#1729](https://github.com/AztecProtocol/aztec-packages/issues/1729)) ([8e5f828](https://github.com/AztecProtocol/aztec-packages/commit/8e5f828c0aff0602c49575139883c8abc3cb6e91)) +* Simplified PXE.registerAccount function ([#1729](https://github.com/AztecProtocol/aztec-packages/issues/1729)) ([8e5f828](https://github.com/AztecProtocol/aztec-packages/commit/8e5f828c0aff0602c49575139883c8abc3cb6e91)) * **simulator:** Initialize ACVM's SimulatedBackend separately (setup pedersen init only happens once) ([#1596](https://github.com/AztecProtocol/aztec-packages/issues/1596)) ([1a260ed](https://github.com/AztecProtocol/aztec-packages/commit/1a260ede0729b1f70b90e06c2e6588bcb5eb9fc3)) * Split out yarn-project bootstrap.sh ([#1790](https://github.com/AztecProtocol/aztec-packages/issues/1790)) ([1788fe6](https://github.com/AztecProtocol/aztec-packages/commit/1788fe6259f5e7fd191929b27996a7342e3f13e5)) * Split SumcheckRound into Prover/Verifier classes ([#1373](https://github.com/AztecProtocol/aztec-packages/issues/1373)) ([8b1d48a](https://github.com/AztecProtocol/aztec-packages/commit/8b1d48a52c41f4f6cf436b481823f59582611b81)) diff --git a/docs/docs/dev_docs/contracts/deploying.md b/docs/docs/dev_docs/contracts/deploying.md index 8431d0154e8..0753fa10c61 100644 --- a/docs/docs/dev_docs/contracts/deploying.md +++ b/docs/docs/dev_docs/contracts/deploying.md @@ -41,7 +41,7 @@ Now you can import it to easily deploy and interact with the contract. ```ts import { ExampleContract } from './Example.js'; -const tx = ExampleContract.deploy(aztecRpc).send(); +const tx = ExampleContract.deploy(pxe).send(); await tx.wait({ interval: 0.5 }); const receipt = await tx.getReceipt(); const exampleContract = await ExampleContract.at(receipt.contractAddress!, myWallet); @@ -78,7 +78,7 @@ By default is set to a random value. Set it, if you need a deterministic contract address (same functionality as Ethereum's `CREATE2` opcode). ```ts -const tx = ExampleContract.deploy(aztecRpc).send({ +const tx = ExampleContract.deploy(pxe).send({ portalContract: EthAddress.from("0x1234..."), contractAddressSalt: new Fr(3n), }); @@ -109,14 +109,14 @@ const publicKey = Point.fromString("0x26e193aef4f83c70651485b5526c6d01a36d763223 const partialAddress = Fr.fromString("0x200e9a6c2d2e8352012e51c6637659713d336405c29386c7c4ac56779ab54fa7"); const completeAddress = CompleteAddress.create(aztecAddress, publicKey, partialKey); -await aztecRpc.registerRecipient(completeAddress); +await pxe.registerRecipient(completeAddress); ``` -When you create a new account, it gets automatically registered. It can be verified by calling `aztec-cli get-accounts` OR in aztec.js by using `await aztecRpc.getRegisteredAccounts()` +When you create a new account, it gets automatically registered. It can be verified by calling `aztec-cli get-accounts` OR in aztec.js by using `await pxe.getRegisteredAccounts()` > **NOTE 1**: If we didn't register owner as a recipient we could not encrypt a note for the owner and the contract deployment would fail because constructor execution would fail (we need owner's public key to encrypt a note). diff --git a/docs/docs/dev_docs/contracts/syntax/events.md b/docs/docs/dev_docs/contracts/syntax/events.md index fb021e0f500..77bd761d968 100644 --- a/docs/docs/dev_docs/contracts/syntax/events.md +++ b/docs/docs/dev_docs/contracts/syntax/events.md @@ -47,7 +47,7 @@ const completeAddress = CompleteAddress.create( publicKey, partialKey ); -await aztecRpc.registerRecipient(completeAddress); +await pxe.registerRecipient(completeAddress); ``` diff --git a/docs/docs/dev_docs/testing/cheat_codes.md b/docs/docs/dev_docs/testing/cheat_codes.md index d3fd1036ec7..beab249668b 100644 --- a/docs/docs/dev_docs/testing/cheat_codes.md +++ b/docs/docs/dev_docs/testing/cheat_codes.md @@ -29,9 +29,9 @@ For this guide, the following Aztec packages are used: ```ts import { createPXEClient, CheatCodes } from "@aztec/aztec.js"; -const aztecRpcUrl = "http://localhost:8080"; -const aztecRpcClient = createPXEClient(aztecRpcUrl); -const cc = await CheatCodes.create(aztecRpcUrl, aztecRpcClient); +const pxeRpcUrl = "http://localhost:8080"; +const pxe = createPXEClient(pxeRpcUrl); +const cc = await CheatCodes.create(pxeRpcUrl, pxe); ``` There are two properties of the CheatCodes class - `eth` and `aztec` for cheatcodes relating to the Ethereum blockchain (L1) and the Aztec network (L2) respectively. diff --git a/docs/internal_notes/dev_docs/sandbox/components.md b/docs/internal_notes/dev_docs/sandbox/components.md index 698e35201bc..e5294fd4e87 100644 --- a/docs/internal_notes/dev_docs/sandbox/components.md +++ b/docs/internal_notes/dev_docs/sandbox/components.md @@ -21,7 +21,7 @@ Responsibilities: - Holds and never exposes private keys. - Provides sign/decrypt functionality. -### AztecRpcClient (Previously Wallet/Private Client) +### PXEClient Responsibilities: @@ -141,7 +141,7 @@ Implementation notes for this milestone: Implements: -- `AztecRpcClient` (The server is a client, when used directly) +- `P` (The server is a client, when used directly) Injected: diff --git a/yarn-project/aztec-sandbox/src/examples/private_token_contract.ts b/yarn-project/aztec-sandbox/src/examples/private_token_contract.ts index 1154d96552a..1617c170a08 100644 --- a/yarn-project/aztec-sandbox/src/examples/private_token_contract.ts +++ b/yarn-project/aztec-sandbox/src/examples/private_token_contract.ts @@ -16,7 +16,7 @@ export const privateKey = GrumpkinScalar.fromString('ac0974bec39a17e36ba4a6b4d23 const url = 'http://localhost:8080'; -const aztecRpcClient = createPXEClient(url); +const pxe = createPXEClient(url); let wallet: AccountWallet; const INITIAL_BALANCE = 333n; @@ -29,7 +29,7 @@ const SECONDARY_AMOUNT = 33n; */ async function deployZKContract(owner: AztecAddress) { logger('Deploying L2 contract...'); - const contract = await PrivateTokenContract.deploy(aztecRpcClient, INITIAL_BALANCE, owner).send().deployed(); + const contract = await PrivateTokenContract.deploy(pxe, INITIAL_BALANCE, owner).send().deployed(); logger('L2 contract deployed'); return contract; } @@ -50,9 +50,9 @@ async function getBalance(contract: Contract, ownerAddress: AztecAddress) { async function main() { logger('Running ZK contract test on HTTP interface.'); - wallet = await getUnsafeSchnorrAccount(aztecRpcClient, privateKey).waitDeploy(); + wallet = await getUnsafeSchnorrAccount(pxe, privateKey).waitDeploy(); const owner = wallet.getCompleteAddress(); - const recipient = await createRecipient(aztecRpcClient); + const recipient = await createRecipient(pxe); logger(`Created Owner account ${owner.toString()}`); diff --git a/yarn-project/aztec-sandbox/src/examples/uniswap_trade_on_l1_from_l2.ts b/yarn-project/aztec-sandbox/src/examples/uniswap_trade_on_l1_from_l2.ts index c003f9ecb6f..dd1d0cb058e 100644 --- a/yarn-project/aztec-sandbox/src/examples/uniswap_trade_on_l1_from_l2.ts +++ b/yarn-project/aztec-sandbox/src/examples/uniswap_trade_on_l1_from_l2.ts @@ -33,7 +33,7 @@ const DAI_ADDRESS = EthAddress.fromString('0x6B175474E89094C44Da98b954EedeAC4952 const EXPECTED_FORKED_BLOCK = 17514288; -const aztecRpcUrl = 'http://localhost:8080'; +const pxeRpcUrl = 'http://localhost:8080'; const ethRpcUrl = 'http://localhost:8545'; const hdAccount = mnemonicToAccount(MNEMONIC); @@ -55,7 +55,7 @@ if (Number(await publicClient.getBlockNumber()) < EXPECTED_FORKED_BLOCK) { const ethAccount = EthAddress.fromString((await walletClient.getAddresses())[0]); -const aztecRpcClient = createPXEClient(aztecRpcUrl); +const pxeClient = createPXEClient(pxeRpcUrl); let wallet: AccountWallet; /** @@ -63,7 +63,7 @@ let wallet: AccountWallet; * @param owner - Owner address. */ async function deployAllContracts(owner: AztecAddress) { - const l1ContractsAddresses = await getL1ContractAddresses(aztecRpcUrl); + const l1ContractsAddresses = await getL1ContractAddresses(pxeRpcUrl); logger('Deploying DAI Portal, initializing and deploying l2 contract...'); const daiContracts = await deployAndInitializeNonNativeL2TokenContracts( wallet, @@ -108,7 +108,7 @@ async function deployAllContracts(owner: AztecAddress) { }); // deploy l2 uniswap contract and attach to portal - const tx = UniswapContract.deploy(aztecRpcClient).send({ portalContract: uniswapPortalAddress }); + const tx = UniswapContract.deploy(pxeClient).send({ portalContract: uniswapPortalAddress }); await tx.isMined({ interval: 0.5 }); const receipt = await tx.getReceipt(); const uniswapL2Contract = await UniswapContract.at(receipt.contractAddress!, wallet); @@ -132,22 +132,22 @@ async function deployAllContracts(owner: AztecAddress) { }; } -const getL2BalanceOf = async (aztecRpcClient: PXE, owner: AztecAddress, l2Contract: NonNativeTokenContract) => { +const getL2BalanceOf = async (pxeClient: PXE, owner: AztecAddress, l2Contract: NonNativeTokenContract) => { return await l2Contract.methods.getBalance(owner).view({ from: owner }); }; const logExpectedBalanceOnL2 = async ( - aztecRpcClient: PXE, + pxeClient: PXE, owner: AztecAddress, expectedBalance: bigint, l2Contract: NonNativeTokenContract, ) => { - const balance = await getL2BalanceOf(aztecRpcClient, owner, l2Contract); + const balance = await getL2BalanceOf(pxeClient, owner, l2Contract); logger(`Account ${owner} balance: ${balance}. Expected to be: ${expectedBalance}`); }; const transferWethOnL2 = async ( - _aztecRpcClient: PXE, + _pxeClient: PXE, wethL2Contract: NonNativeTokenContract, ownerAddress: AztecAddress, receiver: AztecAddress, @@ -166,9 +166,9 @@ const transferWethOnL2 = async ( async function main() { logger('Running L1/L2 messaging test on HTTP interface.'); - wallet = await getUnsafeSchnorrAccount(aztecRpcClient, privateKey).waitDeploy(); + wallet = await getUnsafeSchnorrAccount(pxeClient, privateKey).waitDeploy(); const owner = wallet.getCompleteAddress(); - const receiver = await createRecipient(aztecRpcClient); + const receiver = await createRecipient(pxeClient); const result = await deployAllContracts(owner.address); const { @@ -213,7 +213,7 @@ async function main() { await delay(5000); // send a transfer tx to force through rollup with the message included const transferAmount = 1n; - await transferWethOnL2(aztecRpcClient, wethL2Contract, owner.address, receiver.address, transferAmount); + await transferWethOnL2(pxeClient, wethL2Contract, owner.address, receiver.address, transferAmount); // 3. Claim WETH on L2 logger('Minting weth on L2'); @@ -228,8 +228,8 @@ async function main() { // await expectBalanceOnL2(ownerAddress, wethAmountToBridge + initialBalance - transferAmount, wethL2Contract); // Store balances - const wethBalanceBeforeSwap = await getL2BalanceOf(aztecRpcClient, owner.address, wethL2Contract); - const daiBalanceBeforeSwap = await getL2BalanceOf(aztecRpcClient, owner.address, daiL2Contract); + const wethBalanceBeforeSwap = await getL2BalanceOf(pxeClient, owner.address, wethL2Contract); + const daiBalanceBeforeSwap = await getL2BalanceOf(pxeClient, owner.address, daiL2Contract); // 4. Send L2 to L1 message to withdraw funds and another message to swap assets. logger('Send L2 tx to withdraw WETH to uniswap portal and send message to swap assets on L1'); @@ -257,7 +257,7 @@ async function main() { logger(`Withdraw receipt status: ${withdrawReceipt.status} should be ${TxStatus.MINED}`); // check weth balance of owner on L2 (we first bridged `wethAmountToBridge` into L2 and now withdrew it!) - await logExpectedBalanceOnL2(aztecRpcClient, owner.address, INITIAL_BALANCE - transferAmount, wethL2Contract); + await logExpectedBalanceOnL2(pxeClient, owner.address, INITIAL_BALANCE - transferAmount, wethL2Contract); // 5. Consume L2 to L1 message by calling uniswapPortal.swap() logger('Execute withdraw and swap on the uniswapPortal!'); @@ -294,7 +294,7 @@ async function main() { // Wait for the archiver to process the message await delay(5000); // send a transfer tx to force through rollup with the message included - await transferWethOnL2(aztecRpcClient, wethL2Contract, owner.address, receiver.address, transferAmount); + await transferWethOnL2(pxeClient, wethL2Contract, owner.address, receiver.address, transferAmount); // 6. claim dai on L2 logger('Consuming messages to mint dai on L2'); @@ -306,15 +306,10 @@ async function main() { const daiMintTxReceipt = await daiMintTx.getReceipt(); // expect(daiMintTxReceipt.status).toBe(TxStatus.MINED); logger(`DAI mint TX status: ${daiMintTxReceipt.status} should be ${TxStatus.MINED}`); - await logExpectedBalanceOnL2( - aztecRpcClient, - owner.address, - INITIAL_BALANCE + BigInt(daiAmountToBridge), - daiL2Contract, - ); + await logExpectedBalanceOnL2(pxeClient, owner.address, INITIAL_BALANCE + BigInt(daiAmountToBridge), daiL2Contract); - const wethBalanceAfterSwap = await getL2BalanceOf(aztecRpcClient, owner.address, wethL2Contract); - const daiBalanceAfterSwap = await getL2BalanceOf(aztecRpcClient, owner.address, daiL2Contract); + const wethBalanceAfterSwap = await getL2BalanceOf(pxeClient, owner.address, wethL2Contract); + const daiBalanceAfterSwap = await getL2BalanceOf(pxeClient, owner.address, daiL2Contract); logger('WETH balance before swap: ', wethBalanceBeforeSwap.toString()); logger('DAI balance before swap : ', daiBalanceBeforeSwap.toString()); diff --git a/yarn-project/boxes/blank-react/src/tests/blank.contract.test.ts b/yarn-project/boxes/blank-react/src/tests/blank.contract.test.ts index a221f195ae3..736e4a5b409 100644 --- a/yarn-project/boxes/blank-react/src/tests/blank.contract.test.ts +++ b/yarn-project/boxes/blank-react/src/tests/blank.contract.test.ts @@ -20,10 +20,10 @@ const logger = createDebugLogger('aztec:http-rpc-client'); // as well as anvil. anvil can be started with yarn test:integration const setupSandbox = async () => { const { SANDBOX_URL = 'http://localhost:8080' } = process.env; - const aztecRpc = createPXEClient(SANDBOX_URL); - await waitForSandbox(aztecRpc); + const pxe = createPXEClient(SANDBOX_URL); + await waitForSandbox(pxe); - return aztecRpc; + return pxe; }; async function deployZKContract(owner: CompleteAddress, wallet: Wallet, rpcClient: PXE) { diff --git a/yarn-project/boxes/blank/src/tests/blank.contract.test.ts b/yarn-project/boxes/blank/src/tests/blank.contract.test.ts index 95aae4ee183..c892b2e9511 100644 --- a/yarn-project/boxes/blank/src/tests/blank.contract.test.ts +++ b/yarn-project/boxes/blank/src/tests/blank.contract.test.ts @@ -19,9 +19,9 @@ const logger = createDebugLogger('aztec:blank-box-test'); // as well as anvil. anvil can be started with yarn test:integration const setupSandbox = async () => { const { SANDBOX_URL = 'http://localhost:8080' } = process.env; - const aztecRpc = createPXEClient(SANDBOX_URL); - await waitForSandbox(aztecRpc); - return aztecRpc; + const pxe = createPXEClient(SANDBOX_URL); + await waitForSandbox(pxe); + return pxe; }; async function deployZKContract(owner: CompleteAddress, wallet: Wallet, rpcClient: PXE) { diff --git a/yarn-project/boxes/private-token/src/tests/privatetoken.sandbox.test.ts b/yarn-project/boxes/private-token/src/tests/privatetoken.sandbox.test.ts index 7ba36aef571..afb4c221d5b 100644 --- a/yarn-project/boxes/private-token/src/tests/privatetoken.sandbox.test.ts +++ b/yarn-project/boxes/private-token/src/tests/privatetoken.sandbox.test.ts @@ -24,9 +24,9 @@ const MINT_AMOUNT = 11n; // as well as anvil. anvil can be started with yarn test:integration const setupSandbox = async () => { const { SANDBOX_URL = 'http://localhost:8080' } = process.env; - const aztecRpc = createPXEClient(SANDBOX_URL); - await waitForSandbox(aztecRpc); - return aztecRpc; + const pxe = createPXEClient(SANDBOX_URL); + await waitForSandbox(pxe); + return pxe; }; async function deployZKContract(owner: CompleteAddress, wallet: Wallet, rpcClient: PXE) { diff --git a/yarn-project/canary/src/cli.test.ts b/yarn-project/canary/src/cli.test.ts index 940df56870e..cd347c6cbd7 100644 --- a/yarn-project/canary/src/cli.test.ts +++ b/yarn-project/canary/src/cli.test.ts @@ -6,9 +6,9 @@ const { SANDBOX_URL = 'http://localhost:8080' } = process.env; const debug = createDebugLogger('aztec:canary_cli'); const setupRPC = async () => { - const aztecRpcClient = createPXEClient(SANDBOX_URL, makeFetch([1, 2, 3, 4, 5], true)); - await waitForSandbox(aztecRpcClient); - return aztecRpcClient; + const pxeClient = createPXEClient(SANDBOX_URL, makeFetch([1, 2, 3, 4, 5], true)); + await waitForSandbox(pxeClient); + return pxeClient; }; cliTestSuite('CLI Canary', setupRPC, () => Promise.resolve(), debug, SANDBOX_URL); diff --git a/yarn-project/canary/src/uniswap_trade_on_l1_from_l2.test.ts b/yarn-project/canary/src/uniswap_trade_on_l1_from_l2.test.ts index 09e0d59dba2..cf44d6914a5 100644 --- a/yarn-project/canary/src/uniswap_trade_on_l1_from_l2.test.ts +++ b/yarn-project/canary/src/uniswap_trade_on_l1_from_l2.test.ts @@ -45,12 +45,12 @@ const DAI_ADDRESS = EthAddress.fromString('0x6B175474E89094C44Da98b954EedeAC4952 const EXPECTED_FORKED_BLOCK = 17514288; -const aztecRpcUrl = SANDBOX_URL; +const pxeRpcUrl = SANDBOX_URL; const ethRpcUrl = ETHEREUM_HOST; const hdAccount = mnemonicToAccount(MNEMONIC); -const aztecRpcClient = createPXEClient(aztecRpcUrl); +const pxeClient = createPXEClient(pxeRpcUrl); let wallet: Wallet; /** @@ -62,7 +62,7 @@ async function deployAllContracts( publicClient: PublicClient, walletClient: WalletClient, ) { - const l1ContractsAddresses = await getL1ContractAddresses(aztecRpcUrl); + const l1ContractsAddresses = await getL1ContractAddresses(pxeRpcUrl); logger('Deploying DAI Portal, initializing and deploying l2 contract...'); const daiContracts = await deployAndInitializeNonNativeL2TokenContracts( wallet, @@ -107,7 +107,7 @@ async function deployAllContracts( }); // deploy l2 uniswap contract and attach to portal - const tx = UniswapContract.deploy(aztecRpcClient).send({ + const tx = UniswapContract.deploy(pxeClient).send({ portalContract: uniswapPortalAddress, }); await tx.isMined(); @@ -163,7 +163,7 @@ describe.skip('uniswap_trade_on_l1_from_l2', () => { let publicClient: PublicClient; let walletClient: WalletClient; beforeAll(async () => { - await waitForSandbox(aztecRpcClient); + await waitForSandbox(pxeClient); walletClient = createWalletClient({ account: hdAccount, @@ -184,7 +184,7 @@ describe.skip('uniswap_trade_on_l1_from_l2', () => { it('should uniswap trade on L1 from L2 funds privately (swaps WETH -> DAI)', async () => { logger('Running L1/L2 messaging test on HTTP interface.'); - [wallet] = await getSandboxAccountsWallets(aztecRpcClient); + [wallet] = await getSandboxAccountsWallets(pxeClient); const accounts = await wallet.getRegisteredAccounts(); const owner = accounts[0].address; const receiver = accounts[1].address; diff --git a/yarn-project/end-to-end/src/canary/cli.ts b/yarn-project/end-to-end/src/canary/cli.ts index d0cc198291e..2f486df6694 100644 --- a/yarn-project/end-to-end/src/canary/cli.ts +++ b/yarn-project/end-to-end/src/canary/cli.ts @@ -16,7 +16,7 @@ export const cliTestSuite = ( ) => describe(name, () => { let cli: ReturnType; - let aztecRpcClient: PXE; + let pxeClient: PXE; let existingAccounts: CompleteAddress[]; let contractAddress: AztecAddress; let log: (...args: any[]) => void; @@ -25,7 +25,7 @@ export const cliTestSuite = ( const logs: string[] = []; beforeAll(async () => { - aztecRpcClient = await setup(); + pxeClient = await setup(); log = (...args: any[]) => { logs.push(format(...args)); debug(...args); @@ -79,14 +79,14 @@ export const cliTestSuite = ( }; it('creates & retrieves an account', async () => { - existingAccounts = await aztecRpcClient.getRegisteredAccounts(); + existingAccounts = await pxeClient.getRegisteredAccounts(); debug('Create an account'); await run(`create-account`); const foundAddress = findInLogs(/Address:\s+(?
0x[a-fA-F0-9]+)/)?.groups?.address; expect(foundAddress).toBeDefined(); const newAddress = AztecAddress.fromString(foundAddress!); - const accountsAfter = await aztecRpcClient.getRegisteredAccounts(); + const accountsAfter = await pxeClient.getRegisteredAccounts(); const expectedAccounts = [...existingAccounts.map(a => a.address), newAddress]; expect(accountsAfter.map(a => a.address)).toEqual(expectedAccounts); const newCompleteAddress = accountsAfter[accountsAfter.length - 1]; @@ -123,7 +123,7 @@ export const cliTestSuite = ( expect(loggedAddress).toBeDefined(); contractAddress = AztecAddress.fromString(loggedAddress!); - const deployedContract = await aztecRpcClient.getContractData(contractAddress); + const deployedContract = await pxeClient.getContractData(contractAddress); expect(deployedContract?.contractAddress).toEqual(contractAddress); debug('Check contract can be found in returned address'); @@ -161,7 +161,7 @@ export const cliTestSuite = ( expect(balance!).toEqual(`${BigInt(INITIAL_BALANCE).toString()}n`); debug('Transfer some tokens'); - const existingAccounts = await aztecRpcClient.getRegisteredAccounts(); + const existingAccounts = await pxeClient.getRegisteredAccounts(); // ensure we pick a different acc const receiver = existingAccounts.find(acc => acc.address.toString() !== ownerAddress.toString()); diff --git a/yarn-project/end-to-end/src/e2e_p2p_network.test.ts b/yarn-project/end-to-end/src/e2e_p2p_network.test.ts index 3f7f0576d2f..0bd2e51ccdf 100644 --- a/yarn-project/end-to-end/src/e2e_p2p_network.test.ts +++ b/yarn-project/end-to-end/src/e2e_p2p_network.test.ts @@ -17,7 +17,7 @@ const BOOT_NODE_TCP_PORT = 40400; interface NodeContext { node: AztecNodeService; - rpcServer: PXEService; + pxeService: PXEService; txs: SentTx[]; account: AztecAddress; } @@ -45,7 +45,7 @@ describe('e2e_p2p_network', () => { const contexts: NodeContext[] = []; for (let i = 0; i < NUM_NODES; i++) { const node = await createNode(i + 1 + BOOT_NODE_TCP_PORT, bootstrapNodeAddress); - const context = await createAztecRpcServerAndSubmitTransactions(node, NUM_TXS_PER_NODE); + const context = await createPXEServiceAndSubmitTransactions(node, NUM_TXS_PER_NODE); contexts.push(context); } @@ -58,15 +58,15 @@ describe('e2e_p2p_network', () => { expect(isMined).toBe(true); expect(receiptAfterMined.status).toBe(TxStatus.MINED); const contractAddress = receiptAfterMined.contractAddress!; - expect(await isContractDeployed(context.rpcServer, contractAddress)).toBeTruthy(); - expect(await isContractDeployed(context.rpcServer, AztecAddress.random())).toBeFalsy(); + expect(await isContractDeployed(context.pxeService, contractAddress)).toBeTruthy(); + expect(await isContractDeployed(context.pxeService, AztecAddress.random())).toBeFalsy(); } } // shutdown all nodes. for (const context of contexts) { await context.node.stop(); - await context.rpcServer.stop(); + await context.pxeService.stop(); } await bootstrapNode.stop(); }, 80_000); @@ -135,25 +135,25 @@ describe('e2e_p2p_network', () => { }; // creates an instance of the PXE and submit a given number of transactions to it. - const createAztecRpcServerAndSubmitTransactions = async ( + const createPXEServiceAndSubmitTransactions = async ( node: AztecNodeService, numTxs: number, ): Promise => { const rpcConfig = getRpcConfig(); - const pxe = await createPXEService(node, rpcConfig, {}, true); + const pxeService = await createPXEService(node, rpcConfig, {}, true); const keyPair = ConstantKeyPair.random(await Grumpkin.new()); const completeAddress = await CompleteAddress.fromPrivateKeyAndPartialAddress( await keyPair.getPrivateKey(), Fr.random(), ); - await pxe.registerAccount(await keyPair.getPrivateKey(), completeAddress.partialAddress); + await pxeService.registerAccount(await keyPair.getPrivateKey(), completeAddress.partialAddress); - const txs = await submitTxsTo(pxe, completeAddress.address, numTxs, completeAddress.publicKey); + const txs = await submitTxsTo(pxeService, completeAddress.address, numTxs, completeAddress.publicKey); return { txs, account: completeAddress.address, - rpcServer: pxe, + pxeService, node, }; }; diff --git a/yarn-project/end-to-end/src/e2e_sandbox_example.test.ts b/yarn-project/end-to-end/src/e2e_sandbox_example.test.ts index 5daed243d1c..62584b0be1e 100644 --- a/yarn-project/end-to-end/src/e2e_sandbox_example.test.ts +++ b/yarn-project/end-to-end/src/e2e_sandbox_example.test.ts @@ -22,11 +22,11 @@ describe('e2e_sandbox_example', () => { const logger = createDebugLogger('token'); // We create PXE client connected to the sandbox URL - const aztecRpc = createPXEClient(SANDBOX_URL); + const pxe = createPXEClient(SANDBOX_URL); // Wait for sandbox to be ready - await waitForSandbox(aztecRpc); + await waitForSandbox(pxe); - const nodeInfo = await aztecRpc.getNodeInfo(); + const nodeInfo = await pxe.getNodeInfo(); logger('Aztec Sandbox Info ', nodeInfo); // docs:end:setup @@ -41,7 +41,7 @@ describe('e2e_sandbox_example', () => { // docs:start:load_accounts ////////////// LOAD SOME ACCOUNTS FROM THE SANDBOX ////////////// // The sandbox comes with a set of created accounts. Load them - const accounts = await getSandboxAccountsWallets(aztecRpc); + const accounts = await getSandboxAccountsWallets(pxe); const alice = accounts[0].getAddress(); const bob = accounts[1].getAddress(); logger(`Loaded alice's account at ${alice.toShortString()}`); @@ -55,7 +55,7 @@ describe('e2e_sandbox_example', () => { const initialSupply = 1_000_000n; logger(`Deploying token contract minting an initial ${initialSupply} tokens to Alice...`); - const contract = await TokenContract.deploy(aztecRpc).send().deployed(); + const contract = await TokenContract.deploy(pxe).send().deployed(); // Create the contract abstraction and link to Alice's wallet for future signing const tokenContractAlice = await TokenContract.at(contract.address, accounts[0]); @@ -74,7 +74,7 @@ describe('e2e_sandbox_example', () => { // docs:end:Deployment // ensure that token contract is registered in the rpc - expect(await aztecRpc.getContracts()).toEqual(expect.arrayContaining([contract.address])); + expect(await pxe.getContracts()).toEqual(expect.arrayContaining([contract.address])); // docs:start:Balance @@ -138,20 +138,20 @@ describe('e2e_sandbox_example', () => { it('can create accounts on the sandbox', async () => { const logger = createDebugLogger('token'); // We create PXE client connected to the sandbox URL - const aztecRpc = createPXEClient(SANDBOX_URL); + const pxe = createPXEClient(SANDBOX_URL); // Wait for sandbox to be ready - await waitForSandbox(aztecRpc); + await waitForSandbox(pxe); // docs:start:create_accounts ////////////// CREATE SOME ACCOUNTS WITH SCHNORR SIGNERS ////////////// // Creates new accounts using an account contract that verifies schnorr signatures // Returns once the deployment transactions have settled - const createSchnorrAccounts = async (numAccounts: number, aztecRpc: PXE) => { + const createSchnorrAccounts = async (numAccounts: number, pxe: PXE) => { const accountManagers = Array(numAccounts) .fill(0) .map(() => getSchnorrAccount( - aztecRpc, + pxe, GrumpkinScalar.random(), // encryption private key GrumpkinScalar.random(), // signing private key ), @@ -166,14 +166,14 @@ describe('e2e_sandbox_example', () => { // Create 2 accounts and wallets to go with each logger(`Creating accounts using schnorr signers...`); - const accounts = await createSchnorrAccounts(2, aztecRpc); + const accounts = await createSchnorrAccounts(2, pxe); ////////////// VERIFY THE ACCOUNTS WERE CREATED SUCCESSFULLY ////////////// const [alice, bob] = (await Promise.all(accounts.map(x => x.getCompleteAddress()))).map(x => x.address); // Verify that the accounts were deployed - const registeredAccounts = (await aztecRpc.getRegisteredAccounts()).map(x => x.address); + const registeredAccounts = (await pxe.getRegisteredAccounts()).map(x => x.address); for (const [account, name] of [ [alice, 'Alice'], [bob, 'Bob'], diff --git a/yarn-project/end-to-end/src/pxe_sandbox.test.ts b/yarn-project/end-to-end/src/pxe_sandbox.test.ts index bc1ea20fc49..cfdee86086e 100644 --- a/yarn-project/end-to-end/src/pxe_sandbox.test.ts +++ b/yarn-project/end-to-end/src/pxe_sandbox.test.ts @@ -4,9 +4,9 @@ import { pxeTestSuite } from '@aztec/pxe'; const { SANDBOX_URL = 'http://localhost:8080' } = process.env; const setup = async () => { - const aztecRpc = createPXEClient(SANDBOX_URL); - await waitForSandbox(aztecRpc); - return aztecRpc; + const pxe = createPXEClient(SANDBOX_URL); + await waitForSandbox(pxe); + return pxe; }; pxeTestSuite('pxe_sandbox', setup); diff --git a/yarn-project/pxe/src/pxe_service/test/pxe_test_suite.ts b/yarn-project/pxe/src/pxe_service/test/pxe_test_suite.ts index b9ba8afa9c1..7020dfdcea0 100644 --- a/yarn-project/pxe/src/pxe_service/test/pxe_test_suite.ts +++ b/yarn-project/pxe/src/pxe_service/test/pxe_test_suite.ts @@ -3,12 +3,12 @@ import { Grumpkin } from '@aztec/circuits.js/barretenberg'; import { ConstantKeyPair } from '@aztec/key-store'; import { DeployedContract, INITIAL_L2_BLOCK_NUM, PXE, TxExecutionRequest, randomDeployedContract } from '@aztec/types'; -export const pxeTestSuite = (testName: string, aztecRpcSetup: () => Promise) => { +export const pxeTestSuite = (testName: string, pxeSetup: () => Promise) => { describe(testName, () => { let rpc: PXE; beforeAll(async () => { - rpc = await aztecRpcSetup(); + rpc = await pxeSetup(); }, 120_000); it('registers an account and returns it as an account only and not as a recipient', async () => { From bc08ffc31aa501d8c4f9ce235a96899badd5f35c Mon Sep 17 00:00:00 2001 From: benesjan Date: Wed, 27 Sep 2023 11:27:22 +0000 Subject: [PATCH 05/23] fixes --- yarn-project/aztec-sandbox/src/examples/util.ts | 2 +- .../src/app/components/contract_function_form.tsx | 8 ++++---- .../boxes/private-token/src/app/components/copy.tsx | 2 +- .../boxes/private-token/src/app/components/dropdown.tsx | 5 ++--- .../boxes/private-token/src/app/components/popup.tsx | 2 +- .../boxes/private-token/src/app/components/select.tsx | 5 ++--- .../private-token/src/app/components/wallet_dropdown.tsx | 8 ++++---- yarn-project/boxes/private-token/src/app/contract.tsx | 8 ++++---- yarn-project/boxes/private-token/src/app/home.tsx | 6 +++--- yarn-project/boxes/private-token/src/app/index.html | 2 +- yarn-project/boxes/private-token/src/app/index.tsx | 4 ++-- yarn-project/boxes/private-token/src/config.ts | 4 +++- .../private-token/src/scripts/call_contract_function.ts | 2 +- .../private-token/src/scripts/view_contract_function.ts | 2 +- .../private-token/src/tests/privatetoken.sandbox.test.ts | 6 +++--- yarn-project/canary/src/utils.ts | 2 +- 16 files changed, 34 insertions(+), 34 deletions(-) diff --git a/yarn-project/aztec-sandbox/src/examples/util.ts b/yarn-project/aztec-sandbox/src/examples/util.ts index d1e261a2a72..d3462673cce 100644 --- a/yarn-project/aztec-sandbox/src/examples/util.ts +++ b/yarn-project/aztec-sandbox/src/examples/util.ts @@ -7,7 +7,7 @@ import { Account, Chain, Hex, HttpTransport, PublicClient, WalletClient, getCont /** * Deploy L1 token and portal, initialize portal, deploy a non native l2 token contract and attach is to the portal. - * @param pxeServicerivate Execution Environment (PXE) instance + * @param wallet - A wallet instance. * @param walletClient - A viem WalletClient. * @param publicClient - A viem PublicClient. * @param rollupRegistryAddress - address of rollup registry to pass to initialize the token portal diff --git a/yarn-project/boxes/private-token/src/app/components/contract_function_form.tsx b/yarn-project/boxes/private-token/src/app/components/contract_function_form.tsx index 69916e7061e..6cd27644e19 100644 --- a/yarn-project/boxes/private-token/src/app/components/contract_function_form.tsx +++ b/yarn-project/boxes/private-token/src/app/components/contract_function_form.tsx @@ -1,12 +1,12 @@ +import { CONTRACT_ADDRESS_PARAM_NAMES, rpcClient } from '../../config.js'; +import { callContractFunction, deployContract, viewContractFunction } from '../../scripts/index.js'; +import { convertArgs } from '../../scripts/util.js'; +import styles from './contract_function_form.module.scss'; import { Button, Loader } from '@aztec/aztec-ui'; import { AztecAddress, CompleteAddress, Fr } from '@aztec/aztec.js'; import { ContractAbi, FunctionAbi } from '@aztec/foundation/abi'; import { useFormik } from 'formik'; import * as Yup from 'yup'; -import { CONTRACT_ADDRESS_PARAM_NAMES, rpcClient } from '../../config.js'; -import { callContractFunction, deployContract, viewContractFunction } from '../../scripts/index.js'; -import { convertArgs } from '../../scripts/util.js'; -import styles from './contract_function_form.module.scss'; type NoirFunctionYupSchema = { // hack: add `any` at the end to get the array schema to typecheck diff --git a/yarn-project/boxes/private-token/src/app/components/copy.tsx b/yarn-project/boxes/private-token/src/app/components/copy.tsx index 4c497833bab..6caa3312159 100644 --- a/yarn-project/boxes/private-token/src/app/components/copy.tsx +++ b/yarn-project/boxes/private-token/src/app/components/copy.tsx @@ -1,5 +1,5 @@ -import { useState } from 'react'; import styles from './copy.module.scss'; +import { useState } from 'react'; export function Copy({ value }: { value: string }) { const [copied, setCopied] = useState(false); diff --git a/yarn-project/boxes/private-token/src/app/components/dropdown.tsx b/yarn-project/boxes/private-token/src/app/components/dropdown.tsx index 2d74e687c93..6470d2c80f3 100644 --- a/yarn-project/boxes/private-token/src/app/components/dropdown.tsx +++ b/yarn-project/boxes/private-token/src/app/components/dropdown.tsx @@ -1,7 +1,6 @@ -import { CSSProperties, useEffect, useRef } from 'react'; -import classnames from 'classnames'; - import style from './dropdown.module.scss'; +import classnames from 'classnames'; +import { CSSProperties, useEffect, useRef } from 'react'; export enum DropdownType { Simple = 'Simple', diff --git a/yarn-project/boxes/private-token/src/app/components/popup.tsx b/yarn-project/boxes/private-token/src/app/components/popup.tsx index cf9a1d8962a..bfbdc7d3f58 100644 --- a/yarn-project/boxes/private-token/src/app/components/popup.tsx +++ b/yarn-project/boxes/private-token/src/app/components/popup.tsx @@ -1,5 +1,5 @@ -import { Button } from '@aztec/aztec-ui'; import styles from './popup.module.scss'; +import { Button } from '@aztec/aztec-ui'; interface Props { children: string; diff --git a/yarn-project/boxes/private-token/src/app/components/select.tsx b/yarn-project/boxes/private-token/src/app/components/select.tsx index 81a4c0c7a97..562f5e12fdf 100644 --- a/yarn-project/boxes/private-token/src/app/components/select.tsx +++ b/yarn-project/boxes/private-token/src/app/components/select.tsx @@ -1,8 +1,7 @@ -import { useState, useEffect, useRef } from 'react'; -import classnames from 'classnames'; - import { DropdownOption, DropdownType, Dropdown } from './dropdown.js'; import style from './select.module.scss'; +import classnames from 'classnames'; +import { useState, useEffect, useRef } from 'react'; interface SelectProps { options: DropdownOption[]; diff --git a/yarn-project/boxes/private-token/src/app/components/wallet_dropdown.tsx b/yarn-project/boxes/private-token/src/app/components/wallet_dropdown.tsx index 131dc2c8d72..90daa98665f 100644 --- a/yarn-project/boxes/private-token/src/app/components/wallet_dropdown.tsx +++ b/yarn-project/boxes/private-token/src/app/components/wallet_dropdown.tsx @@ -1,10 +1,10 @@ -import { Loader } from '@aztec/aztec-ui'; -import { CompleteAddress } from '@aztec/aztec.js'; -import { useEffect, useState } from 'react'; import { rpcClient } from '../../config.js'; +import { Copy } from './copy.js'; import { Select } from './select.js'; import styles from './wallet_dropdown.module.scss'; -import { Copy } from './copy.js'; +import { Loader } from '@aztec/aztec-ui'; +import { CompleteAddress } from '@aztec/aztec.js'; +import { useEffect, useState } from 'react'; interface Props { selected: CompleteAddress | undefined; diff --git a/yarn-project/boxes/private-token/src/app/contract.tsx b/yarn-project/boxes/private-token/src/app/contract.tsx index 87495ef8cf3..3b9e3c3c80b 100644 --- a/yarn-project/boxes/private-token/src/app/contract.tsx +++ b/yarn-project/boxes/private-token/src/app/contract.tsx @@ -1,11 +1,11 @@ -import { Button, ButtonSize, ButtonTheme, Card, CardTheme, ImageButton, ImageButtonIcon } from '@aztec/aztec-ui'; -import { AztecAddress, CompleteAddress } from '@aztec/aztec.js'; -import { FunctionAbi } from '@aztec/foundation/abi'; -import { ReactNode, useState } from 'react'; import { FILTERED_FUNCTION_NAMES, contractAbi } from '../config.js'; import { Copy } from './components/copy.js'; import { ContractFunctionForm, Popup } from './components/index.js'; import styles from './contract.module.scss'; +import { Button, ButtonSize, ButtonTheme, Card, CardTheme, ImageButton, ImageButtonIcon } from '@aztec/aztec-ui'; +import { AztecAddress, CompleteAddress } from '@aztec/aztec.js'; +import { FunctionAbi } from '@aztec/foundation/abi'; +import { ReactNode, useState } from 'react'; const functionTypeSortOrder = { secret: 0, diff --git a/yarn-project/boxes/private-token/src/app/home.tsx b/yarn-project/boxes/private-token/src/app/home.tsx index f6d7186fcb1..64e73a44d12 100644 --- a/yarn-project/boxes/private-token/src/app/home.tsx +++ b/yarn-project/boxes/private-token/src/app/home.tsx @@ -1,10 +1,10 @@ -import { Loader } from '@aztec/aztec-ui'; -import { CompleteAddress } from '@aztec/aztec.js'; -import { useEffect, useRef, useState } from 'react'; import { SANDBOX_URL } from '../config.js'; import { WalletDropdown } from './components/wallet_dropdown.js'; import { Contract } from './contract.js'; import styles from './home.module.scss'; +import { Loader } from '@aztec/aztec-ui'; +import { CompleteAddress } from '@aztec/aztec.js'; +import { useEffect, useRef, useState } from 'react'; export function Home() { const [isLoadingWallet, setIsLoadingWallet] = useState(true); diff --git a/yarn-project/boxes/private-token/src/app/index.html b/yarn-project/boxes/private-token/src/app/index.html index a81c17f2a87..6fedf6b23a6 100644 --- a/yarn-project/boxes/private-token/src/app/index.html +++ b/yarn-project/boxes/private-token/src/app/index.html @@ -1,4 +1,4 @@ - + diff --git a/yarn-project/boxes/private-token/src/app/index.tsx b/yarn-project/boxes/private-token/src/app/index.tsx index c5f7c020418..451c1c89648 100644 --- a/yarn-project/boxes/private-token/src/app/index.tsx +++ b/yarn-project/boxes/private-token/src/app/index.tsx @@ -1,7 +1,7 @@ -import * as React from 'react'; -import * as ReactDOM from 'react-dom/client'; import { Home } from './home.js'; import './index.css'; +import * as React from 'react'; +import * as ReactDOM from 'react-dom/client'; const root = ReactDOM.createRoot(document.getElementById('root') as HTMLElement); root.render( diff --git a/yarn-project/boxes/private-token/src/config.ts b/yarn-project/boxes/private-token/src/config.ts index 7e999ea5dbd..b8f0f1507be 100644 --- a/yarn-project/boxes/private-token/src/config.ts +++ b/yarn-project/boxes/private-token/src/config.ts @@ -1,6 +1,8 @@ +import { PrivateTokenContractAbi } from './artifacts/private_token.js'; import { PXE, createPXEClient } from '@aztec/aztec.js'; import { ContractAbi } from '@aztec/foundation/abi'; -import { PrivateTokenContractAbi } from './artifacts/private_token.js'; // update this if using a different contract + +// update this if using a different contract export const contractAbi: ContractAbi = PrivateTokenContractAbi; diff --git a/yarn-project/boxes/private-token/src/scripts/call_contract_function.ts b/yarn-project/boxes/private-token/src/scripts/call_contract_function.ts index bd0e52489c3..6565be4ce68 100644 --- a/yarn-project/boxes/private-token/src/scripts/call_contract_function.ts +++ b/yarn-project/boxes/private-token/src/scripts/call_contract_function.ts @@ -1,6 +1,6 @@ +import { getWallet } from './util.js'; import { AztecAddress, PXE, CompleteAddress, Contract } from '@aztec/aztec.js'; import { ContractAbi } from '@aztec/foundation/abi'; -import { getWallet } from './util.js'; export async function callContractFunction( address: AztecAddress, diff --git a/yarn-project/boxes/private-token/src/scripts/view_contract_function.ts b/yarn-project/boxes/private-token/src/scripts/view_contract_function.ts index b0417af71c9..aa02bc916f6 100644 --- a/yarn-project/boxes/private-token/src/scripts/view_contract_function.ts +++ b/yarn-project/boxes/private-token/src/scripts/view_contract_function.ts @@ -1,6 +1,6 @@ +import { getWallet } from './util.js'; import { AztecAddress, PXE, CompleteAddress, Contract } from '@aztec/aztec.js'; import { ContractAbi } from '@aztec/foundation/abi'; -import { getWallet } from './util.js'; export async function viewContractFunction( address: AztecAddress, diff --git a/yarn-project/boxes/private-token/src/tests/privatetoken.sandbox.test.ts b/yarn-project/boxes/private-token/src/tests/privatetoken.sandbox.test.ts index afb4c221d5b..3580cd45442 100644 --- a/yarn-project/boxes/private-token/src/tests/privatetoken.sandbox.test.ts +++ b/yarn-project/boxes/private-token/src/tests/privatetoken.sandbox.test.ts @@ -1,3 +1,6 @@ +import { PrivateTokenContract } from '../artifacts/private_token.js'; +import { rpcClient } from '../config.js'; +import { callContractFunction, deployContract, getWallet, viewContractFunction } from '../scripts/index.js'; import { AccountWallet, AztecAddress, @@ -10,9 +13,6 @@ import { waitForSandbox, } from '@aztec/aztec.js'; import { createDebugLogger } from '@aztec/foundation/log'; -import { PrivateTokenContract } from '../artifacts/private_token.js'; -import { rpcClient } from '../config.js'; -import { callContractFunction, deployContract, getWallet, viewContractFunction } from '../scripts/index.js'; const logger = createDebugLogger('aztec:private-token-box-sandbox-test'); diff --git a/yarn-project/canary/src/utils.ts b/yarn-project/canary/src/utils.ts index 58367905e0b..d5404a0fdae 100644 --- a/yarn-project/canary/src/utils.ts +++ b/yarn-project/canary/src/utils.ts @@ -7,7 +7,7 @@ import { Account, Chain, Hex, HttpTransport, PublicClient, WalletClient, getCont /** * Deploy L1 token and portal, initialize portal, deploy a non native l2 token contract and attach is to the portal. - * @param pxeServicerivate Execution Environment (PXE) instance + * @param wallet - A wallet instance. * @param walletClient - A viem WalletClient. * @param publicClient - A viem PublicClient. * @param rollupRegistryAddress - address of rollup registry to pass to initialize the token portal From 7beabe57203f2896a58b52a319f7b2ac1559992b Mon Sep 17 00:00:00 2001 From: benesjan Date: Wed, 27 Sep 2023 11:37:02 +0000 Subject: [PATCH 06/23] cleanup --- docs/docs/dev_docs/wallets/architecture.md | 2 +- yarn-project/aztec-sandbox/src/bin/index.ts | 4 ++-- yarn-project/aztec-sandbox/src/server.ts | 4 ++-- yarn-project/{aztec-rpc => pxe}/src/bin/index.ts | 14 +++++++------- yarn-project/pxe/src/pxe_http/pxe_http_server.ts | 6 +++--- yarn-project/types/src/interfaces/pxe.ts | 4 ++-- 6 files changed, 17 insertions(+), 17 deletions(-) rename yarn-project/{aztec-rpc => pxe}/src/bin/index.ts (68%) diff --git a/docs/docs/dev_docs/wallets/architecture.md b/docs/docs/dev_docs/wallets/architecture.md index 6c533f34868..a2034d0d1ea 100644 --- a/docs/docs/dev_docs/wallets/architecture.md +++ b/docs/docs/dev_docs/wallets/architecture.md @@ -22,7 +22,7 @@ Refer to the page on [writing an account contract](./writing_an_account_contract A wallet exposes the RPC interface to dapps by running an PXE instance. The PXE requires a keystore and a database implementation for storing keys, private state, and recipient encryption public keys. -#include_code rpc-interface /yarn-project/types/src/interfaces/aztec_rpc.ts typescript +#include_code pxe-interface /yarn-project/types/src/interfaces/pxe.ts typescript diff --git a/yarn-project/aztec-sandbox/src/bin/index.ts b/yarn-project/aztec-sandbox/src/bin/index.ts index 760cbbab705..b2dbab35dd4 100644 --- a/yarn-project/aztec-sandbox/src/bin/index.ts +++ b/yarn-project/aztec-sandbox/src/bin/index.ts @@ -3,7 +3,7 @@ import { deployInitialSandboxAccounts } from '@aztec/aztec.js'; import { createDebugLogger } from '@aztec/foundation/log'; import { fileURLToPath } from '@aztec/foundation/url'; import NoirVersion from '@aztec/noir-compiler/noir-version'; -import { startPxeHttpServer } from '@aztec/pxe'; +import { startPXEHttpServer } from '@aztec/pxe'; import { readFileSync } from 'fs'; import { dirname, resolve } from 'path'; @@ -52,7 +52,7 @@ async function main() { process.once('SIGINT', shutdown); process.once('SIGTERM', shutdown); - startPxeHttpServer(rpcServer, SERVER_PORT); + startPXEHttpServer(rpcServer, SERVER_PORT); logger.info(`Aztec Sandbox JSON-RPC Server listening on port ${SERVER_PORT}`); logger.info(`Debug logs will be written to ${logPath}`); const accountStrings = [`Initial Accounts:\n\n`]; diff --git a/yarn-project/aztec-sandbox/src/server.ts b/yarn-project/aztec-sandbox/src/server.ts index 156349e64a2..4affe2f2b21 100644 --- a/yarn-project/aztec-sandbox/src/server.ts +++ b/yarn-project/aztec-sandbox/src/server.ts @@ -1,4 +1,4 @@ -import { createPxeRpcServer } from '@aztec/pxe'; +import { createPXERpcServer } from '@aztec/pxe'; import { PXE } from '@aztec/types'; import http from 'http'; @@ -12,7 +12,7 @@ import { createApiRouter } from './routes.js'; * @returns A running http server. */ export function startHttpRpcServer(pxe: PXE, port: string | number): http.Server { - const rpcServer = createPxeRpcServer(pxe); + const rpcServer = createPXERpcServer(pxe); const app = rpcServer.getApp(); const apiRouter = createApiRouter(); diff --git a/yarn-project/aztec-rpc/src/bin/index.ts b/yarn-project/pxe/src/bin/index.ts similarity index 68% rename from yarn-project/aztec-rpc/src/bin/index.ts rename to yarn-project/pxe/src/bin/index.ts index a5b87a28ba2..a2e088b8902 100644 --- a/yarn-project/aztec-rpc/src/bin/index.ts +++ b/yarn-project/pxe/src/bin/index.ts @@ -2,8 +2,8 @@ import { createDebugLogger } from '@aztec/foundation/log'; import { createAztecNodeRpcClient } from '@aztec/types'; -import { startHttpRpcServer } from '../aztec_rpc_http/index.js'; -import { createPXEService } from '../aztec_rpc_server/index.js'; +import { startPXEHttpServer } from '../pxe_http/index.js'; +import { createPXEService } from '../pxe_service/index.js'; import { getConfigEnvVars } from '../config/index.js'; const { SERVER_PORT = 8080, AZTEC_NODE_RPC_URL = '' } = process.env; @@ -11,25 +11,25 @@ const { SERVER_PORT = 8080, AZTEC_NODE_RPC_URL = '' } = process.env; const logger = createDebugLogger('aztec:rpc_server'); /** - * Create and start a new Aztec RCP HTTP Server + * Create and start a new PXE HTTP Server */ async function main() { logger.info(`Setting up PXE...`); - const rpcConfig = getConfigEnvVars(); + const pxeConfig = getConfigEnvVars(); const nodeRpcClient = createAztecNodeRpcClient(AZTEC_NODE_RPC_URL); - const rpcServer = await createPXEService(nodeRpcClient, rpcConfig); + const pxeService = await createPXEService(nodeRpcClient, pxeConfig); const shutdown = async () => { logger.info('Shutting down...'); - await rpcServer.stop(); + await pxeService.stop(); process.exit(0); }; process.once('SIGINT', shutdown); process.once('SIGTERM', shutdown); - startHttpRpcServer(rpcServer, SERVER_PORT); + startPXEHttpServer(pxeService, SERVER_PORT); logger.info(`PXE listening on port ${SERVER_PORT}`); } diff --git a/yarn-project/pxe/src/pxe_http/pxe_http_server.ts b/yarn-project/pxe/src/pxe_http/pxe_http_server.ts index 9cf95e4bda9..76c3c97a733 100644 --- a/yarn-project/pxe/src/pxe_http/pxe_http_server.ts +++ b/yarn-project/pxe/src/pxe_http/pxe_http_server.ts @@ -28,7 +28,7 @@ export const localAnvil = foundry; * Wraps an instance of Private Execution Environment (PXE) implementation to a JSON RPC HTTP interface. * @returns A new instance of the HTTP server. */ -export function createPxeRpcServer(pxeService: PXE): JsonRpcServer { +export function createPXERpcServer(pxeService: PXE): JsonRpcServer { return new JsonRpcServer( pxeService, { @@ -59,8 +59,8 @@ export function createPxeRpcServer(pxeService: PXE): JsonRpcServer { * @param port - Port to listen in. * @returns A running http server. */ -export function startPxeHttpServer(pxeService: PXE, port: string | number): http.Server { - const rpcServer = createPxeRpcServer(pxeService); +export function startPXEHttpServer(pxeService: PXE, port: string | number): http.Server { + const rpcServer = createPXERpcServer(pxeService); const app = rpcServer.getApp(); const httpServer = http.createServer(app.callback()); diff --git a/yarn-project/types/src/interfaces/pxe.ts b/yarn-project/types/src/interfaces/pxe.ts index ec36db4fb40..12878f1ee52 100644 --- a/yarn-project/types/src/interfaces/pxe.ts +++ b/yarn-project/types/src/interfaces/pxe.ts @@ -18,7 +18,7 @@ import { DeployedContract } from './deployed-contract.js'; import { NodeInfo } from './node-info.js'; import { SyncStatus } from './sync-status.js'; -// docs:start:rpc-interface +// docs:start:pxe-interface /** * Private Execution Environment (PXE) runs locally for each user, providing functionality for all the operations * needed to interact with the Aztec network, including account management, private data management, @@ -278,4 +278,4 @@ export interface PXE { */ getSyncStatus(): Promise; } -// docs:end:rpc-interface +// docs:end:pxe-interface From e781736cdf1758cc2ea143ff2e43300df2b16e67 Mon Sep 17 00:00:00 2001 From: benesjan Date: Wed, 27 Sep 2023 11:50:26 +0000 Subject: [PATCH 07/23] fixes --- yarn-project/end-to-end/src/e2e_2_pxes.test.ts | 2 +- yarn-project/pxe/src/bin/index.ts | 4 ++-- yarn-project/pxe/src/synchronizer/synchronizer.ts | 4 +--- 3 files changed, 4 insertions(+), 6 deletions(-) diff --git a/yarn-project/end-to-end/src/e2e_2_pxes.test.ts b/yarn-project/end-to-end/src/e2e_2_pxes.test.ts index 60ee21df181..e4f81856930 100644 --- a/yarn-project/end-to-end/src/e2e_2_pxes.test.ts +++ b/yarn-project/end-to-end/src/e2e_2_pxes.test.ts @@ -15,7 +15,7 @@ const { SANDBOX_URL = '' } = process.env; const TIMEOUT = 60_000; -describe('e2e_2_rpc_servers', () => { +describe('e2e_2_pxes', () => { jest.setTimeout(TIMEOUT); let aztecNode: AztecNodeService | undefined; diff --git a/yarn-project/pxe/src/bin/index.ts b/yarn-project/pxe/src/bin/index.ts index a2e088b8902..9c7cd3f41b7 100644 --- a/yarn-project/pxe/src/bin/index.ts +++ b/yarn-project/pxe/src/bin/index.ts @@ -2,13 +2,13 @@ import { createDebugLogger } from '@aztec/foundation/log'; import { createAztecNodeRpcClient } from '@aztec/types'; +import { getConfigEnvVars } from '../config/index.js'; import { startPXEHttpServer } from '../pxe_http/index.js'; import { createPXEService } from '../pxe_service/index.js'; -import { getConfigEnvVars } from '../config/index.js'; const { SERVER_PORT = 8080, AZTEC_NODE_RPC_URL = '' } = process.env; -const logger = createDebugLogger('aztec:rpc_server'); +const logger = createDebugLogger('aztec:pxe_service'); /** * Create and start a new PXE HTTP Server diff --git a/yarn-project/pxe/src/synchronizer/synchronizer.ts b/yarn-project/pxe/src/synchronizer/synchronizer.ts index e8e69c7b004..8a6796de435 100644 --- a/yarn-project/pxe/src/synchronizer/synchronizer.ts +++ b/yarn-project/pxe/src/synchronizer/synchronizer.ts @@ -25,9 +25,7 @@ export class Synchronizer { private noteProcessorsToCatchUp: NoteProcessor[] = []; constructor(private node: AztecNode, private db: Database, logSuffix = '') { - this.log = createDebugLogger( - logSuffix ? `aztec:aztec_rpc_synchronizer_${logSuffix}` : 'aztec:aztec_rpc_synchronizer', - ); + this.log = createDebugLogger(logSuffix ? `aztec:pxe_synchronizer_${logSuffix}` : 'aztec:pxe_synchronizer'); } /** From 6ec7855aa11982b597d3fdd262d7599674830f74 Mon Sep 17 00:00:00 2001 From: benesjan Date: Wed, 27 Sep 2023 11:51:20 +0000 Subject: [PATCH 08/23] triggering full rebuild --- .../kernel/private/native_private_kernel_circuit_init.test.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/circuits/cpp/src/aztec3/circuits/kernel/private/native_private_kernel_circuit_init.test.cpp b/circuits/cpp/src/aztec3/circuits/kernel/private/native_private_kernel_circuit_init.test.cpp index d1fecdf6745..aa100692071 100644 --- a/circuits/cpp/src/aztec3/circuits/kernel/private/native_private_kernel_circuit_init.test.cpp +++ b/circuits/cpp/src/aztec3/circuits/kernel/private/native_private_kernel_circuit_init.test.cpp @@ -122,7 +122,7 @@ TEST_F(native_private_kernel_init_tests, DISABLED_contract_deployment_call_stack { auto private_inputs = do_private_call_get_kernel_inputs_init(true, constructor, standard_test_args()); - // Randomise the second item in the private call stack (i.e. hash of the private call item). + // Randomize the second item in the private call stack (i.e. hash of the private call item). private_inputs.private_call.call_stack_item.public_inputs.private_call_stack[1] = NT::fr::random_element(); DummyBuilder builder = From 15e931e040f868aa630732768dc4a7dd7c439452 Mon Sep 17 00:00:00 2001 From: benesjan Date: Wed, 27 Sep 2023 12:00:01 +0000 Subject: [PATCH 09/23] docs fixes --- docs/docusaurus.config.js | 2 +- docs/sidebars.js | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/docs/docusaurus.config.js b/docs/docusaurus.config.js index 0c90df95875..f44a59109ab 100644 --- a/docs/docusaurus.config.js +++ b/docs/docusaurus.config.js @@ -126,7 +126,7 @@ const config = { "@spalladino/docusaurus-plugin-typedoc", { id: "apis/pxe", - entryPoints: ["../yarn-project/types/src/interfaces/aztec_rpc.ts"], + entryPoints: ["../yarn-project/types/src/interfaces/pxe.ts"], tsconfig: "../yarn-project/types/tsconfig.json", entryPointStrategy: "expand", out: "apis/pxe", diff --git a/docs/sidebars.js b/docs/sidebars.js index 9f852752483..ab75b2abe2a 100644 --- a/docs/sidebars.js +++ b/docs/sidebars.js @@ -218,7 +218,7 @@ const sidebars = { }, items: [ "dev_docs/tutorials/writing_dapp/project_setup", - "dev_docs/tutorials/writing_dapp/rpc_server", + "dev_docs/tutorials/writing_dapp/pxe_service", "dev_docs/tutorials/writing_dapp/contract_deployment", "dev_docs/tutorials/writing_dapp/contract_interaction", "dev_docs/tutorials/writing_dapp/testing", From 3576b5c7aa30f614cb8e43f05abf1854b917c903 Mon Sep 17 00:00:00 2001 From: benesjan Date: Wed, 27 Sep 2023 13:00:49 +0000 Subject: [PATCH 10/23] WIP --- docs/docs/dev_docs/contracts/compiling.md | 2 +- yarn-project/aztec-sandbox/src/bin/index.ts | 12 ++--- yarn-project/aztec-sandbox/src/sandbox.ts | 10 ++-- .../boxes/blank-react/src/artifacts/blank.ts | 8 +-- .../src/scripts/call_contract_function.ts | 4 +- .../boxes/blank-react/src/scripts/util.ts | 6 +-- .../src/scripts/view_contract_function.ts | 4 +- .../src/tests/blank.contract.test.ts | 2 +- .../boxes/blank/src/artifacts/blank.ts | 8 +-- yarn-project/boxes/blank/src/index.ts | 10 ++-- .../src/artifacts/private_token.ts | 8 +-- .../src/scripts/call_contract_function.ts | 4 +- .../boxes/private-token/src/scripts/util.ts | 6 +-- .../src/scripts/view_contract_function.ts | 4 +- yarn-project/cli/src/client.test.ts | 20 ++++---- .../src/e2e_account_contracts.test.ts | 6 +-- .../src/e2e_escrow_contract.test.ts | 2 +- .../end-to-end/src/e2e_p2p_network.test.ts | 2 +- .../src/e2e_sandbox_example.test.ts | 2 +- .../end-to-end/src/e2e_token_contract.test.ts | 16 +++--- yarn-project/end-to-end/src/fixtures/utils.ts | 20 ++++---- .../src/guides/dapp_testing.test.ts | 50 +++++++++---------- .../end-to-end/src/sample-dapp/index.test.mjs | 8 +-- .../src/contract-interface-gen/typescript.ts | 8 +-- yarn-project/pxe/src/bin/index.ts | 4 +- yarn-project/pxe/src/config/index.ts | 6 +-- .../src/pxe_service/test/pxe_test_suite.ts | 48 +++++++++--------- yarn-project/types/src/interfaces/pxe.ts | 24 ++++----- 28 files changed, 152 insertions(+), 152 deletions(-) diff --git a/docs/docs/dev_docs/contracts/compiling.md b/docs/docs/dev_docs/contracts/compiling.md index 090cae9b788..a9c1a346954 100644 --- a/docs/docs/dev_docs/contracts/compiling.md +++ b/docs/docs/dev_docs/contracts/compiling.md @@ -54,7 +54,7 @@ export class PrivateTokenContract extends ContractBase { public static async at(address: AztecAddress, wallet: Wallet) { ... } /** Creates a tx to deploy a new instance of this contract. */ - public static deploy(rpc: PXE, initial_supply: FieldLike, owner: FieldLike) { ... } + public static deploy(pxe: PXE, initial_supply: FieldLike, owner: FieldLike) { ... } /** Type-safe wrappers for the public methods exposed by the contract. */ public methods!: { diff --git a/yarn-project/aztec-sandbox/src/bin/index.ts b/yarn-project/aztec-sandbox/src/bin/index.ts index b2dbab35dd4..44387c6b36a 100644 --- a/yarn-project/aztec-sandbox/src/bin/index.ts +++ b/yarn-project/aztec-sandbox/src/bin/index.ts @@ -20,12 +20,12 @@ const logger = createDebugLogger('aztec:sandbox'); * Creates the sandbox from provided config and deploys any initial L1 and L2 contracts */ async function createAndInitialiseSandbox() { - const { l1Contracts, rpcServer, stop } = await createSandbox(); + const { l1Contracts, pxe, stop } = await createSandbox(); logger.info('Setting up test accounts...'); - const accounts = await deployInitialSandboxAccounts(rpcServer); + const accounts = await deployInitialSandboxAccounts(pxe); return { l1Contracts, - rpcServer, + pxe, stop, accounts, }; @@ -41,7 +41,7 @@ async function main() { logger.info(`Setting up Aztec Sandbox v${version} (nargo ${NoirVersion.tag}), please stand by...`); - const { rpcServer, stop, accounts } = await createAndInitialiseSandbox(); + const { pxe, stop, accounts } = await createAndInitialiseSandbox(); const shutdown = async () => { logger.info('Shutting down...'); @@ -52,12 +52,12 @@ async function main() { process.once('SIGINT', shutdown); process.once('SIGTERM', shutdown); - startPXEHttpServer(rpcServer, SERVER_PORT); + startPXEHttpServer(pxe, SERVER_PORT); logger.info(`Aztec Sandbox JSON-RPC Server listening on port ${SERVER_PORT}`); logger.info(`Debug logs will be written to ${logPath}`); const accountStrings = [`Initial Accounts:\n\n`]; - const registeredAccounts = await rpcServer.getRegisteredAccounts(); + const registeredAccounts = await pxe.getRegisteredAccounts(); for (const account of accounts) { const completeAddress = await account.account.getCompleteAddress(); if (registeredAccounts.find(a => a.equals(completeAddress))) { diff --git a/yarn-project/aztec-sandbox/src/sandbox.ts b/yarn-project/aztec-sandbox/src/sandbox.ts index e798ba1a62e..00d36e66977 100644 --- a/yarn-project/aztec-sandbox/src/sandbox.ts +++ b/yarn-project/aztec-sandbox/src/sandbox.ts @@ -20,7 +20,7 @@ import { RollupAbi, RollupBytecode, } from '@aztec/l1-artifacts'; -import { createPXEService, getConfigEnvVars as getRpcConfigEnvVars } from '@aztec/pxe'; +import { createPXEService, getPXEServiceConfig as getRpcConfigEnvVars } from '@aztec/pxe'; import { createPublicClient, http as httpViemTransport } from 'viem'; import { mnemonicToAccount } from 'viem/accounts'; @@ -78,7 +78,7 @@ export type SandboxConfig = AztecNodeConfig & { */ export async function createSandbox(config: Partial = {}) { const aztecNodeConfig: AztecNodeConfig = { ...getConfigEnvVars(), ...config }; - const rpcConfig = getRpcConfigEnvVars(); + const pxeServiceConfig = getRpcConfigEnvVars(); const hdAccount = mnemonicToAccount(config.l1Mnemonic ?? MNEMONIC); const privKey = hdAccount.getHdKey().privateKey; @@ -116,12 +116,12 @@ export async function createSandbox(config: Partial = {}) { aztecNodeConfig.l1Contracts.registryAddress = l1Contracts.l1ContractAddresses.registryAddress; const node = await AztecNodeService.createAndSync(aztecNodeConfig); - const rpcServer = await createPXEService(node, rpcConfig); + const pxe = await createPXEService(node, pxeServiceConfig); const stop = async () => { - await rpcServer.stop(); + await pxe.stop(); await node.stop(); }; - return { node, rpcServer, l1Contracts, stop }; + return { node, pxe, l1Contracts, stop }; } diff --git a/yarn-project/boxes/blank-react/src/artifacts/blank.ts b/yarn-project/boxes/blank-react/src/artifacts/blank.ts index fdf14283c3e..2003f379bfe 100644 --- a/yarn-project/boxes/blank-react/src/artifacts/blank.ts +++ b/yarn-project/boxes/blank-react/src/artifacts/blank.ts @@ -54,15 +54,15 @@ export class BlankContract extends ContractBase { /** * Creates a tx to deploy a new instance of this contract. */ - public static deploy(rpc: PXE) { - return new DeployMethod(Point.ZERO, rpc, BlankContractAbi, Array.from(arguments).slice(1)); + public static deploy(pxe: PXE) { + return new DeployMethod(Point.ZERO, pxe, BlankContractAbi, Array.from(arguments).slice(1)); } /** * Creates a tx to deploy a new instance of this contract using the specified public key to derive the address. */ - public static deployWithPublicKey(rpc: PXE, publicKey: PublicKey) { - return new DeployMethod(publicKey, rpc, BlankContractAbi, Array.from(arguments).slice(2)); + public static deployWithPublicKey(pxe: PXE, publicKey: PublicKey) { + return new DeployMethod(publicKey, pxe, BlankContractAbi, Array.from(arguments).slice(2)); } /** diff --git a/yarn-project/boxes/blank-react/src/scripts/call_contract_function.ts b/yarn-project/boxes/blank-react/src/scripts/call_contract_function.ts index 1c324bf5a40..eee3953023a 100644 --- a/yarn-project/boxes/blank-react/src/scripts/call_contract_function.ts +++ b/yarn-project/boxes/blank-react/src/scripts/call_contract_function.ts @@ -8,11 +8,11 @@ export async function callContractFunction( abi: ContractAbi, functionName: string, typedArgs: any[], // for the exposed functions, this is an array of field elements Fr[] - rpc: PXE, + pxe: PXE, wallet: CompleteAddress, ): Promise> { // selectedWallet is how we specify the "sender" of the transaction - const selectedWallet = await getWallet(wallet, rpc); + const selectedWallet = await getWallet(wallet, pxe); // TODO: switch to the generated typescript class? const contract = await Contract.at(address, abi, selectedWallet); diff --git a/yarn-project/boxes/blank-react/src/scripts/util.ts b/yarn-project/boxes/blank-react/src/scripts/util.ts index 8c61a1d3b57..9e895edca15 100644 --- a/yarn-project/boxes/blank-react/src/scripts/util.ts +++ b/yarn-project/boxes/blank-react/src/scripts/util.ts @@ -23,11 +23,11 @@ export function convertArgs(functionAbi: FunctionAbi, args: any): Fr[] { * while the "wallet" has the account's private key and is used to sign transactions * we need the "wallet" to actually submit transactions using the "account" identity * @param account - * @param rpc + * @param pxe * @returns */ -export async function getWallet(account: CompleteAddress, rpc: PXE): Promise { - const accountWallets: AccountWallet[] = await getSandboxAccountsWallets(rpc); +export async function getWallet(account: CompleteAddress, pxe: PXE): Promise { + const accountWallets: AccountWallet[] = await getSandboxAccountsWallets(pxe); const selectedWallet: AccountWallet = accountWallets.find(w => w.getAddress().equals(account.address))!; if (!selectedWallet) { throw new Error(`Wallet for account ${account.address.toShortString()} not found in the RPC server.`); diff --git a/yarn-project/boxes/blank-react/src/scripts/view_contract_function.ts b/yarn-project/boxes/blank-react/src/scripts/view_contract_function.ts index aa02bc916f6..79bd9b16f92 100644 --- a/yarn-project/boxes/blank-react/src/scripts/view_contract_function.ts +++ b/yarn-project/boxes/blank-react/src/scripts/view_contract_function.ts @@ -7,11 +7,11 @@ export async function viewContractFunction( abi: ContractAbi, functionName: string, typedArgs: any[], - rpc: PXE, + pxe: PXE, wallet: CompleteAddress, ) { // we specify the account that is calling the view function by passing in the wallet to the Contract - const selectedWallet = await getWallet(wallet, rpc); + const selectedWallet = await getWallet(wallet, pxe); const contract = await Contract.at(address, abi, selectedWallet); return await contract.methods[functionName](...typedArgs).view({ from: wallet.address }); diff --git a/yarn-project/boxes/blank-react/src/tests/blank.contract.test.ts b/yarn-project/boxes/blank-react/src/tests/blank.contract.test.ts index 736e4a5b409..1aa055bfbb6 100644 --- a/yarn-project/boxes/blank-react/src/tests/blank.contract.test.ts +++ b/yarn-project/boxes/blank-react/src/tests/blank.contract.test.ts @@ -14,7 +14,7 @@ import { } from '@aztec/aztec.js'; import { createDebugLogger } from '@aztec/foundation/log'; -const logger = createDebugLogger('aztec:http-rpc-client'); +const logger = createDebugLogger('aztec:http-pxe-client'); // assumes sandbox is running locally, which this script does not trigger // as well as anvil. anvil can be started with yarn test:integration diff --git a/yarn-project/boxes/blank/src/artifacts/blank.ts b/yarn-project/boxes/blank/src/artifacts/blank.ts index fdf14283c3e..2003f379bfe 100644 --- a/yarn-project/boxes/blank/src/artifacts/blank.ts +++ b/yarn-project/boxes/blank/src/artifacts/blank.ts @@ -54,15 +54,15 @@ export class BlankContract extends ContractBase { /** * Creates a tx to deploy a new instance of this contract. */ - public static deploy(rpc: PXE) { - return new DeployMethod(Point.ZERO, rpc, BlankContractAbi, Array.from(arguments).slice(1)); + public static deploy(pxe: PXE) { + return new DeployMethod(Point.ZERO, pxe, BlankContractAbi, Array.from(arguments).slice(1)); } /** * Creates a tx to deploy a new instance of this contract using the specified public key to derive the address. */ - public static deployWithPublicKey(rpc: PXE, publicKey: PublicKey) { - return new DeployMethod(publicKey, rpc, BlankContractAbi, Array.from(arguments).slice(2)); + public static deployWithPublicKey(pxe: PXE, publicKey: PublicKey) { + return new DeployMethod(publicKey, pxe, BlankContractAbi, Array.from(arguments).slice(2)); } /** diff --git a/yarn-project/boxes/blank/src/index.ts b/yarn-project/boxes/blank/src/index.ts index e90dc9cb330..e5e73415a60 100644 --- a/yarn-project/boxes/blank/src/index.ts +++ b/yarn-project/boxes/blank/src/index.ts @@ -81,11 +81,11 @@ export async function callContractFunction( abi: ContractAbi, functionName: string, typedArgs: any[], // for the exposed functions, this is an array of field elements Fr[] - rpc: PXE, + pxe: PXE, wallet: CompleteAddress, ): Promise> { // selectedWallet is how we specify the "sender" of the transaction - const selectedWallet = await getWallet(wallet, rpc); + const selectedWallet = await getWallet(wallet, pxe); // TODO: switch to the generated typescript class? const contract = await Contract.at(address, abi, selectedWallet); @@ -100,11 +100,11 @@ export async function callContractFunction( * while the "wallet" has the account's private key and is used to sign transactions * we need the "wallet" to actually submit transactions using the "account" identity * @param account - * @param rpc + * @param pxe * @returns */ -export async function getWallet(account: CompleteAddress, rpc: PXE): Promise { - const accountWallets: AccountWallet[] = await getSandboxAccountsWallets(rpc); +export async function getWallet(account: CompleteAddress, pxe: PXE): Promise { + const accountWallets: AccountWallet[] = await getSandboxAccountsWallets(pxe); const selectedWallet: AccountWallet = accountWallets.find(w => w.getAddress().equals(account.address))!; if (!selectedWallet) { throw new Error(`Wallet for account ${account.address.toShortString()} not found in the RPC server.`); diff --git a/yarn-project/boxes/private-token/src/artifacts/private_token.ts b/yarn-project/boxes/private-token/src/artifacts/private_token.ts index ce103625cc1..7796d8f86b4 100644 --- a/yarn-project/boxes/private-token/src/artifacts/private_token.ts +++ b/yarn-project/boxes/private-token/src/artifacts/private_token.ts @@ -54,10 +54,10 @@ export class PrivateTokenContract extends ContractBase { /** * Creates a tx to deploy a new instance of this contract. */ - public static deploy(rpc: PXE, initial_supply: FieldLike, owner: FieldLike) { + public static deploy(pxe: PXE, initial_supply: FieldLike, owner: FieldLike) { return new DeployMethod( Point.ZERO, - rpc, + pxe, PrivateTokenContractAbi, Array.from(arguments).slice(1), ); @@ -66,10 +66,10 @@ export class PrivateTokenContract extends ContractBase { /** * Creates a tx to deploy a new instance of this contract using the specified public key to derive the address. */ - public static deployWithPublicKey(rpc: PXE, publicKey: PublicKey, initial_supply: FieldLike, owner: FieldLike) { + public static deployWithPublicKey(pxe: PXE, publicKey: PublicKey, initial_supply: FieldLike, owner: FieldLike) { return new DeployMethod( publicKey, - rpc, + pxe, PrivateTokenContractAbi, Array.from(arguments).slice(2), ); diff --git a/yarn-project/boxes/private-token/src/scripts/call_contract_function.ts b/yarn-project/boxes/private-token/src/scripts/call_contract_function.ts index 6565be4ce68..86fc722777a 100644 --- a/yarn-project/boxes/private-token/src/scripts/call_contract_function.ts +++ b/yarn-project/boxes/private-token/src/scripts/call_contract_function.ts @@ -7,11 +7,11 @@ export async function callContractFunction( abi: ContractAbi, functionName: string, typedArgs: any[], // for the exposed functions, this is an array of field elements Fr[] - rpc: PXE, + pxe: PXE, wallet: CompleteAddress, ) { // selectedWallet is how we specify the "sender" of the transaction - const selectedWallet = await getWallet(wallet, rpc); + const selectedWallet = await getWallet(wallet, pxe); // TODO: switch to the generated typescript class? const contract = await Contract.at(address, abi, selectedWallet); diff --git a/yarn-project/boxes/private-token/src/scripts/util.ts b/yarn-project/boxes/private-token/src/scripts/util.ts index 8c61a1d3b57..9e895edca15 100644 --- a/yarn-project/boxes/private-token/src/scripts/util.ts +++ b/yarn-project/boxes/private-token/src/scripts/util.ts @@ -23,11 +23,11 @@ export function convertArgs(functionAbi: FunctionAbi, args: any): Fr[] { * while the "wallet" has the account's private key and is used to sign transactions * we need the "wallet" to actually submit transactions using the "account" identity * @param account - * @param rpc + * @param pxe * @returns */ -export async function getWallet(account: CompleteAddress, rpc: PXE): Promise { - const accountWallets: AccountWallet[] = await getSandboxAccountsWallets(rpc); +export async function getWallet(account: CompleteAddress, pxe: PXE): Promise { + const accountWallets: AccountWallet[] = await getSandboxAccountsWallets(pxe); const selectedWallet: AccountWallet = accountWallets.find(w => w.getAddress().equals(account.address))!; if (!selectedWallet) { throw new Error(`Wallet for account ${account.address.toShortString()} not found in the RPC server.`); diff --git a/yarn-project/boxes/private-token/src/scripts/view_contract_function.ts b/yarn-project/boxes/private-token/src/scripts/view_contract_function.ts index aa02bc916f6..79bd9b16f92 100644 --- a/yarn-project/boxes/private-token/src/scripts/view_contract_function.ts +++ b/yarn-project/boxes/private-token/src/scripts/view_contract_function.ts @@ -7,11 +7,11 @@ export async function viewContractFunction( abi: ContractAbi, functionName: string, typedArgs: any[], - rpc: PXE, + pxe: PXE, wallet: CompleteAddress, ) { // we specify the account that is calling the view function by passing in the wallet to the Contract - const selectedWallet = await getWallet(wallet, rpc); + const selectedWallet = await getWallet(wallet, pxe); const contract = await Contract.at(address, abi, selectedWallet); return await contract.methods[functionName](...typedArgs).view({ from: wallet.address }); diff --git a/yarn-project/cli/src/client.test.ts b/yarn-project/cli/src/client.test.ts index d90f1487394..acb23c96e0a 100644 --- a/yarn-project/cli/src/client.test.ts +++ b/yarn-project/cli/src/client.test.ts @@ -6,27 +6,27 @@ import { checkServerVersion } from './client.js'; describe('client', () => { describe('checkServerVersion', () => { - let rpc: MockProxy; + let pxe: MockProxy; beforeEach(() => { - rpc = mock(); + pxe = mock(); }); it('checks versions match', async () => { - rpc.getNodeInfo.mockResolvedValue({ sandboxVersion: '0.1.0-alpha47' } as NodeInfo); - await checkServerVersion(rpc, '0.1.0-alpha47'); + pxe.getNodeInfo.mockResolvedValue({ sandboxVersion: '0.1.0-alpha47' } as NodeInfo); + await checkServerVersion(pxe, '0.1.0-alpha47'); }); - it('reports mismatch on older rpc version', async () => { - rpc.getNodeInfo.mockResolvedValue({ sandboxVersion: '0.1.0-alpha47' } as NodeInfo); - await expect(checkServerVersion(rpc, '0.1.0-alpha48')).rejects.toThrowError( + it('reports mismatch on older pxe version', async () => { + pxe.getNodeInfo.mockResolvedValue({ sandboxVersion: '0.1.0-alpha47' } as NodeInfo); + await expect(checkServerVersion(pxe, '0.1.0-alpha48')).rejects.toThrowError( /is older than the expected by this CLI/, ); }); - it('reports mismatch on newer rpc version', async () => { - rpc.getNodeInfo.mockResolvedValue({ sandboxVersion: '0.1.0-alpha48' } as NodeInfo); - await expect(checkServerVersion(rpc, '0.1.0-alpha47')).rejects.toThrowError( + it('reports mismatch on newer pxe version', async () => { + pxe.getNodeInfo.mockResolvedValue({ sandboxVersion: '0.1.0-alpha48' } as NodeInfo); + await expect(checkServerVersion(pxe, '0.1.0-alpha47')).rejects.toThrowError( /is newer than the expected by this CLI/, ); }); diff --git a/yarn-project/end-to-end/src/e2e_account_contracts.test.ts b/yarn-project/end-to-end/src/e2e_account_contracts.test.ts index c308043de8f..aaca09892b7 100644 --- a/yarn-project/end-to-end/src/e2e_account_contracts.test.ts +++ b/yarn-project/end-to-end/src/e2e_account_contracts.test.ts @@ -19,7 +19,7 @@ import { setup } from './fixtures/utils.js'; function itShouldBehaveLikeAnAccountContract( getAccountContract: (encryptionKey: GrumpkinPrivateKey) => AccountContract, walletSetup: ( - rpc: PXE, + pxe: PXE, encryptionPrivateKey: GrumpkinPrivateKey, accountContract: AccountContract, address?: CompleteAddress, @@ -77,12 +77,12 @@ function itShouldBehaveLikeAnAccountContract( describe('e2e_account_contracts', () => { const base = async ( - rpc: PXE, + pxe: PXE, encryptionPrivateKey: GrumpkinPrivateKey, accountContract: AccountContract, address?: CompleteAddress, ) => { - const account = new AccountManager(rpc, encryptionPrivateKey, accountContract, address); + const account = new AccountManager(pxe, encryptionPrivateKey, accountContract, address); const wallet = !address ? await account.deploy().then(tx => tx.getWallet()) : await account.getWallet(); return { account, wallet }; }; diff --git a/yarn-project/end-to-end/src/e2e_escrow_contract.test.ts b/yarn-project/end-to-end/src/e2e_escrow_contract.test.ts index d54e8400790..075df4b3ef1 100644 --- a/yarn-project/end-to-end/src/e2e_escrow_contract.test.ts +++ b/yarn-project/end-to-end/src/e2e_escrow_contract.test.ts @@ -35,7 +35,7 @@ describe('e2e_escrow_contract', () => { owner = accounts[0].address; recipient = accounts[1].address; - // Generate private key for escrow contract, register key in rpc server, and deploy + // Generate private key for escrow contract, register key in pxe service, and deploy // Note that we need to register it first if we want to emit an encrypted note for it in the constructor escrowPrivateKey = GrumpkinScalar.random(); escrowPublicKey = await generatePublicKey(escrowPrivateKey); diff --git a/yarn-project/end-to-end/src/e2e_p2p_network.test.ts b/yarn-project/end-to-end/src/e2e_p2p_network.test.ts index 0bd2e51ccdf..1ad20b9f413 100644 --- a/yarn-project/end-to-end/src/e2e_p2p_network.test.ts +++ b/yarn-project/end-to-end/src/e2e_p2p_network.test.ts @@ -5,7 +5,7 @@ import { Grumpkin } from '@aztec/circuits.js/barretenberg'; import { DebugLogger } from '@aztec/foundation/log'; import { TestContractAbi } from '@aztec/noir-contracts/artifacts'; import { BootstrapNode, P2PConfig, createLibP2PPeerId } from '@aztec/p2p'; -import { ConstantKeyPair, PXEService, createPXEService, getConfigEnvVars as getRpcConfig } from '@aztec/pxe'; +import { ConstantKeyPair, PXEService, createPXEService, getPXEServiceConfig as getRpcConfig } from '@aztec/pxe'; import { TxStatus } from '@aztec/types'; import { setup } from './fixtures/utils.js'; diff --git a/yarn-project/end-to-end/src/e2e_sandbox_example.test.ts b/yarn-project/end-to-end/src/e2e_sandbox_example.test.ts index 62584b0be1e..d08674bb55c 100644 --- a/yarn-project/end-to-end/src/e2e_sandbox_example.test.ts +++ b/yarn-project/end-to-end/src/e2e_sandbox_example.test.ts @@ -73,7 +73,7 @@ describe('e2e_sandbox_example', () => { await tokenContractAlice.methods.redeem_shield(alice, initialSupply, secret).send().wait(); // docs:end:Deployment - // ensure that token contract is registered in the rpc + // ensure that token contract is registered in PXE expect(await pxe.getContracts()).toEqual(expect.arrayContaining([contract.address])); // docs:start:Balance diff --git a/yarn-project/end-to-end/src/e2e_token_contract.test.ts b/yarn-project/end-to-end/src/e2e_token_contract.test.ts index 53536987de8..feb683d59a5 100644 --- a/yarn-project/end-to-end/src/e2e_token_contract.test.ts +++ b/yarn-project/end-to-end/src/e2e_token_contract.test.ts @@ -437,7 +437,7 @@ describe('e2e_token_contract', () => { // We need to compute the message we want to sign and add it to the wallet as approved const messageHash = await transferMessageHash(accounts[1], accounts[0], accounts[1], amount, nonce); - // Both wallets are connected to same node and rpc so we could just insert directly using + // Both wallets are connected to same node and pxe so we could just insert directly using // await wallet.signAndAddAuthWitness(messageHash, ); // But doing it in two actions to show the flow. const witness = await wallets[0].createAuthWitness(messageHash); @@ -491,7 +491,7 @@ describe('e2e_token_contract', () => { // We need to compute the message we want to sign and add it to the wallet as approved const messageHash = await transferMessageHash(accounts[1], accounts[0], accounts[1], amount, nonce); - // Both wallets are connected to same node and rpc so we could just insert directly using + // Both wallets are connected to same node and pxe so we could just insert directly using // await wallet.signAndAddAuthWitness(messageHash, ); // But doing it in two actions to show the flow. const witness = await wallets[0].createAuthWitness(messageHash); @@ -772,7 +772,7 @@ describe('e2e_token_contract', () => { // We need to compute the message we want to sign and add it to the wallet as approved const messageHash = await unshieldMessageHash(accounts[1], accounts[0], accounts[1], amount, nonce); - // Both wallets are connected to same node and rpc so we could just insert directly using + // Both wallets are connected to same node and pxe so we could just insert directly using // await wallet.signAndAddAuthWitness(messageHash, ); // But doing it in two actions to show the flow. const witness = await wallets[0].createAuthWitness(messageHash); @@ -826,7 +826,7 @@ describe('e2e_token_contract', () => { // We need to compute the message we want to sign and add it to the wallet as approved const messageHash = await unshieldMessageHash(accounts[1], accounts[0], accounts[1], amount, nonce); - // Both wallets are connected to same node and rpc so we could just insert directly using + // Both wallets are connected to same node and pxe so we could just insert directly using // await wallet.signAndAddAuthWitness(messageHash, ); // But doing it in two actions to show the flow. const witness = await wallets[0].createAuthWitness(messageHash); @@ -850,7 +850,7 @@ describe('e2e_token_contract', () => { const messageHash = await unshieldMessageHash(accounts[1], accounts[0], accounts[1], amount, nonce); const expectedMessageHash = await unshieldMessageHash(accounts[2], accounts[0], accounts[1], amount, nonce); - // Both wallets are connected to same node and rpc so we could just insert directly using + // Both wallets are connected to same node and pxe so we could just insert directly using // await wallet.signAndAddAuthWitness(messageHash, ); // But doing it in two actions to show the flow. const witness = await wallets[0].createAuthWitness(messageHash); @@ -1005,7 +1005,7 @@ describe('e2e_token_contract', () => { // We need to compute the message we want to sign and add it to the wallet as approved const messageHash = await burnMessageHash(accounts[1], accounts[0], amount, nonce); - // Both wallets are connected to same node and rpc so we could just insert directly using + // Both wallets are connected to same node and pxe so we could just insert directly using // await wallet.signAndAddAuthWitness(messageHash, ); // But doing it in two actions to show the flow. const witness = await wallets[0].createAuthWitness(messageHash); @@ -1051,7 +1051,7 @@ describe('e2e_token_contract', () => { // We need to compute the message we want to sign and add it to the wallet as approved const messageHash = await burnMessageHash(accounts[1], accounts[0], amount, nonce); - // Both wallets are connected to same node and rpc so we could just insert directly using + // Both wallets are connected to same node and pxe so we could just insert directly using // await wallet.signAndAddAuthWitness(messageHash, ); // But doing it in two actions to show the flow. const witness = await wallets[0].createAuthWitness(messageHash); @@ -1105,7 +1105,7 @@ describe('e2e_token_contract', () => { const messageHash = await burnMessageHash(accounts[1], accounts[0], amount, nonce); const expectedMessageHash = await burnMessageHash(accounts[2], accounts[0], amount, nonce); - // Both wallets are connected to same node and rpc so we could just insert directly using + // Both wallets are connected to same node and pxe so we could just insert directly using // await wallet.signAndAddAuthWitness(messageHash, { origin: accounts[0].address }); // But doing it in two actions to show the flow. const witness = await wallets[0].createAuthWitness(messageHash); diff --git a/yarn-project/end-to-end/src/fixtures/utils.ts b/yarn-project/end-to-end/src/fixtures/utils.ts index b5ae35f1688..458bc3e77ac 100644 --- a/yarn-project/end-to-end/src/fixtures/utils.ts +++ b/yarn-project/end-to-end/src/fixtures/utils.ts @@ -41,7 +41,7 @@ import { TokenPortalBytecode, } from '@aztec/l1-artifacts'; import { NonNativeTokenContract, TokenBridgeContract, TokenContract } from '@aztec/noir-contracts/types'; -import { PXEService, createPXEService, getConfigEnvVars as getRpcConfigEnvVars } from '@aztec/pxe'; +import { PXEService, createPXEService, getPXEServiceConfig as getRpcConfigEnvVars } from '@aztec/pxe'; import { L2BlockL2Logs, LogType, PXE, TxStatus } from '@aztec/types'; import { @@ -158,13 +158,13 @@ export async function setupPXEService( logger: DebugLogger; }> { const rpcConfig = getRpcConfigEnvVars(); - const rpc = await createPXEService(aztecNode, rpcConfig, {}, useLogSuffix); + const pxe = await createPXEService(aztecNode, rpcConfig, {}, useLogSuffix); - const wallets = await createAccounts(rpc, numberOfAccounts); + const wallets = await createAccounts(pxe, numberOfAccounts); return { - pxe: rpc!, - accounts: await rpc!.getRegisteredAccounts(), + pxe, + accounts: await pxe.getRegisteredAccounts(), wallets, logger, }; @@ -532,7 +532,7 @@ export const expectsNumOfEncryptedLogsInTheLastBlockToBe = async ( numEncryptedLogs: number, ) => { if (!aztecNode) { - // An api for retrieving encrypted logs does not exist on the rpc server so we have to use the node + // An api for retrieving encrypted logs does not exist on the PXE Service so we have to use the node // This means we can't perform this check if there is no node return; } @@ -544,15 +544,15 @@ export const expectsNumOfEncryptedLogsInTheLastBlockToBe = async ( /** * Checks that the last block contains the given expected unencrypted log messages. - * @param rpc - The instance of PXE for retrieving the logs. + * @param pxe - The instance of PXE for retrieving the logs. * @param logMessages - The set of expected log messages. */ -export const expectUnencryptedLogsFromLastBlockToBe = async (rpc: PXE, logMessages: string[]) => { +export const expectUnencryptedLogsFromLastBlockToBe = async (pxe: PXE, logMessages: string[]) => { // docs:start:get_logs // Get the latest block number to retrieve logs from - const l2BlockNum = await rpc.getBlockNumber(); + const l2BlockNum = await pxe.getBlockNumber(); // Get the unencrypted logs from the last block - const unencryptedLogs = await rpc.getUnencryptedLogs(l2BlockNum, 1); + const unencryptedLogs = await pxe.getUnencryptedLogs(l2BlockNum, 1); // docs:end:get_logs const unrolledLogs = L2BlockL2Logs.unrollLogs(unencryptedLogs); const asciiLogs = unrolledLogs.map(log => log.toString('ascii')); diff --git a/yarn-project/end-to-end/src/guides/dapp_testing.test.ts b/yarn-project/end-to-end/src/guides/dapp_testing.test.ts index aeae2ca3a23..0c9aa989a23 100644 --- a/yarn-project/end-to-end/src/guides/dapp_testing.test.ts +++ b/yarn-project/end-to-end/src/guides/dapp_testing.test.ts @@ -19,7 +19,7 @@ const { SANDBOX_URL = 'http://localhost:8080', ETHEREUM_HOST = 'http://localhost describe('guides/dapp/testing', () => { describe('on in-proc sandbox', () => { describe('private token contract', () => { - let rpc: PXE; + let pxe: PXE; let stop: () => Promise; let owner: AccountWallet; let recipient: AccountWallet; @@ -27,10 +27,10 @@ describe('guides/dapp/testing', () => { beforeAll(async () => { // docs:start:in-proc-sandbox - ({ rpcServer: rpc, stop } = await createSandbox()); + ({ pxe, stop } = await createSandbox()); // docs:end:in-proc-sandbox - owner = await createAccount(rpc); - recipient = await createAccount(rpc); + owner = await createAccount(pxe); + recipient = await createAccount(pxe); token = await TokenContract.deploy(owner).send().deployed(); await token.methods._initialize(owner.getAddress()).send().wait(); }, 60_000); @@ -52,21 +52,21 @@ describe('guides/dapp/testing', () => { describe('on local sandbox', () => { beforeAll(async () => { - const rpc = createPXEClient(SANDBOX_URL); - await waitForSandbox(rpc); + const pxe = createPXEClient(SANDBOX_URL); + await waitForSandbox(pxe); }); // docs:start:sandbox-example describe('private token contract', () => { - let rpc: PXE; + let pxe: PXE; let owner: AccountWallet; let recipient: AccountWallet; let token: TokenContract; beforeEach(async () => { - rpc = createPXEClient(SANDBOX_URL); - owner = await createAccount(rpc); - recipient = await createAccount(rpc); + pxe = createPXEClient(SANDBOX_URL); + owner = await createAccount(pxe); + recipient = await createAccount(pxe); token = await TokenContract.deploy(owner).send().deployed(); await token.methods._initialize(owner.getAddress()).send().wait(); }, 30_000); @@ -83,15 +83,15 @@ describe('guides/dapp/testing', () => { // docs:end:sandbox-example describe('private token contract with initial accounts', () => { - let rpc: PXE; + let pxe: PXE; let owner: AccountWallet; let recipient: AccountWallet; let token: TokenContract; beforeEach(async () => { // docs:start:use-existing-wallets - rpc = createPXEClient(SANDBOX_URL); - [owner, recipient] = await getSandboxAccountsWallets(rpc); + pxe = createPXEClient(SANDBOX_URL); + [owner, recipient] = await getSandboxAccountsWallets(pxe); token = await TokenContract.deploy(owner).send().deployed(); await token.methods._initialize(owner.getAddress()).send().wait(); // docs:end:use-existing-wallets @@ -108,16 +108,16 @@ describe('guides/dapp/testing', () => { }); describe('cheats', () => { - let rpc: PXE; + let pxe: PXE; let owner: AccountWallet; let testContract: TestContract; let cheats: CheatCodes; beforeAll(async () => { - rpc = createPXEClient(SANDBOX_URL); - owner = await createAccount(rpc); + pxe = createPXEClient(SANDBOX_URL); + owner = await createAccount(pxe); testContract = await TestContract.deploy(owner).send().deployed(); - cheats = await CheatCodes.create(ETHEREUM_HOST, rpc); + cheats = await CheatCodes.create(ETHEREUM_HOST, pxe); }, 30_000); it('warps time to 1h into the future', async () => { @@ -130,7 +130,7 @@ describe('guides/dapp/testing', () => { }); describe('assertions', () => { - let rpc: PXE; + let pxe: PXE; let owner: AccountWallet; let recipient: AccountWallet; let testContract: TestContract; @@ -139,9 +139,9 @@ describe('guides/dapp/testing', () => { let ownerSlot: Fr; beforeAll(async () => { - rpc = createPXEClient(SANDBOX_URL); - owner = await createAccount(rpc); - recipient = await createAccount(rpc); + pxe = createPXEClient(SANDBOX_URL); + owner = await createAccount(pxe); + recipient = await createAccount(pxe); testContract = await TestContract.deploy(owner).send().deployed(); token = await TokenContract.deploy(owner).send().deployed(); await token.methods._initialize(owner.getAddress()).send().wait(); @@ -151,7 +151,7 @@ describe('guides/dapp/testing', () => { await token.methods.redeem_shield(owner.getAddress(), 100n, secret).send().wait(); // docs:start:calc-slot - cheats = await CheatCodes.create(ETHEREUM_HOST, rpc); + cheats = await CheatCodes.create(ETHEREUM_HOST, pxe); // The balances mapping is defined on storage slot 3 and is indexed by user address ownerSlot = cheats.aztec.computeSlotInMap(3n, owner.getAddress()); // docs:end:calc-slot @@ -159,7 +159,7 @@ describe('guides/dapp/testing', () => { it('checks private storage', async () => { // docs:start:private-storage - const notes = await rpc.getPrivateStorageAt(owner.getAddress(), token.address, ownerSlot); + const notes = await pxe.getPrivateStorageAt(owner.getAddress(), token.address, ownerSlot); const values = notes.map(note => note.items[0]); const balance = values.reduce((sum, current) => sum + current.toBigInt(), 0n); expect(balance).toEqual(100n); @@ -170,7 +170,7 @@ describe('guides/dapp/testing', () => { // docs:start:public-storage await token.methods.mint_public(owner.getAddress(), 100n).send().wait(); const ownerPublicBalanceSlot = cheats.aztec.computeSlotInMap(6n, owner.getAddress()); - const balance = await rpc.getPublicStorageAt(token.address, ownerPublicBalanceSlot); + const balance = await pxe.getPublicStorageAt(token.address, ownerPublicBalanceSlot); expect(toBigIntBE(balance!)).toEqual(100n); // docs:end:public-storage }); @@ -179,7 +179,7 @@ describe('guides/dapp/testing', () => { // docs:start:unencrypted-logs const value = Fr.fromString('ef'); // Only 1 bytes will make its way in there :( so no larger stuff const tx = await testContract.methods.emit_unencrypted(value).send().wait(); - const logs = await rpc.getUnencryptedLogs(tx.blockNumber!, 1); + const logs = await pxe.getUnencryptedLogs(tx.blockNumber!, 1); const log = L2BlockL2Logs.unrollLogs(logs)[0]; expect(Fr.fromBuffer(log)).toEqual(value); // docs:end:unencrypted-logs diff --git a/yarn-project/end-to-end/src/sample-dapp/index.test.mjs b/yarn-project/end-to-end/src/sample-dapp/index.test.mjs index 1f695549787..0b52196b14d 100644 --- a/yarn-project/end-to-end/src/sample-dapp/index.test.mjs +++ b/yarn-project/end-to-end/src/sample-dapp/index.test.mjs @@ -4,11 +4,11 @@ import { TokenContractAbi } from '@aztec/noir-contracts/artifacts'; describe('token', () => { // docs:start:setup - let rpc, stop, owner, recipient, token; + let pxe, stop, owner, recipient, token; beforeAll(async () => { - ({ rpcServer: rpc, stop } = await createSandbox()); - owner = await createAccount(rpc); - recipient = await createAccount(rpc); + ({ pxe, stop } = await createSandbox()); + owner = await createAccount(pxe); + recipient = await createAccount(pxe); token = await Contract.deploy(owner, TokenContractAbi, []).send().deployed(); await token.methods._initialize(owner.getAddress()).send().wait(); diff --git a/yarn-project/noir-compiler/src/contract-interface-gen/typescript.ts b/yarn-project/noir-compiler/src/contract-interface-gen/typescript.ts index 272179adf61..31ddb4ad10b 100644 --- a/yarn-project/noir-compiler/src/contract-interface-gen/typescript.ts +++ b/yarn-project/noir-compiler/src/contract-interface-gen/typescript.ts @@ -69,15 +69,15 @@ function generateDeploy(input: ContractAbi) { /** * Creates a tx to deploy a new instance of this contract. */ - public static deploy(rpc: PXE, ${args}) { - return new DeployMethod<${input.name}Contract>(Point.ZERO, rpc, ${abiName}, Array.from(arguments).slice(1)); + public static deploy(pxe: PXE, ${args}) { + return new DeployMethod<${input.name}Contract>(Point.ZERO, pxe, ${abiName}, Array.from(arguments).slice(1)); } /** * Creates a tx to deploy a new instance of this contract using the specified public key to derive the address. */ - public static deployWithPublicKey(rpc: PXE, publicKey: PublicKey, ${args}) { - return new DeployMethod<${input.name}Contract>(publicKey, rpc, ${abiName}, Array.from(arguments).slice(2)); + public static deployWithPublicKey(pxe: PXE, publicKey: PublicKey, ${args}) { + return new DeployMethod<${input.name}Contract>(publicKey, pxe, ${abiName}, Array.from(arguments).slice(2)); } `; } diff --git a/yarn-project/pxe/src/bin/index.ts b/yarn-project/pxe/src/bin/index.ts index 9c7cd3f41b7..2cfb5794c51 100644 --- a/yarn-project/pxe/src/bin/index.ts +++ b/yarn-project/pxe/src/bin/index.ts @@ -2,7 +2,7 @@ import { createDebugLogger } from '@aztec/foundation/log'; import { createAztecNodeRpcClient } from '@aztec/types'; -import { getConfigEnvVars } from '../config/index.js'; +import { getPXEServiceConfig } from '../config/index.js'; import { startPXEHttpServer } from '../pxe_http/index.js'; import { createPXEService } from '../pxe_service/index.js'; @@ -16,7 +16,7 @@ const logger = createDebugLogger('aztec:pxe_service'); async function main() { logger.info(`Setting up PXE...`); - const pxeConfig = getConfigEnvVars(); + const pxeConfig = getPXEServiceConfig(); const nodeRpcClient = createAztecNodeRpcClient(AZTEC_NODE_RPC_URL); const pxeService = await createPXEService(nodeRpcClient, pxeConfig); diff --git a/yarn-project/pxe/src/config/index.ts b/yarn-project/pxe/src/config/index.ts index e6f85c85e26..81dab01b2ab 100644 --- a/yarn-project/pxe/src/config/index.ts +++ b/yarn-project/pxe/src/config/index.ts @@ -3,7 +3,7 @@ import { dirname, resolve } from 'path'; import { fileURLToPath } from 'url'; /** - * Configuration settings for the RPC Server. + * Configuration settings for the PXE Service. */ export interface PXEServiceConfig { /** @@ -13,9 +13,9 @@ export interface PXEServiceConfig { } /** - * Creates an instance of SequencerClientConfig out of environment variables using sensible defaults for integration testing if not set. + * Creates an instance of PXEServiceConfig out of environment variables using sensible defaults for integration testing if not set. */ -export function getConfigEnvVars(): PXEServiceConfig { +export function getPXEServiceConfig(): PXEServiceConfig { const { PXE_SERVICE_BLOCK_POLLING_INTERVAL_MS } = process.env; return { diff --git a/yarn-project/pxe/src/pxe_service/test/pxe_test_suite.ts b/yarn-project/pxe/src/pxe_service/test/pxe_test_suite.ts index 7020dfdcea0..cbb772b36fa 100644 --- a/yarn-project/pxe/src/pxe_service/test/pxe_test_suite.ts +++ b/yarn-project/pxe/src/pxe_service/test/pxe_test_suite.ts @@ -5,10 +5,10 @@ import { DeployedContract, INITIAL_L2_BLOCK_NUM, PXE, TxExecutionRequest, random export const pxeTestSuite = (testName: string, pxeSetup: () => Promise) => { describe(testName, () => { - let rpc: PXE; + let pxe: PXE; beforeAll(async () => { - rpc = await pxeSetup(); + pxe = await pxeSetup(); }, 120_000); it('registers an account and returns it as an account only and not as a recipient', async () => { @@ -18,17 +18,17 @@ export const pxeTestSuite = (testName: string, pxeSetup: () => Promise) => Fr.random(), ); - await rpc.registerAccount(await keyPair.getPrivateKey(), completeAddress.partialAddress); + await pxe.registerAccount(await keyPair.getPrivateKey(), completeAddress.partialAddress); // Check that the account is correctly registered using the getAccounts and getRecipients methods - const accounts = await rpc.getRegisteredAccounts(); - const recipients = await rpc.getRecipients(); + const accounts = await pxe.getRegisteredAccounts(); + const recipients = await pxe.getRecipients(); expect(accounts).toContainEqual(completeAddress); expect(recipients).not.toContainEqual(completeAddress); // Check that the account is correctly registered using the getAccount and getRecipient methods - const account = await rpc.getRegisteredAccount(completeAddress.address); - const recipient = await rpc.getRecipient(completeAddress.address); + const account = await pxe.getRegisteredAccount(completeAddress.address); + const recipient = await pxe.getRecipient(completeAddress.address); expect(account).toEqual(completeAddress); expect(recipient).toBeUndefined(); }); @@ -36,17 +36,17 @@ export const pxeTestSuite = (testName: string, pxeSetup: () => Promise) => it('registers a recipient and returns it as a recipient only and not as an account', async () => { const completeAddress = await CompleteAddress.random(); - await rpc.registerRecipient(completeAddress); + await pxe.registerRecipient(completeAddress); // Check that the recipient is correctly registered using the getAccounts and getRecipients methods - const accounts = await rpc.getRegisteredAccounts(); - const recipients = await rpc.getRecipients(); + const accounts = await pxe.getRegisteredAccounts(); + const recipients = await pxe.getRecipients(); expect(accounts).not.toContainEqual(completeAddress); expect(recipients).toContainEqual(completeAddress); // Check that the recipient is correctly registered using the getAccount and getRecipient methods - const account = await rpc.getRegisteredAccount(completeAddress.address); - const recipient = await rpc.getRecipient(completeAddress.address); + const account = await pxe.getRegisteredAccount(completeAddress.address); + const recipient = await pxe.getRecipient(completeAddress.address); expect(account).toBeUndefined(); expect(recipient).toEqual(completeAddress); }); @@ -58,16 +58,16 @@ export const pxeTestSuite = (testName: string, pxeSetup: () => Promise) => Fr.random(), ); - await rpc.registerAccount(await keyPair.getPrivateKey(), completeAddress.partialAddress); - await rpc.registerAccount(await keyPair.getPrivateKey(), completeAddress.partialAddress); + await pxe.registerAccount(await keyPair.getPrivateKey(), completeAddress.partialAddress); + await pxe.registerAccount(await keyPair.getPrivateKey(), completeAddress.partialAddress); }); it('cannot register a recipient with the same aztec address but different pub key or partial address', async () => { const recipient1 = await CompleteAddress.random(); const recipient2 = new CompleteAddress(recipient1.address, Point.random(), Fr.random()); - await rpc.registerRecipient(recipient1); - await expect(() => rpc.registerRecipient(recipient2)).rejects.toThrow( + await pxe.registerRecipient(recipient1); + await expect(() => pxe.registerRecipient(recipient2)).rejects.toThrow( `Complete address with aztec address ${recipient1.address}`, ); }); @@ -75,16 +75,16 @@ export const pxeTestSuite = (testName: string, pxeSetup: () => Promise) => it('does not throw when registering the same recipient twice (just ignores the second attempt)', async () => { const completeAddress = await CompleteAddress.random(); - await rpc.registerRecipient(completeAddress); - await rpc.registerRecipient(completeAddress); + await pxe.registerRecipient(completeAddress); + await pxe.registerRecipient(completeAddress); }); it('successfully adds a contract', async () => { const contracts: DeployedContract[] = [await randomDeployedContract(), await randomDeployedContract()]; - await rpc.addContracts(contracts); + await pxe.addContracts(contracts); const expectedContractAddresses = contracts.map(contract => contract.completeAddress.address); - const contractAddresses = await rpc.getContracts(); + const contractAddresses = await pxe.getContracts(); // check if all the contracts were returned expect(contractAddresses).toEqual(expect.arrayContaining(expectedContractAddresses)); @@ -102,7 +102,7 @@ export const pxeTestSuite = (testName: string, pxeSetup: () => Promise) => authWitnesses: [], }); - await expect(async () => await rpc.simulateTx(txExecutionRequest, false)).rejects.toThrow( + await expect(async () => await pxe.simulateTx(txExecutionRequest, false)).rejects.toThrow( 'Public entrypoints are not allowed', ); }); @@ -112,7 +112,7 @@ export const pxeTestSuite = (testName: string, pxeSetup: () => Promise) => it('throws when getting public storage for non-existent contract', async () => { const contract = AztecAddress.random(); - await expect(async () => await rpc.getPublicStorageAt(contract, new Fr(0n))).rejects.toThrow( + await expect(async () => await pxe.getPublicStorageAt(contract, new Fr(0n))).rejects.toThrow( `Contract ${contract.toString()} is not deployed`, ); }); @@ -121,12 +121,12 @@ export const pxeTestSuite = (testName: string, pxeSetup: () => Promise) => // functions only call AztecNode and these methods are frequently used by the e2e tests. it('successfully gets a block number', async () => { - const blockNum = await rpc.getBlockNumber(); + const blockNum = await pxe.getBlockNumber(); expect(blockNum).toBeGreaterThanOrEqual(INITIAL_L2_BLOCK_NUM); }); it('successfully gets node info', async () => { - const nodeInfo = await rpc.getNodeInfo(); + const nodeInfo = await pxe.getNodeInfo(); expect(typeof nodeInfo.protocolVersion).toEqual('number'); expect(typeof nodeInfo.chainId).toEqual('number'); expect(nodeInfo.l1ContractAddresses.rollupAddress.toString()).toMatch(/0x[a-fA-F0-9]+/); diff --git a/yarn-project/types/src/interfaces/pxe.ts b/yarn-project/types/src/interfaces/pxe.ts index 12878f1ee52..938b1ca0fcc 100644 --- a/yarn-project/types/src/interfaces/pxe.ts +++ b/yarn-project/types/src/interfaces/pxe.ts @@ -42,7 +42,7 @@ export interface PXE { /** * Registers a user account in PXE given its master encryption private key. - * Once a new account is registered, the RPC server will trial-decrypt all published notes on + * Once a new account is registered, the PXE Service will trial-decrypt all published notes on * the chain and store those that correspond to the registered account. * * @param privKey - Private key of the corresponding user master public key. @@ -54,11 +54,11 @@ export interface PXE { /** * Registers a recipient in PXE. This is required when sending encrypted notes to * a user who hasn't deployed their account contract yet. Since their account is not deployed, their - * encryption public key has not been broadcasted, so we need to manually register it on the RPC server + * encryption public key has not been broadcasted, so we need to manually register it on the PXE Service * in order to be able to encrypt data for this recipient. * * @param recipient - The complete address of the recipient - * @remarks Called recipient because we can only send notes to this account and not receive them via this RPC server. + * @remarks Called recipient because we can only send notes to this account and not receive them via this PXE Service. * This is because we don't have the associated private key and for this reason we can't decrypt * the recipient's notes. We can send notes to this account because we can encrypt them with the recipient's * public key. @@ -66,8 +66,8 @@ export interface PXE { registerRecipient(recipient: CompleteAddress): Promise; /** - * Retrieves the user accounts registered on this rpc server. - * @returns An array of the accounts registered on this RPC server. + * Retrieves the user accounts registered on this PXE Service. + * @returns An array of the accounts registered on this PXE Service. */ getRegisteredAccounts(): Promise; @@ -81,8 +81,8 @@ export interface PXE { getRegisteredAccount(address: AztecAddress): Promise; /** - * Retrieves the recipients added to this rpc server. - * @returns An array of recipients registered on this RPC server. + * Retrieves the recipients added to this PXE Service. + * @returns An array of recipients registered on this PXE Service. */ getRecipients(): Promise; @@ -96,18 +96,18 @@ export interface PXE { getRecipient(address: AztecAddress): Promise; /** - * Adds deployed contracts to the RPC server. Deployed contract information is used to access the + * Adds deployed contracts to the PXE Service. Deployed contract information is used to access the * contract code when simulating local transactions. This is automatically called by aztec.js when * deploying a contract. Dapps that wish to interact with contracts already deployed should register - * these contracts in their users' RPC server through this method. + * these contracts in their users' PXE Service through this method. * * @param contracts - An array of DeployedContract objects containing contract ABI, address, and portal contract. */ addContracts(contracts: DeployedContract[]): Promise; /** - * Retrieves the addresses of contracts added to this rpc server. - * @returns An array of contracts addresses registered on this RPC server. + * Retrieves the addresses of contracts added to this PXE Service. + * @returns An array of contracts addresses registered on this PXE Service. */ getContracts(): Promise; @@ -149,7 +149,7 @@ export interface PXE { /** * Retrieves the private storage data at a specified contract address and storage slot. Returns only data - * encrypted for the specified owner that has been already decrypted by the RPC server. Note that there + * encrypted for the specified owner that has been already decrypted by the PXE Service. Note that there * may be multiple notes for a user in a single slot. * * @param owner - The address for whom the private data is encrypted. From fee79b3aa120c45519a19d9f3edcc1fde81b07fb Mon Sep 17 00:00:00 2001 From: benesjan Date: Wed, 27 Sep 2023 13:02:02 +0000 Subject: [PATCH 11/23] Revert "triggering full rebuild" This reverts commit 6ec7855aa11982b597d3fdd262d7599674830f74. --- .../kernel/private/native_private_kernel_circuit_init.test.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/circuits/cpp/src/aztec3/circuits/kernel/private/native_private_kernel_circuit_init.test.cpp b/circuits/cpp/src/aztec3/circuits/kernel/private/native_private_kernel_circuit_init.test.cpp index aa100692071..d1fecdf6745 100644 --- a/circuits/cpp/src/aztec3/circuits/kernel/private/native_private_kernel_circuit_init.test.cpp +++ b/circuits/cpp/src/aztec3/circuits/kernel/private/native_private_kernel_circuit_init.test.cpp @@ -122,7 +122,7 @@ TEST_F(native_private_kernel_init_tests, DISABLED_contract_deployment_call_stack { auto private_inputs = do_private_call_get_kernel_inputs_init(true, constructor, standard_test_args()); - // Randomize the second item in the private call stack (i.e. hash of the private call item). + // Randomise the second item in the private call stack (i.e. hash of the private call item). private_inputs.private_call.call_stack_item.public_inputs.private_call_stack[1] = NT::fr::random_element(); DummyBuilder builder = From f93544a2a6802179b1801078a0493a33c15f1d20 Mon Sep 17 00:00:00 2001 From: benesjan Date: Wed, 27 Sep 2023 13:13:57 +0000 Subject: [PATCH 12/23] formatting fix attempt --- yarn-project/boxes/private-token/src/app/index.html | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/yarn-project/boxes/private-token/src/app/index.html b/yarn-project/boxes/private-token/src/app/index.html index 6fedf6b23a6..a81c17f2a87 100644 --- a/yarn-project/boxes/private-token/src/app/index.html +++ b/yarn-project/boxes/private-token/src/app/index.html @@ -1,4 +1,4 @@ - + From 02619122b84c24a88054536c88b45159ec949290 Mon Sep 17 00:00:00 2001 From: benesjan Date: Wed, 27 Sep 2023 13:15:47 +0000 Subject: [PATCH 13/23] no changes to changelog --- CHANGELOG.md | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 188f95ee5ff..56efb0a7915 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -7,7 +7,7 @@ * Aztec-cli unbox "really empty box" ([#2388](https://github.com/AztecProtocol/aztec-packages/issues/2388)) ([b57182d](https://github.com/AztecProtocol/aztec-packages/commit/b57182d6dff9fc27d5fb555a4c4cb948d9e5cc55)) * **docs:** Document noir macros ([#2016](https://github.com/AztecProtocol/aztec-packages/issues/2016)) ([1f1a17f](https://github.com/AztecProtocol/aztec-packages/commit/1f1a17fe056d8898c4c065fb6244e53da04800cb)) -* **docs:** Include PXE interface typedoc output in docs ([#2255](https://github.com/AztecProtocol/aztec-packages/issues/2255)) ([62c9e9b](https://github.com/AztecProtocol/aztec-packages/commit/62c9e9bfdc9535ccfc6bd76782971e22478a7784)) +* **docs:** Include aztec rpc interface typedoc output in docs ([#2255](https://github.com/AztecProtocol/aztec-packages/issues/2255)) ([62c9e9b](https://github.com/AztecProtocol/aztec-packages/commit/62c9e9bfdc9535ccfc6bd76782971e22478a7784)) * **token portal standard:** Create a token portal standard ([#2351](https://github.com/AztecProtocol/aztec-packages/issues/2351)) ([426a3ea](https://github.com/AztecProtocol/aztec-packages/commit/426a3ea6a5c3529b4edaea94affaece97d39a35b)) @@ -16,7 +16,7 @@ * **build:** Fix build system post deployment tests ([#2420](https://github.com/AztecProtocol/aztec-packages/issues/2420)) ([d509dc3](https://github.com/AztecProtocol/aztec-packages/commit/d509dc359c4cd9dc37492a434a1eb3813c002839)) * CLI encoding for arrays and structs ([#2407](https://github.com/AztecProtocol/aztec-packages/issues/2407)) ([85283bd](https://github.com/AztecProtocol/aztec-packages/commit/85283bdd5b0916c207dca11ad17338f524ae18f6)) * Correct sandbox addresses in up-quick-start test ([#2412](https://github.com/AztecProtocol/aztec-packages/issues/2412)) ([974d859](https://github.com/AztecProtocol/aztec-packages/commit/974d85922fc11734c543e7ce9fe7edaad527bd69)) -* **docs:** Revert include PXE interface typedoc output in docs ([#2255](https://github.com/AztecProtocol/aztec-packages/issues/2255)) ([f852432](https://github.com/AztecProtocol/aztec-packages/commit/f85243298ef2a5c01764e592c6f6ea50d835bf07)) +* **docs:** Revert include aztec rpc interface typedoc output in docs ([#2255](https://github.com/AztecProtocol/aztec-packages/issues/2255)) ([f852432](https://github.com/AztecProtocol/aztec-packages/commit/f85243298ef2a5c01764e592c6f6ea50d835bf07)) * Handle falsy bigints in json-rpc ([#2403](https://github.com/AztecProtocol/aztec-packages/issues/2403)) ([d100650](https://github.com/AztecProtocol/aztec-packages/commit/d100650d107b6685e17fcdbbf68363505c5ed0ed)), closes [#2402](https://github.com/AztecProtocol/aztec-packages/issues/2402) * **nargo_check.sh:** UNIX standard grep ([#2396](https://github.com/AztecProtocol/aztec-packages/issues/2396)) ([02e788a](https://github.com/AztecProtocol/aztec-packages/commit/02e788a8e39c7fcb5c75a6aaf4ceb705a8ebaa4a)) @@ -385,7 +385,7 @@ ### Features -* `CompleteAddress` type and overall PXE refactor ([#1524](https://github.com/AztecProtocol/aztec-packages/issues/1524)) ([aa2c74c](https://github.com/AztecProtocol/aztec-packages/commit/aa2c74c8503469630611b7004c4052b80b5fe815)) +* `CompleteAddress` type and overall AztecRPC refactor ([#1524](https://github.com/AztecProtocol/aztec-packages/issues/1524)) ([aa2c74c](https://github.com/AztecProtocol/aztec-packages/commit/aa2c74c8503469630611b7004c4052b80b5fe815)) * `FunctionSelector` type ([#1518](https://github.com/AztecProtocol/aztec-packages/issues/1518)) ([942f705](https://github.com/AztecProtocol/aztec-packages/commit/942f7058adc706924ff26d2490bec7f7d57d7149)), closes [#1424](https://github.com/AztecProtocol/aztec-packages/issues/1424) * `GrumpkinScalar` type ([#1919](https://github.com/AztecProtocol/aztec-packages/issues/1919)) ([3a9238a](https://github.com/AztecProtocol/aztec-packages/commit/3a9238a99a32259d8d6b85df6335a002c7bab354)) * **892:** Add hints for matching transient read requests with correspondiā€¦ ([#1995](https://github.com/AztecProtocol/aztec-packages/issues/1995)) ([0955bb7](https://github.com/AztecProtocol/aztec-packages/commit/0955bb7b0903b12c4f041096d51a1dbb48f6359d)) @@ -568,7 +568,7 @@ ### Miscellaneous -* `PXE` API using sandbox ([#1568](https://github.com/AztecProtocol/aztec-packages/issues/1568)) ([b2662db](https://github.com/AztecProtocol/aztec-packages/commit/b2662dbc45b0149b380ae3c88d058b70174266cb)) +* `AztecRPC` API using sandbox ([#1568](https://github.com/AztecProtocol/aztec-packages/issues/1568)) ([b2662db](https://github.com/AztecProtocol/aztec-packages/commit/b2662dbc45b0149b380ae3c88d058b70174266cb)) * **1074:** Remove read request data from final private kernel circuit public inputs ([#1840](https://github.com/AztecProtocol/aztec-packages/issues/1840)) ([c61557a](https://github.com/AztecProtocol/aztec-packages/commit/c61557ae926f89cead7306368197fdbe8f23dd6d)) * **1407:** Remove forwarding witnesses ([#1930](https://github.com/AztecProtocol/aztec-packages/issues/1930)) ([cc8bc8f](https://github.com/AztecProtocol/aztec-packages/commit/cc8bc8f48b175479e1c4dfbcf9b92159f096c2cf)), closes [#1407](https://github.com/AztecProtocol/aztec-packages/issues/1407) * **1879:** Add use of PrivateKernelPublicInputs in TS whenever relevant ([#1911](https://github.com/AztecProtocol/aztec-packages/issues/1911)) ([8d5f548](https://github.com/AztecProtocol/aztec-packages/commit/8d5f548e42d627da1685820f99fc28ff5f47abbe)) @@ -582,7 +582,7 @@ * Add tests that check ordering of public state updates ([#1661](https://github.com/AztecProtocol/aztec-packages/issues/1661)) ([5b9aedd](https://github.com/AztecProtocol/aztec-packages/commit/5b9aeddd4a1bffcf9015786819dd3f6c1ff66fb4)) * Add todo for using generator indices in note commitment and nullifier computation. ([#1762](https://github.com/AztecProtocol/aztec-packages/issues/1762)) ([2db6728](https://github.com/AztecProtocol/aztec-packages/commit/2db6728fcaf75ce8c98d821b65695543bb0c82a2)) * Another pedantic change to public state naming ([#1359](https://github.com/AztecProtocol/aztec-packages/issues/1359)) ([cb77440](https://github.com/AztecProtocol/aztec-packages/commit/cb774405e89c71a622e32b51032aa761cd767959)) -* PXE interface cleanup ([#1423](https://github.com/AztecProtocol/aztec-packages/issues/1423)) ([1a6168a](https://github.com/AztecProtocol/aztec-packages/commit/1a6168abc9cdc092cf7c9843191194c9b90adae7)) +* Aztec RPC interface cleanup ([#1423](https://github.com/AztecProtocol/aztec-packages/issues/1423)) ([1a6168a](https://github.com/AztecProtocol/aztec-packages/commit/1a6168abc9cdc092cf7c9843191194c9b90adae7)) * **Aztec.nr:** Remove implicit imports ([#1901](https://github.com/AztecProtocol/aztec-packages/issues/1901)) ([c7d5190](https://github.com/AztecProtocol/aztec-packages/commit/c7d5190e48771c334bfa7062c361bcd623faa318)) * **Aztec.nr:** Remove the open keyword from public functions ([#1917](https://github.com/AztecProtocol/aztec-packages/issues/1917)) ([4db8603](https://github.com/AztecProtocol/aztec-packages/commit/4db8603a4ee293c64a67be5ba74072bd654c7ec5)) * **bb:** Refactor bb CLI interface ([#1672](https://github.com/AztecProtocol/aztec-packages/issues/1672)) ([a5bf6e0](https://github.com/AztecProtocol/aztec-packages/commit/a5bf6e008b19127bf15c8b12a5a699182b7ff4e7)), closes [#1671](https://github.com/AztecProtocol/aztec-packages/issues/1671) @@ -673,7 +673,7 @@ * Rework nonces ([#1210](https://github.com/AztecProtocol/aztec-packages/issues/1210)) ([#1331](https://github.com/AztecProtocol/aztec-packages/issues/1331)) ([665cb75](https://github.com/AztecProtocol/aztec-packages/commit/665cb753f50f003ccd21935755aa1f08bfb78deb)) * Sandbox logging tweaks ([#1797](https://github.com/AztecProtocol/aztec-packages/issues/1797)) ([0e3914e](https://github.com/AztecProtocol/aztec-packages/commit/0e3914ed6ad63062add1cc08f6ea85646c068f8a)) * **scripts:** Convenience script to update local generated artifacts ([#1349](https://github.com/AztecProtocol/aztec-packages/issues/1349)) ([317981a](https://github.com/AztecProtocol/aztec-packages/commit/317981a13c9faf791a2760a07e9808a8474ecae2)) -* Simplified PXE.registerAccount function ([#1729](https://github.com/AztecProtocol/aztec-packages/issues/1729)) ([8e5f828](https://github.com/AztecProtocol/aztec-packages/commit/8e5f828c0aff0602c49575139883c8abc3cb6e91)) +* Simplified AztecRpc.registerAccount function ([#1729](https://github.com/AztecProtocol/aztec-packages/issues/1729)) ([8e5f828](https://github.com/AztecProtocol/aztec-packages/commit/8e5f828c0aff0602c49575139883c8abc3cb6e91)) * **simulator:** Initialize ACVM's SimulatedBackend separately (setup pedersen init only happens once) ([#1596](https://github.com/AztecProtocol/aztec-packages/issues/1596)) ([1a260ed](https://github.com/AztecProtocol/aztec-packages/commit/1a260ede0729b1f70b90e06c2e6588bcb5eb9fc3)) * Split out yarn-project bootstrap.sh ([#1790](https://github.com/AztecProtocol/aztec-packages/issues/1790)) ([1788fe6](https://github.com/AztecProtocol/aztec-packages/commit/1788fe6259f5e7fd191929b27996a7342e3f13e5)) * Split SumcheckRound into Prover/Verifier classes ([#1373](https://github.com/AztecProtocol/aztec-packages/issues/1373)) ([8b1d48a](https://github.com/AztecProtocol/aztec-packages/commit/8b1d48a52c41f4f6cf436b481823f59582611b81)) @@ -1098,4 +1098,4 @@ ### Documentation * convert quick start guides into e2e tests ([#1726](https://github.com/AztecProtocol/aztec-packages/issues/1726)) ([802a678](https://github.com/AztecProtocol/aztec-packages/commit/802a678e3dd19339cd88b105a0ce341026b58054)), closes [#1564](https://github.com/AztecProtocol/aztec-packages/issues/1564) -* including "real" code in keys docs ([#1767](https://github.com/AztecProtocol/aztec-packages/issues/1767)) ([cd9cadb](https://github.com/AztecProtocol/aztec-packages/commit/cd9cadbfb6b0311c381586799588a5f64df98f29)) +* including "real" code in keys docs ([#1767](https://github.com/AztecProtocol/aztec-packages/issues/1767)) ([cd9cadb](https://github.com/AztecProtocol/aztec-packages/commit/cd9cadbfb6b0311c381586799588a5f64df98f29)) \ No newline at end of file From 5fe4602973a8f9f04256c7403a19d186440d8d94 Mon Sep 17 00:00:00 2001 From: benesjan Date: Wed, 27 Sep 2023 13:27:17 +0000 Subject: [PATCH 14/23] WIP --- docs/docs/dev_docs/wallets/architecture.md | 4 +-- .../dev_docs/sandbox/components.md | 2 +- yarn-project/aztec-sandbox/src/sandbox.ts | 4 +-- yarn-project/aztec.js/src/account/index.ts | 36 +++++++++---------- yarn-project/end-to-end/src/fixtures/utils.ts | 6 ++-- 5 files changed, 26 insertions(+), 26 deletions(-) diff --git a/docs/docs/dev_docs/wallets/architecture.md b/docs/docs/dev_docs/wallets/architecture.md index a2034d0d1ea..55de4c160be 100644 --- a/docs/docs/dev_docs/wallets/architecture.md +++ b/docs/docs/dev_docs/wallets/architecture.md @@ -18,9 +18,9 @@ The account interface is used for creating an _execution request_ out of one or Refer to the page on [writing an account contract](./writing_an_account_contract.md) for an example on how to implement this interface. -## RPC interface +## PXE interface -A wallet exposes the RPC interface to dapps by running an PXE instance. The PXE requires a keystore and a database implementation for storing keys, private state, and recipient encryption public keys. +A wallet exposes the PXE interface to dapps by running an PXE instance. The PXE requires a keystore and a database implementation for storing keys, private state, and recipient encryption public keys. #include_code pxe-interface /yarn-project/types/src/interfaces/pxe.ts typescript diff --git a/docs/internal_notes/dev_docs/sandbox/components.md b/docs/internal_notes/dev_docs/sandbox/components.md index e5294fd4e87..cc3f335c784 100644 --- a/docs/internal_notes/dev_docs/sandbox/components.md +++ b/docs/internal_notes/dev_docs/sandbox/components.md @@ -141,7 +141,7 @@ Implementation notes for this milestone: Implements: -- `P` (The server is a client, when used directly) +- `PXE` (The server is a client, when used directly) Injected: diff --git a/yarn-project/aztec-sandbox/src/sandbox.ts b/yarn-project/aztec-sandbox/src/sandbox.ts index 00d36e66977..d3f2b342069 100644 --- a/yarn-project/aztec-sandbox/src/sandbox.ts +++ b/yarn-project/aztec-sandbox/src/sandbox.ts @@ -20,7 +20,7 @@ import { RollupAbi, RollupBytecode, } from '@aztec/l1-artifacts'; -import { createPXEService, getPXEServiceConfig as getRpcConfigEnvVars } from '@aztec/pxe'; +import { createPXEService, getPXEServiceConfig } from '@aztec/pxe'; import { createPublicClient, http as httpViemTransport } from 'viem'; import { mnemonicToAccount } from 'viem/accounts'; @@ -78,7 +78,7 @@ export type SandboxConfig = AztecNodeConfig & { */ export async function createSandbox(config: Partial = {}) { const aztecNodeConfig: AztecNodeConfig = { ...getConfigEnvVars(), ...config }; - const pxeServiceConfig = getRpcConfigEnvVars(); + const pxeServiceConfig = getPXEServiceConfig(); const hdAccount = mnemonicToAccount(config.l1Mnemonic ?? MNEMONIC); const privKey = hdAccount.getHdKey().privateKey; diff --git a/yarn-project/aztec.js/src/account/index.ts b/yarn-project/aztec.js/src/account/index.ts index 6123115aa01..9c240bba333 100644 --- a/yarn-project/aztec.js/src/account/index.ts +++ b/yarn-project/aztec.js/src/account/index.ts @@ -7,7 +7,7 @@ * ```ts * const encryptionPrivateKey = GrumpkinScalar.random(); * const signingPrivateKey = GrumpkinScalar.random(); - * const wallet = getSchnorrAccount(rpc, encryptionPrivateKey, signingPrivateKey).waitDeploy(); + * const wallet = getSchnorrAccount(pxe, encryptionPrivateKey, signingPrivateKey).waitDeploy(); * ``` * * For testing purposes, consider using the {@link createAccount} and {@link createAccounts} methods, @@ -38,49 +38,49 @@ export type Salt = Fr | number | bigint; /** * Creates an Account that relies on an ECDSA signing key for authentication. - * @param rpc - An PXE server instance. + * @param pxe - An PXE server instance. * @param encryptionPrivateKey - Grumpkin key used for note encryption. * @param signingPrivateKey - Secp256k1 key used for signing transactions. * @param saltOrAddress - Deployment salt or complete address if account contract is already deployed. */ export function getEcdsaAccount( - rpc: PXE, + pxe: PXE, encryptionPrivateKey: GrumpkinPrivateKey, signingPrivateKey: Buffer, saltOrAddress?: Salt | CompleteAddress, ): AccountManager { - return new AccountManager(rpc, encryptionPrivateKey, new EcdsaAccountContract(signingPrivateKey), saltOrAddress); + return new AccountManager(pxe, encryptionPrivateKey, new EcdsaAccountContract(signingPrivateKey), saltOrAddress); } /** * Creates an Account that relies on a Grumpkin signing key for authentication. - * @param rpc - An PXE server instance. + * @param pxe - An PXE server instance. * @param encryptionPrivateKey - Grumpkin key used for note encryption. * @param signingPrivateKey - Grumpkin key used for signing transactions. * @param saltOrAddress - Deployment salt or complete address if account contract is already deployed. */ export function getSchnorrAccount( - rpc: PXE, + pxe: PXE, encryptionPrivateKey: GrumpkinPrivateKey, signingPrivateKey: GrumpkinPrivateKey, saltOrAddress?: Salt | CompleteAddress, ): AccountManager { - return new AccountManager(rpc, encryptionPrivateKey, new SchnorrAccountContract(signingPrivateKey), saltOrAddress); + return new AccountManager(pxe, encryptionPrivateKey, new SchnorrAccountContract(signingPrivateKey), saltOrAddress); } /** * Creates an Account that uses the same Grumpkin key for encryption and authentication. - * @param rpc - An PXE server instance. + * @param pxe - An PXE server instance. * @param encryptionAndSigningPrivateKey - Grumpkin key used for note encryption and signing transactions. * @param saltOrAddress - Deployment salt or complete address if account contract is already deployed. */ export function getUnsafeSchnorrAccount( - rpc: PXE, + pxe: PXE, encryptionAndSigningPrivateKey: GrumpkinPrivateKey, saltOrAddress?: Salt | CompleteAddress, ): AccountManager { return new AccountManager( - rpc, + pxe, encryptionAndSigningPrivateKey, new SingleKeyAccountContract(encryptionAndSigningPrivateKey), saltOrAddress, @@ -89,36 +89,36 @@ export function getUnsafeSchnorrAccount( /** * Gets a wallet for an already registered account using Schnorr signatures with a single key for encryption and authentication. - * @param rpc - An PXE server instance. + * @param pxe - An PXE server instance. * @param address - Address for the account. * @param signingPrivateKey - Grumpkin key used for note encryption and signing transactions. * @returns A wallet for this account that can be used to interact with a contract instance. */ export function getUnsafeSchnorrWallet( - rpc: PXE, + pxe: PXE, address: AztecAddress, signingKey: GrumpkinPrivateKey, ): Promise { - return getWallet(rpc, address, new SingleKeyAccountContract(signingKey)); + return getWallet(pxe, address, new SingleKeyAccountContract(signingKey)); } /** * Gets a wallet for an already registered account. - * @param rpc - An PXE server instance. + * @param pxe - PXE Service instance. * @param address - Address for the account. * @param accountContract - Account contract implementation. * @returns A wallet for this account that can be used to interact with a contract instance. */ export async function getWallet( - rpc: PXE, + pxe: PXE, address: AztecAddress, accountContract: AccountContract, ): Promise { - const completeAddress = await rpc.getRegisteredAccount(address); + const completeAddress = await pxe.getRegisteredAccount(address); if (!completeAddress) { throw new Error(`Account ${address} not found`); } - const nodeInfo = await rpc.getNodeInfo(); + const nodeInfo = await pxe.getNodeInfo(); const entrypoint = await accountContract.getInterface(completeAddress, nodeInfo); - return new AccountWallet(rpc, entrypoint); + return new AccountWallet(pxe, entrypoint); } diff --git a/yarn-project/end-to-end/src/fixtures/utils.ts b/yarn-project/end-to-end/src/fixtures/utils.ts index 458bc3e77ac..cc25ceb19de 100644 --- a/yarn-project/end-to-end/src/fixtures/utils.ts +++ b/yarn-project/end-to-end/src/fixtures/utils.ts @@ -41,7 +41,7 @@ import { TokenPortalBytecode, } from '@aztec/l1-artifacts'; import { NonNativeTokenContract, TokenBridgeContract, TokenContract } from '@aztec/noir-contracts/types'; -import { PXEService, createPXEService, getPXEServiceConfig as getRpcConfigEnvVars } from '@aztec/pxe'; +import { PXEService, createPXEService, getPXEServiceConfig } from '@aztec/pxe'; import { L2BlockL2Logs, LogType, PXE, TxStatus } from '@aztec/types'; import { @@ -157,8 +157,8 @@ export async function setupPXEService( */ logger: DebugLogger; }> { - const rpcConfig = getRpcConfigEnvVars(); - const pxe = await createPXEService(aztecNode, rpcConfig, {}, useLogSuffix); + const pxeServiceConfig = getPXEServiceConfig(); + const pxe = await createPXEService(aztecNode, pxeServiceConfig, {}, useLogSuffix); const wallets = await createAccounts(pxe, numberOfAccounts); From 926d1e9e4cf431602f66a6b0eb91e20bc190e2fa Mon Sep 17 00:00:00 2001 From: benesjan Date: Wed, 27 Sep 2023 13:38:51 +0000 Subject: [PATCH 15/23] WIP --- yarn-project/aztec.js/README.md | 2 +- .../aztec.js/src/account/manager/index.ts | 20 +++---- yarn-project/aztec.js/src/account/utils.ts | 20 +++---- .../src/contract/base_contract_interaction.ts | 8 +-- yarn-project/aztec.js/src/contract/index.ts | 2 +- .../aztec.js/src/contract/sent_tx.test.ts | 18 +++---- yarn-project/aztec.js/src/contract/sent_tx.ts | 4 +- .../src/contract_deployer/deploy_method.ts | 4 +- .../src/contract_deployer/deploy_sent_tx.ts | 2 +- yarn-project/aztec.js/src/sandbox/index.ts | 20 +++---- .../aztec.js/src/utils/cheat_codes.ts | 18 +++---- .../aztec.js/src/utils/l2_contracts.ts | 6 +-- .../aztec.js/src/wallet/account_wallet.ts | 6 +-- .../aztec.js/src/wallet/base_wallet.ts | 54 +++++++++---------- .../aztec.js/src/wallet/signerless_wallet.ts | 2 +- 15 files changed, 93 insertions(+), 93 deletions(-) diff --git a/yarn-project/aztec.js/README.md b/yarn-project/aztec.js/README.md index 371be3ba4ca..b3cc8e34374 100644 --- a/yarn-project/aztec.js/README.md +++ b/yarn-project/aztec.js/README.md @@ -12,7 +12,7 @@ import { GrumpkinPrivateKey } from '@aztec/types'; const encryptionPrivateKey = GrumpkinPrivateKey.random(); const signingPrivateKey = GrumpkinPrivateKey.random(); -const wallet = getSchnorrAccount(rpc, encryptionPrivateKey, signingPrivateKey).waitDeploy(); +const wallet = getSchnorrAccount(pxe, encryptionPrivateKey, signingPrivateKey).waitDeploy(); console.log(`New account deployed at ${wallet.getAddress()}`); ``` diff --git a/yarn-project/aztec.js/src/account/manager/index.ts b/yarn-project/aztec.js/src/account/manager/index.ts index f8260b33bd6..f4c4255e56a 100644 --- a/yarn-project/aztec.js/src/account/manager/index.ts +++ b/yarn-project/aztec.js/src/account/manager/index.ts @@ -8,7 +8,7 @@ import { DeployAccountSentTx } from './deploy_account_sent_tx.js'; /** * Manages a user account. Provides methods for calculating the account's address, deploying the account contract, - * and creating and registering the user wallet in the RPC server. + * and creating and registering the user wallet in the PXE Service. */ export class AccountManager { /** Deployment salt for the account contract. */ @@ -19,7 +19,7 @@ export class AccountManager { private deployMethod?: DeployMethod; constructor( - private rpc: PXE, + private pxe: PXE, private encryptionPrivateKey: GrumpkinPrivateKey, private accountContract: AccountContract, saltOrAddress?: Salt | CompleteAddress, @@ -43,7 +43,7 @@ export class AccountManager { * @returns An entrypoint. */ public async getAccount(): Promise { - const nodeInfo = await this.rpc.getNodeInfo(); + const nodeInfo = await this.pxe.getNodeInfo(); const completeAddress = await this.getCompleteAddress(); return this.accountContract.getInterface(completeAddress, nodeInfo); } @@ -74,18 +74,18 @@ export class AccountManager { */ public async getWallet(): Promise { const entrypoint = await this.getAccount(); - return new AccountWallet(this.rpc, entrypoint); + return new AccountWallet(this.pxe, entrypoint); } /** - * Registers this account in the RPC server and returns the associated wallet. Registering - * the account on the RPC server is required for managing private state associated with it. + * Registers this account in the PXE Service and returns the associated wallet. Registering + * the account on the PXE Service is required for managing private state associated with it. * Use the returned wallet to create Contract instances to be interacted with from this account. * @returns A Wallet instance. */ public async register(): Promise { const completeAddress = await this.getCompleteAddress(); - await this.rpc.registerAccount(this.encryptionPrivateKey, completeAddress.partialAddress); + await this.pxe.registerAccount(this.encryptionPrivateKey, completeAddress.partialAddress); return this.getWallet(); } @@ -100,7 +100,7 @@ export class AccountManager { if (!this.salt) throw new Error(`Cannot deploy account contract without known salt.`); await this.register(); const encryptionPublicKey = await this.getEncryptionPublicKey(); - const deployer = new ContractDeployer(this.accountContract.getContractAbi(), this.rpc, encryptionPublicKey); + const deployer = new ContractDeployer(this.accountContract.getContractAbi(), this.pxe, encryptionPublicKey); const args = await this.accountContract.getDeploymentArgs(); this.deployMethod = deployer.deploy(...args); } @@ -112,7 +112,7 @@ export class AccountManager { * Uses the salt provided in the constructor or a randomly generated one. * Note that if the Account is constructed with an explicit complete address * it is assumed that the account contract has already been deployed and this method will throw. - * Registers the account in the RPC server before deploying the contract. + * Registers the account in the PXE Service before deploying the contract. * @returns A SentTx object that can be waited to get the associated Wallet. */ public async deploy(): Promise { @@ -127,7 +127,7 @@ export class AccountManager { * Uses the salt provided in the constructor or a randomly generated one. * Note that if the Account is constructed with an explicit complete address * it is assumed that the account contract has already been deployed and this method will throw. - * Registers the account in the RPC server before deploying the contract. + * Registers the account in the PXE Service before deploying the contract. * @param opts - Options to wait for the tx to be mined. * @returns A Wallet instance. */ diff --git a/yarn-project/aztec.js/src/account/utils.ts b/yarn-project/aztec.js/src/account/utils.ts index 3bf16d80070..593ca2cdd8a 100644 --- a/yarn-project/aztec.js/src/account/utils.ts +++ b/yarn-project/aztec.js/src/account/utils.ts @@ -6,36 +6,36 @@ import { AccountWallet } from '../wallet/account_wallet.js'; /** * Deploys and registers a new account using random private keys and returns the associated Schnorr account wallet. Useful for testing. - * @param rpc - RPC client. + * @param pxe - PXE. * @returns - A wallet for a fresh account. */ -export function createAccount(rpc: PXE): Promise { - return getSchnorrAccount(rpc, GrumpkinScalar.random(), GrumpkinScalar.random()).waitDeploy(); +export function createAccount(pxe: PXE): Promise { + return getSchnorrAccount(pxe, GrumpkinScalar.random(), GrumpkinScalar.random()).waitDeploy(); } /** - * Creates a random address and registers it as a recipient on the RPC server. Useful for testing. - * @param rpc - RPC client. + * Creates a random address and registers it as a recipient on the pxe server. Useful for testing. + * @param pxe - PXE. * @returns Complete address of the registered recipient. */ -export async function createRecipient(rpc: PXE): Promise { +export async function createRecipient(pxe: PXE): Promise { const completeAddress = await CompleteAddress.random(); - await rpc.registerRecipient(completeAddress); + await pxe.registerRecipient(completeAddress); return completeAddress; } /** * Creates a given number of random accounts using the Schnorr account wallet. - * @param rpc - RPC interface. + * @param pxe - PXE. * @param numberOfAccounts - How many accounts to create. * @returns The created account wallets. */ -export async function createAccounts(rpc: PXE, numberOfAccounts = 1): Promise { +export async function createAccounts(pxe: PXE, numberOfAccounts = 1): Promise { const accounts = []; // Prepare deployments for (let i = 0; i < numberOfAccounts; ++i) { - const account = getSchnorrAccount(rpc, GrumpkinScalar.random(), GrumpkinScalar.random()); + const account = getSchnorrAccount(pxe, GrumpkinScalar.random(), GrumpkinScalar.random()); await account.getDeployMethod().then(d => d.simulate({ contractAddressSalt: account.salt })); accounts.push(account); } diff --git a/yarn-project/aztec.js/src/contract/base_contract_interaction.ts b/yarn-project/aztec.js/src/contract/base_contract_interaction.ts index c63f6d9a96f..800ae901c8d 100644 --- a/yarn-project/aztec.js/src/contract/base_contract_interaction.ts +++ b/yarn-project/aztec.js/src/contract/base_contract_interaction.ts @@ -21,7 +21,7 @@ export abstract class BaseContractInteraction { protected tx?: Tx; protected txRequest?: TxExecutionRequest; - constructor(protected rpc: PXE) {} + constructor(protected pxe: PXE) {} /** * Create a transaction execution request ready to be simulated. @@ -37,7 +37,7 @@ export abstract class BaseContractInteraction { */ public async simulate(options: SendMethodOptions = {}): Promise { const txRequest = this.txRequest ?? (await this.create(options)); - this.tx = await this.rpc.simulateTx(txRequest, !options.skipPublicSimulation); + this.tx = await this.pxe.simulateTx(txRequest, !options.skipPublicSimulation); return this.tx; } @@ -53,9 +53,9 @@ export abstract class BaseContractInteraction { public send(options: SendMethodOptions = {}) { const promise = (async () => { const tx = this.tx ?? (await this.simulate(options)); - return this.rpc.sendTx(tx); + return this.pxe.sendTx(tx); })(); - return new SentTx(this.rpc, promise); + return new SentTx(this.pxe, promise); } } diff --git a/yarn-project/aztec.js/src/contract/index.ts b/yarn-project/aztec.js/src/contract/index.ts index 9ef6df45049..620c4d1e968 100644 --- a/yarn-project/aztec.js/src/contract/index.ts +++ b/yarn-project/aztec.js/src/contract/index.ts @@ -26,7 +26,7 @@ * or obtaining the `request` for aggregating into a {@link BatchCall}. * * The result of `send`ing a transaction is a {@link SentTx} object, from which you can get the - * transaction hash, or simply `wait` until the transaction is mined and the local RPC server + * transaction hash, or simply `wait` until the transaction is mined and the local PXE Service * has synchronised its changes. * * @remarks If you are using typescript, consider using the diff --git a/yarn-project/aztec.js/src/contract/sent_tx.test.ts b/yarn-project/aztec.js/src/contract/sent_tx.test.ts index a1f4e72c192..29cf7ef450f 100644 --- a/yarn-project/aztec.js/src/contract/sent_tx.test.ts +++ b/yarn-project/aztec.js/src/contract/sent_tx.test.ts @@ -5,26 +5,26 @@ import { MockProxy, mock } from 'jest-mock-extended'; import { SentTx } from './sent_tx.js'; describe('SentTx', () => { - let rpc: MockProxy; + let pxe: MockProxy; let txHashPromise: Promise; let sentTx: SentTx; beforeEach(() => { - rpc = mock(); + pxe = mock(); txHashPromise = Promise.resolve(TxHash.fromBigInt(1n)); - sentTx = new SentTx(rpc, txHashPromise); + sentTx = new SentTx(pxe, txHashPromise); }); describe('wait', () => { let txReceipt: TxReceipt; beforeEach(() => { txReceipt = { status: TxStatus.MINED, blockNumber: 20 } as TxReceipt; - rpc.getTxReceipt.mockResolvedValue(txReceipt); + pxe.getTxReceipt.mockResolvedValue(txReceipt); }); it('waits for all notes accounts to be synced', async () => { - rpc.getSyncStatus + pxe.getSyncStatus .mockResolvedValueOnce({ blocks: 25, notes: { '0x1': 19, '0x2': 20 } }) .mockResolvedValueOnce({ blocks: 25, notes: { '0x1': 20, '0x2': 20 } }); @@ -33,19 +33,19 @@ describe('SentTx', () => { }); it('fails if an account is not synced', async () => { - rpc.getSyncStatus.mockResolvedValue({ blocks: 25, notes: { '0x1': 19, '0x2': 20 } }); + pxe.getSyncStatus.mockResolvedValue({ blocks: 25, notes: { '0x1': 19, '0x2': 20 } }); await expect(sentTx.wait({ timeout: 1, interval: 0.4 })).rejects.toThrowError(/timeout/i); }); it('does not wait for notes sync', async () => { - rpc.getSyncStatus.mockResolvedValue({ blocks: 19, notes: { '0x1': 19, '0x2': 19 } }); + pxe.getSyncStatus.mockResolvedValue({ blocks: 19, notes: { '0x1': 19, '0x2': 19 } }); const actual = await sentTx.wait({ timeout: 1, interval: 0.4, waitForNotesSync: false }); expect(actual).toEqual(txReceipt); }); it('throws if tx is dropped', async () => { - rpc.getTxReceipt.mockResolvedValue({ ...txReceipt, status: TxStatus.DROPPED } as TxReceipt); - rpc.getSyncStatus.mockResolvedValue({ blocks: 19, notes: { '0x1': 19, '0x2': 19 } }); + pxe.getTxReceipt.mockResolvedValue({ ...txReceipt, status: TxStatus.DROPPED } as TxReceipt); + pxe.getSyncStatus.mockResolvedValue({ blocks: 19, notes: { '0x1': 19, '0x2': 19 } }); await expect(sentTx.wait({ timeout: 1, interval: 0.4 })).rejects.toThrowError(/dropped/); }); }); diff --git a/yarn-project/aztec.js/src/contract/sent_tx.ts b/yarn-project/aztec.js/src/contract/sent_tx.ts index 4e3eedcb236..2cf092348f8 100644 --- a/yarn-project/aztec.js/src/contract/sent_tx.ts +++ b/yarn-project/aztec.js/src/contract/sent_tx.ts @@ -11,7 +11,7 @@ export type WaitOpts = { /** The time interval (in seconds) between retries to fetch the transaction receipt. Defaults to 1. */ interval?: number; /** - * Whether to wait for the RPC server to sync all notes up to the block in which this tx was mined. + * Whether to wait for the PXE Service to sync all notes up to the block in which this tx was mined. * If false, then any queries that depend on state set by this transaction may return stale data. Defaults to true. **/ waitForNotesSync?: boolean; @@ -92,7 +92,7 @@ export class SentTx { // If we don't care about waiting for notes to be synced, return the receipt const waitForNotesSync = opts?.waitForNotesSync ?? DefaultWaitOpts.waitForNotesSync; if (!waitForNotesSync) return txReceipt; - // Check if all sync blocks on the rpc server are greater or equal than the block in which the tx was mined + // Check if all sync blocks on the PXE Service are greater or equal than the block in which the tx was mined const { blocks, notes } = await this.arc.getSyncStatus(); const targetBlock = txReceipt.blockNumber!; const areNotesSynced = blocks >= targetBlock && every(notes, block => block >= targetBlock); diff --git a/yarn-project/aztec.js/src/contract_deployer/deploy_method.ts b/yarn-project/aztec.js/src/contract_deployer/deploy_method.ts index 1353d121f43..6713bec9711 100644 --- a/yarn-project/aztec.js/src/contract_deployer/deploy_method.ts +++ b/yarn-project/aztec.js/src/contract_deployer/deploy_method.ts @@ -60,7 +60,7 @@ export class DeployMethod extends Bas const portalContract = options.portalContract ?? EthAddress.ZERO; const contractAddressSalt = options.contractAddressSalt ?? Fr.random(); - const { chainId, protocolVersion } = await this.rpc.getNodeInfo(); + const { chainId, protocolVersion } = await this.pxe.getNodeInfo(); const { completeAddress, constructorHash, functionTreeRoot } = await getContractDeploymentInfo( this.abi, @@ -103,7 +103,7 @@ export class DeployMethod extends Bas this.completeAddress = completeAddress; // TODO: Should we add the contracts to the DB here, or once the tx has been sent or mined? - await this.rpc.addContracts([{ abi: this.abi, completeAddress, portalContract }]); + await this.pxe.addContracts([{ abi: this.abi, completeAddress, portalContract }]); return this.txRequest; } diff --git a/yarn-project/aztec.js/src/contract_deployer/deploy_sent_tx.ts b/yarn-project/aztec.js/src/contract_deployer/deploy_sent_tx.ts index f40cc63232f..8a138eb70a9 100644 --- a/yarn-project/aztec.js/src/contract_deployer/deploy_sent_tx.ts +++ b/yarn-project/aztec.js/src/contract_deployer/deploy_sent_tx.ts @@ -46,7 +46,7 @@ export class DeploySentTx extends Sen } protected getContractInstance(wallet?: Wallet, address?: AztecAddress): Promise { - const isWallet = (rpc: PXE | Wallet): rpc is Wallet => !!(rpc as Wallet).createTxExecutionRequest; + const isWallet = (pxe: PXE | Wallet): pxe is Wallet => !!(pxe as Wallet).createTxExecutionRequest; const contractWallet = wallet ?? (isWallet(this.arc) && this.arc); if (!contractWallet) throw new Error(`A wallet is required for creating a contract instance`); if (!address) throw new Error(`Contract address is missing from transaction receipt`); diff --git a/yarn-project/aztec.js/src/sandbox/index.ts b/yarn-project/aztec.js/src/sandbox/index.ts index 2d9fea54564..4a471adcc1c 100644 --- a/yarn-project/aztec.js/src/sandbox/index.ts +++ b/yarn-project/aztec.js/src/sandbox/index.ts @@ -22,25 +22,25 @@ export const { SANDBOX_URL = 'http://localhost:8080' } = process.env; /** * Gets a collection of wallets for the Aztec accounts that are initially stored in the sandbox. - * @param aztecRpc - A PXE instance.PXE + * @param pxe - A PXE instance. * @returns A set of AccountWallet implementations for each of the initial accounts. */ -export function getSandboxAccountsWallets(aztecRpc: PXE): Promise { +export function getSandboxAccountsWallets(pxe: PXE): Promise { return Promise.all( zip(INITIAL_SANDBOX_ENCRYPTION_KEYS, INITIAL_SANDBOX_SIGNING_KEYS, INITIAL_SANDBOX_SALTS).map( - ([encryptionKey, signingKey, salt]) => getSchnorrAccount(aztecRpc, encryptionKey!, signingKey!, salt).getWallet(), + ([encryptionKey, signingKey, salt]) => getSchnorrAccount(pxe, encryptionKey!, signingKey!, salt).getWallet(), ), ); } /** * Deploys the initial set of schnorr signature accounts to the sandbox - * @param aztecRpc - A PXE instance.PXE + * @param pxe - A PXE instance. * @returns The set of deployed Account objects and associated private encryption keys */ -export async function deployInitialSandboxAccounts(aztecRpc: PXE) { +export async function deployInitialSandboxAccounts(pxe: PXE) { const accounts = INITIAL_SANDBOX_ENCRYPTION_KEYS.map((privateKey, i) => { - const account = getSchnorrAccount(aztecRpc, privateKey, INITIAL_SANDBOX_SIGNING_KEYS[i], INITIAL_SANDBOX_SALTS[i]); + const account = getSchnorrAccount(pxe, privateKey, INITIAL_SANDBOX_SIGNING_KEYS[i], INITIAL_SANDBOX_SALTS[i]); return { account, privateKey, @@ -70,13 +70,13 @@ export async function deployInitialSandboxAccounts(aztecRpc: PXE) { /** * Function to wait until the sandbox becomes ready for use. - * @param rpc - The rpc client connected to the sandbox. + * @param pxe - The pxe client connected to the sandbox. */ -export async function waitForSandbox(rpc?: PXE) { - rpc = rpc ?? createPXEClient(SANDBOX_URL); +export async function waitForSandbox(pxe?: PXE) { + pxe = pxe ?? createPXEClient(SANDBOX_URL); while (true) { try { - await rpc.getNodeInfo(); + await pxe.getNodeInfo(); break; } catch (err) { await sleep(1000); diff --git a/yarn-project/aztec.js/src/utils/cheat_codes.ts b/yarn-project/aztec.js/src/utils/cheat_codes.ts index 865aec75158..32013adebe6 100644 --- a/yarn-project/aztec.js/src/utils/cheat_codes.ts +++ b/yarn-project/aztec.js/src/utils/cheat_codes.ts @@ -22,9 +22,9 @@ export class CheatCodes { public aztec: AztecCheatCodes, ) {} - static async create(rpcUrl: string, aztecRpc: PXE): Promise { + static async create(rpcUrl: string, pxe: PXE): Promise { const ethCheatCodes = new EthCheatCodes(rpcUrl); - const aztecCheatCodes = new AztecCheatCodes(aztecRpc, await CircuitsWasm.get(), ethCheatCodes); + const aztecCheatCodes = new AztecCheatCodes(pxe, await CircuitsWasm.get(), ethCheatCodes); return new CheatCodes(ethCheatCodes, aztecCheatCodes); } } @@ -35,7 +35,7 @@ export class CheatCodes { export class EthCheatCodes { constructor( /** - * The RPC client to use for interacting with the chain + * The RPC URL to use for interacting with the chain */ public rpcUrl: string, /** @@ -209,9 +209,9 @@ export class EthCheatCodes { export class AztecCheatCodes { constructor( /** - * The RPC client to use for interacting with the chain + * The PXE Service to use for interacting with the chain */ - public aztecRpc: PXE, + public pxe: PXE, /** * The circuits wasm module used for pedersen hashing */ @@ -248,7 +248,7 @@ export class AztecCheatCodes { * @returns The current block number */ public async blockNumber(): Promise { - return await this.aztecRpc.getBlockNumber(); + return await this.pxe.getBlockNumber(); } /** @@ -257,7 +257,7 @@ export class AztecCheatCodes { * @param to - The timestamp to set the next block to (must be greater than current time) */ public async warp(to: number): Promise { - const rollupContract = (await this.aztecRpc.getNodeInfo()).l1ContractAddresses.rollupAddress; + const rollupContract = (await this.pxe.getNodeInfo()).l1ContractAddresses.rollupAddress; await this.eth.setNextBlockTimestamp(to); // also store this time on the rollup contract (slot 1 tracks `lastBlockTs`). // This is because when the sequencer executes public functions, it uses the timestamp stored in the rollup contract. @@ -273,7 +273,7 @@ export class AztecCheatCodes { * @returns The value stored at the given slot */ public async loadPublic(who: AztecAddress, slot: Fr | bigint): Promise { - const storageValue = await this.aztecRpc.getPublicStorageAt(who, new Fr(slot)); + const storageValue = await this.pxe.getPublicStorageAt(who, new Fr(slot)); if (storageValue === undefined) { throw new Error(`Storage slot ${slot} not found`); } @@ -288,6 +288,6 @@ export class AztecCheatCodes { * @returns The notes stored at the given slot */ public loadPrivate(owner: AztecAddress, contract: AztecAddress, slot: Fr | bigint): Promise { - return this.aztecRpc.getPrivateStorageAt(owner, contract, new Fr(slot)); + return this.pxe.getPrivateStorageAt(owner, contract, new Fr(slot)); } } diff --git a/yarn-project/aztec.js/src/utils/l2_contracts.ts b/yarn-project/aztec.js/src/utils/l2_contracts.ts index 3f570597629..67fcdb2851b 100644 --- a/yarn-project/aztec.js/src/utils/l2_contracts.ts +++ b/yarn-project/aztec.js/src/utils/l2_contracts.ts @@ -3,10 +3,10 @@ import { PXE } from '@aztec/types'; /** * Checks whether a give contract is deployed on the network. - * @param aztecRpcClient - The PXE client to use to obtain the information. + * @param pxe - The PXE to use to obtain the information. * @param contractAddress - The address of the contract to check. * @returns A flag indicating whether the contract is deployed. */ -export async function isContractDeployed(aztecRpcClient: PXE, contractAddress: AztecAddress): Promise { - return !!(await aztecRpcClient.getContractData(contractAddress)); +export async function isContractDeployed(pxe: PXE, contractAddress: AztecAddress): Promise { + return !!(await pxe.getContractData(contractAddress)); } diff --git a/yarn-project/aztec.js/src/wallet/account_wallet.ts b/yarn-project/aztec.js/src/wallet/account_wallet.ts index d5888de9753..f51fb13307b 100644 --- a/yarn-project/aztec.js/src/wallet/account_wallet.ts +++ b/yarn-project/aztec.js/src/wallet/account_wallet.ts @@ -10,8 +10,8 @@ import { BaseWallet } from './base_wallet.js'; * A wallet implementation that forwards authentication requests to a provided account. */ export class AccountWallet extends BaseWallet { - constructor(rpc: PXE, protected account: AccountInterface) { - super(rpc); + constructor(pxe: PXE, protected account: AccountInterface) { + super(pxe); } createTxExecutionRequest(execs: FunctionCall[]): Promise { @@ -21,7 +21,7 @@ export class AccountWallet extends BaseWallet { async createAuthWitness(message: Fr | Buffer): Promise { message = Buffer.isBuffer(message) ? Fr.fromBuffer(message) : message; const witness = await this.account.createAuthWitness(message); - await this.rpc.addAuthWitness(witness); + await this.pxe.addAuthWitness(witness); return witness; } diff --git a/yarn-project/aztec.js/src/wallet/base_wallet.ts b/yarn-project/aztec.js/src/wallet/base_wallet.ts index f81a99f96bb..56cce1ea25c 100644 --- a/yarn-project/aztec.js/src/wallet/base_wallet.ts +++ b/yarn-project/aztec.js/src/wallet/base_wallet.ts @@ -24,7 +24,7 @@ import { Wallet } from './index.js'; * A base class for Wallet implementations */ export abstract class BaseWallet implements Wallet { - constructor(protected readonly rpc: PXE) {} + constructor(protected readonly pxe: PXE) {} abstract getCompleteAddress(): CompleteAddress; @@ -33,81 +33,81 @@ export abstract class BaseWallet implements Wallet { abstract createAuthWitness(message: Fr): Promise; registerAccount(privKey: GrumpkinPrivateKey, partialAddress: PartialAddress): Promise { - return this.rpc.registerAccount(privKey, partialAddress); + return this.pxe.registerAccount(privKey, partialAddress); } registerRecipient(account: CompleteAddress): Promise { - return this.rpc.registerRecipient(account); + return this.pxe.registerRecipient(account); } getRegisteredAccounts(): Promise { - return this.rpc.getRegisteredAccounts(); + return this.pxe.getRegisteredAccounts(); } getRegisteredAccount(address: AztecAddress): Promise { - return this.rpc.getRegisteredAccount(address); + return this.pxe.getRegisteredAccount(address); } getRecipients(): Promise { - return this.rpc.getRecipients(); + return this.pxe.getRecipients(); } getRecipient(address: AztecAddress): Promise { - return this.rpc.getRecipient(address); + return this.pxe.getRecipient(address); } addContracts(contracts: DeployedContract[]): Promise { - return this.rpc.addContracts(contracts); + return this.pxe.addContracts(contracts); } getContracts(): Promise { - return this.rpc.getContracts(); + return this.pxe.getContracts(); } simulateTx(txRequest: TxExecutionRequest, simulatePublic: boolean): Promise { - return this.rpc.simulateTx(txRequest, simulatePublic); + return this.pxe.simulateTx(txRequest, simulatePublic); } sendTx(tx: Tx): Promise { - return this.rpc.sendTx(tx); + return this.pxe.sendTx(tx); } getTx(txHash: TxHash): Promise { - return this.rpc.getTx(txHash); + return this.pxe.getTx(txHash); } getTxReceipt(txHash: TxHash): Promise { - return this.rpc.getTxReceipt(txHash); + return this.pxe.getTxReceipt(txHash); } getPrivateStorageAt(owner: AztecAddress, contract: AztecAddress, storageSlot: Fr): Promise { - return this.rpc.getPrivateStorageAt(owner, contract, storageSlot); + return this.pxe.getPrivateStorageAt(owner, contract, storageSlot); } getPublicStorageAt(contract: AztecAddress, storageSlot: Fr): Promise { - return this.rpc.getPublicStorageAt(contract, storageSlot); + return this.pxe.getPublicStorageAt(contract, storageSlot); } addNote(contract: AztecAddress, storageSlot: Fr, preimage: NotePreimage, nonce: Fr, account: Point): Promise { - return this.rpc.addNote(contract, storageSlot, preimage, nonce, account); + return this.pxe.addNote(contract, storageSlot, preimage, nonce, account); } getNoteNonces(contract: AztecAddress, storageSlot: Fr, preimage: NotePreimage, txHash: TxHash): Promise { - return this.rpc.getNoteNonces(contract, storageSlot, preimage, txHash); + return this.pxe.getNoteNonces(contract, storageSlot, preimage, txHash); } viewTx(functionName: string, args: any[], to: AztecAddress, from?: AztecAddress | undefined): Promise { - return this.rpc.viewTx(functionName, args, to, from); + return this.pxe.viewTx(functionName, args, to, from); } getExtendedContractData(contractAddress: AztecAddress): Promise { - return this.rpc.getExtendedContractData(contractAddress); + return this.pxe.getExtendedContractData(contractAddress); } getContractData(contractAddress: AztecAddress): Promise { - return this.rpc.getContractData(contractAddress); + return this.pxe.getContractData(contractAddress); } getUnencryptedLogs(from: number, limit: number): Promise { - return this.rpc.getUnencryptedLogs(from, limit); + return this.pxe.getUnencryptedLogs(from, limit); } getBlockNumber(): Promise { - return this.rpc.getBlockNumber(); + return this.pxe.getBlockNumber(); } getNodeInfo(): Promise { - return this.rpc.getNodeInfo(); + return this.pxe.getNodeInfo(); } isGlobalStateSynchronized() { - return this.rpc.isGlobalStateSynchronized(); + return this.pxe.isGlobalStateSynchronized(); } isAccountStateSynchronized(account: AztecAddress) { - return this.rpc.isAccountStateSynchronized(account); + return this.pxe.isAccountStateSynchronized(account); } getSyncStatus(): Promise { - return this.rpc.getSyncStatus(); + return this.pxe.getSyncStatus(); } addAuthWitness(authWitness: AuthWitness) { - return this.rpc.addAuthWitness(authWitness); + return this.pxe.addAuthWitness(authWitness); } } diff --git a/yarn-project/aztec.js/src/wallet/signerless_wallet.ts b/yarn-project/aztec.js/src/wallet/signerless_wallet.ts index 6de0eec702e..03368dd8611 100644 --- a/yarn-project/aztec.js/src/wallet/signerless_wallet.ts +++ b/yarn-project/aztec.js/src/wallet/signerless_wallet.ts @@ -15,7 +15,7 @@ export class SignerlessWallet extends BaseWallet { const [execution] = executions; const wasm = await CircuitsWasm.get(); const packedArguments = await PackedArguments.fromArgs(execution.args, wasm); - const { chainId, protocolVersion } = await this.rpc.getNodeInfo(); + const { chainId, protocolVersion } = await this.pxe.getNodeInfo(); const txContext = TxContext.empty(chainId, protocolVersion); return Promise.resolve( new TxExecutionRequest( From f00a6c21dbd31849d171469c002a435fe5924608 Mon Sep 17 00:00:00 2001 From: benesjan Date: Wed, 27 Sep 2023 13:57:49 +0000 Subject: [PATCH 16/23] WIP --- CHANGELOG.md | 2 +- yarn-project/aztec.js/README.md | 2 +- .../aztec.js/src/contract/contract.ts | 2 +- .../aztec.js/src/contract/contract_base.ts | 4 ++-- yarn-project/aztec.js/src/contract/sent_tx.ts | 12 +++++----- .../contract_deployer.test.ts | 14 ++++++------ .../contract_deployer/contract_deployer.ts | 6 ++--- .../src/contract_deployer/deploy_method.ts | 6 ++--- .../src/contract_deployer/deploy_sent_tx.ts | 2 +- yarn-project/aztec.js/src/sandbox/index.ts | 4 ++-- .../app/components/contract_function_form.tsx | 8 +++---- .../src/app/components/wallet_dropdown.tsx | 4 ++-- yarn-project/boxes/blank-react/src/config.ts | 2 +- .../src/scripts/deploy_contract.ts | 2 +- .../src/tests/blank.contract.test.ts | 16 +++++++------- yarn-project/boxes/blank/src/index.ts | 14 ++++++------ .../blank/src/tests/blank.contract.test.ts | 16 +++++++------- .../app/components/contract_function_form.tsx | 8 +++---- .../src/app/components/wallet_dropdown.tsx | 4 ++-- .../boxes/private-token/src/config.ts | 2 +- .../src/scripts/deploy_contract.ts | 2 +- .../src/tests/privatetoken.sandbox.test.ts | 22 +++++++++---------- yarn-project/cli/src/client.ts | 15 +++---------- yarn-project/cli/src/utils.ts | 7 +++--- 24 files changed, 83 insertions(+), 93 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 56efb0a7915..8ecf411908f 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1098,4 +1098,4 @@ ### Documentation * convert quick start guides into e2e tests ([#1726](https://github.com/AztecProtocol/aztec-packages/issues/1726)) ([802a678](https://github.com/AztecProtocol/aztec-packages/commit/802a678e3dd19339cd88b105a0ce341026b58054)), closes [#1564](https://github.com/AztecProtocol/aztec-packages/issues/1564) -* including "real" code in keys docs ([#1767](https://github.com/AztecProtocol/aztec-packages/issues/1767)) ([cd9cadb](https://github.com/AztecProtocol/aztec-packages/commit/cd9cadbfb6b0311c381586799588a5f64df98f29)) \ No newline at end of file +* including "real" code in keys docs ([#1767](https://github.com/AztecProtocol/aztec-packages/issues/1767)) ([cd9cadb](https://github.com/AztecProtocol/aztec-packages/commit/cd9cadbfb6b0311c381586799588a5f64df98f29)) diff --git a/yarn-project/aztec.js/README.md b/yarn-project/aztec.js/README.md index b3cc8e34374..14b0aa536dd 100644 --- a/yarn-project/aztec.js/README.md +++ b/yarn-project/aztec.js/README.md @@ -1,6 +1,6 @@ # Aztec.js -Aztec.js is a library that provides APIs for managing accounts and interacting with contracts on the Aztec network. It communicates with the [Private Execution Environment (PXE)](https://docs.aztec.network/apis/pxe/interfaces/PXE) through an `PXEClient` implementation, allowing developers to easily register new accounts, deploy contracts, view functions, and send transactions. +Aztec.js is a library that provides APIs for managing accounts and interacting with contracts on the Aztec network. It communicates with the [Private Execution Environment (PXE)](https://docs.aztec.network/apis/pxe/interfaces/PXE) through a `PXE` implementation, allowing developers to easily register new accounts, deploy contracts, view functions, and send transactions. ## Usage diff --git a/yarn-project/aztec.js/src/contract/contract.ts b/yarn-project/aztec.js/src/contract/contract.ts index a6e47552129..4fa1a4f9ff7 100644 --- a/yarn-project/aztec.js/src/contract/contract.ts +++ b/yarn-project/aztec.js/src/contract/contract.ts @@ -10,7 +10,7 @@ import { ContractBase } from './contract_base.js'; * The Contract class represents a contract and provides utility methods for interacting with it. * It enables the creation of ContractFunctionInteraction instances for each function in the contract's ABI, * allowing users to call or send transactions to these functions. Additionally, the Contract class can be used - * to attach the contract instance to a deployed contract on-chain through the PXEClient, which facilitates + * to attach the contract instance to a deployed contract on-chain through the PXE, which facilitates * interaction with Aztec's privacy protocol. */ export class Contract extends ContractBase { diff --git a/yarn-project/aztec.js/src/contract/contract_base.ts b/yarn-project/aztec.js/src/contract/contract_base.ts index 451e4b47185..b408d386bf5 100644 --- a/yarn-project/aztec.js/src/contract/contract_base.ts +++ b/yarn-project/aztec.js/src/contract/contract_base.ts @@ -74,12 +74,12 @@ export class ContractBase { /** * Attach the current contract instance to a portal contract and optionally add its dependencies. - * The function will return a promise that resolves when all contracts have been added to the PXEClient. + * The function will return a promise that resolves when all contracts have been added to the PXE. * This is useful when you need to interact with a deployed contract that has multiple nested contracts. * * @param portalContract - The Ethereum address of the portal contract. * @param dependencies - An optional array of additional DeployedContract instances to be attached. - * @returns A promise that resolves when all contracts are successfully added to the PXEClient. + * @returns A promise that resolves when all contracts are successfully added to the PXE. */ public attach(portalContract: EthAddress, dependencies: DeployedContract[] = []) { const deployedContract: DeployedContract = { diff --git a/yarn-project/aztec.js/src/contract/sent_tx.ts b/yarn-project/aztec.js/src/contract/sent_tx.ts index 2cf092348f8..9ab94c115e3 100644 --- a/yarn-project/aztec.js/src/contract/sent_tx.ts +++ b/yarn-project/aztec.js/src/contract/sent_tx.ts @@ -24,11 +24,11 @@ const DefaultWaitOpts: WaitOpts = { }; /** - * The SentTx class represents a sent transaction through the PXEClient, providing methods to fetch + * The SentTx class represents a sent transaction through the PXE, providing methods to fetch * its hash, receipt, and mining status. */ export class SentTx { - constructor(protected arc: PXE, protected txHashPromise: Promise) {} + constructor(protected pxe: PXE, protected txHashPromise: Promise) {} /** * Retrieves the transaction hash of the SentTx instance. @@ -43,13 +43,13 @@ export class SentTx { /** * Retrieve the transaction receipt associated with the current SentTx instance. * The function fetches the transaction hash using 'getTxHash' and then queries - * the PXEClient to get the corresponding transaction receipt. + * the PXE to get the corresponding transaction receipt. * * @returns A promise that resolves to a TxReceipt object representing the fetched transaction receipt. */ public async getReceipt(): Promise { const txHash = await this.getTxHash(); - return await this.arc.getTxReceipt(txHash); + return await this.pxe.getTxReceipt(txHash); } /** @@ -84,7 +84,7 @@ export class SentTx { const txHash = await this.getTxHash(); return await retryUntil( async () => { - const txReceipt = await this.arc.getTxReceipt(txHash); + const txReceipt = await this.pxe.getTxReceipt(txHash); // If receipt is not yet available, try again if (txReceipt.status === TxStatus.PENDING) return undefined; // If the tx was dropped, return it @@ -93,7 +93,7 @@ export class SentTx { const waitForNotesSync = opts?.waitForNotesSync ?? DefaultWaitOpts.waitForNotesSync; if (!waitForNotesSync) return txReceipt; // Check if all sync blocks on the PXE Service are greater or equal than the block in which the tx was mined - const { blocks, notes } = await this.arc.getSyncStatus(); + const { blocks, notes } = await this.pxe.getSyncStatus(); const targetBlock = txReceipt.blockNumber!; const areNotesSynced = blocks >= targetBlock && every(notes, block => block >= targetBlock); return areNotesSynced ? txReceipt : undefined; diff --git a/yarn-project/aztec.js/src/contract_deployer/contract_deployer.test.ts b/yarn-project/aztec.js/src/contract_deployer/contract_deployer.test.ts index 8a3b4d1be7e..a95e6c45b97 100644 --- a/yarn-project/aztec.js/src/contract_deployer/contract_deployer.test.ts +++ b/yarn-project/aztec.js/src/contract_deployer/contract_deployer.test.ts @@ -7,7 +7,7 @@ import { MockProxy, mock } from 'jest-mock-extended'; import { ContractDeployer } from './contract_deployer.js'; describe.skip('Contract Deployer', () => { - let arc: MockProxy; + let pxe: MockProxy; const abi: ContractAbi = { name: 'MyContract', @@ -33,13 +33,13 @@ describe.skip('Contract Deployer', () => { const mockTxReceipt = { type: 'TxReceipt' } as any as TxReceipt; beforeEach(() => { - arc = mock(); - arc.sendTx.mockResolvedValue(mockTxHash); - arc.getTxReceipt.mockResolvedValue(mockTxReceipt); + pxe = mock(); + pxe.sendTx.mockResolvedValue(mockTxHash); + pxe.getTxReceipt.mockResolvedValue(mockTxReceipt); }); it('should create and send a contract deployment tx', async () => { - const deployer = new ContractDeployer(abi, arc, publicKey); + const deployer = new ContractDeployer(abi, pxe, publicKey); const sentTx = deployer.deploy(args[0], args[1]).send({ portalContract, contractAddressSalt, @@ -49,7 +49,7 @@ describe.skip('Contract Deployer', () => { expect(txHash).toBe(mockTxHash); expect(receipt).toBe(mockTxReceipt); - expect(arc.sendTx).toHaveBeenCalledTimes(1); - expect(arc.sendTx).toHaveBeenCalledWith(mockTx); + expect(pxe.sendTx).toHaveBeenCalledTimes(1); + expect(pxe.sendTx).toHaveBeenCalledWith(mockTx); }); }); diff --git a/yarn-project/aztec.js/src/contract_deployer/contract_deployer.ts b/yarn-project/aztec.js/src/contract_deployer/contract_deployer.ts index b195e1da9f8..92ed8e23fc6 100644 --- a/yarn-project/aztec.js/src/contract_deployer/contract_deployer.ts +++ b/yarn-project/aztec.js/src/contract_deployer/contract_deployer.ts @@ -9,7 +9,7 @@ import { DeployMethod } from './deploy_method.js'; * @remarks Keeping this around even though we have Aztec.nr contract types because it can be useful for non-TS users. */ export class ContractDeployer { - constructor(private abi: ContractAbi, private arc: PXE, private publicKey?: PublicKey) {} + constructor(private abi: ContractAbi, private pxe: PXE, private publicKey?: PublicKey) {} /** * Deploy a contract using the provided ABI and constructor arguments. @@ -18,9 +18,9 @@ export class ContractDeployer { * be passed to the contract's constructor during deployment. * * @param args - The constructor arguments for the contract being deployed. - * @returns A DeployMethod instance configured with the ABI, PXEClient, and constructor arguments. + * @returns A DeployMethod instance configured with the ABI, PXE, and constructor arguments. */ public deploy(...args: any[]) { - return new DeployMethod(this.publicKey ?? Point.ZERO, this.arc, this.abi, args); + return new DeployMethod(this.publicKey ?? Point.ZERO, this.pxe, this.abi, args); } } diff --git a/yarn-project/aztec.js/src/contract_deployer/deploy_method.ts b/yarn-project/aztec.js/src/contract_deployer/deploy_method.ts index 6713bec9711..2cf6dbd9ad6 100644 --- a/yarn-project/aztec.js/src/contract_deployer/deploy_method.ts +++ b/yarn-project/aztec.js/src/contract_deployer/deploy_method.ts @@ -40,8 +40,8 @@ export class DeployMethod extends Bas /** Constructor function to call. */ private constructorAbi: FunctionAbi; - constructor(private publicKey: PublicKey, private arc: PXE, private abi: ContractAbi, private args: any[] = []) { - super(arc); + constructor(private publicKey: PublicKey, protected pxe: PXE, private abi: ContractAbi, private args: any[] = []) { + super(pxe); const constructorAbi = abi.functions.find(f => f.name === 'constructor'); if (!constructorAbi) throw new Error('Cannot find constructor in the ABI.'); this.constructorAbi = constructorAbi; @@ -118,7 +118,7 @@ export class DeployMethod extends Bas */ public send(options: DeployOptions = {}): DeploySentTx { const txHashPromise = super.send(options).getTxHash(); - return new DeploySentTx(this.abi, this.arc, txHashPromise); + return new DeploySentTx(this.abi, this.pxe, txHashPromise); } /** diff --git a/yarn-project/aztec.js/src/contract_deployer/deploy_sent_tx.ts b/yarn-project/aztec.js/src/contract_deployer/deploy_sent_tx.ts index 8a138eb70a9..a442f3bee3c 100644 --- a/yarn-project/aztec.js/src/contract_deployer/deploy_sent_tx.ts +++ b/yarn-project/aztec.js/src/contract_deployer/deploy_sent_tx.ts @@ -47,7 +47,7 @@ export class DeploySentTx extends Sen protected getContractInstance(wallet?: Wallet, address?: AztecAddress): Promise { const isWallet = (pxe: PXE | Wallet): pxe is Wallet => !!(pxe as Wallet).createTxExecutionRequest; - const contractWallet = wallet ?? (isWallet(this.arc) && this.arc); + const contractWallet = wallet ?? (isWallet(this.pxe) && this.pxe); if (!contractWallet) throw new Error(`A wallet is required for creating a contract instance`); if (!address) throw new Error(`Contract address is missing from transaction receipt`); return Contract.at(address, this.abi, contractWallet) as Promise; diff --git a/yarn-project/aztec.js/src/sandbox/index.ts b/yarn-project/aztec.js/src/sandbox/index.ts index 4a471adcc1c..e94cbca275c 100644 --- a/yarn-project/aztec.js/src/sandbox/index.ts +++ b/yarn-project/aztec.js/src/sandbox/index.ts @@ -22,7 +22,7 @@ export const { SANDBOX_URL = 'http://localhost:8080' } = process.env; /** * Gets a collection of wallets for the Aztec accounts that are initially stored in the sandbox. - * @param pxe - A PXE instance. + * @param pxe - PXE instance. * @returns A set of AccountWallet implementations for each of the initial accounts. */ export function getSandboxAccountsWallets(pxe: PXE): Promise { @@ -35,7 +35,7 @@ export function getSandboxAccountsWallets(pxe: PXE): Promise { /** * Deploys the initial set of schnorr signature accounts to the sandbox - * @param pxe - A PXE instance. + * @param pxe - PXE instance. * @returns The set of deployed Account objects and associated private encryption keys */ export async function deployInitialSandboxAccounts(pxe: PXE) { diff --git a/yarn-project/boxes/blank-react/src/app/components/contract_function_form.tsx b/yarn-project/boxes/blank-react/src/app/components/contract_function_form.tsx index 69916e7061e..7340fb5d9a7 100644 --- a/yarn-project/boxes/blank-react/src/app/components/contract_function_form.tsx +++ b/yarn-project/boxes/blank-react/src/app/components/contract_function_form.tsx @@ -3,7 +3,7 @@ import { AztecAddress, CompleteAddress, Fr } from '@aztec/aztec.js'; import { ContractAbi, FunctionAbi } from '@aztec/foundation/abi'; import { useFormik } from 'formik'; import * as Yup from 'yup'; -import { CONTRACT_ADDRESS_PARAM_NAMES, rpcClient } from '../../config.js'; +import { CONTRACT_ADDRESS_PARAM_NAMES, pxe } from '../../config.js'; import { callContractFunction, deployContract, viewContractFunction } from '../../scripts/index.js'; import { convertArgs } from '../../scripts/util.js'; import styles from './contract_function_form.module.scss'; @@ -80,18 +80,18 @@ async function handleFunctionCall( // for now, dont let user change the salt. requires some change to the form generation if we want to let user choose one // since everything is currently based on parsing the contractABI, and the salt parameter is not present there const salt = Fr.random(); - return await deployContract(wallet, contractAbi, typedArgs, salt, rpcClient); + return await deployContract(wallet, contractAbi, typedArgs, salt, pxe); } if (functionAbi.functionType === 'unconstrained') { - return await viewContractFunction(contractAddress!, contractAbi, functionName, typedArgs, rpcClient, wallet); + return await viewContractFunction(contractAddress!, contractAbi, functionName, typedArgs, pxe, wallet); } else { const txnReceipt = await callContractFunction( contractAddress!, contractAbi, functionName, typedArgs, - rpcClient, + pxe, wallet, ); return `Transaction ${txnReceipt.status} on block number ${txnReceipt.blockNumber}`; diff --git a/yarn-project/boxes/blank-react/src/app/components/wallet_dropdown.tsx b/yarn-project/boxes/blank-react/src/app/components/wallet_dropdown.tsx index 131dc2c8d72..852ae9ffcb4 100644 --- a/yarn-project/boxes/blank-react/src/app/components/wallet_dropdown.tsx +++ b/yarn-project/boxes/blank-react/src/app/components/wallet_dropdown.tsx @@ -1,7 +1,7 @@ import { Loader } from '@aztec/aztec-ui'; import { CompleteAddress } from '@aztec/aztec.js'; import { useEffect, useState } from 'react'; -import { rpcClient } from '../../config.js'; +import { pxe } from '../../config.js'; import { Select } from './select.js'; import styles from './wallet_dropdown.module.scss'; import { Copy } from './copy.js'; @@ -20,7 +20,7 @@ export function WalletDropdown({ selected, onSelectChange, onError }: Props) { return; } const loadOptions = async () => { - const fetchedOptions = await rpcClient.getRegisteredAccounts(); + const fetchedOptions = await pxe.getRegisteredAccounts(); setOptions(fetchedOptions); onSelectChange(fetchedOptions[0]); }; diff --git a/yarn-project/boxes/blank-react/src/config.ts b/yarn-project/boxes/blank-react/src/config.ts index 79ce241a04b..2c406a9302b 100644 --- a/yarn-project/boxes/blank-react/src/config.ts +++ b/yarn-project/boxes/blank-react/src/config.ts @@ -7,7 +7,7 @@ import { ContractAbi } from '@aztec/foundation/abi'; export const contractAbi: ContractAbi = BlankContractAbi; export const SANDBOX_URL: string = process.env.SANDBOX_URL || 'http://localhost:8080'; -export const rpcClient: PXE = createPXEClient(SANDBOX_URL); +export const pxe: PXE = createPXEClient(SANDBOX_URL); export const CONTRACT_ADDRESS_PARAM_NAMES = ['address']; export const FILTERED_FUNCTION_NAMES = []; diff --git a/yarn-project/boxes/blank-react/src/scripts/deploy_contract.ts b/yarn-project/boxes/blank-react/src/scripts/deploy_contract.ts index 36a9e9c300b..ed6ca31dd32 100644 --- a/yarn-project/boxes/blank-react/src/scripts/deploy_contract.ts +++ b/yarn-project/boxes/blank-react/src/scripts/deploy_contract.ts @@ -7,7 +7,7 @@ export async function deployContract( contractAbi: ContractAbi, typedArgs: Fr[], // encode prior to passing in salt: Fr, - client: PXE, + pxe: PXE, ): Promise { const tx = new DeployMethod(activeWallet.publicKey, client, contractAbi, typedArgs).send({ contractAddressSalt: salt, diff --git a/yarn-project/boxes/blank-react/src/tests/blank.contract.test.ts b/yarn-project/boxes/blank-react/src/tests/blank.contract.test.ts index 1aa055bfbb6..7f1eed6e2c8 100644 --- a/yarn-project/boxes/blank-react/src/tests/blank.contract.test.ts +++ b/yarn-project/boxes/blank-react/src/tests/blank.contract.test.ts @@ -26,9 +26,9 @@ const setupSandbox = async () => { return pxe; }; -async function deployZKContract(owner: CompleteAddress, wallet: Wallet, rpcClient: PXE) { +async function deployZKContract(owner: CompleteAddress, wallet: Wallet, pxe: PXE) { logger('Deploying Blank contract...'); - const contractAddress = await deployContract(owner, BlankContract.abi, [], Fr.random(), rpcClient); + const contractAddress = await deployContract(owner, BlankContract.abi, [], Fr.random(), pxe); logger(`L2 contract deployed at ${contractAddress}`); return BlankContract.at(contractAddress, wallet); @@ -41,16 +41,16 @@ describe('ZK Contract Tests', () => { let _account3: CompleteAddress; let contract: Contract; let contractAddress: AztecAddress; - let rpcClient: PXE; + let pxe: PXE; beforeAll(async () => { - rpcClient = await setupSandbox(); - const accounts = await rpcClient.getRegisteredAccounts(); + pxe = await setupSandbox(); + const accounts = await pxe.getRegisteredAccounts(); [owner, _account2, _account3] = accounts; - wallet = await getWallet(owner, rpcClient); + wallet = await getWallet(owner, pxe); - contract = await deployZKContract(owner, wallet, rpcClient); + contract = await deployZKContract(owner, wallet, pxe); contractAddress = contract.address; }, 60000); @@ -60,7 +60,7 @@ describe('ZK Contract Tests', () => { contract.abi, 'getPublicKey', [owner.address.toField()], - rpcClient, + pxe, owner, ); diff --git a/yarn-project/boxes/blank/src/index.ts b/yarn-project/boxes/blank/src/index.ts index e5e73415a60..81e54fe4fcf 100644 --- a/yarn-project/boxes/blank/src/index.ts +++ b/yarn-project/boxes/blank/src/index.ts @@ -16,7 +16,7 @@ import { BlankContractAbi } from './artifacts/blank.js'; export const contractAbi: ContractAbi = BlankContractAbi; export const SANDBOX_URL: string = process.env.SANDBOX_URL || 'http://localhost:8080'; -export const rpcClient: PXE = createPXEClient(SANDBOX_URL); +export const pxe: PXE = createPXEClient(SANDBOX_URL); export const CONTRACT_ADDRESS_PARAM_NAMES = ['owner', 'contract_address', 'recipient']; export const FILTERED_FUNCTION_NAMES = []; @@ -40,21 +40,21 @@ if (typeof document !== 'undefined') { export async function handleDeployClick(): Promise { console.log('Deploying Contract'); - const [wallet, ..._rest] = await getSandboxAccountsWallets(rpcClient); + const [wallet, ..._rest] = await getSandboxAccountsWallets(pxe); const contractAztecAddress = await deployContract( wallet.getCompleteAddress(), contractAbi, [], Fr.random(), - rpcClient, + pxe, ); return contractAztecAddress.toString(); } export async function handleInteractClick(contractAddress: string) { - const [wallet, ..._rest] = await getSandboxAccountsWallets(rpcClient); + const [wallet, ..._rest] = await getSandboxAccountsWallets(pxe); const callArgs = { address: wallet.getCompleteAddress().address }; const getPkAbi = getFunctionAbi(BlankContractAbi, 'getPublicKey'); const typedArgs = convertArgs(getPkAbi, callArgs); @@ -65,7 +65,7 @@ export async function handleInteractClick(contractAddress: string) { contractAbi, 'getPublicKey', typedArgs, - rpcClient, + pxe, wallet.getCompleteAddress(), ); } @@ -117,9 +117,9 @@ export async function deployContract( contractAbi: ContractAbi, typedArgs: Fr[], // encode prior to passing in salt: Fr, - client: PXE, + pxe: PXE, ): Promise { - const tx = new DeployMethod(activeWallet.publicKey, client, contractAbi, typedArgs).send({ + const tx = new DeployMethod(activeWallet.publicKey, pxe, contractAbi, typedArgs).send({ contractAddressSalt: salt, }); await tx.wait(); diff --git a/yarn-project/boxes/blank/src/tests/blank.contract.test.ts b/yarn-project/boxes/blank/src/tests/blank.contract.test.ts index c892b2e9511..883ef265369 100644 --- a/yarn-project/boxes/blank/src/tests/blank.contract.test.ts +++ b/yarn-project/boxes/blank/src/tests/blank.contract.test.ts @@ -24,9 +24,9 @@ const setupSandbox = async () => { return pxe; }; -async function deployZKContract(owner: CompleteAddress, wallet: Wallet, rpcClient: PXE) { +async function deployZKContract(owner: CompleteAddress, wallet: Wallet, pxe: PXE) { logger('Deploying Blank contract...'); - const contractAddress = await deployContract(owner, BlankContract.abi, [], Fr.random(), rpcClient); + const contractAddress = await deployContract(owner, BlankContract.abi, [], Fr.random(), pxe); logger(`L2 contract deployed at ${contractAddress}`); return BlankContract.at(contractAddress, wallet); @@ -39,16 +39,16 @@ describe('ZK Contract Tests', () => { let _account3: CompleteAddress; let contract: Contract; let contractAddress: AztecAddress; - let rpcClient: PXE; + let pxe: PXE; beforeAll(async () => { - rpcClient = await setupSandbox(); - const accounts = await rpcClient.getRegisteredAccounts(); + pxe = await setupSandbox(); + const accounts = await pxe.getRegisteredAccounts(); [owner, _account2, _account3] = accounts; - wallet = await getWallet(owner, rpcClient); + wallet = await getWallet(owner, pxe); - contract = await deployZKContract(owner, wallet, rpcClient); + contract = await deployZKContract(owner, wallet, pxe); contractAddress = contract.address; }, 60000); @@ -58,7 +58,7 @@ describe('ZK Contract Tests', () => { contract.abi, 'getPublicKey', [owner.address.toField()], - rpcClient, + pxe, owner, ); expect(callTxReceipt.status).toBe(TxStatus.MINED); diff --git a/yarn-project/boxes/private-token/src/app/components/contract_function_form.tsx b/yarn-project/boxes/private-token/src/app/components/contract_function_form.tsx index 6cd27644e19..701dec89f72 100644 --- a/yarn-project/boxes/private-token/src/app/components/contract_function_form.tsx +++ b/yarn-project/boxes/private-token/src/app/components/contract_function_form.tsx @@ -1,4 +1,4 @@ -import { CONTRACT_ADDRESS_PARAM_NAMES, rpcClient } from '../../config.js'; +import { CONTRACT_ADDRESS_PARAM_NAMES, pxe } from '../../config.js'; import { callContractFunction, deployContract, viewContractFunction } from '../../scripts/index.js'; import { convertArgs } from '../../scripts/util.js'; import styles from './contract_function_form.module.scss'; @@ -80,18 +80,18 @@ async function handleFunctionCall( // for now, dont let user change the salt. requires some change to the form generation if we want to let user choose one // since everything is currently based on parsing the contractABI, and the salt parameter is not present there const salt = Fr.random(); - return await deployContract(wallet, contractAbi, typedArgs, salt, rpcClient); + return await deployContract(wallet, contractAbi, typedArgs, salt, pxe); } if (functionAbi.functionType === 'unconstrained') { - return await viewContractFunction(contractAddress!, contractAbi, functionName, typedArgs, rpcClient, wallet); + return await viewContractFunction(contractAddress!, contractAbi, functionName, typedArgs, pxe, wallet); } else { const txnReceipt = await callContractFunction( contractAddress!, contractAbi, functionName, typedArgs, - rpcClient, + pxe, wallet, ); return `Transaction ${txnReceipt.status} on block number ${txnReceipt.blockNumber}`; diff --git a/yarn-project/boxes/private-token/src/app/components/wallet_dropdown.tsx b/yarn-project/boxes/private-token/src/app/components/wallet_dropdown.tsx index 90daa98665f..28cba3e570a 100644 --- a/yarn-project/boxes/private-token/src/app/components/wallet_dropdown.tsx +++ b/yarn-project/boxes/private-token/src/app/components/wallet_dropdown.tsx @@ -1,4 +1,4 @@ -import { rpcClient } from '../../config.js'; +import { pxe } from '../../config.js'; import { Copy } from './copy.js'; import { Select } from './select.js'; import styles from './wallet_dropdown.module.scss'; @@ -20,7 +20,7 @@ export function WalletDropdown({ selected, onSelectChange, onError }: Props) { return; } const loadOptions = async () => { - const fetchedOptions = await rpcClient.getRegisteredAccounts(); + const fetchedOptions = await pxe.getRegisteredAccounts(); setOptions(fetchedOptions); onSelectChange(fetchedOptions[0]); }; diff --git a/yarn-project/boxes/private-token/src/config.ts b/yarn-project/boxes/private-token/src/config.ts index b8f0f1507be..074f5eea5fa 100644 --- a/yarn-project/boxes/private-token/src/config.ts +++ b/yarn-project/boxes/private-token/src/config.ts @@ -7,7 +7,7 @@ import { ContractAbi } from '@aztec/foundation/abi'; export const contractAbi: ContractAbi = PrivateTokenContractAbi; export const SANDBOX_URL: string = process.env.SANDBOX_URL || 'http://localhost:8080'; -export const rpcClient: PXE = createPXEClient(SANDBOX_URL); +export const pxe: PXE = createPXEClient(SANDBOX_URL); export const CONTRACT_ADDRESS_PARAM_NAMES = ['owner', 'contract_address', 'recipient']; export const FILTERED_FUNCTION_NAMES = ['compute_note_hash_and_nullifier']; diff --git a/yarn-project/boxes/private-token/src/scripts/deploy_contract.ts b/yarn-project/boxes/private-token/src/scripts/deploy_contract.ts index 36a9e9c300b..ed6ca31dd32 100644 --- a/yarn-project/boxes/private-token/src/scripts/deploy_contract.ts +++ b/yarn-project/boxes/private-token/src/scripts/deploy_contract.ts @@ -7,7 +7,7 @@ export async function deployContract( contractAbi: ContractAbi, typedArgs: Fr[], // encode prior to passing in salt: Fr, - client: PXE, + pxe: PXE, ): Promise { const tx = new DeployMethod(activeWallet.publicKey, client, contractAbi, typedArgs).send({ contractAddressSalt: salt, diff --git a/yarn-project/boxes/private-token/src/tests/privatetoken.sandbox.test.ts b/yarn-project/boxes/private-token/src/tests/privatetoken.sandbox.test.ts index 3580cd45442..230f0bf51e0 100644 --- a/yarn-project/boxes/private-token/src/tests/privatetoken.sandbox.test.ts +++ b/yarn-project/boxes/private-token/src/tests/privatetoken.sandbox.test.ts @@ -1,5 +1,5 @@ import { PrivateTokenContract } from '../artifacts/private_token.js'; -import { rpcClient } from '../config.js'; +import { pxe } from '../config.js'; import { callContractFunction, deployContract, getWallet, viewContractFunction } from '../scripts/index.js'; import { AccountWallet, @@ -29,11 +29,11 @@ const setupSandbox = async () => { return pxe; }; -async function deployZKContract(owner: CompleteAddress, wallet: Wallet, rpcClient: PXE) { +async function deployZKContract(owner: CompleteAddress, wallet: Wallet, pxe: PXE) { logger('Deploying PrivateToken contract...'); const typedArgs = [new Fr(INITIAL_BALANCE), owner.address.toField()]; - const contractAddress = await deployContract(owner, PrivateTokenContract.abi, typedArgs, Fr.random(), rpcClient); + const contractAddress = await deployContract(owner, PrivateTokenContract.abi, typedArgs, Fr.random(), pxe); logger(`L2 contract deployed at ${contractAddress}`); return PrivateTokenContract.at(contractAddress, wallet); @@ -47,7 +47,7 @@ async function getBalance(contractAddress: AztecAddress, privateTokenContract: C privateTokenContract.abi, 'getBalance', typedArgs, - rpcClient, + pxe, owner, ); } @@ -61,7 +61,7 @@ async function mint( ) { const typedArgs = [new Fr(amount), to.address.toField()]; - return await callContractFunction(contractAddress, privateTokenContract.abi, 'mint', typedArgs, rpcClient, from); + return await callContractFunction(contractAddress, privateTokenContract.abi, 'mint', typedArgs, pxe, from); } async function transfer( @@ -73,7 +73,7 @@ async function transfer( ) { const typedArgs = [new Fr(amount), to.address.toField()]; - return await callContractFunction(contractAddress, privateTokenContract.abi, 'transfer', typedArgs, rpcClient, from); + return await callContractFunction(contractAddress, privateTokenContract.abi, 'transfer', typedArgs, pxe, from); } describe('ZK Contract Tests', () => { @@ -83,16 +83,16 @@ describe('ZK Contract Tests', () => { let _account3: CompleteAddress; let privateTokenContract: Contract; let contractAddress: AztecAddress; - let rpcClient: PXE; + let pxe: PXE; beforeAll(async () => { - rpcClient = await setupSandbox(); - const accounts = await rpcClient.getRegisteredAccounts(); + pxe = await setupSandbox(); + const accounts = await pxe.getRegisteredAccounts(); [owner, account2, _account3] = accounts; - wallet = await getWallet(owner, rpcClient); + wallet = await getWallet(owner, pxe); - privateTokenContract = await deployZKContract(owner, wallet, rpcClient); + privateTokenContract = await deployZKContract(owner, wallet, pxe); contractAddress = privateTokenContract.address; }, 60000); diff --git a/yarn-project/cli/src/client.ts b/yarn-project/cli/src/client.ts index 19c588b5936..c30b129419f 100644 --- a/yarn-project/cli/src/client.ts +++ b/yarn-project/cli/src/client.ts @@ -6,15 +6,6 @@ import { readFileSync } from 'fs'; import { dirname, resolve } from 'path'; import { gtr, ltr, satisfies, valid } from 'semver'; -/** - * Creates a PXE client with a given set of retries on non-server errors. - * @param rpcUrl - URL of the RPC server wrapping the PXE. - * @returns A PXE client. - */ -export function createClient(rpcUrl: string) { - return createPXEClient(rpcUrl); -} - /** * Creates a PXE client with a given set of retries on non-server errors. * Checks that PXE matches the expected version, and warns if not. @@ -23,13 +14,13 @@ export function createClient(rpcUrl: string) { * @returns A PXE client. */ export async function createCompatibleClient(rpcUrl: string, logger: DebugLogger) { - const client = createClient(rpcUrl); + const pxe = createPXEClient(rpcUrl); const packageJsonPath = resolve(dirname(fileURLToPath(import.meta.url)), '../package.json'); const packageJsonContents = JSON.parse(readFileSync(packageJsonPath).toString()); const expectedVersionRange = packageJsonContents.version; // During sandbox, we'll expect exact matches try { - await checkServerVersion(client, expectedVersionRange); + await checkServerVersion(pxe, expectedVersionRange); } catch (err) { if (err instanceof VersionMismatchError) { logger.warn(err.message); @@ -38,7 +29,7 @@ export async function createCompatibleClient(rpcUrl: string, logger: DebugLogger } } - return client; + return pxe; } /** Mismatch between server and client versions. */ diff --git a/yarn-project/cli/src/utils.ts b/yarn-project/cli/src/utils.ts index 2aec1e854c1..38d54da538d 100644 --- a/yarn-project/cli/src/utils.ts +++ b/yarn-project/cli/src/utils.ts @@ -21,7 +21,6 @@ import { mnemonicToAccount, privateKeyToAccount } from 'viem/accounts'; import { encodeArgs } from './encoding.js'; -export { createClient } from './client.js'; /** * Helper type to dynamically import contracts. */ @@ -126,11 +125,11 @@ export async function getContractAbi(fileDir: string, log: LogFn) { /** * Utility to select a TX sender either from user input * or from the first account that is found in an PXE instance. - * @param client - The PXE instance that will be checked for an account. + * @param pxe - The PXE instance that will be checked for an account. * @param _from - The user input. * @returns An Aztec address. Will throw if one can't be found in either options. */ -export async function getTxSender(client: PXE, _from?: string) { +export async function getTxSender(pxe: PXE, _from?: string) { let from: AztecAddress; if (_from) { try { @@ -139,7 +138,7 @@ export async function getTxSender(client: PXE, _from?: string) { throw new Error(`Invalid option 'from' passed: ${_from}`); } } else { - const accounts = await client.getRegisteredAccounts(); + const accounts = await pxe.getRegisteredAccounts(); if (!accounts.length) { throw new Error('No accounts found in PXE instance.'); } From e5e5414d81d4a403295d90bd279d7d071d4f932b Mon Sep 17 00:00:00 2001 From: benesjan Date: Wed, 27 Sep 2023 14:08:56 +0000 Subject: [PATCH 17/23] WIP --- .../examples/uniswap_trade_on_l1_from_l2.ts | 32 +++++++++---------- yarn-project/canary/src/cli.test.ts | 6 ++-- .../src/uniswap_trade_on_l1_from_l2.test.ts | 8 ++--- yarn-project/cli/README.md | 30 ++++++++--------- yarn-project/cli/src/utils.ts | 2 +- yarn-project/end-to-end/src/canary/cli.ts | 12 +++---- 6 files changed, 45 insertions(+), 45 deletions(-) diff --git a/yarn-project/aztec-sandbox/src/examples/uniswap_trade_on_l1_from_l2.ts b/yarn-project/aztec-sandbox/src/examples/uniswap_trade_on_l1_from_l2.ts index dd1d0cb058e..2f2a05b6173 100644 --- a/yarn-project/aztec-sandbox/src/examples/uniswap_trade_on_l1_from_l2.ts +++ b/yarn-project/aztec-sandbox/src/examples/uniswap_trade_on_l1_from_l2.ts @@ -55,7 +55,7 @@ if (Number(await publicClient.getBlockNumber()) < EXPECTED_FORKED_BLOCK) { const ethAccount = EthAddress.fromString((await walletClient.getAddresses())[0]); -const pxeClient = createPXEClient(pxeRpcUrl); +const pxe = createPXEClient(pxeRpcUrl); let wallet: AccountWallet; /** @@ -108,7 +108,7 @@ async function deployAllContracts(owner: AztecAddress) { }); // deploy l2 uniswap contract and attach to portal - const tx = UniswapContract.deploy(pxeClient).send({ portalContract: uniswapPortalAddress }); + const tx = UniswapContract.deploy(pxe).send({ portalContract: uniswapPortalAddress }); await tx.isMined({ interval: 0.5 }); const receipt = await tx.getReceipt(); const uniswapL2Contract = await UniswapContract.at(receipt.contractAddress!, wallet); @@ -132,22 +132,22 @@ async function deployAllContracts(owner: AztecAddress) { }; } -const getL2BalanceOf = async (pxeClient: PXE, owner: AztecAddress, l2Contract: NonNativeTokenContract) => { +const getL2BalanceOf = async (pxe: PXE, owner: AztecAddress, l2Contract: NonNativeTokenContract) => { return await l2Contract.methods.getBalance(owner).view({ from: owner }); }; const logExpectedBalanceOnL2 = async ( - pxeClient: PXE, + pxe: PXE, owner: AztecAddress, expectedBalance: bigint, l2Contract: NonNativeTokenContract, ) => { - const balance = await getL2BalanceOf(pxeClient, owner, l2Contract); + const balance = await getL2BalanceOf(pxe, owner, l2Contract); logger(`Account ${owner} balance: ${balance}. Expected to be: ${expectedBalance}`); }; const transferWethOnL2 = async ( - _pxeClient: PXE, + _pxe: PXE, wethL2Contract: NonNativeTokenContract, ownerAddress: AztecAddress, receiver: AztecAddress, @@ -166,9 +166,9 @@ const transferWethOnL2 = async ( async function main() { logger('Running L1/L2 messaging test on HTTP interface.'); - wallet = await getUnsafeSchnorrAccount(pxeClient, privateKey).waitDeploy(); + wallet = await getUnsafeSchnorrAccount(pxe, privateKey).waitDeploy(); const owner = wallet.getCompleteAddress(); - const receiver = await createRecipient(pxeClient); + const receiver = await createRecipient(pxe); const result = await deployAllContracts(owner.address); const { @@ -213,7 +213,7 @@ async function main() { await delay(5000); // send a transfer tx to force through rollup with the message included const transferAmount = 1n; - await transferWethOnL2(pxeClient, wethL2Contract, owner.address, receiver.address, transferAmount); + await transferWethOnL2(pxe, wethL2Contract, owner.address, receiver.address, transferAmount); // 3. Claim WETH on L2 logger('Minting weth on L2'); @@ -228,8 +228,8 @@ async function main() { // await expectBalanceOnL2(ownerAddress, wethAmountToBridge + initialBalance - transferAmount, wethL2Contract); // Store balances - const wethBalanceBeforeSwap = await getL2BalanceOf(pxeClient, owner.address, wethL2Contract); - const daiBalanceBeforeSwap = await getL2BalanceOf(pxeClient, owner.address, daiL2Contract); + const wethBalanceBeforeSwap = await getL2BalanceOf(pxe, owner.address, wethL2Contract); + const daiBalanceBeforeSwap = await getL2BalanceOf(pxe, owner.address, daiL2Contract); // 4. Send L2 to L1 message to withdraw funds and another message to swap assets. logger('Send L2 tx to withdraw WETH to uniswap portal and send message to swap assets on L1'); @@ -257,7 +257,7 @@ async function main() { logger(`Withdraw receipt status: ${withdrawReceipt.status} should be ${TxStatus.MINED}`); // check weth balance of owner on L2 (we first bridged `wethAmountToBridge` into L2 and now withdrew it!) - await logExpectedBalanceOnL2(pxeClient, owner.address, INITIAL_BALANCE - transferAmount, wethL2Contract); + await logExpectedBalanceOnL2(pxe, owner.address, INITIAL_BALANCE - transferAmount, wethL2Contract); // 5. Consume L2 to L1 message by calling uniswapPortal.swap() logger('Execute withdraw and swap on the uniswapPortal!'); @@ -294,7 +294,7 @@ async function main() { // Wait for the archiver to process the message await delay(5000); // send a transfer tx to force through rollup with the message included - await transferWethOnL2(pxeClient, wethL2Contract, owner.address, receiver.address, transferAmount); + await transferWethOnL2(pxe, wethL2Contract, owner.address, receiver.address, transferAmount); // 6. claim dai on L2 logger('Consuming messages to mint dai on L2'); @@ -306,10 +306,10 @@ async function main() { const daiMintTxReceipt = await daiMintTx.getReceipt(); // expect(daiMintTxReceipt.status).toBe(TxStatus.MINED); logger(`DAI mint TX status: ${daiMintTxReceipt.status} should be ${TxStatus.MINED}`); - await logExpectedBalanceOnL2(pxeClient, owner.address, INITIAL_BALANCE + BigInt(daiAmountToBridge), daiL2Contract); + await logExpectedBalanceOnL2(pxe, owner.address, INITIAL_BALANCE + BigInt(daiAmountToBridge), daiL2Contract); - const wethBalanceAfterSwap = await getL2BalanceOf(pxeClient, owner.address, wethL2Contract); - const daiBalanceAfterSwap = await getL2BalanceOf(pxeClient, owner.address, daiL2Contract); + const wethBalanceAfterSwap = await getL2BalanceOf(pxe, owner.address, wethL2Contract); + const daiBalanceAfterSwap = await getL2BalanceOf(pxe, owner.address, daiL2Contract); logger('WETH balance before swap: ', wethBalanceBeforeSwap.toString()); logger('DAI balance before swap : ', daiBalanceBeforeSwap.toString()); diff --git a/yarn-project/canary/src/cli.test.ts b/yarn-project/canary/src/cli.test.ts index cd347c6cbd7..a7fef24cc07 100644 --- a/yarn-project/canary/src/cli.test.ts +++ b/yarn-project/canary/src/cli.test.ts @@ -6,9 +6,9 @@ const { SANDBOX_URL = 'http://localhost:8080' } = process.env; const debug = createDebugLogger('aztec:canary_cli'); const setupRPC = async () => { - const pxeClient = createPXEClient(SANDBOX_URL, makeFetch([1, 2, 3, 4, 5], true)); - await waitForSandbox(pxeClient); - return pxeClient; + const pxe = createPXEClient(SANDBOX_URL, makeFetch([1, 2, 3, 4, 5], true)); + await waitForSandbox(pxe); + return pxe; }; cliTestSuite('CLI Canary', setupRPC, () => Promise.resolve(), debug, SANDBOX_URL); diff --git a/yarn-project/canary/src/uniswap_trade_on_l1_from_l2.test.ts b/yarn-project/canary/src/uniswap_trade_on_l1_from_l2.test.ts index cf44d6914a5..f53765b96eb 100644 --- a/yarn-project/canary/src/uniswap_trade_on_l1_from_l2.test.ts +++ b/yarn-project/canary/src/uniswap_trade_on_l1_from_l2.test.ts @@ -50,7 +50,7 @@ const ethRpcUrl = ETHEREUM_HOST; const hdAccount = mnemonicToAccount(MNEMONIC); -const pxeClient = createPXEClient(pxeRpcUrl); +const pxe = createPXEClient(pxeRpcUrl); let wallet: Wallet; /** @@ -107,7 +107,7 @@ async function deployAllContracts( }); // deploy l2 uniswap contract and attach to portal - const tx = UniswapContract.deploy(pxeClient).send({ + const tx = UniswapContract.deploy(pxe).send({ portalContract: uniswapPortalAddress, }); await tx.isMined(); @@ -163,7 +163,7 @@ describe.skip('uniswap_trade_on_l1_from_l2', () => { let publicClient: PublicClient; let walletClient: WalletClient; beforeAll(async () => { - await waitForSandbox(pxeClient); + await waitForSandbox(pxe); walletClient = createWalletClient({ account: hdAccount, @@ -184,7 +184,7 @@ describe.skip('uniswap_trade_on_l1_from_l2', () => { it('should uniswap trade on L1 from L2 funds privately (swaps WETH -> DAI)', async () => { logger('Running L1/L2 messaging test on HTTP interface.'); - [wallet] = await getSandboxAccountsWallets(pxeClient); + [wallet] = await getSandboxAccountsWallets(pxe); const accounts = await wallet.getRegisteredAccounts(); const owner = accounts[0].address; const receiver = accounts[1].address; diff --git a/yarn-project/cli/README.md b/yarn-project/cli/README.md index c9dd1adb0d3..8b30b9c72f2 100644 --- a/yarn-project/cli/README.md +++ b/yarn-project/cli/README.md @@ -43,7 +43,7 @@ These options are: - `PRIVATE_KEY` -> `-k, --private-key` for all commands that require a private key. - `PUBLIC_KEY` -> `-k, --public-key` for all commands that require a public key. -- `PXE_HOST` -> `-u, --rpc-url` for commands that require an PXE +- `PXE_HOST` -> `-u, --rpc-url` for commands that require a PXE - `API_KEY` -> `a, --api-key` for `deploy-l1-contracts`. - `ETHEREUM_RPC_HOST` -> `-u, --rpc-url` for `deploy-l1-contracts`. @@ -123,7 +123,7 @@ aztec-cli create-account [options] Options: - `-k, --private-key`: Private key to use for the account generation. Uses a random key by default. -- `-u, --rpc-url `: URL of the PXEult: `http://localhost:8080`. +- `-u, --rpc-url `: URL of PXE Service. Default: `http://localhost:8080`. This command creates an Aztec account that can be used for transactions. It generates a new account with a private key or uses the provided private key. The command displays the account's address and public key. @@ -147,7 +147,7 @@ Options: - `-c, --contract-abi `: Path to the compiled Aztec.nr contract's ABI file in JSON format. You can also use one of Aztec's example contracts found in [@aztec/noir-contracts](https://www.npmjs.com/package/@aztec/noir-contracts), e.g. PrivateTokenContractAbi. You can get a full ist of the available contracts with `aztec-cli example-contracts` - `-a, --args ` (optional): Contract constructor arguments Default: []. -- `-u, --rpc-url `: URL of the PXEult: `http://localhost:8080`. +- `-u, --rpc-url `: URL of PXE Service. Default: `http://localhost:8080`. - `-k, --public-key `: Public key of the deployer. If not provided, it will check the RPC for existing ones. This command deploys a compiled Aztec.nr contract to Aztec. It requires the path to the contract's ABI file in JSON format. Optionally, you can specify the public key of the deployer and provide constructor arguments for the contract. The command displays the address of the deployed contract. @@ -177,7 +177,7 @@ aztec-cli check-deploy [options] Options: - `-ca, --contract-address
`: An Aztec address to check if the contract has been deployed to. -- `-u, --rpc-url `: URL of the PXEult: `http://localhost:8080`. +- `-u, --rpc-url `: URL of PXE Service. Default: `http://localhost:8080`. This command checks if a contract is deployed to the specified Aztec address. It verifies if the contract is present at the given address and displays the result. @@ -201,7 +201,7 @@ aztec-cli get-tx-receipt [options] Options: -- `-u, --rpc-url `: URL of the PXEult: `http://localhost:8080`. +- `-u, --rpc-url `: URL of PXE Service. Default: `http://localhost:8080`. This command retrieves and displays the receipt for the specified transaction hash. It shows details such as the transaction status, block number, and block hash. @@ -225,7 +225,7 @@ aztec-cli get-contract-data [options] Options: -- `-u, --rpc-url `: URL of the PXEult: `http://localhost:8080`. +- `-u, --rpc-url `: URL of PXE Service. Default: `http://localhost:8080`. - `-b, --include-bytecode`: Include the contract's public function bytecode, if any. This command retrieves and displays information about the Aztec contract deployed at the specified address. It shows the contract address, portal contract address, and optionally, the bytecode of the contract's public functions. @@ -252,7 +252,7 @@ Options: - `-a, --address `: The account's Aztec address. - `-p, --public-key `: 'The account public key.' - `-pa, --partial-address `: URL of the PXEult: `http://localhost:8080`. +- `-u, --rpc-url `: URL of PXE Service. Default: `http://localhost:8080`. Example usage: @@ -262,7 +262,7 @@ aztec-cli register-recipient -p 0x20d9d93c4a9eb2b4bdb70ead07d28d1edb74bfd78443a8 ### get-accounts -Gets all the Aztec accounts stored in an PXE +Gets all the Aztec accounts stored in a PXE Syntax: @@ -272,7 +272,7 @@ aztec-cli get-accounts [options] Options: -- `-u, --rpc-url `: URL of the PXEult: `http://localhost:8080`. +- `-u, --rpc-url `: URL of PXE Service. Default: `http://localhost:8080`. This command retrieves and displays all the Aztec accounts available in the system. @@ -296,7 +296,7 @@ aztec-cli get-account
[options] Options: -- `-u, --rpc-url `: URL of the PXEult: `http://localhost:8080`. +- `-u, --rpc-url `: URL of PXE Service. Default: `http://localhost:8080`. This command retrieves and displays the public key of an account given its Aztec address. @@ -324,7 +324,7 @@ Options: - `-c, --contract-abi `: The compiled contract's ABI in JSON format. You can also use one of Aztec's example contracts found in (@aztec/noir-contracts)[https://www.npmjs.com/package/@aztec/noir-contracts], e.g. PrivateTokenContractAbi. - `-ca, --contract-address
`: Address of the contract. - `-k, --private-key `: The sender's private key. -- `-u, --rpc-url `: URL of the PXEult: `http://localhost:8080`. +- `-u, --rpc-url `: URL of PXE Service. Default: `http://localhost:8080`. This command calls a function on an Aztec contract. It requires the contract's ABI, address, function name, and optionally, function arguments. The command executes the function call and displays the transaction details. @@ -353,7 +353,7 @@ Options: - `-c, --contract-abi `: The compiled contract's ABI in JSON format. You can also use one of Aztec's example contracts found in (@aztec/noir-contracts)[https://www.npmjs.com/package/@aztec/noir-contracts], e.g. PrivateTokenContractAbi. - `-ca, --contract-address
`: Address of the contract. - `-f, --from `: Address of the caller. If empty, first account in the Private Execution Environment (PXE) will be used. -- `-u, --rpc-url `: URL of the PXEult: `http://localhost:8080`. +- `-u, --rpc-url `: URL of PXE Service. Default: `http://localhost:8080`. This command simulates the execution of a view function on a deployed contract without modifying the state. It requires the contract's ABI, address, function name, and optionally, function arguments. The command displays the result of the view function. @@ -400,7 +400,7 @@ aztec-cli get-logs --from --limit [options] Options: -- `-u, --rpc-url `: URL of the PXEult: `http://localhost:8080`. +- `-u, --rpc-url `: URL of PXE Service. Default: `http://localhost:8080`. This command retrieves and displays all the unencrypted logs from L2 blocks in the specified range. It shows the logs found in the blocks and unrolls them for readability. @@ -422,7 +422,7 @@ aztec-cli block-number Options: -- `-u, --rpc-url `: URL of the PXEult: `http://localhost:8080`. +- `-u, --rpc-url `: URL of PXE Service. Default: `http://localhost:8080`. This command retrieves and displays the current Aztec L2 block number. @@ -448,7 +448,7 @@ aztec-cli get-node-info Options: -- `-u, --rpc-url `: URL of the PXEult: `http://localhost:8080`. +- `-u, --rpc-url `: URL of PXE Service. Default: `http://localhost:8080`. ## Conclusion diff --git a/yarn-project/cli/src/utils.ts b/yarn-project/cli/src/utils.ts index 38d54da538d..54cde4490de 100644 --- a/yarn-project/cli/src/utils.ts +++ b/yarn-project/cli/src/utils.ts @@ -124,7 +124,7 @@ export async function getContractAbi(fileDir: string, log: LogFn) { /** * Utility to select a TX sender either from user input - * or from the first account that is found in an PXE instance. + * or from the first account that is found in a PXE instance. * @param pxe - The PXE instance that will be checked for an account. * @param _from - The user input. * @returns An Aztec address. Will throw if one can't be found in either options. diff --git a/yarn-project/end-to-end/src/canary/cli.ts b/yarn-project/end-to-end/src/canary/cli.ts index 2f486df6694..cffc82ff952 100644 --- a/yarn-project/end-to-end/src/canary/cli.ts +++ b/yarn-project/end-to-end/src/canary/cli.ts @@ -16,7 +16,7 @@ export const cliTestSuite = ( ) => describe(name, () => { let cli: ReturnType; - let pxeClient: PXE; + let pxe: PXE; let existingAccounts: CompleteAddress[]; let contractAddress: AztecAddress; let log: (...args: any[]) => void; @@ -25,7 +25,7 @@ export const cliTestSuite = ( const logs: string[] = []; beforeAll(async () => { - pxeClient = await setup(); + pxe = await setup(); log = (...args: any[]) => { logs.push(format(...args)); debug(...args); @@ -79,14 +79,14 @@ export const cliTestSuite = ( }; it('creates & retrieves an account', async () => { - existingAccounts = await pxeClient.getRegisteredAccounts(); + existingAccounts = await pxe.getRegisteredAccounts(); debug('Create an account'); await run(`create-account`); const foundAddress = findInLogs(/Address:\s+(?
0x[a-fA-F0-9]+)/)?.groups?.address; expect(foundAddress).toBeDefined(); const newAddress = AztecAddress.fromString(foundAddress!); - const accountsAfter = await pxeClient.getRegisteredAccounts(); + const accountsAfter = await pxe.getRegisteredAccounts(); const expectedAccounts = [...existingAccounts.map(a => a.address), newAddress]; expect(accountsAfter.map(a => a.address)).toEqual(expectedAccounts); const newCompleteAddress = accountsAfter[accountsAfter.length - 1]; @@ -123,7 +123,7 @@ export const cliTestSuite = ( expect(loggedAddress).toBeDefined(); contractAddress = AztecAddress.fromString(loggedAddress!); - const deployedContract = await pxeClient.getContractData(contractAddress); + const deployedContract = await pxe.getContractData(contractAddress); expect(deployedContract?.contractAddress).toEqual(contractAddress); debug('Check contract can be found in returned address'); @@ -161,7 +161,7 @@ export const cliTestSuite = ( expect(balance!).toEqual(`${BigInt(INITIAL_BALANCE).toString()}n`); debug('Transfer some tokens'); - const existingAccounts = await pxeClient.getRegisteredAccounts(); + const existingAccounts = await pxe.getRegisteredAccounts(); // ensure we pick a different acc const receiver = existingAccounts.find(acc => acc.address.toString() !== ownerAddress.toString()); From 25be0795177caa3dd449b005d284f853866de7c1 Mon Sep 17 00:00:00 2001 From: benesjan Date: Wed, 27 Sep 2023 14:20:17 +0000 Subject: [PATCH 18/23] WIP --- yarn-project/cli/README.md | 2 +- yarn-project/end-to-end/src/canary/browser.ts | 28 +++++----- .../e2e_public_cross_chain_messaging.test.ts | 4 +- .../e2e_public_to_private_messaging.test.ts | 8 +-- .../end-to-end/src/e2e_token_contract.test.ts | 16 +++--- yarn-project/end-to-end/src/fixtures/utils.ts | 6 +- .../end-to-end/src/sample-dapp/connect.mjs | 4 +- .../end-to-end/src/sample-dapp/deploy.mjs | 6 +- .../end-to-end/src/sample-dapp/index.mjs | 56 +++++++++---------- 9 files changed, 65 insertions(+), 65 deletions(-) diff --git a/yarn-project/cli/README.md b/yarn-project/cli/README.md index 8b30b9c72f2..ecfe629562d 100644 --- a/yarn-project/cli/README.md +++ b/yarn-project/cli/README.md @@ -262,7 +262,7 @@ aztec-cli register-recipient -p 0x20d9d93c4a9eb2b4bdb70ead07d28d1edb74bfd78443a8 ### get-accounts -Gets all the Aztec accounts stored in a PXE +Gets all the Aztec accounts stored in a PXE. Syntax: diff --git a/yarn-project/end-to-end/src/canary/browser.ts b/yarn-project/end-to-end/src/canary/browser.ts index 21a2fe5115c..d8934c72b6a 100644 --- a/yarn-project/end-to-end/src/canary/browser.ts +++ b/yarn-project/end-to-end/src/canary/browser.ts @@ -91,9 +91,9 @@ export const browserTestSuite = (setup: () => Server, pageLogger: AztecJs.DebugL const result = await page.evaluate( async (rpcUrl, privateKeyString) => { const { GrumpkinScalar, createPXEClient: createPXEClient, getUnsafeSchnorrAccount } = window.AztecJs; - const client = createPXEClient(rpcUrl!); + const pxe = createPXEClient(rpcUrl!); const privateKey = GrumpkinScalar.fromString(privateKeyString); - const account = getUnsafeSchnorrAccount(client, privateKey); + const account = getUnsafeSchnorrAccount(pxe, privateKey); await account.waitDeploy(); const completeAddress = await account.getCompleteAddress(); const addressString = completeAddress.address.toString(); @@ -116,9 +116,9 @@ export const browserTestSuite = (setup: () => Server, pageLogger: AztecJs.DebugL const result = await page.evaluate( async (rpcUrl, contractAddress, TokenContractAbi) => { const { Contract, AztecAddress, createPXEClient: createPXEClient } = window.AztecJs; - const client = createPXEClient(rpcUrl!); - const owner = (await client.getRegisteredAccounts())[0].address; - const [wallet] = await AztecJs.getSandboxAccountsWallets(client); + const pxe = createPXEClient(rpcUrl!); + const owner = (await pxe.getRegisteredAccounts())[0].address; + const [wallet] = await AztecJs.getSandboxAccountsWallets(pxe); const contract = await Contract.at(AztecAddress.fromString(contractAddress), TokenContractAbi, wallet); const balance = await contract.methods.balance_of_private(owner).view({ from: owner }); return balance; @@ -135,10 +135,10 @@ export const browserTestSuite = (setup: () => Server, pageLogger: AztecJs.DebugL async (rpcUrl, contractAddress, transferAmount, TokenContractAbi) => { console.log(`Starting transfer tx`); const { AztecAddress, Contract, createPXEClient: createPXEClient } = window.AztecJs; - const client = createPXEClient(rpcUrl!); - const accounts = await client.getRegisteredAccounts(); + const pxe = createPXEClient(rpcUrl!); + const accounts = await pxe.getRegisteredAccounts(); const receiver = accounts[1].address; - const [wallet] = await AztecJs.getSandboxAccountsWallets(client); + const [wallet] = await AztecJs.getSandboxAccountsWallets(pxe); const contract = await Contract.at(AztecAddress.fromString(contractAddress), TokenContractAbi, wallet); await contract.methods.transfer(accounts[0].address, receiver, transferAmount, 0).send().wait(); console.log(`Transferred ${transferAmount} tokens to new Account`); @@ -165,16 +165,16 @@ export const browserTestSuite = (setup: () => Server, pageLogger: AztecJs.DebugL computeMessageSecretHash, getSandboxAccountsWallets, } = window.AztecJs; - const client = createPXEClient(rpcUrl!); - let accounts = await client.getRegisteredAccounts(); + const pxe = createPXEClient(rpcUrl!); + let accounts = await pxe.getRegisteredAccounts(); if (accounts.length === 0) { // This test needs an account for deployment. We create one in case there is none available in the RPC server. const privateKey = GrumpkinScalar.fromString(privateKeyString); - await getUnsafeSchnorrAccount(client, privateKey).waitDeploy(); - accounts = await client.getRegisteredAccounts(); + await getUnsafeSchnorrAccount(pxe, privateKey).waitDeploy(); + accounts = await pxe.getRegisteredAccounts(); } - const [owner] = await getSandboxAccountsWallets(client); - const tx = new DeployMethod(accounts[0].publicKey, client, TokenContractAbi).send(); + const [owner] = await getSandboxAccountsWallets(pxe); + const tx = new DeployMethod(accounts[0].publicKey, pxe, TokenContractAbi).send(); await tx.wait(); const receipt = await tx.getReceipt(); console.log(`Contract Deployed: ${receipt.contractAddress}`); diff --git a/yarn-project/end-to-end/src/e2e_public_cross_chain_messaging.test.ts b/yarn-project/end-to-end/src/e2e_public_cross_chain_messaging.test.ts index dab03de4fdc..88980573b2c 100644 --- a/yarn-project/end-to-end/src/e2e_public_cross_chain_messaging.test.ts +++ b/yarn-project/end-to-end/src/e2e_public_cross_chain_messaging.test.ts @@ -25,7 +25,7 @@ describe('e2e_public_cross_chain_messaging', () => { beforeEach(async () => { const { aztecNode: aztecNode_, - pxe: pxe_, + pxe, deployL1ContractsValues, accounts, wallets, @@ -35,7 +35,7 @@ describe('e2e_public_cross_chain_messaging', () => { } = await setup(2); crossChainTestHarness = await CrossChainTestHarness.new( aztecNode_, - pxe_, + pxe, deployL1ContractsValues, accounts, wallets[0], diff --git a/yarn-project/end-to-end/src/e2e_public_to_private_messaging.test.ts b/yarn-project/end-to-end/src/e2e_public_to_private_messaging.test.ts index 31d08635522..3514744c0a7 100644 --- a/yarn-project/end-to-end/src/e2e_public_to_private_messaging.test.ts +++ b/yarn-project/end-to-end/src/e2e_public_to_private_messaging.test.ts @@ -19,8 +19,8 @@ describe('e2e_public_to_private_messaging', () => { beforeEach(async () => { const { - aztecNode: aztecNode_, - pxe: pxe_, + aztecNode, + pxe, deployL1ContractsValues, accounts, wallet, @@ -29,8 +29,8 @@ describe('e2e_public_to_private_messaging', () => { teardown: teardown_, } = await setup(2); crossChainTestHarness = await CrossChainTestHarness.new( - aztecNode_, - pxe_, + aztecNode, + pxe, deployL1ContractsValues, accounts, wallet, diff --git a/yarn-project/end-to-end/src/e2e_token_contract.test.ts b/yarn-project/end-to-end/src/e2e_token_contract.test.ts index feb683d59a5..578c0a3e291 100644 --- a/yarn-project/end-to-end/src/e2e_token_contract.test.ts +++ b/yarn-project/end-to-end/src/e2e_token_contract.test.ts @@ -437,7 +437,7 @@ describe('e2e_token_contract', () => { // We need to compute the message we want to sign and add it to the wallet as approved const messageHash = await transferMessageHash(accounts[1], accounts[0], accounts[1], amount, nonce); - // Both wallets are connected to same node and pxe so we could just insert directly using + // Both wallets are connected to same node and PXE so we could just insert directly using // await wallet.signAndAddAuthWitness(messageHash, ); // But doing it in two actions to show the flow. const witness = await wallets[0].createAuthWitness(messageHash); @@ -491,7 +491,7 @@ describe('e2e_token_contract', () => { // We need to compute the message we want to sign and add it to the wallet as approved const messageHash = await transferMessageHash(accounts[1], accounts[0], accounts[1], amount, nonce); - // Both wallets are connected to same node and pxe so we could just insert directly using + // Both wallets are connected to same node and PXE so we could just insert directly using // await wallet.signAndAddAuthWitness(messageHash, ); // But doing it in two actions to show the flow. const witness = await wallets[0].createAuthWitness(messageHash); @@ -772,7 +772,7 @@ describe('e2e_token_contract', () => { // We need to compute the message we want to sign and add it to the wallet as approved const messageHash = await unshieldMessageHash(accounts[1], accounts[0], accounts[1], amount, nonce); - // Both wallets are connected to same node and pxe so we could just insert directly using + // Both wallets are connected to same node and PXE so we could just insert directly using // await wallet.signAndAddAuthWitness(messageHash, ); // But doing it in two actions to show the flow. const witness = await wallets[0].createAuthWitness(messageHash); @@ -826,7 +826,7 @@ describe('e2e_token_contract', () => { // We need to compute the message we want to sign and add it to the wallet as approved const messageHash = await unshieldMessageHash(accounts[1], accounts[0], accounts[1], amount, nonce); - // Both wallets are connected to same node and pxe so we could just insert directly using + // Both wallets are connected to same node and PXE so we could just insert directly using // await wallet.signAndAddAuthWitness(messageHash, ); // But doing it in two actions to show the flow. const witness = await wallets[0].createAuthWitness(messageHash); @@ -850,7 +850,7 @@ describe('e2e_token_contract', () => { const messageHash = await unshieldMessageHash(accounts[1], accounts[0], accounts[1], amount, nonce); const expectedMessageHash = await unshieldMessageHash(accounts[2], accounts[0], accounts[1], amount, nonce); - // Both wallets are connected to same node and pxe so we could just insert directly using + // Both wallets are connected to same node and PXE so we could just insert directly using // await wallet.signAndAddAuthWitness(messageHash, ); // But doing it in two actions to show the flow. const witness = await wallets[0].createAuthWitness(messageHash); @@ -1005,7 +1005,7 @@ describe('e2e_token_contract', () => { // We need to compute the message we want to sign and add it to the wallet as approved const messageHash = await burnMessageHash(accounts[1], accounts[0], amount, nonce); - // Both wallets are connected to same node and pxe so we could just insert directly using + // Both wallets are connected to same node and PXE so we could just insert directly using // await wallet.signAndAddAuthWitness(messageHash, ); // But doing it in two actions to show the flow. const witness = await wallets[0].createAuthWitness(messageHash); @@ -1051,7 +1051,7 @@ describe('e2e_token_contract', () => { // We need to compute the message we want to sign and add it to the wallet as approved const messageHash = await burnMessageHash(accounts[1], accounts[0], amount, nonce); - // Both wallets are connected to same node and pxe so we could just insert directly using + // Both wallets are connected to same node and PXE so we could just insert directly using // await wallet.signAndAddAuthWitness(messageHash, ); // But doing it in two actions to show the flow. const witness = await wallets[0].createAuthWitness(messageHash); @@ -1105,7 +1105,7 @@ describe('e2e_token_contract', () => { const messageHash = await burnMessageHash(accounts[1], accounts[0], amount, nonce); const expectedMessageHash = await burnMessageHash(accounts[2], accounts[0], amount, nonce); - // Both wallets are connected to same node and pxe so we could just insert directly using + // Both wallets are connected to same node and PXE so we could just insert directly using // await wallet.signAndAddAuthWitness(messageHash, { origin: accounts[0].address }); // But doing it in two actions to show the flow. const witness = await wallets[0].createAuthWitness(messageHash); diff --git a/yarn-project/end-to-end/src/fixtures/utils.ts b/yarn-project/end-to-end/src/fixtures/utils.ts index cc25ceb19de..d63d8dec105 100644 --- a/yarn-project/end-to-end/src/fixtures/utils.ts +++ b/yarn-project/end-to-end/src/fixtures/utils.ts @@ -63,11 +63,11 @@ import { MNEMONIC, localAnvil } from './fixtures.js'; const { SANDBOX_URL = '' } = process.env; -export const waitForRPCServer = async (rpcServer: PXE, logger: DebugLogger) => { +export const waitForRPCServer = async (pxe: PXE, logger: DebugLogger) => { await retryUntil(async () => { try { logger('Attempting to contact RPC Server...'); - await rpcServer.getNodeInfo(); + await pxe.getNodeInfo(); return true; } catch (error) { logger('Failed to contact RPC Server!'); @@ -455,7 +455,7 @@ export async function deployAndInitializeStandardizedTokenAndBridgeContracts( /** * Deploy L1 token and portal, initialize portal, deploy a non native l2 token contract and attach is to the portal. - * @param pxeService - Private Execution Environment (PXE) instance + * @param wallet - Aztec wallet instance. * @param walletClient - A viem WalletClient. * @param publicClient - A viem PublicClient. * @param rollupRegistryAddress - address of rollup registry to pass to initialize the token portal diff --git a/yarn-project/end-to-end/src/sample-dapp/connect.mjs b/yarn-project/end-to-end/src/sample-dapp/connect.mjs index dfaa55e26bc..0785fb1ca3a 100644 --- a/yarn-project/end-to-end/src/sample-dapp/connect.mjs +++ b/yarn-project/end-to-end/src/sample-dapp/connect.mjs @@ -4,8 +4,8 @@ import { createPXEClient } from '@aztec/aztec.js'; const { SANDBOX_URL = 'http://localhost:8080' } = process.env; async function main() { - const client = createPXEClient(SANDBOX_URL); - const { chainId } = await client.getNodeInfo(); + const pxe = createPXEClient(SANDBOX_URL); + const { chainId } = await pxe.getNodeInfo(); console.log(`Connected to chain ${chainId}`); } diff --git a/yarn-project/end-to-end/src/sample-dapp/deploy.mjs b/yarn-project/end-to-end/src/sample-dapp/deploy.mjs index c3ff3a9c2f7..7d9c655ac19 100644 --- a/yarn-project/end-to-end/src/sample-dapp/deploy.mjs +++ b/yarn-project/end-to-end/src/sample-dapp/deploy.mjs @@ -8,10 +8,10 @@ import { fileURLToPath } from 'url'; const { SANDBOX_URL = 'http://localhost:8080' } = process.env; async function main() { - const client = createPXEClient(SANDBOX_URL); - const [owner] = await getSandboxAccountsWallets(client); + const pxe = createPXEClient(SANDBOX_URL); + const [owner] = await getSandboxAccountsWallets(pxe); - const token = await Contract.deploy(client, TokenContractAbi, []).send().deployed(); + const token = await Contract.deploy(pxe, TokenContractAbi, []).send().deployed(); await token.withWallet(owner).methods._initialize(owner.getAddress()).send().wait(); console.log(`Token deployed at ${token.address.toString()}`); diff --git a/yarn-project/end-to-end/src/sample-dapp/index.mjs b/yarn-project/end-to-end/src/sample-dapp/index.mjs index c0d61e1a593..32d8e256692 100644 --- a/yarn-project/end-to-end/src/sample-dapp/index.mjs +++ b/yarn-project/end-to-end/src/sample-dapp/index.mjs @@ -11,17 +11,17 @@ import { getToken } from './contracts.mjs'; const { SANDBOX_URL = 'http://localhost:8080' } = process.env; -async function showAccounts(client) { +async function showAccounts(pxe) { // docs:start:showAccounts - const accounts = await client.getRegisteredAccounts(); + const accounts = await pxe.getRegisteredAccounts(); console.log(`User accounts:\n${accounts.map(a => a.address).join('\n')}`); // docs:end:showAccounts } -async function showPrivateBalances(client) { +async function showPrivateBalances(pxe) { // docs:start:showPrivateBalances - const accounts = await client.getRegisteredAccounts(); - const token = await getToken(client); + const accounts = await pxe.getRegisteredAccounts(); + const token = await getToken(pxe); for (const account of accounts) { // highlight-next-line:showPrivateBalances @@ -31,11 +31,11 @@ async function showPrivateBalances(client) { // docs:end:showPrivateBalances } -async function mintPrivateFunds(client) { - const [owner] = await getSandboxAccountsWallets(client); +async function mintPrivateFunds(pxe) { + const [owner] = await getSandboxAccountsWallets(pxe); const token = await getToken(owner); - await showPrivateBalances(client); + await showPrivateBalances(pxe); const mintAmount = 20n; const secret = Fr.random(); @@ -43,29 +43,29 @@ async function mintPrivateFunds(client) { await token.methods.mint_private(mintAmount, secretHash).send().wait(); await token.methods.redeem_shield(owner.getAddress(), mintAmount, secret).send().wait(); - await showPrivateBalances(client); + await showPrivateBalances(pxe); } -async function transferPrivateFunds(client) { +async function transferPrivateFunds(pxe) { // docs:start:transferPrivateFunds - const [owner, recipient] = await getSandboxAccountsWallets(client); + const [owner, recipient] = await getSandboxAccountsWallets(pxe); const token = await getToken(owner); const tx = token.methods.transfer(owner.getAddress(), recipient.getAddress(), 1n, 0).send(); console.log(`Sent transfer transaction ${await tx.getTxHash()}`); - await showPrivateBalances(client); + await showPrivateBalances(pxe); console.log(`Awaiting transaction to be mined`); const receipt = await tx.wait(); console.log(`Transaction has been mined on block ${receipt.blockNumber}`); - await showPrivateBalances(client); + await showPrivateBalances(pxe); // docs:end:transferPrivateFunds } -async function showPublicBalances(client) { +async function showPublicBalances(pxe) { // docs:start:showPublicBalances - const accounts = await client.getRegisteredAccounts(); - const token = await getToken(client); + const accounts = await pxe.getRegisteredAccounts(); + const token = await getToken(pxe); for (const account of accounts) { // highlight-next-line:showPublicBalances @@ -75,41 +75,41 @@ async function showPublicBalances(client) { // docs:end:showPublicBalances } -async function mintPublicFunds(client) { +async function mintPublicFunds(pxe) { // docs:start:mintPublicFunds - const [owner] = await getSandboxAccountsWallets(client); + const [owner] = await getSandboxAccountsWallets(pxe); const token = await getToken(owner); const tx = token.methods.mint_public(owner.getAddress(), 100n).send(); console.log(`Sent mint transaction ${await tx.getTxHash()}`); - await showPublicBalances(client); + await showPublicBalances(pxe); console.log(`Awaiting transaction to be mined`); const receipt = await tx.wait(); console.log(`Transaction has been mined on block ${receipt.blockNumber}`); - await showPublicBalances(client); + await showPublicBalances(pxe); // docs:end:mintPublicFunds // docs:start:showLogs - const blockNumber = await client.getBlockNumber(); - const logs = await client.getUnencryptedLogs(blockNumber, 1); + const blockNumber = await pxe.getBlockNumber(); + const logs = await pxe.getUnencryptedLogs(blockNumber, 1); const textLogs = L2BlockL2Logs.unrollLogs(logs).map(log => log.toString('ascii')); for (const log of textLogs) console.log(`Log emitted: ${log}`); // docs:end:showLogs } async function main() { - const client = createPXEClient(SANDBOX_URL); - const { chainId } = await client.getNodeInfo(); + const pxe = createPXEClient(SANDBOX_URL); + const { chainId } = await pxe.getNodeInfo(); console.log(`Connected to chain ${chainId}`); - await showAccounts(client); + await showAccounts(pxe); - await mintPrivateFunds(client); + await mintPrivateFunds(pxe); - await transferPrivateFunds(client); + await transferPrivateFunds(pxe); - await mintPublicFunds(client); + await mintPublicFunds(pxe); } // Execute main only if run directly From b5a387d4d514c1893af3813ca89548db93982473 Mon Sep 17 00:00:00 2001 From: benesjan Date: Wed, 27 Sep 2023 14:25:03 +0000 Subject: [PATCH 19/23] fixes --- yarn-project/boxes/blank-react/src/scripts/deploy_contract.ts | 2 +- yarn-project/boxes/private-token/src/scripts/deploy_contract.ts | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/yarn-project/boxes/blank-react/src/scripts/deploy_contract.ts b/yarn-project/boxes/blank-react/src/scripts/deploy_contract.ts index ed6ca31dd32..7a0dc7d4d76 100644 --- a/yarn-project/boxes/blank-react/src/scripts/deploy_contract.ts +++ b/yarn-project/boxes/blank-react/src/scripts/deploy_contract.ts @@ -9,7 +9,7 @@ export async function deployContract( salt: Fr, pxe: PXE, ): Promise { - const tx = new DeployMethod(activeWallet.publicKey, client, contractAbi, typedArgs).send({ + const tx = new DeployMethod(activeWallet.publicKey, pxe, contractAbi, typedArgs).send({ contractAddressSalt: salt, }); await tx.wait(); diff --git a/yarn-project/boxes/private-token/src/scripts/deploy_contract.ts b/yarn-project/boxes/private-token/src/scripts/deploy_contract.ts index ed6ca31dd32..7a0dc7d4d76 100644 --- a/yarn-project/boxes/private-token/src/scripts/deploy_contract.ts +++ b/yarn-project/boxes/private-token/src/scripts/deploy_contract.ts @@ -9,7 +9,7 @@ export async function deployContract( salt: Fr, pxe: PXE, ): Promise { - const tx = new DeployMethod(activeWallet.publicKey, client, contractAbi, typedArgs).send({ + const tx = new DeployMethod(activeWallet.publicKey, pxe, contractAbi, typedArgs).send({ contractAddressSalt: salt, }); await tx.wait(); From d466a9137a0aa79f34a9856a769ab7e37eb090f0 Mon Sep 17 00:00:00 2001 From: benesjan Date: Wed, 27 Sep 2023 14:28:44 +0000 Subject: [PATCH 20/23] formatting fix --- .../src/app/components/contract_function_form.tsx | 9 +-------- .../private-token/src/tests/privatetoken.sandbox.test.ts | 9 +-------- 2 files changed, 2 insertions(+), 16 deletions(-) diff --git a/yarn-project/boxes/private-token/src/app/components/contract_function_form.tsx b/yarn-project/boxes/private-token/src/app/components/contract_function_form.tsx index 701dec89f72..860c99e45b0 100644 --- a/yarn-project/boxes/private-token/src/app/components/contract_function_form.tsx +++ b/yarn-project/boxes/private-token/src/app/components/contract_function_form.tsx @@ -86,14 +86,7 @@ async function handleFunctionCall( if (functionAbi.functionType === 'unconstrained') { return await viewContractFunction(contractAddress!, contractAbi, functionName, typedArgs, pxe, wallet); } else { - const txnReceipt = await callContractFunction( - contractAddress!, - contractAbi, - functionName, - typedArgs, - pxe, - wallet, - ); + const txnReceipt = await callContractFunction(contractAddress!, contractAbi, functionName, typedArgs, pxe, wallet); return `Transaction ${txnReceipt.status} on block number ${txnReceipt.blockNumber}`; } } diff --git a/yarn-project/boxes/private-token/src/tests/privatetoken.sandbox.test.ts b/yarn-project/boxes/private-token/src/tests/privatetoken.sandbox.test.ts index 230f0bf51e0..bfbe139e133 100644 --- a/yarn-project/boxes/private-token/src/tests/privatetoken.sandbox.test.ts +++ b/yarn-project/boxes/private-token/src/tests/privatetoken.sandbox.test.ts @@ -42,14 +42,7 @@ async function deployZKContract(owner: CompleteAddress, wallet: Wallet, pxe: PXE async function getBalance(contractAddress: AztecAddress, privateTokenContract: Contract, owner: CompleteAddress) { const typedArgs = [owner.address.toField()]; - return await viewContractFunction( - contractAddress, - privateTokenContract.abi, - 'getBalance', - typedArgs, - pxe, - owner, - ); + return await viewContractFunction(contractAddress, privateTokenContract.abi, 'getBalance', typedArgs, pxe, owner); } async function mint( From ee65e780262641b116855f357e086b47e210d8d6 Mon Sep 17 00:00:00 2001 From: benesjan Date: Wed, 27 Sep 2023 14:45:19 +0000 Subject: [PATCH 21/23] formatting fix --- .../app/components/contract_function_form.tsx | 8 +++--- yarn-project/boxes/blank/src/index.ts | 28 +++++++++---------- 2 files changed, 18 insertions(+), 18 deletions(-) diff --git a/yarn-project/boxes/blank-react/src/app/components/contract_function_form.tsx b/yarn-project/boxes/blank-react/src/app/components/contract_function_form.tsx index 7340fb5d9a7..69916e7061e 100644 --- a/yarn-project/boxes/blank-react/src/app/components/contract_function_form.tsx +++ b/yarn-project/boxes/blank-react/src/app/components/contract_function_form.tsx @@ -3,7 +3,7 @@ import { AztecAddress, CompleteAddress, Fr } from '@aztec/aztec.js'; import { ContractAbi, FunctionAbi } from '@aztec/foundation/abi'; import { useFormik } from 'formik'; import * as Yup from 'yup'; -import { CONTRACT_ADDRESS_PARAM_NAMES, pxe } from '../../config.js'; +import { CONTRACT_ADDRESS_PARAM_NAMES, rpcClient } from '../../config.js'; import { callContractFunction, deployContract, viewContractFunction } from '../../scripts/index.js'; import { convertArgs } from '../../scripts/util.js'; import styles from './contract_function_form.module.scss'; @@ -80,18 +80,18 @@ async function handleFunctionCall( // for now, dont let user change the salt. requires some change to the form generation if we want to let user choose one // since everything is currently based on parsing the contractABI, and the salt parameter is not present there const salt = Fr.random(); - return await deployContract(wallet, contractAbi, typedArgs, salt, pxe); + return await deployContract(wallet, contractAbi, typedArgs, salt, rpcClient); } if (functionAbi.functionType === 'unconstrained') { - return await viewContractFunction(contractAddress!, contractAbi, functionName, typedArgs, pxe, wallet); + return await viewContractFunction(contractAddress!, contractAbi, functionName, typedArgs, rpcClient, wallet); } else { const txnReceipt = await callContractFunction( contractAddress!, contractAbi, functionName, typedArgs, - pxe, + rpcClient, wallet, ); return `Transaction ${txnReceipt.status} on block number ${txnReceipt.blockNumber}`; diff --git a/yarn-project/boxes/blank/src/index.ts b/yarn-project/boxes/blank/src/index.ts index 81e54fe4fcf..a3bde8b5c11 100644 --- a/yarn-project/boxes/blank/src/index.ts +++ b/yarn-project/boxes/blank/src/index.ts @@ -1,13 +1,13 @@ import { AccountWallet, AztecAddress, - PXE, + AztecRPC, CompleteAddress, Contract, DeployMethod, Fr, TxReceipt, - createPXEClient, + createAztecRpcClient, getSandboxAccountsWallets, } from '@aztec/aztec.js'; import { ContractAbi, FunctionAbi, encodeArguments } from '@aztec/foundation/abi'; @@ -16,7 +16,7 @@ import { BlankContractAbi } from './artifacts/blank.js'; export const contractAbi: ContractAbi = BlankContractAbi; export const SANDBOX_URL: string = process.env.SANDBOX_URL || 'http://localhost:8080'; -export const pxe: PXE = createPXEClient(SANDBOX_URL); +export const rpcClient: AztecRPC = createAztecRpcClient(SANDBOX_URL); export const CONTRACT_ADDRESS_PARAM_NAMES = ['owner', 'contract_address', 'recipient']; export const FILTERED_FUNCTION_NAMES = []; @@ -40,21 +40,21 @@ if (typeof document !== 'undefined') { export async function handleDeployClick(): Promise { console.log('Deploying Contract'); - const [wallet, ..._rest] = await getSandboxAccountsWallets(pxe); + const [wallet, ..._rest] = await getSandboxAccountsWallets(rpcClient); const contractAztecAddress = await deployContract( wallet.getCompleteAddress(), contractAbi, [], Fr.random(), - pxe, + rpcClient, ); return contractAztecAddress.toString(); } export async function handleInteractClick(contractAddress: string) { - const [wallet, ..._rest] = await getSandboxAccountsWallets(pxe); + const [wallet, ..._rest] = await getSandboxAccountsWallets(rpcClient); const callArgs = { address: wallet.getCompleteAddress().address }; const getPkAbi = getFunctionAbi(BlankContractAbi, 'getPublicKey'); const typedArgs = convertArgs(getPkAbi, callArgs); @@ -65,7 +65,7 @@ export async function handleInteractClick(contractAddress: string) { contractAbi, 'getPublicKey', typedArgs, - pxe, + rpcClient, wallet.getCompleteAddress(), ); } @@ -81,11 +81,11 @@ export async function callContractFunction( abi: ContractAbi, functionName: string, typedArgs: any[], // for the exposed functions, this is an array of field elements Fr[] - pxe: PXE, + rpc: AztecRPC, wallet: CompleteAddress, ): Promise> { // selectedWallet is how we specify the "sender" of the transaction - const selectedWallet = await getWallet(wallet, pxe); + const selectedWallet = await getWallet(wallet, rpc); // TODO: switch to the generated typescript class? const contract = await Contract.at(address, abi, selectedWallet); @@ -100,11 +100,11 @@ export async function callContractFunction( * while the "wallet" has the account's private key and is used to sign transactions * we need the "wallet" to actually submit transactions using the "account" identity * @param account - * @param pxe + * @param rpc * @returns */ -export async function getWallet(account: CompleteAddress, pxe: PXE): Promise { - const accountWallets: AccountWallet[] = await getSandboxAccountsWallets(pxe); +export async function getWallet(account: CompleteAddress, rpc: AztecRPC): Promise { + const accountWallets: AccountWallet[] = await getSandboxAccountsWallets(rpc); const selectedWallet: AccountWallet = accountWallets.find(w => w.getAddress().equals(account.address))!; if (!selectedWallet) { throw new Error(`Wallet for account ${account.address.toShortString()} not found in the RPC server.`); @@ -117,9 +117,9 @@ export async function deployContract( contractAbi: ContractAbi, typedArgs: Fr[], // encode prior to passing in salt: Fr, - pxe: PXE, + client: AztecRPC, ): Promise { - const tx = new DeployMethod(activeWallet.publicKey, pxe, contractAbi, typedArgs).send({ + const tx = new DeployMethod(activeWallet.publicKey, client, contractAbi, typedArgs).send({ contractAddressSalt: salt, }); await tx.wait(); From 181f3e028290a16601faae64e16024001eb20cc5 Mon Sep 17 00:00:00 2001 From: benesjan Date: Wed, 27 Sep 2023 15:03:06 +0000 Subject: [PATCH 22/23] fixes --- yarn-project/aztec-sandbox/src/sandbox.ts | 2 +- .../boxes/blank-react/src/scripts/util.ts | 2 +- yarn-project/boxes/blank/src/index.ts | 34 ++++++++----------- .../boxes/private-token/src/scripts/util.ts | 2 +- yarn-project/cli/README.md | 2 +- yarn-project/cli/src/index.ts | 2 +- yarn-project/end-to-end/src/canary/browser.ts | 2 +- .../end-to-end/src/e2e_2_pxes.test.ts | 20 +++++------ yarn-project/end-to-end/src/fixtures/utils.ts | 22 ++++++------ .../pxe/src/pxe_http/pxe_http_server.ts | 4 +-- .../pxe/src/pxe_service/create_pxe_service.ts | 2 +- .../pxe/src/pxe_service/pxe_service.ts | 6 ++-- .../types/src/tx_execution_request.ts | 2 +- 13 files changed, 48 insertions(+), 54 deletions(-) diff --git a/yarn-project/aztec-sandbox/src/sandbox.ts b/yarn-project/aztec-sandbox/src/sandbox.ts index d3f2b342069..81ba9429050 100644 --- a/yarn-project/aztec-sandbox/src/sandbox.ts +++ b/yarn-project/aztec-sandbox/src/sandbox.ts @@ -72,7 +72,7 @@ export type SandboxConfig = AztecNodeConfig & { }; /** - * Create and start a new Aztec Node and RPC Server. Deploys L1 contracts. + * Create and start a new Aztec Node and PXE. Deploys L1 contracts. * Does not start any HTTP services nor populate any initial accounts. * @param config - Optional Sandbox settings. */ diff --git a/yarn-project/boxes/blank-react/src/scripts/util.ts b/yarn-project/boxes/blank-react/src/scripts/util.ts index 9e895edca15..cac4d8afddc 100644 --- a/yarn-project/boxes/blank-react/src/scripts/util.ts +++ b/yarn-project/boxes/blank-react/src/scripts/util.ts @@ -30,7 +30,7 @@ export async function getWallet(account: CompleteAddress, pxe: PXE): Promise w.getAddress().equals(account.address))!; if (!selectedWallet) { - throw new Error(`Wallet for account ${account.address.toShortString()} not found in the RPC server.`); + throw new Error(`Wallet for account ${account.address.toShortString()} not found in the PXE.`); } return selectedWallet; } diff --git a/yarn-project/boxes/blank/src/index.ts b/yarn-project/boxes/blank/src/index.ts index a3bde8b5c11..67f3b7bbc10 100644 --- a/yarn-project/boxes/blank/src/index.ts +++ b/yarn-project/boxes/blank/src/index.ts @@ -1,13 +1,13 @@ import { AccountWallet, AztecAddress, - AztecRPC, + PXE, CompleteAddress, Contract, DeployMethod, Fr, TxReceipt, - createAztecRpcClient, + createPXEClient, getSandboxAccountsWallets, } from '@aztec/aztec.js'; import { ContractAbi, FunctionAbi, encodeArguments } from '@aztec/foundation/abi'; @@ -16,7 +16,7 @@ import { BlankContractAbi } from './artifacts/blank.js'; export const contractAbi: ContractAbi = BlankContractAbi; export const SANDBOX_URL: string = process.env.SANDBOX_URL || 'http://localhost:8080'; -export const rpcClient: AztecRPC = createAztecRpcClient(SANDBOX_URL); +export const pxe: PXE = createPXEClient(SANDBOX_URL); export const CONTRACT_ADDRESS_PARAM_NAMES = ['owner', 'contract_address', 'recipient']; export const FILTERED_FUNCTION_NAMES = []; @@ -40,21 +40,15 @@ if (typeof document !== 'undefined') { export async function handleDeployClick(): Promise { console.log('Deploying Contract'); - const [wallet, ..._rest] = await getSandboxAccountsWallets(rpcClient); + const [wallet, ..._rest] = await getSandboxAccountsWallets(pxe); - const contractAztecAddress = await deployContract( - wallet.getCompleteAddress(), - contractAbi, - [], - Fr.random(), - rpcClient, - ); + const contractAztecAddress = await deployContract(wallet.getCompleteAddress(), contractAbi, [], Fr.random(), pxe); return contractAztecAddress.toString(); } export async function handleInteractClick(contractAddress: string) { - const [wallet, ..._rest] = await getSandboxAccountsWallets(rpcClient); + const [wallet, ..._rest] = await getSandboxAccountsWallets(pxe); const callArgs = { address: wallet.getCompleteAddress().address }; const getPkAbi = getFunctionAbi(BlankContractAbi, 'getPublicKey'); const typedArgs = convertArgs(getPkAbi, callArgs); @@ -65,7 +59,7 @@ export async function handleInteractClick(contractAddress: string) { contractAbi, 'getPublicKey', typedArgs, - rpcClient, + pxe, wallet.getCompleteAddress(), ); } @@ -81,11 +75,11 @@ export async function callContractFunction( abi: ContractAbi, functionName: string, typedArgs: any[], // for the exposed functions, this is an array of field elements Fr[] - rpc: AztecRPC, + pxe: PXE, wallet: CompleteAddress, ): Promise> { // selectedWallet is how we specify the "sender" of the transaction - const selectedWallet = await getWallet(wallet, rpc); + const selectedWallet = await getWallet(wallet, pxe); // TODO: switch to the generated typescript class? const contract = await Contract.at(address, abi, selectedWallet); @@ -100,14 +94,14 @@ export async function callContractFunction( * while the "wallet" has the account's private key and is used to sign transactions * we need the "wallet" to actually submit transactions using the "account" identity * @param account - * @param rpc + * @param pxe * @returns */ -export async function getWallet(account: CompleteAddress, rpc: AztecRPC): Promise { - const accountWallets: AccountWallet[] = await getSandboxAccountsWallets(rpc); +export async function getWallet(account: CompleteAddress, pxe: PXE): Promise { + const accountWallets: AccountWallet[] = await getSandboxAccountsWallets(pxe); const selectedWallet: AccountWallet = accountWallets.find(w => w.getAddress().equals(account.address))!; if (!selectedWallet) { - throw new Error(`Wallet for account ${account.address.toShortString()} not found in the RPC server.`); + throw new Error(`Wallet for account ${account.address.toShortString()} not found in the PXE.`); } return selectedWallet; } @@ -117,7 +111,7 @@ export async function deployContract( contractAbi: ContractAbi, typedArgs: Fr[], // encode prior to passing in salt: Fr, - client: AztecRPC, + client: PXE, ): Promise { const tx = new DeployMethod(activeWallet.publicKey, client, contractAbi, typedArgs).send({ contractAddressSalt: salt, diff --git a/yarn-project/boxes/private-token/src/scripts/util.ts b/yarn-project/boxes/private-token/src/scripts/util.ts index 9e895edca15..cac4d8afddc 100644 --- a/yarn-project/boxes/private-token/src/scripts/util.ts +++ b/yarn-project/boxes/private-token/src/scripts/util.ts @@ -30,7 +30,7 @@ export async function getWallet(account: CompleteAddress, pxe: PXE): Promise w.getAddress().equals(account.address))!; if (!selectedWallet) { - throw new Error(`Wallet for account ${account.address.toShortString()} not found in the RPC server.`); + throw new Error(`Wallet for account ${account.address.toShortString()} not found in the PXE.`); } return selectedWallet; } diff --git a/yarn-project/cli/README.md b/yarn-project/cli/README.md index ecfe629562d..e4544aec0e2 100644 --- a/yarn-project/cli/README.md +++ b/yarn-project/cli/README.md @@ -238,7 +238,7 @@ aztec-cli get-contract-data 0x123456789abcdef123456789abcdef12345678 ### register-recipient -Register a recipient account on the RPC server (called recipient because we can only send notes to this account and not receive them via this RPC server). +Register a recipient account on the PXE (called recipient because we can only send notes to this account and not receive them via this PXE). To read about how keys are generated and used, head to our docs [here](https://github.com/AztecProtocol/aztec-packages/blob/master/docs/docs/aztec/developer/wallet-providers/keys.md#addresses-partial-addresses-and-public-keys). Syntax: diff --git a/yarn-project/cli/src/index.ts b/yarn-project/cli/src/index.ts index 3e4ae97fc06..35847632d76 100644 --- a/yarn-project/cli/src/index.ts +++ b/yarn-project/cli/src/index.ts @@ -131,7 +131,7 @@ export function getProgram(log: LogFn, debugLogger: DebugLogger): Command { program .command('create-account') .description( - 'Creates an aztec account that can be used for sending transactions. Registers the account on the RPC server and deploys an account contract. Uses a Schnorr single-key account which uses the same key for encryption and authentication (not secure for production usage).', + 'Creates an aztec account that can be used for sending transactions. Registers the account on the PXE and deploys an account contract. Uses a Schnorr single-key account which uses the same key for encryption and authentication (not secure for production usage).', ) .summary('Creates an aztec account that can be used for sending transactions.') .option( diff --git a/yarn-project/end-to-end/src/canary/browser.ts b/yarn-project/end-to-end/src/canary/browser.ts index d8934c72b6a..2053fbfab21 100644 --- a/yarn-project/end-to-end/src/canary/browser.ts +++ b/yarn-project/end-to-end/src/canary/browser.ts @@ -168,7 +168,7 @@ export const browserTestSuite = (setup: () => Server, pageLogger: AztecJs.DebugL const pxe = createPXEClient(rpcUrl!); let accounts = await pxe.getRegisteredAccounts(); if (accounts.length === 0) { - // This test needs an account for deployment. We create one in case there is none available in the RPC server. + // This test needs an account for deployment. We create one in case there is none available in the PXE. const privateKey = GrumpkinScalar.fromString(privateKeyString); await getUnsafeSchnorrAccount(pxe, privateKey).waitDeploy(); accounts = await pxe.getRegisteredAccounts(); diff --git a/yarn-project/end-to-end/src/e2e_2_pxes.test.ts b/yarn-project/end-to-end/src/e2e_2_pxes.test.ts index e4f81856930..e81995f0239 100644 --- a/yarn-project/end-to-end/src/e2e_2_pxes.test.ts +++ b/yarn-project/end-to-end/src/e2e_2_pxes.test.ts @@ -29,9 +29,9 @@ describe('e2e_2_pxes', () => { let teardownA: () => Promise; beforeEach(async () => { - // this test can't be run against the sandbox as it requires 2 RPC servers + // this test can't be run against the sandbox as it requires 2 PXEs if (SANDBOX_URL) { - throw new Error(`Test can't be run against the sandbox as 2 RPC servers are required`); + throw new Error(`Test can't be run against the sandbox as 2 PXEs are required`); } let accounts: CompleteAddress[] = []; ({ @@ -72,7 +72,7 @@ describe('e2e_2_pxes', () => { checkIfSynchronized = true, ) => { if (checkIfSynchronized) { - // First wait until the corresponding RPC server has synchronized the account + // First wait until the corresponding PXE has synchronized the account await awaitUserSynchronized(wallet, owner); } @@ -107,7 +107,7 @@ describe('e2e_2_pxes', () => { ); }; - it('transfers fund from user A to B via RPC server A followed by transfer from B to A via RPC server B', async () => { + it('transfers fund from user A to B via PXE A followed by transfer from B to A via PXE B', async () => { const initialBalance = 987n; const transferAmount1 = 654n; const transferAmount2 = 323n; @@ -120,7 +120,7 @@ describe('e2e_2_pxes', () => { // Add account A to wallet B await pxeB.registerRecipient(userA); - // Add token to RPC server B (RPC server A already has it because it was deployed through it) + // Add token to PXE B (PXE A already has it because it was deployed through it) await pxeB.addContracts([ { abi: TokenContract.abi, @@ -134,7 +134,7 @@ describe('e2e_2_pxes', () => { await expectTokenBalance(walletB, tokenAddress, userB.address, 0n); await expectsNumOfEncryptedLogsInTheLastBlockToBe(aztecNode, 1); - // Transfer funds from A to B via RPC server A + // Transfer funds from A to B via PXE A const contractWithWalletA = await TokenContract.at(tokenAddress, walletA); const receiptAToB = await contractWithWalletA.methods .transfer(userA.address, userB.address, transferAmount1, 0) @@ -147,7 +147,7 @@ describe('e2e_2_pxes', () => { await expectTokenBalance(walletB, tokenAddress, userB.address, transferAmount1); await expectsNumOfEncryptedLogsInTheLastBlockToBe(aztecNode, 2); - // Transfer funds from B to A via RPC server B + // Transfer funds from B to A via PXE B const contractWithWalletB = await TokenContract.at(tokenAddress, walletB); await contractWithWalletB.methods .transfer(userB.address, userA.address, transferAmount2, 0) @@ -178,12 +178,12 @@ describe('e2e_2_pxes', () => { const getChildStoredValue = (child: { address: AztecAddress }, pxe: PXE) => pxe.getPublicStorageAt(child.address, new Fr(1)).then(x => toBigInt(x!)); - it('user calls a public function on a contract deployed by a different user using a different RPC server', async () => { + it('user calls a public function on a contract deployed by a different user using a different PXE', async () => { const childCompleteAddress = await deployChildContractViaServerA(); await awaitServerSynchronized(pxeA); - // Add Child to RPC server B + // Add Child to PXE B await pxeB.addContracts([ { abi: ChildContract.abi, @@ -215,7 +215,7 @@ describe('e2e_2_pxes', () => { // Add account A to wallet B await pxeB.registerRecipient(userA); - // Add token to RPC server B (RPC server A already has it because it was deployed through it) + // Add token to PXE B (PXE A already has it because it was deployed through it) await pxeB.addContracts([ { abi: TokenContract.abi, diff --git a/yarn-project/end-to-end/src/fixtures/utils.ts b/yarn-project/end-to-end/src/fixtures/utils.ts index d63d8dec105..3ed19980085 100644 --- a/yarn-project/end-to-end/src/fixtures/utils.ts +++ b/yarn-project/end-to-end/src/fixtures/utils.ts @@ -63,14 +63,14 @@ import { MNEMONIC, localAnvil } from './fixtures.js'; const { SANDBOX_URL = '' } = process.env; -export const waitForRPCServer = async (pxe: PXE, logger: DebugLogger) => { +export const waitForPXE = async (pxe: PXE, logger: DebugLogger) => { await retryUntil(async () => { try { - logger('Attempting to contact RPC Server...'); + logger('Attempting to contact PXE...'); await pxe.getNodeInfo(); return true; } catch (error) { - logger('Failed to contact RPC Server!'); + logger('Failed to contact PXE!'); } return undefined; }, 'RPC Get Node Info'); @@ -127,11 +127,11 @@ export const setupL1Contracts = async ( /** * Sets up Private Execution Environment (PXE). - * @param numberOfAccounts - The number of new accounts to be created once the RPC server is initiated. + * @param numberOfAccounts - The number of new accounts to be created once the PXE is initiated. * @param aztecNode - The instance of an aztec node, if one is required * @param firstPrivKey - The private key of the first account to be created. * @param logger - The logger to be used. - * @param useLogSuffix - Whether to add a randomly generated suffix to the RPC server debug logs. + * @param useLogSuffix - Whether to add a randomly generated suffix to the PXE debug logs. * @returns Private Execution Environment (PXE), accounts, wallets and logger. */ export async function setupPXEService( @@ -145,7 +145,7 @@ export async function setupPXEService( */ pxe: PXE; /** - * The accounts created by the RPC server. + * The accounts created by the PXE. */ accounts: CompleteAddress[]; /** @@ -181,11 +181,11 @@ async function setupWithSandbox(account: Account, config: AztecNodeConfig, logge // we are setting up against the sandbox, l1 contracts are already deployed logger(`Creating JSON RPC client to remote host ${SANDBOX_URL}`); const jsonClient = createJsonRpcClient(SANDBOX_URL); - await waitForRPCServer(jsonClient, logger); - logger('JSON RPC client connected to RPC Server'); + await waitForPXE(jsonClient, logger); + logger('JSON RPC client connected to PXE'); logger(`Retrieving contract addresses from ${SANDBOX_URL}`); const l1Contracts = (await jsonClient.getNodeInfo()).l1ContractAddresses; - logger('RPC server created, constructing wallets from initial sandbox accounts...'); + logger('PXE created, constructing wallets from initial sandbox accounts...'); const wallets = await getSandboxAccountsWallets(jsonClient); const walletClient = createWalletClient({ @@ -220,7 +220,7 @@ async function setupWithSandbox(account: Account, config: AztecNodeConfig, logge /** * Sets up the environment for the end-to-end tests. - * @param numberOfAccounts - The number of new accounts to be created once the RPC server is initiated. + * @param numberOfAccounts - The number of new accounts to be created once the PXE is initiated. */ export async function setup( numberOfAccounts = 1, @@ -239,7 +239,7 @@ export async function setup( */ deployL1ContractsValues: DeployL1Contracts; /** - * The accounts created by the RPC server. + * The accounts created by the PXE. */ accounts: CompleteAddress[]; /** diff --git a/yarn-project/pxe/src/pxe_http/pxe_http_server.ts b/yarn-project/pxe/src/pxe_http/pxe_http_server.ts index 76c3c97a733..a6dc6cada6e 100644 --- a/yarn-project/pxe/src/pxe_http/pxe_http_server.ts +++ b/yarn-project/pxe/src/pxe_http/pxe_http_server.ts @@ -54,8 +54,8 @@ export function createPXERpcServer(pxeService: PXE): JsonRpcServer { } /** - * Creates an http server that forwards calls to the rpc server and starts it on the given port. - * @param pxeService - RPC server that answers queries to the created HTTP server. + * Creates an http server that forwards calls to the PXE and starts it on the given port. + * @param pxeService - PXE that answers queries to the created HTTP server. * @param port - Port to listen in. * @returns A running http server. */ diff --git a/yarn-project/pxe/src/pxe_service/create_pxe_service.ts b/yarn-project/pxe/src/pxe_service/create_pxe_service.ts index 9319a880dfa..4fc15e58f6f 100644 --- a/yarn-project/pxe/src/pxe_service/create_pxe_service.ts +++ b/yarn-project/pxe/src/pxe_service/create_pxe_service.ts @@ -15,7 +15,7 @@ interface CreatePXEServiceOptions { */ keyStore?: KeyStore; /** - * Storage for the RPC server. + * Storage for the PXE. */ db?: Database; } diff --git a/yarn-project/pxe/src/pxe_service/pxe_service.ts b/yarn-project/pxe/src/pxe_service/pxe_service.ts index 47218a0fe43..9a808b2b395 100644 --- a/yarn-project/pxe/src/pxe_service/pxe_service.ts +++ b/yarn-project/pxe/src/pxe_service/pxe_service.ts @@ -95,7 +95,7 @@ export class PXEService implements PXE { public async start() { await this.synchronizer.start(INITIAL_L2_BLOCK_NUM, 1, this.config.l2BlockPollingIntervalMS); const info = await this.getNodeInfo(); - this.log.info(`Started RPC server connected to chain ${info.chainId} version ${info.protocolVersion}`); + this.log.info(`Started PXE connected to chain ${info.chainId} version ${info.protocolVersion}`); } /** @@ -193,7 +193,7 @@ export class PXEService implements PXE { } const notes = await this.db.getNoteSpendingInfo(contract, storageSlot); const ownerCompleteAddress = await this.db.getCompleteAddress(owner); - if (!ownerCompleteAddress) throw new Error(`Owner ${owner} not registered in RPC server`); + if (!ownerCompleteAddress) throw new Error(`Owner ${owner} not registered in PXE`); const { publicKey: ownerPublicKey } = ownerCompleteAddress; const ownerNotes = notes.filter(n => n.publicKey.equals(ownerPublicKey)); return ownerNotes.map(n => n.notePreimage); @@ -480,7 +480,7 @@ export class PXEService implements PXE { try { await this.node.simulatePublicCalls(tx); } catch (err) { - // Try to fill in the noir call stack since the RPC server may have access to the debug metadata + // Try to fill in the noir call stack since the PXE may have access to the debug metadata if (err instanceof SimulationError) { const callStack = err.getCallStack(); const originalFailingFunction = callStack[callStack.length - 1]; diff --git a/yarn-project/types/src/tx_execution_request.ts b/yarn-project/types/src/tx_execution_request.ts index f9abc90104b..e3e5e830dcd 100644 --- a/yarn-project/types/src/tx_execution_request.ts +++ b/yarn-project/types/src/tx_execution_request.ts @@ -33,7 +33,7 @@ export class TxExecutionRequest { public packedArguments: PackedArguments[], /** * Transient authorization witnesses for authorizing the execution of one or more actions during this tx. - * These witnesses are not expected to be stored in the local witnesses database of the RPC server. + * These witnesses are not expected to be stored in the local witnesses database of the PXE. */ public authWitnesses: AuthWitness[], ) {} From 558c34ad4d2cd156302262fbef2ff0d82741e272 Mon Sep 17 00:00:00 2001 From: benesjan Date: Wed, 27 Sep 2023 15:07:29 +0000 Subject: [PATCH 23/23] improved readme --- yarn-project/pxe/README.md | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/yarn-project/pxe/README.md b/yarn-project/pxe/README.md index ccbe49a9032..ba56822b3db 100644 --- a/yarn-project/pxe/README.md +++ b/yarn-project/pxe/README.md @@ -1,10 +1,10 @@ -# PXEService & PXEClient +# PXE Service & PXE -`PXEService` is a server-side software that provides a set of apis for interacting with the Aztec network. It acts as a bridge between the network and client applications by exposing methods to manage accounts, deploy contracts, create transactions, and retrieve public and account-specific information. It provides a secure environment for the execution of sensitive operations, ensuring private information and decrypted data are not accessible to unauthorized applications. The PXEService is a critical component of the Aztec network, and its security and reliability are essential to the overall trustworthiness of user's data. +`PXE Service` (pronounced "pixie service") is a server-side software that provides a set of apis for interacting with the Aztec network. It acts as a bridge between the network and client applications by exposing methods to manage accounts, deploy contracts, create transactions, and retrieve public and account-specific information. It provides a secure environment for the execution of sensitive operations, ensuring private information and decrypted data are not accessible to unauthorized applications. The PXE Service is a critical component of the Aztec network, and its security and reliability are essential to the overall trustworthiness of user's data. -`PXEClient` is the interface the PXEService and every client-side instance implement. Various implementations of the client-side can exist, including those for different platforms such as mobile apps and web browsers. It is a relay between the dApps and the actual PXEService. +`PXE` is the interface the PXE Service and every client-side instance implement. Various implementations of the client-side can exist, including those for different platforms such as mobile apps and web browsers. It is a relay between the dApps and the actual PXE Service. -### Main Components in an PXEService +### Main Components in an PXE Service - [Acir Simulator](../acir-simulator/) - [Key Store](../key-store/)