summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFlorian Klink <flokli@flokli.de>2020-10-15 22:55:18 +0200
committerFlorian Klink <flokli@flokli.de>2020-10-21 00:02:18 +0200
commit72cd3086ccf9b465c40a4874f7b770f1639e6dff (patch)
tree59d87dc2127176f987b5fec0f88d978288a585b6
parent24c9b05ac53e422f1af81a156f1fd58499eb27fb (diff)
networkmanager-sstp: init at unstable-2020-04-20
-rw-r--r--nixos/modules/services/networking/networkmanager.nix4
-rw-r--r--pkgs/tools/networking/network-manager/sstp/default.nix64
-rw-r--r--pkgs/top-level/all-packages.nix2
3 files changed, 70 insertions, 0 deletions
diff --git a/nixos/modules/services/networking/networkmanager.nix b/nixos/modules/services/networking/networkmanager.nix
index 17c549d42c32..201a51ff70b1 100644
--- a/nixos/modules/services/networking/networkmanager.nix
+++ b/nixos/modules/services/networking/networkmanager.nix
@@ -15,6 +15,7 @@ let
networkmanager-openconnect
networkmanager-openvpn
networkmanager-vpnc
+ networkmanager-sstp
] ++ optional (!delegateWireless && !enableIwd) wpa_supplicant;
delegateWireless = config.networking.wireless.enable == true && cfg.unmanaged != [];
@@ -386,6 +387,9 @@ in {
"NetworkManager/VPN/nm-iodine-service.name".source =
"${networkmanager-iodine}/lib/NetworkManager/VPN/nm-iodine-service.name";
+
+ "NetworkManager/VPN/nm-sstp-service.name".source =
+ "${networkmanager-sstp}/lib/NetworkManager/VPN/nm-sstp-service.name";
}
// optionalAttrs (cfg.appendNameservers != [] || cfg.insertNameservers != [])
{
diff --git a/pkgs/tools/networking/network-manager/sstp/default.nix b/pkgs/tools/networking/network-manager/sstp/default.nix
new file mode 100644
index 000000000000..d5195cba3453
--- /dev/null
+++ b/pkgs/tools/networking/network-manager/sstp/default.nix
@@ -0,0 +1,64 @@
+{ stdenv
+, autoreconfHook
+, fetchFromGitHub
+, fetchpatch
+, file
+, glib
+, gnome3
+, gtk3
+, intltool
+, libnma
+, libsecret
+, networkmanager
+, pkgconfig
+, ppp
+, sstp
+, substituteAll
+, withGnome ? true }:
+
+let
+ pname = "NetworkManager-sstp";
+ version = "unstable-2020-04-20";
+in stdenv.mkDerivation {
+ name = "${pname}${if withGnome then "-gnome" else ""}-${version}";
+
+ src = fetchFromGitHub {
+ owner = "enaess";
+ repo = "network-manager-sstp";
+ rev = "735d8ca078f933e085029f60a737e3cf1d8c29a8";
+ sha256 = "0aahfhy2ch951kzj6gnd8p8hv2s5yd5y10wrmj68djhnx2ml8cd3";
+ };
+
+ buildInputs = [ sstp networkmanager glib ppp ]
+ ++ stdenv.lib.optionals withGnome [ gtk3 libsecret libnma ];
+
+ nativeBuildInputs = [ file intltool autoreconfHook pkgconfig ];
+
+ postPatch = ''
+ sed -i 's#/sbin/pppd#${ppp}/bin/pppd#' src/nm-sstp-service.c
+ sed -i 's#/sbin/sstpc#${sstp}/bin/sstpc#' src/nm-sstp-service.c
+ '';
+
+ # glib-2.62 deprecations
+ NIX_CFLAGS_COMPILE = "-DGLIB_DISABLE_DEPRECATION_WARNINGS";
+
+ preConfigure = "intltoolize";
+ configureFlags = [
+ "--without-libnm-glib"
+ "--with-gnome=${if withGnome then "yes" else "no"}"
+ "--enable-absolute-paths"
+ ];
+
+ passthru = {
+ updateScript = gnome3.updateScript {
+ packageName = pname;
+ attrPath = "networkmanager-sstp";
+ };
+ };
+
+ meta = with stdenv.lib; {
+ description = "NetworkManager's sstp plugin";
+ inherit (networkmanager.meta) maintainers platforms;
+ license = licenses.gpl2Plus;
+ };
+}
diff --git a/pkgs/top-level/all-packages.nix b/pkgs/top-level/all-packages.nix
index f25888c3a60d..0e7f4c8ad6ab 100644
--- a/pkgs/top-level/all-packages.nix
+++ b/pkgs/top-level/all-packages.nix
@@ -5714,6 +5714,8 @@ in
networkmanager_strongswan = callPackage ../tools/networking/network-manager/strongswan { };
+ networkmanager-sstp = callPackage ../tools/networking/network-manager/sstp { };
+
networkmanagerapplet = callPackage ../tools/networking/network-manager/applet { };
libnma = callPackage ../tools/networking/network-manager/libnma { };