2023-01-11 07:51:40 +00:00
|
|
|
{ lib, stdenv, fetchFromGitHub, openssl, makeWrapper, runtimeShell }:
|
2020-04-24 23:36:52 +00:00
|
|
|
|
2023-01-11 07:51:40 +00:00
|
|
|
stdenv.mkDerivation rec {
|
2020-04-24 23:36:52 +00:00
|
|
|
pname = "easyrsa";
|
2024-09-26 11:04:55 +00:00
|
|
|
version = "3.2.1";
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "OpenVPN";
|
|
|
|
repo = "easy-rsa";
|
|
|
|
rev = "v${version}";
|
2024-09-26 11:04:55 +00:00
|
|
|
hash = "sha256-/c2Redb6whfM2D8hHBrcSaQ3YsBESLjeoKFb5a2lFbQ=";
|
2020-04-24 23:36:52 +00:00
|
|
|
};
|
|
|
|
|
2023-01-11 07:51:40 +00:00
|
|
|
nativeBuildInputs = [ makeWrapper ];
|
2024-04-21 15:54:59 +00:00
|
|
|
nativeInstallCheckInputs = [ openssl.bin ];
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
installPhase = ''
|
2023-01-11 07:51:40 +00:00
|
|
|
mkdir -p $out/share/easy-rsa
|
|
|
|
cp -r easyrsa3/{*.cnf,x509-types,vars.example} $out/share/easy-rsa
|
2020-04-24 23:36:52 +00:00
|
|
|
install -D -m755 easyrsa3/easyrsa $out/bin/easyrsa
|
2023-01-11 07:51:40 +00:00
|
|
|
|
2020-04-24 23:36:52 +00:00
|
|
|
substituteInPlace $out/bin/easyrsa \
|
2023-01-11 07:51:40 +00:00
|
|
|
--replace /usr/ $out/ \
|
|
|
|
--replace '~VER~' '${version}' \
|
|
|
|
--replace '~GITHEAD~' 'v${version}' \
|
|
|
|
--replace '~DATE~' '1970-01-01'
|
|
|
|
|
|
|
|
# Wrap it with the correct OpenSSL binary.
|
|
|
|
wrapProgram $out/bin/easyrsa \
|
2024-04-21 15:54:59 +00:00
|
|
|
--set-default EASYRSA_OPENSSL ${openssl.bin}/bin/openssl
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
# Helper utility
|
|
|
|
cat > $out/bin/easyrsa-init <<EOF
|
|
|
|
#!${runtimeShell} -e
|
2023-01-11 07:51:40 +00:00
|
|
|
cp -r $out/share/easy-rsa/* .
|
2020-04-24 23:36:52 +00:00
|
|
|
EOF
|
|
|
|
chmod +x $out/bin/easyrsa-init
|
|
|
|
'';
|
|
|
|
|
2024-04-21 15:54:59 +00:00
|
|
|
doInstallCheck = true;
|
|
|
|
postInstallCheck = ''
|
|
|
|
set -euo pipefail
|
|
|
|
export EASYRSA_BATCH=1
|
|
|
|
export EASYRSA_PASSIN=pass:nixpkgs
|
|
|
|
export EASYRSA_PASSOUT="$EASYRSA_PASSIN"
|
|
|
|
export EASYRSA_REQ_CN='nixpkgs test CA'
|
|
|
|
export EASYRSA_KEY_SIZE=3072
|
|
|
|
export EASYRSA_ALGO=rsa
|
|
|
|
export EASYRSA_DIGEST=sha512
|
|
|
|
$out/bin/easyrsa init-pki
|
|
|
|
$out/bin/easyrsa build-ca
|
|
|
|
openssl x509 -in pki/ca.crt -noout -subject | tee /dev/stderr | grep -zq "$EASYRSA_REQ_CN"
|
|
|
|
'';
|
|
|
|
|
2021-01-15 22:18:51 +00:00
|
|
|
meta = with lib; {
|
2020-04-24 23:36:52 +00:00
|
|
|
description = "Simple shell based CA utility";
|
|
|
|
homepage = "https://openvpn.net/";
|
2024-05-15 15:35:15 +00:00
|
|
|
license = licenses.gpl2Only;
|
2020-12-07 07:45:13 +00:00
|
|
|
maintainers = [ maintainers.offline maintainers.numinit ];
|
2020-04-24 23:36:52 +00:00
|
|
|
platforms = platforms.unix;
|
|
|
|
};
|
|
|
|
}
|