Skip to content

Commit

Permalink
fix: typo fix roundup (#3302)
Browse files Browse the repository at this point in the history
We now have a policy about trivial changes. We regret this, but have
felt it is the right call on balance to deal with a precendent set with
using github commit counts for airdrops. We will revisit this. Rounding
up these changes:

commit d26a855d989c8bca7787e979024a6fbfc7af15c6
Author: Darigov Research
<[email protected]>
Date:   Sun Nov 12 13:34:24 2023 +0000

    fix: Corrects typo in privacy considerations page

commit ce63e9875041542ed537c18ee7227101a8cb775e
Author: Darigov Research
<[email protected]>
Date:   Sun Nov 12 13:28:49 2023 +0000

    fix: Removes unintended new line

commit 34c841ff40b3a6126b7abf25e5a81ec18c7e472a
Author: Darigov Research
<[email protected]>
Date:   Sun Nov 12 13:27:42 2023 +0000

    fix: Makes typo corrections to limitations page of docs

commit 7be85ee645a120d260d3c679bf8aa7158e419f2d
Author: Darigov Research
<[email protected]>
Date:   Sun Nov 12 13:10:25 2023 +0000

    refactor: Makes Boxes subrepo readme easier to consume

commit 6c481f6667633fe602ab56bcce162168283918ea
Author: Darigov Research
<[email protected]>
Date:   Sun Nov 12 13:04:06 2023 +0000

    fix: corrects typos in aztec-sandbox readme

commit 718a33684f126f24213d6b0ebd0e9d63e1d2cc13
Author: Darigov Research
<[email protected]>
Date:   Sun Nov 12 13:00:23 2023 +0000

refactor: Updates packages readme to make commands one click copyable

commit 3ffd0fc56d3fd725b7301d782ff512345cd1581c
Author: Darigov Research
<[email protected]>
Date:   Sun Nov 12 12:48:46 2023 +0000

    refactor: removes incorrect adjustment

commit 07a203327a05eb6ba43f15d3eb98c42fbb34cfa5
Author: Darigov Research
<[email protected]>
Date:   Sun Nov 12 12:46:43 2023 +0000

    fix: Corrects typo in circuits readme

commit ac0d407699ff069cfb8cff197dec8ac580badf14
Author: Darigov Research
<[email protected]>
Date:   Sat Nov 11 23:20:26 2023 +0000

    fix: Makes nargo install command one click copyable

commit 19f499c06c9eb933870e6734e9e44da466c18150
Author: Darigov Research
<[email protected]>
Date:   Sat Nov 11 22:43:34 2023 +0000

    fix: Updates storage_slots.md in docs to be easier to read

commit e75dce05ff23d55b374a76d07290db70e54e756c
Author: Darigov Research
<[email protected]>
Date:   Sat Nov 11 22:20:33 2023 +0000

    fix: Corrects copy in state model page

commit 5ae91ba138a21340942af73fd380aaabce3140b7
Author: Web-person <[email protected]>
Date:   Sat Nov 11 21:50:37 2023 +0100

    typos in public_vm.md

    fix typos

Please provide a paragraph or two giving a summary of the change,
including relevant motivation and context.
  • Loading branch information
ludamad authored Nov 14, 2023
1 parent df76636 commit 9dd778d
Show file tree
Hide file tree
Showing 10 changed files with 67 additions and 25 deletions.
6 changes: 5 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,11 @@ To build the C++ code, follow the [instructions in the circuits subdirectory](./
To build Typescript code, make sure to have [`nvm`](https://github.com/nvm-sh/nvm) (node version manager) installed.

To build noir code, make sure that you are using the version from `yarn-project/noir-compiler/src/noir-version.json`.
Install nargo by running `noirup -v TAG_FROM_THE_FILE`.

Install nargo by running
```
noirup -v TAG_FROM_THE_FILE
```

## Continuous Integration

Expand Down
2 changes: 1 addition & 1 deletion circuits/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -215,7 +215,7 @@ See pseudocode in [this diagram](https://miro.com/app/board/uXjVPlafJWM=/) and t

## Public Kernel Circuit

The public kernel circuit performs many of the functions of the private kernel circuit but for public functions. Public functions differ from public functions in that they they are exeucted by the sequencer and can modify the public state tree. Like private functions, public functions can include calls to other public functions and these calls are validated within the circuit.
The public kernel circuit performs many of the functions of the private kernel circuit but for public functions. Public functions differ from public functions in that they they are executed by the sequencer and can modify the public state tree. Like private functions, public functions can include calls to other public functions and these calls are validated within the circuit.

The public kernel circuit in Aztec 3 is implemented in [`circuit/kernel/public`](https://github.com/AztecProtocol/aztec3-packages/tree/master/circuits/cpp/src/aztec3/circuits/kernel/publlic) directory. The input and output interface of the private kernel circuit is written in [`circuits/abis/public_kernel`](https://github.com/AztecProtocol/aztec3-packages/tree/master/circuits/cpp/src/aztec3/circuits/abis/public_kernel).

Expand Down
6 changes: 3 additions & 3 deletions docs/docs/concepts/advanced/public_vm.md
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ Point 2 requires a Virtual Machine architecture. The older model of having ACIR

The kernel circuit cannot prevent this by _requiring_ the public function proof to succeed, as it is trivial for a malicious contract writer to create unsatisfiable programs (e.g. `assert(true == false)`).

We cannot require a Prover/Sequencer simulates the transaction to determine whether it is possible to include it in the block proof, as this amounts to unpaid compute that can be used as a DoS attack vector.
We cannot require that a Prover/Sequencer simulates the transaction to determine whether it is possible to include it in the block proof, as this amounts to unpaid compute that can be used as a DoS attack vector.

### VM Solution

Expand Down Expand Up @@ -51,7 +51,7 @@ The following L1 costs also apply:

Under a VM model, the VM simulator can perform opcode-by-opcode gas metering.

(need to define VM arch for more detail)
(need to define VM architecture for more detail)

## VM ABI

Expand Down Expand Up @@ -242,7 +242,7 @@ Additional witness commitments required that are not part of UltraPlonk/Honk:

$PC, I, C_{w1}, C_{w2}, C_{w3}, C_{w4}, E, G, T_{w1}, T_{w2}, T_{w3}, T_{w4}$

In addition, selector context polynomials $C_{q}$ will likely represent least 4 selectors in order to handle ACIR's linear combination instruction
In addition, selector context polynomials $C_{q}$ will likely represent at least 4 selectors in order to handle ACIR's linear combination instruction

That's 28 additional witness polynomial commitments on top of the usual Honk commitments.

Expand Down
2 changes: 1 addition & 1 deletion docs/docs/concepts/foundation/state_model/main.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ Aztec has a hybrid public/private state model. Aztec contract developers can spe

## Public State

Aztec has public state that will be familiar to developers coming that have worked on other blockchains. Public state is transparent is managed by the associated smart contract logic.
Aztec has public state that will be familiar to developers coming that have worked on other blockchains. Public state is transparent and is managed by the associated smart contract logic.

Internal to the Aztec network, public state is stored and updated by the sequencer. The sequencer executes state transitions, generates proofs of correct execution (or delegates proof generation to the prover network), and publishes the associated data to Ethereum.

Expand Down
6 changes: 3 additions & 3 deletions docs/docs/concepts/foundation/state_model/storage_slots.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ title: Storage Slots
description: How are storage slots derived for public and private state
---

In Aztec private data and public data are stored in two trees, a public data tree and a note hashes tree.
In Aztec, private data and public data are stored in two trees; a public data tree and a note hashes tree.

These trees have in common that they store state for *all* accounts on the Aztec network directly as leaves. This is different from Ethereum, where a state trie contains smaller tries that hold the individual accounts' storage.

Expand All @@ -28,7 +28,7 @@ For structs and arrays, we are logically using a similar storage slot computatio

Private storage is a different beast. As you might remember from [State Model](./main.md), private state is stored in encrypted logs and the corresponding private state commitments in append-only tree where each leaf is a commitment. Being append-only, means that leaves are never updated or deleted; instead a nullifier is emitted to signify that some note is no longer valid. A major reason we used this tree, is that lookups at a specific storage slot would leak information in the context of private state. If you could look up a specific address balance just by looking at the storage slot, even if encrypted you would be able to see it changing! That is not good privacy.

Following this. The storage slot as we know it doesn't really exists. The leaves of the note hashes tree are just commitments to content (think of it as a hash of its content).
Following this, the storage slot as we know it doesn't really exist. The leaves of the note hashes tree are just commitments to content (think of it as a hash of its content).

Nevertheless, the concept of a storage slot is very useful when writing applications, since it allows us to reason about distinct and disjoint pieces of data. For example we can say that the balance of an account is stored in a specific slot and that the balance of another account is stored in another slot with the total supply stored in some third slot. By making sure that these slots are disjoint, we can be sure that the balances are not mixed up and that someone cannot use the total supply as their balance.

Expand Down Expand Up @@ -62,4 +62,4 @@ By doing this address-siloing at the kernel circuit we *force* the inserted comm
To ensure that nullifiers don't collide across contracts we also force this contract siloing at the kernel level.
:::

For an example of this see [developer documentation storage slots](./../../../dev_docs/contracts/syntax/storage/storage_slots.md).
For an example of this see [developer documentation storage slots](./../../../dev_docs/contracts/syntax/storage/storage_slots.md).
6 changes: 3 additions & 3 deletions docs/docs/dev_docs/limitations/main.md
Original file line number Diff line number Diff line change
Expand Up @@ -221,7 +221,7 @@ Note that there is no plan to change this in the future.

### Example

Let us assume that the main function named $f_1$ is calling in order $f_2$, $f_3$ (which calls $f_5$ folllowed by $f_6$), and $f_4$.
Let us assume that the main function named $f_1$ is calling in order $f_2$, $f_3$ (which calls $f_5$ followed by $f_6$), and $f_4$.

Call Dependency:

Expand All @@ -239,13 +239,13 @@ Private Kernel Processing Order:
#### What are the consequences?

Transaction output elements such as notes in encrypted logs, note hashes (commitments), nullifiers might be ordered differently than the one exepected by the execution.
Transaction output elements such as notes in encrypted logs, note hashes (commitments), nullifiers might be ordered differently than the one expected by the execution.

### Chopped Transient Notes are still Emitted in Logs

A note which is created and nullified during the very same transaction is called transient. Such a note is chopped by the [private kernel circuit](../../concepts/advanced/circuits/kernels/private_kernel.md) and is never stored in any persistent data tree.

For the time being, such chopped notes are still emitted through encrypted logs (which is the communication channel to transmit notes). When a log containing a chopped note is processed, a warning will be logged about a decrypted note which does not exist in data tree. We [improved](https://github.com/AztecProtocol/aztec-packages/issues/1603) error logging to help identify such an occurence. However, this might be a source of confusion.
For the time being, such chopped notes are still emitted through encrypted logs (which is the communication channel to transmit notes). When a log containing a chopped note is processed, a warning will be logged about a decrypted note which does not exist in data tree. We [improved](https://github.com/AztecProtocol/aztec-packages/issues/1603) error logging to help identify such an occurrence. However, this might be a source of confusion.
This issue is tracked in ticket [#1641](https://github.com/AztecProtocol/aztec-packages/issues/1641).

### Note Terminology: Note Commitments and Note Hashes
Expand Down
2 changes: 1 addition & 1 deletion docs/docs/dev_docs/privacy/main.md
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,7 @@ Tl;dr: app developers should think about the _timing_ of user transactions, and

### Function Fingerprints and Tx Fingerprints

A 'Function Fingerprint' is any data which is exposed by a function to the outside world. A 'Tx Fingerprint' is any data which is exposed by a tx to the outside world. We're interested in minimising leakages of information from private txs. The leakiness of a Tx Fingerprint depends on the leakiness of its consituent functions' Function Fingerprints _and_ on the appearance of the tx's Tx Fingerprint as a whole. For a private function (and by extension, for a private tx), the following information _could_ be leaked (depending on the function, of course):
A 'Function Fingerprint' is any data which is exposed by a function to the outside world. A 'Tx Fingerprint' is any data which is exposed by a tx to the outside world. We're interested in minimising leakages of information from private txs. The leakiness of a Tx Fingerprint depends on the leakiness of its constituent functions' Function Fingerprints _and_ on the appearance of the tx's Tx Fingerprint as a whole. For a private function (and by extension, for a private tx), the following information _could_ be leaked (depending on the function, of course):

- All calls to public functions.
- The contract address of the private function (if it calls an internal public function).
Expand Down
43 changes: 35 additions & 8 deletions yarn-project/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,15 +6,36 @@ All the Typescript packages that make up [Aztec](https://docs.aztec.network/azte

All scripts are run in the `yarn-project` workspace root:

- Run `yarn` to install dependencies
- Run `yarn build:dev` to compile all packages on file changes
- Run `yarn prepare` to update `tsconfig.json` and `build_manifest.json` references
- Run `yarn format` to prettify all files
- Run `yarn formatting` to check prettier and eslint rules on each package (slow)
- To install dependencies run
```
yarn
```
- To compile all packages on file changes run
```
yarn build:dev
```
- To update `tsconfig.json` and `build_manifest.json` references run
```
yarn prepare
```
- To prettify all files run
```
yarn format
```
- To check prettier and eslint rules on each package (slow) run
```
yarn formatting
```

## Tests

To run tests for a specific package, just run `yarn test` in its folder. Note that `end-to-end` tests require `anvil` to be running, which is installed as part of the Foundry toolchain.
To run tests for a specific package, in its folder just run

```
yarn test
```

Note that `end-to-end` tests require `anvil` to be running, which is installed as part of the Foundry toolchain.

## Useful extensions

Expand All @@ -27,7 +48,13 @@ Consider installing the Prettier and ESLint extensions if using VSCode. Configur

## Package.json inheritance

To simplify the management of all package.json files, we have a custom script that injects the contents of `package.common.json` into all packages that reference it via the `inherits` custom field. To run the script, just run `yarn prepare`. To override any of the fields from `package.common.json`, declare a `package.local.json` local to the package and add it to the `inherits` field.
To simplify the management of all package.json files, we have a custom script that injects the contents of `package.common.json` into all packages that reference it via the `inherits` custom field. To run the script, just run

```
yarn prepare
```

To override any of the fields from `package.common.json`, declare a `package.local.json` local to the package and add it to the `inherits` field.

## Adding a new package

Expand Down Expand Up @@ -61,4 +88,4 @@ COMMIT_TAG=<RELEASE_TAG_NUMBER_YOU_WANT e.g. aztec-packages-v0.8.8>
- Locally update the package version in package.json using `jq` as shown in the script
- Do a dry-run
- If dry run succeeds, publish the package!
5. Create a PR by adding your package into the `deploy-npm` script so next release onwards, CI can cut releases for your package.
5. Create a PR by adding your package into the `deploy-npm` script so next release onwards, CI can cut releases for your package.
4 changes: 2 additions & 2 deletions yarn-project/aztec-sandbox/README.md
Original file line number Diff line number Diff line change
@@ -1,12 +1,12 @@
# aztec-sandbox

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.
Aztec Sandbox is a package that allows for a simple development environment on Aztec stack. It creates a 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:

### Docker Compose

The easiesty way to run is by using `docker compose up`. This will create two containers:
The easiest way to run is by using `docker compose up`. This will create two containers:

1. The sandbox listening on port `8080`
2. An anvil instance listening on port `8545`
Expand Down
15 changes: 13 additions & 2 deletions yarn-project/boxes/README.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,14 @@
This contains the "boxes" that are meant for quickstarts for Aztec smart contract developers, containing simple Noir smart contracts and frontends.
# Aztec Boxes
A minimal framework for building full stack applications for Aztec (using React).

If CI is failing, it may be due to incompatibility with previous build artifacts - running "./bootstrap.sh" inside this boxes folder should regenerate the artifacts.
## Introduction

This folder contains the "boxes" that are meant for quickstarts for Aztec smart contract developers, including simple Noir smart contracts and frontends.

## Debugging

If CI is failing, it may be due to incompatibility with previous build artifacts - running the following command inside this boxes folder should regenerate the artifacts.

```
./bootstrap.sh
```

0 comments on commit 9dd778d

Please sign in to comment.