Here is a list of user stories that the application covers:
# | User Story Description |
---|---|
1 | As a user, I want to send Ether tokens to my wallet on Layer 2. |
2 | As a user, I want to send ERC20 tokens to my wallet on Layer 2. |
3 | As a user, I want to transfer Ether tokens between wallets on Layer 2. |
4 | As a user, I want to transfer ERC20 tokens between wallets on Layer 2. |
5 | As a user, I want to withdraw my deposit in ERC20. |
6 | As a user, I want to withdraw my deposit in Ether. |
7 | As a user, I want to request the balance of Ether in my wallet on Layer 2. |
8 | As a user, I want to request the balance of ERC20 tokens in my wallet on Layer 2. |
9 | As a user, I want to verify if the Ether deposit was received correctly on Layer 2. |
10 | As a user, I want to verify if the ERC20 token deposit was received correctly on Layer 2. |
11 | As a user, I want to receive a confirmation of Ether transfer between wallets on Layer 2. |
12 | As a user, I want to receive a confirmation of ERC20 token transfer between wallets on Layer 2. |
1º - Install all dependencies:
- Cartesi CLI:
$ npm i -g @cartesi/cli
- Foundry: Follow the instruction here
2º - Clone this repo using the code below:
git clone https://github.com/Mugen-Builders/learn-rollmelette.git
The command below will run all unit tests present in the repository.
make test
Note
All user stories covered here can also be fulfilled using the CLI. For more information, please refer to the documentation.
This section will help you set up a Cartesi dApp with Avail on your local machine. You'll be able to send transactions either directly through Cartesi Rollups Smart Contracts on L1 or via Avail DA using EIP-712 signed messages. You'll also learn how to check the dApp's state and outputs using Cartesi Rollups Framework APIs.
As a reference for setting up your machine, follow these steps
- Start brunodo using the command with the flag with the flag that enables integration with Avail:
$ brunodo
- Build your machine:
$ cartesi build
- Run the Cartesi Machine Locally on bare metal using the command:
$ cartesi-machine --network \
--flash-drive=label:root,filename:.cartesi/image.ext2 \
--env=ROLLUP_HTTP_SERVER_URL=http://10.0.2.2:5004 -- /var/opt/cartesi-app/app
- Start brunodo using the command with the flag with the flag that enables integration with Avail:
$ brunodo --avail-enabled -d --contracts-input-box-block 6850934 --rpc-url https://sepolia.drpc.org
- Build your machine:
$ cartesi build
- Run the Cartesi Machine Locally on bare metal using the command:
$ cartesi-machine --network \
--flash-drive=label:root,filename:.cartesi/image.ext2 \
--env=ROLLUP_HTTP_SERVER_URL=http://10.0.2.2:5004 -- /var/opt/cartesi-app/app