Features - Local Developer Testnet
We're aiming for a minimal version of a Local Developer Testnet -- with the below features -- in Q3.
An Aztec 3 Local Developer Testnet (LDT) Node is indended to provide developers with a lightweight & fast node, with features similar to Ethereum's Ganache or Anvil 'local node' packages.
Devs should be able to quickly spin up local, emulated instances of an Ethereum blockchain and an Aztec encrypted rollup, and start deploying confidential contracts and submitting confidential txs.
Here's a summary of the features we intend to support with the first release of the A3 LDT.
Noir Contracts
- Noir
contract
scopes.- Declare a
contract
, containing a collection of state variables and functions.
- Declare a
secret
state variables:read
,write
, anddelete
secret
state variables withinsecret
functions.
- public (non-
secret
) state variables:- Manipulate 'public' state in a familiar way to Ethereum state.
secret
functions- May read and modify
secret
state.
- May read and modify
- public functions
- May read and modify public state.
constructor
functions, for initialising contract state.import
other Noir contracts, so their functions may be called.- Nested function calls, for contract composability
secret
functions can callsecret
functions of other contracts, and receive return values.secret
functions can call public functions any contract.- public functions can call
secret
functions of any contract. - public functions can call public functions of other contracts, and receive return values.
secret
functions can be called recursively.- public functions can be called recursively.
- Send messages from Noir contracts to Ethereum L1, for consumption by L1 smart contracts.
- Useful, for example, if writing an app to withdraw funds from L2 to L1.
- Consume messages which have been sent by:
- L1 functions.
- Useful, for example, if writing an app to deposit funds from L1 to L2.
- public L2 functions.
- L1 functions.
- Emit
event
data from a Noir Contract.- Allows applications to subscribe to events which have been emitted by a Noir contract's functions, for example.
- Write
unconstrained
functions.- These allow developers to write
pure
andview
functions, which can perform calculations and retrieve state. E.g. for fetching contract-specific information, which may then be consumed by a dapp, without having to generate a zero-knowledge proof or interact with the 'network'.
- These allow developers to write
aztec.js
A typescript wrapper for making RPC calls to an Aztec LDT node.
- Similar in purpose to
web3.js
/ethers.js
/viem
, but for interacting with Aztec Network nodes. The RPC interface for an Aztec node is necessarily different from that of an Ethereum node, because it deals with encrypted transactions and state variables. - A library for public/private key management.
- Construct
Contract
instances from a Noir contract's JSON ABI. - Deploy new contracts to the Aztec LDT.
- Construct tx requests, passing arguments to a function of a contract.
- Sign tx requests.
- Send txs to the LDT node, for simulating.
- Send txs to the LDT node, to be sent to the LDT network.
- Call
unconstrained
functions of a Noir contract, to performpure
calculations or retrieve state.
Aztec Local Developer Testnet Node
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
- Simulate and/or execute
secret
functions locally.
- Simulate and/or execute
- Aztec Public Node
- Broadcasts a user's txs to the tx pool.
- Simulate public functions locally.
- Tx Pool
- An in-memory emulation of a tx pool. By default, a user's txs will be rolled-up into an L2 block immediately.
- Sequencer Node
- Reads the tx pool and bundles pending txs into a rollup block immediately.
- Orders txs.
- Executes public functions.
- Passes messages between L1 and L2.
- L1 Rollup smart contract
- Verifies the rollup's snark.
- Reconciles calldata with snark public inputs.
- Updates the rollup's state hash.
- L1 data archiver
- Gobbles up and stores all calldata, events, and state changes from L1
- World state DB
- Reconstructs the Aztec Network's various trees.
- Allows tree state to be queried.
Participate
Keep up with the latest discussion and join the conversation in the Aztec forum.