2022-03-13 17:20:16 +00:00
|
|
|
{ buildGoModule
|
|
|
|
, fetchFromGitHub
|
|
|
|
, pam
|
|
|
|
, lib
|
2022-03-13 17:20:23 +00:00
|
|
|
, nixosTests
|
2022-03-13 17:20:16 +00:00
|
|
|
}:
|
|
|
|
|
|
|
|
buildGoModule rec {
|
|
|
|
pname = "pam_ussh";
|
|
|
|
version = "unstable-20210615";
|
|
|
|
|
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "uber";
|
|
|
|
repo = "pam-ussh";
|
|
|
|
rev = "e9524bda90ba19d3b9eb24f49cb63a6a56a19193"; # HEAD as of 2022-03-13
|
|
|
|
sha256 = "0nb9hpqbghgi3zvq41kabydzyc6ffaaw9b4jkc5jrwn1klpw1xk8";
|
|
|
|
};
|
|
|
|
|
|
|
|
prePatch = ''
|
|
|
|
cp ${./go.mod} go.mod
|
|
|
|
'';
|
|
|
|
overrideModAttrs = (_: {
|
|
|
|
inherit prePatch;
|
|
|
|
});
|
|
|
|
|
|
|
|
vendorSha256 = "0hjifc3kbwmx7kjn858vi05cwwra6q19cqjfd94k726pwhk37qkw";
|
|
|
|
|
|
|
|
buildInputs = [
|
|
|
|
pam
|
|
|
|
];
|
|
|
|
|
|
|
|
buildPhase = ''
|
|
|
|
runHook preBuild
|
|
|
|
|
|
|
|
if [ -z "$enableParallelBuilding" ]; then
|
|
|
|
export NIX_BUILD_CORES=1
|
|
|
|
fi
|
|
|
|
go build -buildmode=c-shared -o pam_ussh.so -v -p $NIX_BUILD_CORES .
|
|
|
|
|
|
|
|
runHook postBuild
|
|
|
|
'';
|
|
|
|
checkPhase = ''
|
|
|
|
runHook preCheck
|
|
|
|
|
|
|
|
go test -v -p $NIX_BUILD_CORES .
|
|
|
|
|
|
|
|
runHook postCheck
|
|
|
|
'';
|
|
|
|
installPhase = ''
|
|
|
|
runHook preInstall
|
|
|
|
|
|
|
|
mkdir -p $out/lib/security
|
|
|
|
cp pam_ussh.so $out/lib/security
|
|
|
|
|
|
|
|
runHook postInstall
|
|
|
|
'';
|
|
|
|
|
2022-03-13 17:20:23 +00:00
|
|
|
passthru.tests = { inherit (nixosTests) pam-ussh; };
|
|
|
|
|
2022-03-13 17:20:16 +00:00
|
|
|
meta = with lib; {
|
|
|
|
homepage = "https://github.com/uber/pam-ussh";
|
|
|
|
description = "PAM module to authenticate using SSH certificates";
|
|
|
|
license = licenses.mit;
|
|
|
|
platforms = platforms.linux;
|
|
|
|
maintainers = with maintainers; [ lukegb ];
|
|
|
|
};
|
|
|
|
}
|