Skip to content

ponkila/ethereum.nix

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ethereum.nix = Ethereum + Nix 🫶

Ethereum Ecosystem Built with nix License

This is an experimental Nix project for integrating the most interesting / important projects in the Ethereum ecosystem as Nix packages / NixOS modules.

Many of the packages found ~~~~here will be added to nixpkgs repository once they're stable / mature enough. But for some others, more experimental ones, they can reside here.

This project is developed entirely in Nix Flakes.

Usage

As a flake (recommended)
{
  inputs = {
    ethereum-nix = {
      url = "github:nix-community/ethereum.nix";
      inputs.nixpkgs.follows = "nixpkgs";
    };
    nixpkgs.url = "nixpkgs/nixos-unstable";
  };

  outputs = { self, ethereum-nix, nixpkgs }: {
    nixosConfigurations.nixos = nixpkgs.lib.nixosSystem {
      system = "x86_64-linux";
      modules = [
        ({ pkgs, ... }: {
          nixpkgs.overlays = [ ethereum-nix.overlays.default ];
        })
      ];
    };
  };
}
As an overlay
# configuration.nix
{ pkgs, ... }: {
  nixpkgs.overlays = [
    (import "${fetchTarball "https://github.com/nix-community/ethereum.nix/archive/main.tar.gz"}/overlays.nix")
  ];
  environment.systemPackages = with pkgs; [
    teku
    lighthouse
    # <...>
  ];
}

Setup

NixOS

If you're on NixOS, chances are you know what you're doing. If you don't have installed direnv, clone this repository and when entering inside the folder, just execute nix develop. It will load a devShell environment ready to be used.

Optional: install direnv, so whenever you enter inside the directory, it will run nix develop for you automatically.

Non-NixOS

To get started, run the following:

  1. Install Nix:
$ curl -L https://nixos.org/nix/install | sh
  1. Clone this repository and when entering inside the folder, just execute nix develop. It will load a devShell environment ready to be used.

Optional: install direnv, so whenever you enter inside the directory, it will run nix develop for you automatically.

Development

Docs

To serve the docs run , docs-serve. You can edit the docs in ./docs.

To build the docs run , docs-build. The output will be inside of ./result.

Running tests

To run all tests you can use nix flake check, it will build all packages and run all tests.

To execute a specific test you can use , test -h which will provide more information.

Formatting

You can manually format using the format command like so:

, fmt

Applications

Note: every command has a local and a remote variant. The local variant requires that the command is run from within the cloned repo. The remote variant can be run from wherever.

Local: nix run .#my-app-name

Remote: nix run github:nix-community/ethereum.nix#my-app-name

For brevity and consistency, all the commands are listed in the local variant

Executables provided

Consensus Clients

  • prysm:
    • beacon-chain: nix run .#prysm-beacon-chain
    • client-stats: nix run .#prysm-client-stats
    • prysmctl: nix run .#prysm-ctl
    • validator: nix run .#prysm-validator
  • teku: nix run .#teku
  • lighthouse: nix run .#lighthouse

Execution Clients

  • besu: nix run .#besu
  • erigon: nix run .#erigon
  • geth:
    • abidump: nix run .#abidump
    • abigen: nix run .#abigen
    • bootnode: nix run .#bootnode
    • clef: nix run .#clef
    • devp2p: nix run .#devp2p
    • ethkey: nix run .#ethkey
    • evm: nix run .#evm
    • faucet: nix run .#faucet
    • geth: nix run .#geth
    • rlpdump: nix run .#rlpdump

Validators

MEV Utilities

Signers

Utilities / Tools / Other

NixOS Modules

We provide modules for configuring and running various services. Some process arguments have been nix'ified. For those which aren't there is typically and an extraArgs array that can be passed to the process.

Geth

services.ethereum.geth.mainnet = {
    enable = true;
    openFirewall = true;
    service.supplementaryGroups = [users.groups.keys.name];
};

services.ethereum.geth.goerli = {
    enable = true;
    openFirewall = true;
    args = {
      network = "goerli";
      dataDir = "/data/ethereum/goerli/geth";
      authrpc.jwtsecret = sops.secrets.geth_jwt_secret.path;
      service.supplementaryGroups = [users.groups.keys.name];
    }
};

Prysm Beacon Chain

services.ethereum.prysm.beacon.mainnet = {
    enable = true;
    args = {
      jwt-secret = secrets.prysm_jwt_secret.path;
      service.supplementaryGroups = [users.groups.keys.name];
    };
};

services.ethereum.prysm.beacon.goerli = {
    enable = true;
    args = {
      network = "goerli";
      dataDir = "/data/ethereum/goerli/prysm-beacon";
      jwt-secret = secrets.prysm_jwt_secret.path;
      service.supplementaryGroups = [users.groups.keys.name];
      checkpoint.sync-url = "https://goerli.checkpoint-sync.ethpandaops.io";
      genesis.beacon-api-url = "https://goerli.checkpoint-sync.ethpandaops.io";
    };
};

Erigon

services.ethereum.erigon.sepolia = {
  enable = true;
  openFirewall = true;
  args = {
    chain = "sepolia";
    datadir = "/data/ethereum/sepolia/erigon";
    http = {
      enable = true;
      addr = "0.0.0.0";
      api = ["eth" "erigon" "engine" "sealer" "net"];
      vhosts = ["localhost" "dione"];
    };
  };
};

Libraries

Some crypto projects may need specific libraries to be available to compile properly. Below you can find the list of included ones:

Libraries provided

Contribute

We welcome any kind of contribution or support to this project but before to do so:

  • Make sure you have read the contribution guide for more details on how to submit a good PR (pull request).

In addition you can always:

Acknowledgements

This project has been inspired by the awesome work of:

  • cosmos.nix by Informal Systems which this repository takes inspiration on it's README and several other places.

  • willruggiano on his work done in eth-nix repository that served as the initial kick-start for working on this project.

About

Nix packages and NixOS modules for the Ethereum ecosystem. [maintainers=@aldoborrero,@brianmcgee,@selfuryon]

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Nix 99.9%
  • Shell 0.1%