2021-10-21 18:48:05 +00:00
|
|
|
{ lib, stdenv, fetchFromGitHub
|
2021-07-21 15:32:00 +00:00
|
|
|
, pkg-config, autoreconfHook, perl, gperf, bison, flex
|
2019-12-25 06:46:32 +00:00
|
|
|
, gmp, python3, iptables, ldns, unbound, openssl, pcsclite, glib
|
2017-10-24 21:55:05 +00:00
|
|
|
, openresolv
|
|
|
|
, systemd, pam
|
2018-04-30 17:28:46 +00:00
|
|
|
, curl
|
|
|
|
, enableTNC ? false, trousers, sqlite, libxml2
|
2017-10-24 21:55:05 +00:00
|
|
|
, enableNetworkManager ? false, networkmanager
|
2019-03-06 14:14:57 +00:00
|
|
|
, darwin
|
2017-10-24 21:55:05 +00:00
|
|
|
}:
|
|
|
|
|
2018-04-30 17:28:46 +00:00
|
|
|
# Note on curl support: If curl is built with gnutls as its backend, the
|
|
|
|
# strongswan curl plugin may break.
|
|
|
|
# See https://wiki.strongswan.org/projects/strongswan/wiki/Curl for more info.
|
|
|
|
|
2021-01-15 09:19:50 +00:00
|
|
|
with lib;
|
2014-09-16 18:10:37 +00:00
|
|
|
|
|
|
|
stdenv.mkDerivation rec {
|
2019-08-15 12:41:18 +00:00
|
|
|
pname = "strongswan";
|
2021-10-21 18:48:05 +00:00
|
|
|
version = "5.9.4"; # Make sure to also update <nixpkgs/nixos/modules/services/networking/strongswan-swanctl/swanctl-params.nix> when upgrading!
|
2014-09-16 18:10:37 +00:00
|
|
|
|
2021-07-21 15:32:00 +00:00
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "strongswan";
|
|
|
|
repo = "strongswan";
|
|
|
|
rev = version;
|
2021-10-21 18:48:05 +00:00
|
|
|
sha256 = "1y1gs232x7hsbccjga9nbkf4bbi5wxazlkg00qd2v1nz86sfy4cd";
|
2014-09-16 18:10:37 +00:00
|
|
|
};
|
|
|
|
|
2014-11-25 01:50:17 +00:00
|
|
|
dontPatchELF = true;
|
|
|
|
|
2021-07-21 15:32:00 +00:00
|
|
|
nativeBuildInputs = [ pkg-config autoreconfHook perl gperf bison flex ];
|
2015-08-03 14:59:33 +00:00
|
|
|
buildInputs =
|
2019-12-25 06:46:32 +00:00
|
|
|
[ curl gmp python3 ldns unbound openssl pcsclite ]
|
2018-04-30 17:28:46 +00:00
|
|
|
++ optionals enableTNC [ trousers sqlite libxml2 ]
|
2019-03-06 14:14:57 +00:00
|
|
|
++ optionals stdenv.isLinux [ systemd.dev pam iptables ]
|
|
|
|
++ optionals stdenv.isDarwin (with darwin.apple_sdk.frameworks; [ SystemConfiguration ])
|
2019-10-15 14:03:21 +00:00
|
|
|
++ optionals enableNetworkManager [ networkmanager glib ];
|
2014-12-22 17:24:19 +00:00
|
|
|
|
|
|
|
patches = [
|
2014-12-22 19:55:01 +00:00
|
|
|
./ext_auth-path.patch
|
2014-12-22 17:24:19 +00:00
|
|
|
./firewall_defaults.patch
|
2014-12-22 19:55:01 +00:00
|
|
|
./updown-path.patch
|
2014-12-22 17:24:19 +00:00
|
|
|
];
|
2014-09-19 05:09:00 +00:00
|
|
|
|
2019-03-08 13:16:15 +00:00
|
|
|
postPatch = optionalString stdenv.isLinux ''
|
2017-11-07 15:40:12 +00:00
|
|
|
# glibc-2.26 reorganized internal includes
|
|
|
|
sed '1i#include <stdint.h>' -i src/libstrongswan/utils/utils/memory.h
|
2019-03-06 14:14:57 +00:00
|
|
|
|
|
|
|
substituteInPlace src/libcharon/plugins/resolve/resolve_handler.c --replace "/sbin/resolvconf" "${openresolv}/sbin/resolvconf"
|
2015-08-05 10:12:09 +00:00
|
|
|
'';
|
|
|
|
|
2015-08-03 14:59:33 +00:00
|
|
|
configureFlags =
|
2019-03-06 14:14:57 +00:00
|
|
|
[ "--enable-swanctl"
|
|
|
|
"--enable-cmd"
|
2017-10-17 08:10:42 +00:00
|
|
|
"--enable-openssl"
|
2015-08-04 17:16:27 +00:00
|
|
|
"--enable-eap-sim" "--enable-eap-sim-file" "--enable-eap-simaka-pseudonym"
|
|
|
|
"--enable-eap-simaka-reauth" "--enable-eap-identity" "--enable-eap-md5"
|
|
|
|
"--enable-eap-gtc" "--enable-eap-aka" "--enable-eap-aka-3gpp2"
|
2017-10-22 08:25:37 +00:00
|
|
|
"--enable-eap-mschapv2" "--enable-eap-radius" "--enable-xauth-eap" "--enable-ext-auth"
|
2019-03-06 14:14:57 +00:00
|
|
|
"--enable-acert"
|
2015-09-06 19:05:11 +00:00
|
|
|
"--enable-pkcs11" "--enable-eap-sim-pcsc" "--enable-dnscert" "--enable-unbound"
|
2019-03-06 14:14:57 +00:00
|
|
|
"--enable-chapoly"
|
2018-04-30 17:28:46 +00:00
|
|
|
"--enable-curl" ]
|
2019-03-06 14:14:57 +00:00
|
|
|
++ optionals stdenv.isLinux [
|
|
|
|
"--enable-farp" "--enable-dhcp"
|
2019-04-30 08:27:49 +00:00
|
|
|
"--enable-systemd" "--with-systemdsystemunitdir=${placeholder "out"}/etc/systemd/system"
|
2019-03-06 14:14:57 +00:00
|
|
|
"--enable-xauth-pam"
|
|
|
|
"--enable-forecast"
|
|
|
|
"--enable-connmark"
|
|
|
|
"--enable-af-alg" ]
|
2017-10-24 21:55:05 +00:00
|
|
|
++ optionals stdenv.isx86_64 [ "--enable-aesni" "--enable-rdrand" ]
|
2018-08-20 19:11:29 +00:00
|
|
|
++ optional (stdenv.hostPlatform.system == "i686-linux") "--enable-padlock"
|
2017-10-24 21:55:05 +00:00
|
|
|
++ optionals enableTNC [
|
2015-08-03 14:59:33 +00:00
|
|
|
"--disable-gmp" "--disable-aes" "--disable-md5" "--disable-sha1" "--disable-sha2" "--disable-fips-prf"
|
|
|
|
"--enable-eap-tnc" "--enable-eap-ttls" "--enable-eap-dynamic" "--enable-tnccs-20"
|
|
|
|
"--enable-tnc-imc" "--enable-imc-os" "--enable-imc-attestation"
|
|
|
|
"--enable-tnc-imv" "--enable-imv-attestation"
|
2015-08-04 17:16:27 +00:00
|
|
|
"--enable-tnc-ifmap" "--enable-tnc-imc" "--enable-tnc-imv"
|
2015-08-03 14:59:33 +00:00
|
|
|
"--with-tss=trousers"
|
|
|
|
"--enable-aikgen"
|
2017-10-24 21:55:05 +00:00
|
|
|
"--enable-sqlite" ]
|
2018-09-06 14:17:52 +00:00
|
|
|
++ optionals enableNetworkManager [
|
|
|
|
"--enable-nm"
|
2019-03-06 14:14:57 +00:00
|
|
|
"--with-nm-ca-dir=/etc/ssl/certs" ]
|
|
|
|
# Taken from: https://wiki.strongswan.org/projects/strongswan/wiki/MacOSX
|
|
|
|
++ optionals stdenv.isDarwin [
|
|
|
|
"--disable-systemd"
|
|
|
|
"--disable-xauth-pam"
|
|
|
|
"--disable-kernel-netlink"
|
|
|
|
"--enable-kernel-pfkey"
|
|
|
|
"--enable-kernel-pfroute"
|
|
|
|
"--enable-kernel-libipsec"
|
|
|
|
"--enable-osx-attr"
|
|
|
|
"--disable-scripts"
|
2018-09-06 14:17:52 +00:00
|
|
|
];
|
2014-09-16 18:10:37 +00:00
|
|
|
|
2017-10-31 11:14:00 +00:00
|
|
|
postInstall = ''
|
|
|
|
# this is needed for l2tp
|
|
|
|
echo "include /etc/ipsec.secrets" >> $out/etc/ipsec.secrets
|
|
|
|
'';
|
|
|
|
|
2019-03-06 14:14:57 +00:00
|
|
|
NIX_LDFLAGS = optionalString stdenv.cc.isGNU "-lgcc_s" ;
|
2014-11-11 06:40:52 +00:00
|
|
|
|
2014-09-16 18:10:37 +00:00
|
|
|
meta = {
|
|
|
|
description = "OpenSource IPsec-based VPN Solution";
|
2020-04-01 01:11:51 +00:00
|
|
|
homepage = "https://www.strongswan.org";
|
2017-10-24 21:55:05 +00:00
|
|
|
license = licenses.gpl2Plus;
|
|
|
|
platforms = platforms.all;
|
2014-09-16 18:10:37 +00:00
|
|
|
};
|
|
|
|
}
|