Skip to content
This repository has been archived by the owner on Jan 8, 2025. It is now read-only.

Latest commit

 

History

History
251 lines (189 loc) · 15.3 KB

README.md

File metadata and controls

251 lines (189 loc) · 15.3 KB

Update - Archive

The development of kakarot-ssj is halted for now. This repository - an Ethereum Virtual Machine (EVM) emulator on Starknet - is frozen, mainly to halt creation of new issues and pull requests. It is MIT licensed, not audited.

Kakarot, the zkEVM written in Cairo.


GitHub Workflow Status GitHub GitHub contributors GitHub top language Telegram Contributions welcome Read FAQ GitHub Repo stars Twitter Follow

Table of Contents

About

Kakarot is an (zk)-Ethereum Virtual Machine implementation written in Cairo. Kakarot is Ethereum compatible, i.e. all existing smart contracts, developer tools and wallets work out-of-the-box on Kakarot. It's been open source from day one. Soon available on Starknet L2 and Appchains.

🚧 It is a work in progress, and it is not ready for production.

Getting Started

This repository is a Cairo rewrite of the CairoZero version of Kakarot zkEVM.

Installation

  • Install Scarb. To make sure your version always matches the one used by Kakarot, you can install Scarb via asdf.

  • Install Starknet Foundry. We also recommend installing it via asdf.

  • Install the Cairo Profiler to profile your Cairo code.

  • Install Bun to run the JavaScript scripts.

  • Fork the repository and clone your fork (git clone https://github.com/<YOUR_USERNAME>/kakarot-ssj)

  • Run make install to install the git hooks.

  • Add your environment variables to .env (see .env.example for an example).

    • Get your Github token here

Usage

Build

scarb build

Test

scarb test

Format

The project uses trunk for everything except cairo files. If you don't have it installed already, you can do:

curl https://get.trunk.io -fsSL | bash

then

trunk check --fix

VS Code users, don't miss the VS Code trunk plugin.

For cairo files, run:

scarb fmt

Roadmap

See the open issues for a list of proposed features (and known issues).

Support

Reach out to the maintainer at one of the following places:

Project assistance

If you want to say thank you or/and support active development of Kakarot:

Together, we can make Kakarot better!

Contributing

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 contribution you make will benefit everybody else and is greatly appreciated.

Please read our contribution guidelines, and thank you for being involved!

Authors & contributors

For a full list of all authors and contributors, see the contributors page.

Security

Kakarot follows good practices of security, but 100% security cannot be assured. Kakarot 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.

License

This project is licensed under the MIT license.

See LICENSE for more information.

Acknowledgements

Contributors ✨

Thanks goes to these wonderful people (emoji key):

Abdel @ StarkWare
Abdel @ StarkWare

💻
johann bestowrous
johann bestowrous

💻
Elias Tazartes
Elias Tazartes

👀 📢
Mathieu
Mathieu

💻 ⚠️ 📖
khaeljy
khaeljy

💻
Clément Walter
Clément Walter

💻
Lucas @ StarkWare
Lucas @ StarkWare

💻
lambda-0x
lambda-0x

💻
danilowhk
danilowhk

💻
Tristan
Tristan

💻
Quentash
Quentash

💻
ftupas
ftupas

💻
Aniket Prajapati
Aniket Prajapati

💻
Daniel Bejarano
Daniel Bejarano

💻
Noeljarillo
Noeljarillo

💻
Thomas Butler
Thomas Butler

💻
Ammar Arif
Ammar Arif

📖
greged93
greged93

💻
Charlotte
Charlotte

💻
akhercha
akhercha

💻
Alexandro T. Netto
Alexandro T. Netto

💻
tedison
tedison

💻
Pia
Pia

💻
glihm
glihm

💻
Add your contributions

This project follows the all-contributors specification. Contributions of any kind welcome!