150 lines
3.5 KiB
Nix
150 lines
3.5 KiB
Nix
{ lib
|
|
, stdenv
|
|
, fetchurl
|
|
, fetchpatch
|
|
, nixosTests
|
|
, pkg-config
|
|
, systemd
|
|
, gmp
|
|
, unbound
|
|
, bison
|
|
, flex
|
|
, pam
|
|
, libevent
|
|
, libcap_ng
|
|
, curl
|
|
, nspr
|
|
, bash
|
|
, iproute2
|
|
, iptables
|
|
, procps
|
|
, coreutils
|
|
, gnused
|
|
, gawk
|
|
, nss
|
|
, which
|
|
, python3
|
|
, libselinux
|
|
, ldns
|
|
, xmlto
|
|
, docbook_xml_dtd_412
|
|
, docbook_xsl
|
|
, findXMLCatalogs
|
|
}:
|
|
|
|
let
|
|
# Tools needed by ipsec scripts
|
|
binPath = lib.makeBinPath [
|
|
iproute2 iptables procps
|
|
coreutils gnused gawk
|
|
nss.tools which
|
|
];
|
|
in
|
|
|
|
stdenv.mkDerivation rec {
|
|
pname = "libreswan";
|
|
version = "4.4";
|
|
|
|
src = fetchurl {
|
|
url = "https://download.libreswan.org/${pname}-${version}.tar.gz";
|
|
sha256 = "0xj974yc0y1r7235zl4jhvxqz3bpb8js2fy9ic820zq9swh0lgsz";
|
|
};
|
|
|
|
strictDeps = true;
|
|
|
|
nativeBuildInputs = [
|
|
bison
|
|
flex
|
|
pkg-config
|
|
xmlto
|
|
docbook_xml_dtd_412
|
|
docbook_xsl
|
|
findXMLCatalogs
|
|
];
|
|
|
|
buildInputs = [
|
|
systemd coreutils
|
|
gnused gawk gmp unbound pam libevent
|
|
libcap_ng curl nspr nss ldns
|
|
# needed to patch shebangs
|
|
python3 bash
|
|
] ++ lib.optional stdenv.isLinux libselinux;
|
|
|
|
patches = [
|
|
# Fix compilation on aarch64, remove on next update
|
|
(fetchpatch {
|
|
url = "https://github.com/libreswan/libreswan/commit/ea50d36d2886e44317ba5ba841de1d1bf91aee6c.patch";
|
|
sha256 = "1jp89rm9jp55zmiyimyhg7yadj0fwwxaw7i5gyclrs38w3y1aacj";
|
|
})
|
|
];
|
|
|
|
prePatch = ''
|
|
# Correct iproute2 path
|
|
sed -e 's|"/sbin/ip"|"${iproute2}/bin/ip"|' \
|
|
-e 's|"/sbin/iptables"|"${iptables}/bin/iptables"|' \
|
|
-i initsystems/systemd/ipsec.service.in \
|
|
programs/verify/verify.in
|
|
|
|
# Prevent the makefile from trying to
|
|
# reload the systemd daemon or create tmpfiles
|
|
sed -e 's|systemctl|true|g' \
|
|
-e 's|systemd-tmpfiles|true|g' \
|
|
-i initsystems/systemd/Makefile
|
|
|
|
# Fix the ipsec program from crushing the PATH
|
|
sed -e 's|\(PATH=".*"\):.*$|\1:$PATH|' -i programs/ipsec/ipsec.in
|
|
|
|
# Fix python script to use the correct python
|
|
sed -e 's/^\(\W*\)installstartcheck()/\1sscmd = "ss"\n\0/' \
|
|
-i programs/verify/verify.in
|
|
|
|
# Replace wget with curl to save a dependency
|
|
curlArgs='-s --remote-name-all --output-dir'
|
|
sed -e "s|wget -q -P|${curl}/bin/curl $curlArgs|g" \
|
|
-i programs/letsencrypt/letsencrypt.in
|
|
|
|
# Patch the Makefile:
|
|
# 1. correct the pam.d directory install path
|
|
# 2. do not create the /var/lib/ directory
|
|
sed -e 's|$(DESTDIR)/etc/pam.d|$(out)/etc/pam.d|' \
|
|
-e '/test ! -d $(NSSDIR)/,+3d' \
|
|
-i configs/Makefile
|
|
'';
|
|
|
|
# Set appropriate paths for build
|
|
preBuild = "export INC_USRLOCAL=\${out}";
|
|
|
|
makeFlags = [
|
|
"INITSYSTEM=systemd"
|
|
"UNITDIR=$(out)/etc/systemd/system/"
|
|
"TMPFILESDIR=$(out)/lib/tmpfiles.d/"
|
|
];
|
|
|
|
# Hack to make install work
|
|
installFlags = [
|
|
"FINALVARDIR=\${out}/var"
|
|
"FINALSYSCONFDIR=\${out}/etc"
|
|
];
|
|
|
|
postInstall = ''
|
|
# Install examples directory (needed for letsencrypt)
|
|
cp -r docs/examples $out/share/doc/libreswan/examples
|
|
'';
|
|
|
|
postFixup = ''
|
|
# Add a PATH to the main "ipsec" script
|
|
sed -e '0,/^$/{s||export PATH=${binPath}:$PATH|}' \
|
|
-i $out/bin/ipsec
|
|
'';
|
|
|
|
passthru.tests.libreswan = nixosTests.libreswan;
|
|
|
|
meta = with lib; {
|
|
homepage = "https://libreswan.org";
|
|
description = "A free software implementation of the VPN protocol based on IPSec and the Internet Key Exchange";
|
|
platforms = platforms.linux ++ platforms.freebsd;
|
|
license = with licenses; [ gpl2Plus mpl20 ] ;
|
|
maintainers = with maintainers; [ afranchuk rnhmjoj ];
|
|
};
|
|
}
|