From 59e3addfebc751fa3f9843dda1a831591bb86c3f Mon Sep 17 00:00:00 2001 From: Alex Wied Date: Mon, 29 Aug 2022 17:34:33 -0400 Subject: [PATCH] lighthouse: init at 3.1.2 --- maintainers/maintainer-list.nix | 10 ++ .../blockchains/lighthouse/default.nix | 103 ++++++++++++++++++ pkgs/top-level/aliases.nix | 1 - pkgs/top-level/all-packages.nix | 4 + 4 files changed, 117 insertions(+), 1 deletion(-) create mode 100644 pkgs/applications/blockchains/lighthouse/default.nix diff --git a/maintainers/maintainer-list.nix b/maintainers/maintainer-list.nix index 00556a82b24c..09d55e7b3a5d 100644 --- a/maintainers/maintainer-list.nix +++ b/maintainers/maintainer-list.nix @@ -10619,6 +10619,16 @@ githubId = 178496; name = "Philipp Middendorf"; }; + pmw = { + email = "philip@mailworks.org"; + matrix = "@philip4g:matrix.org"; + name = "Philip White"; + github = "philipmw"; + githubId = 1379645; + keys = [{ + fingerprint = "9AB0 6C94 C3D1 F9D0 B9D9 A832 BC54 6FB3 B16C 8B0B"; + }]; + }; pmy = { email = "pmy@xqzp.net"; github = "pmeiyu"; diff --git a/pkgs/applications/blockchains/lighthouse/default.nix b/pkgs/applications/blockchains/lighthouse/default.nix new file mode 100644 index 000000000000..fc95295d3d9e --- /dev/null +++ b/pkgs/applications/blockchains/lighthouse/default.nix @@ -0,0 +1,103 @@ +{ clang +, cmake +, fetchFromGitHub +, fetchurl +, lib +, lighthouse +, llvmPackages +, nodePackages +, perl +, protobuf +, rustPlatform +, Security +, stdenv +, testers +, unzip +}: + +rustPlatform.buildRustPackage rec { + pname = "lighthouse"; + version = "3.1.2"; + + # lighthouse/common/deposit_contract/build.rs + depositContractSpecVersion = "0.12.1"; + testnetDepositContractSpecVersion = "0.9.2.1"; + + src = fetchFromGitHub { + owner = "sigp"; + repo = "lighthouse"; + rev = "v${version}"; + hash = "sha256-EJFg6ZjxxijxJNMwKRh0cYeqwujUV3OJgXBvBRsnbVI="; + }; + + cargoHash = "sha256-iXqRtBqvM9URQsL8qGmpr3CNX2fpbtDOaluibAX/lWo="; + + buildFeatures = [ "modern" "gnosis" ]; + + nativeBuildInputs = [ clang cmake perl protobuf ]; + + buildInputs = lib.optionals stdenv.isDarwin [ + Security + ]; + + LIBCLANG_PATH = "${llvmPackages.libclang.lib}/lib"; + + depositContractSpec = fetchurl { + url = "https://raw.githubusercontent.com/ethereum/eth2.0-specs/v${depositContractSpecVersion}/deposit_contract/contracts/validator_registration.json"; + hash = "sha256-ZslAe1wkmkg8Tua/AmmEfBmjqMVcGIiYHwi+WssEwa8="; + }; + + testnetDepositContractSpec = fetchurl { + url = "https://raw.githubusercontent.com/sigp/unsafe-eth2-deposit-contract/v${testnetDepositContractSpecVersion}/unsafe_validator_registration.json"; + hash = "sha256-aeTeHRT3QtxBRSNMCITIWmx89vGtox2OzSff8vZ+RYY="; + }; + + LIGHTHOUSE_DEPOSIT_CONTRACT_SPEC_URL = "file://${depositContractSpec}"; + LIGHTHOUSE_DEPOSIT_CONTRACT_TESTNET_URL = "file://${testnetDepositContractSpec}"; + + cargoBuildFlags = [ + "--package lighthouse" + ]; + + __darwinAllowLocalNetworking = true; + + checkFeatures = [ ]; + + # All of these tests require network access + cargoTestFlags = [ + "--workspace" + "--exclude beacon_node" + "--exclude http_api" + "--exclude beacon_chain" + "--exclude lighthouse" + "--exclude lighthouse_network" + "--exclude slashing_protection" + "--exclude web3signer_tests" + ]; + + # All of these tests require network access + checkFlags = [ + "--skip service::tests::tests::test_dht_persistence" + "--skip time::test::test_reinsertion_updates_timeout" + ] ++ lib.optionals (stdenv.isAarch64 && stdenv.isDarwin) [ + "--skip subnet_service::tests::sync_committee_service::same_subscription_with_lower_until_epoch" + "--skip subnet_service::tests::sync_committee_service::subscribe_and_unsubscribe" + ]; + + checkInputs = [ + nodePackages.ganache + ]; + + passthru.tests.version = testers.testVersion { + package = lighthouse; + command = "lighthouse --version"; + version = "v${lighthouse.version}"; + }; + + meta = with lib; { + description = "Ethereum consensus client in Rust"; + homepage = "https://lighthouse.sigmaprime.io/"; + license = licenses.asl20; + maintainers = with maintainers; [ centromere pmw ]; + }; +} diff --git a/pkgs/top-level/aliases.nix b/pkgs/top-level/aliases.nix index 61263109006b..e959a79493ce 100644 --- a/pkgs/top-level/aliases.nix +++ b/pkgs/top-level/aliases.nix @@ -765,7 +765,6 @@ mapAliases ({ libva1-full = throw "'libva1-full' has been renamed to/replaced by 'libva1'"; # Converted to throw 2022-02-22 libwnck3 = libwnck; lightdm_gtk_greeter = lightdm-gtk-greeter; # Added 2022-08-01 - lighthouse = throw "lighthouse has been removed: abandoned by upstream"; # Added 2022-04-24 lighttable = throw "'lighttable' crashes (SIGSEGV) on startup, has not been updated in years and depends on deprecated GTK2"; # Added 2022-06-15 lilyterm = throw "lilyterm has been removed from nixpkgs, because it was relying on a vte version that depended on python2"; # Added 2022-01-14 lilyterm-git = throw "lilyterm-git has been removed from nixpkgs, because it was relying on a vte version that depended on python2"; # Added 2022-01-14 diff --git a/pkgs/top-level/all-packages.nix b/pkgs/top-level/all-packages.nix index 07ed8daa9bc3..1993b0b975aa 100644 --- a/pkgs/top-level/all-packages.nix +++ b/pkgs/top-level/all-packages.nix @@ -35914,6 +35914,10 @@ with pkgs; lguf-brightness = callPackage ../misc/lguf-brightness { }; + lighthouse = callPackage ../applications/blockchains/lighthouse { + inherit (darwin.apple_sdk.frameworks) Security; + }; + lilypond = callPackage ../misc/lilypond { guile = guile_1_8; }; lilypond-unstable = callPackage ../misc/lilypond/unstable.nix { };