Skip to content

Repo to show how to Make a splitwise like contract and frontend in Aztec. This is my LIP

Notifications You must be signed in to change notification settings

Cheetah0x/aztec-privategroup

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

21 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Private Expense Splitting Contract in Aztec

This project is a walk-through for creating an expense splitting contract in Aztec, focusing on private and public contexts, contract deployment, testing with AztecJS and the Testing Execution Environment (TXE), creating notes, and setting up a demo frontend. This project uses Aztec version 0.60.0, which is in pre-release. Future updates may include breaking changes.

Project Overview

In this tutorial, you’ll learn to:

  1. Write contracts with private state in Aztec.
  2. Understand and compare design patterns for public and private contexts.
  3. Create notes and interact with contract state through notes.
  4. Test Aztec contracts using AztecJS and the TXE.
  5. Implement a simple frontend using AztecJS.

These contracts are for educational purposes and are not optimized or production-ready.

Prerequisites

  • Aztec Sandbox with PXE, aztec-nargo version 0.60.0

For more background, review Aztec’s documentation at Aztec Network.


Setup

  1. Install Dependencies:

    yarn install
  2. Initialize Project:

    • Initialize your Aztec project within the src folder:

      mkdir src && cd src
      aztec-nargo new --contract circuits
  3. Generate TypeScript Artifacts:

    • Compile the Noir contract and generate TypeScript artifacts:

      cd src/circuits
      aztec-nargo compile
      aztec codegen -o src/artifacts target
  4. Installing the Aztec Sandbox .

    bash -i <(curl -s https://install.aztec.network)
  1. Running the Aztec Sandbox (make sure it’s running for contract interaction)

    aztec start --sandbox


Writing Contracts and Notes

In this tutorial, we’ll create:

  • PrivateGroups: A contract to manage shared balances, member groups, and payments.
  • NewAddressNote: A custom note type that includes an Aztec address and encrypted data.

For more information on contract functions and design patterns, refer to the comments within main.nr and NewAddressNote.nr.


Testing

Two main testing options are available:

1. End-to-End Testing with AztecJS

  1. Setup Testing Files:

    • Add Jest and TypeScript configuration files:
      • jest.integration.config.json
      • tsconfig.json
  2. Run Tests:

    yarn test

2. TXE Testing

TXE tests allow direct contract storage access without full protocol checks, ideal for rapid development. Tests are stored within src/circuits/src/test.

  1. Run TXE Tests:

    cd src/circuits
    aztec test --show-output

Key Concepts

  1. Notes: In Aztec, notes provide a private, UTXO-like model for transactions, where each note can represent value or arbitrary data, stored in a private, append-only Merkle tree.
  2. Contexts:
    • Public Context: Simpler structure, all data accessible.
    • Private Context: Requires encrypted notes for private state, offering higher privacy.
  3. Testing with TXE: TXE enables faster testing through “cheatcodes” for flexible, isolated testing without full protocol compliance.

Additional Resources

About

Repo to show how to Make a splitwise like contract and frontend in Aztec. This is my LIP

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published