Table of Contents
Kakarot RPC fits in the three-part architecture of the Kakarot zkEVM rollup (Kakarot EVM Cairo Programs, Kakarot RPC, Kakarot Indexer). It is the implementation of the Ethereum JSON-RPC specification made to interact with Kakarot zkEVM in a fully Ethereum-compatible way.
The Kakarot RPC layer's goal is to receive and output EVM-compatible payloads & calls while interacting with an underlying StarknetOS client. This enables Kakarot zkEVM to interact with the usual Ethereum tooling: Metamask, Hardhat, Foundry, etc.
Note that this is necessary because Kakarot zkEVM is implemented as a set of Cairo Programs that run on an underlying CairoVM (so-called StarknetOS) chain.
This adapter layer is based on:
Here is a high level overview of the architecture of Kakarot RPC.
Below is a lower level detailed overview of the internal architecture.
TL;DR:
- Run
make setup
to build dependencies. - Run
cargo build
to build Kakarot RPC. - Test with
make test
. - Run Kakarot RPC in dev mode:
- Run dev RPC:
make run-dev
(you'll need a StarknetOS instance running in another process and Kakarot contracts deployed)
- Run dev RPC:
- Run with Docker Compose:
make katana-rpc-up
- To kill these processes,
make docker-down
To set up the repository (pulling git submodule and building Cairo dependencies), run:
make setup
Caveats: the setup
make command uses linux (MacOs compatible)
commands to allow running the ./scripts/extract_abi.sh
.
This script is used to use strongly typed Rust bindings for Cairo programs.
If you encounter problems when building the project, try running ./scripts/extract_abi.sh
To build the project from source (in release mode):
cargo build --release
Note that there are sometimes issues with some dependencies (notably scarb or cairo related packages, there are sometimes needs to cargo clean
and cargo build
)
Copy the .env.example
file to a .env
file and populate each variable
cp .env.example .env
Meanwhile you can just use unit tests to dev.
make test
The binaries will be located in target/release/
.
Dev mode with Katana
To run a local StarknetOS client (Katana) and deploy Kakarot zkEVM on it, i.e. the set of Cairo smart contracts implementing the EVM:
make run-katana
To deploy Kakarot Core EVM (set of Cairo Programs):
make deploy-kakarot
To run the Kakarot RPC pointing to this local devnet:
STARKNET_NETWORK=katana make run-dev
Some notes on this local devnet:
-
this will run a devnet by running katana, with contracts automatically deployed, so you don't have to do them manually (see in
./lib/kakarot/scripts/deploy_kakarot.py
for the list of contracts). -
the deployments and declarations for the devnet will be written to the
deployments/katana
folder inside your project root after a successful run of themake deploy-kakarot
command.
Running with Docker Compose
To orchestrate running a Katana/Madara devnet instance, deploy Kakarot contracts and initialize the RPC, you may use the following commands:
For Katana
make katana-rpc-up
For Madara
make madara-rpc-up
Sending transactions to RPC using forge script
An example script to run which uses a pre-funded EOA account with private key
EVM_PRIVATE_KEY
forge script scripts/PlainOpcodes.s.sol --broadcast --legacy --slow
Kakarot RPC is configurable through environment variables.
Check out .env.example
file to see the environment variables.
You can take a look at rpc-call-examples
directory. Please note the following:
sendRawTransaction.hurl
: the raw transaction provided allows to call theinc()
function for the Counter contract. However, given that this transaction is signed for the EOA's nonce at the current devnet state (0x2), the call will only work once. If you want to keep incrementing (or decrementing) the counter, you need to regenerate the payload for the call with an updated nonce using the provided python script.
If you want to say thank you or/and support active development of Kakarot RPC:
- Add a GitHub Star to the project.
- Tweet about the Kakarot RPC: https://twitter.com/KakarotZkEvm.
First off, thanks for taking the time to contribute! Contributions are what make the open-source community such an amazing place to learn, inspire, and create. Any contributions you make will benefit everybody else and are greatly appreciated.
Please read our contribution guidelines, and thank you for being involved!
- StarknetOS chain: also called CairoVM chain, or Starknet appchain, it is a full-node (or sequencer) that is powered by the Cairo VM (Cairo smart contracts can be deployed to it). It a chain that behaves in most ways similarly to Starknet L2.
- Kakarot Core EVM: The set of Cairo Programs that implement the Ethereum Virtual Machine instruction set.
- Katana: A StarknetOS sequencer developed by the Dojo team. Serves as the underlying StarknetOS client for Kakarot zkEVM locally. It is built with speed and minimalism in mind.
- Madara: A StarknetOS sequencer and full-node developed by the Madara (e.g. Pragma Oracle, Deoxys, etc.) and Starkware exploration teams. Based on the Substrate framework, it is built with decentralization and robustness in mind.
- Kakarot zkEVM: the entire system that forms the Kakarot zkRollup: the core EVM Cairo Programs and the StarknetOS chain they are deployed to, the RPC layer (this repository), and the Kakarot Indexer (the backend service that ingests Starknet data types and formats them in EVM format for RPC read requests).
For a full list of all authors and contributors, see the contributors page.
Kakarot RPC follows good practices of security, but 100% security cannot be assured. Kakarot RPC is provided "as is" without any warranty. Use at your own risk.
For more information and to report security issues, please refer to our security documentation.
This project is licensed under the MIT license.
See LICENSE for more information.
We warmly thank all the people who made this project possible.
- Reth (Rust Ethereum), Thank you for providing open source libraries for us to reuse.
- jsonrpsee
- Starkware and its exploration team, thank you for helping and providing a great test environment with Madara.
- Lambdaclass
- Dojo, thank you for providing great test utils.
- starknet-rs, thank you for a great SDK.
- All our contributors. This journey wouldn't be possible without you.
For now, Kakarot RPC provides a minimal benchmarking methodology. You'll need Bun installed locally.
- Run a Starknet node locally (Katana or Madara),
e.g.
katana --block-time 6000 --disable-fee
if you have the dojo binary locally, ormake madara-rpc-up
for Madara. - Deploy the Kakarot smart contract (
make deploy-kakarot
) - Run the Kakarot RPC binary (
make run-dev
) - Run
make benchmark-katana
ormake benchmark-madara
Thanks goes to these wonderful people (emoji key):
This project follows the all-contributors specification. Contributions of any kind welcome!