ratchet: init at 0.9.2
Signed-off-by: Cameron Smith <cameron.ray.smith@gmail.com>
This commit is contained in:
parent
d66286f688
commit
59921e79a2
70
pkgs/by-name/ra/ratchet/package.nix
Normal file
70
pkgs/by-name/ra/ratchet/package.nix
Normal file
@ -0,0 +1,70 @@
|
||||
{
|
||||
lib,
|
||||
buildGoModule,
|
||||
fetchFromGitHub,
|
||||
callPackage,
|
||||
}:
|
||||
buildGoModule rec {
|
||||
pname = "ratchet";
|
||||
version = "0.9.2";
|
||||
|
||||
# ratchet uses the git sha-1 in the version string, e.g.
|
||||
#
|
||||
# $ ./ratchet --version
|
||||
# ratchet 0.9.2 (d57cc1a53c022d3f87c4820bc6b64384a06c8a07, darwin/arm64)
|
||||
#
|
||||
# so we need to either hard-code the sha-1 corresponding to the version tag
|
||||
# head or retain the git metadata folder and extract it using the git cli.
|
||||
# We currently hard-code it.
|
||||
src = fetchFromGitHub {
|
||||
owner = "sethvargo";
|
||||
repo = "ratchet";
|
||||
rev = "d57cc1a53c022d3f87c4820bc6b64384a06c8a07";
|
||||
hash = "sha256-gQ98uD9oPUsECsduv/lqGdYNmtHetU49ETfWCE8ft8U=";
|
||||
};
|
||||
|
||||
proxyVendor = true;
|
||||
vendorHash = "sha256-J7LijbhpKDIfTcQMgk2x5FVaYG7Kgkba/1aSTmgs5yw=";
|
||||
|
||||
subPackages = [ "." ];
|
||||
|
||||
ldflags =
|
||||
let
|
||||
package_url = "github.com/sethvargo/ratchet";
|
||||
in
|
||||
[
|
||||
"-s"
|
||||
"-w"
|
||||
"-X ${package_url}/internal/version.name=${pname}"
|
||||
"-X ${package_url}/internal/version.version=${version}"
|
||||
"-X ${package_url}/internal/version.commit=${src.rev}"
|
||||
];
|
||||
|
||||
doInstallCheck = true;
|
||||
installCheckPhase = ''
|
||||
$out/bin/ratchet --version 2>&1 | grep ${version};
|
||||
'';
|
||||
|
||||
installPhase = ''
|
||||
runHook preInstall
|
||||
mkdir -p $out/bin
|
||||
install -Dm755 "$GOPATH/bin/ratchet" -T $out/bin/ratchet
|
||||
runHook postInstall
|
||||
'';
|
||||
|
||||
passthru.tests = {
|
||||
execution = callPackage ./tests.nix { };
|
||||
};
|
||||
|
||||
meta = with lib; {
|
||||
description = "A tool for securing CI/CD workflows with version pinning.";
|
||||
mainProgram = "ratchet";
|
||||
downloadPage = "https://github.com/sethvargo/ratchet";
|
||||
homepage = "https://github.com/sethvargo/ratchet";
|
||||
license = licenses.asl20;
|
||||
maintainers = with maintainers; [
|
||||
cameronraysmith
|
||||
ryanccn
|
||||
];
|
||||
};
|
||||
}
|
17
pkgs/by-name/ra/ratchet/tests.nix
Normal file
17
pkgs/by-name/ra/ratchet/tests.nix
Normal file
@ -0,0 +1,17 @@
|
||||
{
|
||||
lib,
|
||||
runCommand,
|
||||
ratchet,
|
||||
}: let
|
||||
inherit (ratchet) pname version;
|
||||
in
|
||||
runCommand "${pname}-tests" {meta.timeout = 60;}
|
||||
''
|
||||
set -euo pipefail
|
||||
|
||||
# Ensure ratchet is executable
|
||||
${ratchet}/bin/ratchet --version
|
||||
${ratchet}/bin/ratchet --help
|
||||
|
||||
touch $out
|
||||
''
|
Loading…
Reference in New Issue
Block a user