eigensdk-rs is an initiative for rust developers to build AVSs on eigenlayer.
List of crates in the repository :-
- eigen-client-avsregistry - Read, Write and subscribe methods for AvsRegistry
- eigen-client-elcontracts - Convenience methods to call Eigenlayer contracts
- eigen-contracts-bindings - Generate ethers bindings for Eigen Layer.
- eigen-crypto-bls - New bls key pair, sign message, conversion utilites between alloy and arkworks bn254.
- eigen-crypto-bn254 - verify message on G2, map to curve.
- eigen-metrics - performance, rpc and economic metrics
- eigen-services - Spawn tokio services for operators info, bls aggregation
- eigen-types - Common types
- eigen-utils - Publicly exportable
m2-mainnet
compatible alloy bindings. - eigen-testing-utils - Contains publicly exportable anvil, holesky, mainnet addresses for eigen contracts.
You can run any example using the command cargo run --example <example-name>
Example :
cargo run --example get_quorum_count
We are actively looking for contributors. Thank you for your interest. We have strict ci checks in place. In case of any questions and support, feel free to raise an issue.
To test locally :-
You need foundry
, docker
and make
to successfully run it. Also, the docker
engine has to be running for all the tests to execute correctly.
make pr
At least 1 approving
review is required to merge the PR.
make lint
Add the following variables to your env
- FIREBLOCKS_API_KEY
- FIREBLOCKS_PRIVATE_KEY_PATH
- FIREBLOCKS_API_URL
and then run the following command
make fireblocks-tests
Test coverage should aim to be around 80%.
Here's how to generate test coverage reports:
Install llvm tools:
make deps
Run the tests with coverage instrumentations:
make coverage
Open the coverage html report in a web browser:
open target/llvm-cov/html/index.html
Rolling MSRV
policy of 6 months. The current MSRV
is 1.79
This software is unaudited
.This is experimental software and is provided on an "as is" and "as available" basis and may not work at all. It should not be used in production.
Please report security vulnerabilities to security@eigenlabs.org. Do NOT report security bugs via Github Issues.
Join our telegram channel .