|
| 1 | +{ |
| 2 | + lib, |
| 3 | + rustPlatform, |
| 4 | + fetchFromGitHub, |
| 5 | + pkg-config, |
| 6 | + shared-mime-info, |
| 7 | + installShellFiles, |
| 8 | + scdoc, |
| 9 | + bzip2, |
| 10 | + openssl, |
| 11 | + sqlite, |
| 12 | + xz, |
| 13 | + zstd, |
| 14 | + stdenv, |
| 15 | + darwin, |
| 16 | + buildPackages, |
| 17 | + versionCheckHook, |
| 18 | + nixosTests, |
| 19 | + nix-update-script, |
| 20 | +}: |
| 21 | + |
| 22 | +rustPlatform.buildRustPackage (finalAttrs: { |
| 23 | + pname = "rebuilderd"; |
| 24 | + version = "0.22.1"; |
| 25 | + |
| 26 | + src = fetchFromGitHub { |
| 27 | + owner = "kpcyrd"; |
| 28 | + repo = "rebuilderd"; |
| 29 | + tag = "v${finalAttrs.version}"; |
| 30 | + hash = "sha256-YMBq+Z9yMQRXOM3U679g2lnBZlH/h0VLjoxySxi4SCo="; |
| 31 | + }; |
| 32 | + |
| 33 | + postPatch = '' |
| 34 | + substituteInPlace tools/src/args.rs \ |
| 35 | + --replace-fail "/etc/rebuilderd-sync.conf" '${placeholder "out"}/etc/rebuilderd-sync.conf' |
| 36 | +
|
| 37 | + substituteInPlace worker/src/config.rs \ |
| 38 | + --replace-fail 'from("/etc/rebuilderd-worker.conf")' 'from("${placeholder "out"}/etc/rebuilderd-worker.conf")' |
| 39 | +
|
| 40 | + substituteInPlace worker/src/proc.rs \ |
| 41 | + --replace-fail '/bin/echo' 'echo' |
| 42 | + ''; |
| 43 | + |
| 44 | + useFetchCargoVendor = true; |
| 45 | + cargoHash = "sha256-MjFQ5d9VWHodjj+hIsKgAIUdaiarXIi5GCS+47n5MGU="; |
| 46 | + |
| 47 | + nativeBuildInputs = [ |
| 48 | + pkg-config |
| 49 | + installShellFiles |
| 50 | + scdoc |
| 51 | + ]; |
| 52 | + |
| 53 | + buildInputs = |
| 54 | + [ |
| 55 | + bzip2 |
| 56 | + openssl |
| 57 | + shared-mime-info |
| 58 | + sqlite |
| 59 | + xz |
| 60 | + zstd |
| 61 | + ] |
| 62 | + ++ lib.optionals stdenv.hostPlatform.isDarwin [ |
| 63 | + darwin.apple_sdk.frameworks.Security |
| 64 | + darwin.apple_sdk.frameworks.SystemConfiguration |
| 65 | + ]; |
| 66 | + |
| 67 | + postInstall = |
| 68 | + let |
| 69 | + emulator = stdenv.hostPlatform.emulator buildPackages; |
| 70 | + in |
| 71 | + '' |
| 72 | + mkdir -p $out/etc |
| 73 | +
|
| 74 | + # install config files |
| 75 | + install -Dm 644 -t "$out/etc" contrib/confs/rebuilderd-sync.conf |
| 76 | + install -Dm 640 -t "$out/etc" contrib/confs/rebuilderd-worker.conf contrib/confs/rebuilderd.conf |
| 77 | +
|
| 78 | + installShellCompletion --cmd rebuildctl \ |
| 79 | + --bash <(${emulator} $out/bin/rebuildctl completions bash) \ |
| 80 | + --fish <(${emulator} $out/bin/rebuildctl completions fish) \ |
| 81 | + --zsh <(${emulator} $out/bin/rebuildctl completions zsh) |
| 82 | +
|
| 83 | + for f in contrib/docs/*.scd; do |
| 84 | + local page="contrib/docs/$(basename "$f" .scd)" |
| 85 | + scdoc < "$f" > "$page" |
| 86 | + installManPage "$page" |
| 87 | + done |
| 88 | + ''; |
| 89 | + |
| 90 | + checkFlags = [ |
| 91 | + # Failing tests |
| 92 | + "--skip=decompress::tests::decompress_bzip2_compression" |
| 93 | + "--skip=decompress::tests::decompress_gzip_compression" |
| 94 | + "--skip=decompress::tests::decompress_xz_compression" |
| 95 | + "--skip=decompress::tests::decompress_zstd_compression" |
| 96 | + "--skip=decompress::tests::detect_bzip2_compression" |
| 97 | + "--skip=decompress::tests::detect_gzip_compression" |
| 98 | + "--skip=decompress::tests::detect_xz_compression" |
| 99 | + "--skip=decompress::tests::detect_zstd_compression" |
| 100 | + "--skip=proc::tests::hello_world" |
| 101 | + "--skip=proc::tests::size_limit_kill" |
| 102 | + "--skip=proc::tests::size_limit_no_kill" |
| 103 | + "--skip=proc::tests::size_limit_no_kill_but_timeout" |
| 104 | + "--skip=proc::tests::timeout" |
| 105 | + ]; |
| 106 | + |
| 107 | + nativeInstallCheckInputs = [ |
| 108 | + versionCheckHook |
| 109 | + ]; |
| 110 | + versionCheckProgramArg = [ "--version" ]; |
| 111 | + doInstallCheck = true; |
| 112 | + |
| 113 | + passthru.tests = { |
| 114 | + rebuilderd = nixosTests.rebuilderd; |
| 115 | + }; |
| 116 | + |
| 117 | + passthru.updateScript = nix-update-script { }; |
| 118 | + |
| 119 | + meta = { |
| 120 | + description = "Independent verification of binary packages - reproducible builds"; |
| 121 | + homepage = "https://github.com/kpcyrd/rebuilderd"; |
| 122 | + license = lib.licenses.gpl3Plus; |
| 123 | + maintainers = with lib.maintainers; [ drupol ]; |
| 124 | + mainProgram = "rebuilderd"; |
| 125 | + }; |
| 126 | +}) |
0 commit comments