Skip to content

Layr-Labs/eigensdk-rs

Repository files navigation

EigenSDK-rs

EigenSDK-rs is an initiative for rust developers to build AVSs on eigenlayer.

Installation

cargo add eigensdk --features full

Overview

List of crates in the repository :-

Examples

You can run any example using the command cargo run --example <example-name>

Example :

cargo run --example get_quorum_count

Contract Bindings

The main branch of this repo is intended to be syncronized with mainnet version of core contracts.

To update the bindings of this repo:

  • Inside the crates/contracts folder, run:
forge bind --alloy --bindings-path <path-eigensdk-rs>/crates/utils --overwrite -C src/contracts

where path-eigensdk-rs is the full path to the eigensdk-rs (this) repo.

This command will generate the bindings files in the folder: <path-eigensdk-rs>/crates/utils.

⚠️ It rewrites Cargo.toml file, this file must be restored to the current version.

  • Fix all compilation warnings.

Contributor Guidelines

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.

Branches

  • main - Points to the latest mainnet release of contracts.
  • testnet - Points to the latest testnet release of contracts.
  • dev - Points to the latest dev branch of the contracts.

PR

To test locally :-

You need foundry to successfully run it.

cargo test

On Mac, you might need to pull the foundry image manually specifying the platform with:

docker pull --platform amd64 foundry-rs/foundry

Sometimes the bindings fail due to containing botched doctests. You can exclude them from the test run with:

cargo test --workspace --exclude eigen-utils

At least 1 approving review is required to merge the PR.

lint

make lint

To run fireblocks tests

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

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

Supported Rust Version

Rolling MSRV policy of 6 months. The current MSRV is 1.79

Disclaimer

🚧 EigenSDK-rs is under active development and has not been audited. EigenSDK-rs is rapidly being upgraded, features may be added, removed or otherwise improved or modified and interfaces will have breaking changes. EigenSDK-rs should be used only for testing purposes and not in production. EigenSDK-rs is provided "as is" and Eigen Labs, Inc. does not guarantee its functionality or provide support for its use in production. 🚧

Credits

Security Bugs

Please report security vulnerabilities to security@eigenlabs.org. Do NOT report security bugs via Github Issues.

Support

Join our telegram channel .