Skip to content
Permalink

Comparing changes

Choose two branches to see what’s changed or to start a new pull request. If you need to, you can also or learn more about diff comparisons.

Open a pull request

Create a new pull request by comparing changes across two branches. If you need to, you can also . Learn more about diff comparisons here.
base repository: NixOS/nixpkgs
Failed to load repositories. Confirm that selected base ref is valid, then try again.
Loading
base: b998139b85a7
Choose a base ref
...
head repository: NixOS/nixpkgs
Failed to load repositories. Confirm that selected head ref is valid, then try again.
Loading
compare: 8bcec815bdec
Choose a head ref
  • 6 commits
  • 5 files changed
  • 3 contributors

Commits on May 18, 2018

  1. wireguard: Enable tools on other platforms

    Wireguard is now split into two pretty much independent packages:
    `wireguard` (Linux-specific kernel module) and `wireguard-tools`,
    which is cross-platform.
    kirelagin committed May 18, 2018

    Verified

    This commit was signed with the committer’s verified signature.
    tilpner Till Höppner
    Copy the full SHA
    865abfa View commit details

Commits on May 19, 2018

  1. Copy the full SHA
    a9defae View commit details
  2. Copy the full SHA
    60d96d7 View commit details
  3. wireguard: use fetchzip instead of fetchurl

    Because cgit snapshots are not deterministic.
    kirelagin committed May 19, 2018
    Copy the full SHA
    95cf07f View commit details
  4. Copy the full SHA
    f8ed43e View commit details
  5. Merge pull request #40744 from kirelagin/wireguard-darwin

    WireGuard: Make tools available on other platforms
    Mic92 authored May 19, 2018
    Copy the full SHA
    8bcec81 View commit details
4 changes: 2 additions & 2 deletions nixos/modules/services/networking/wireguard.nix
Original file line number Diff line number Diff line change
@@ -193,7 +193,7 @@ let
after = [ "network.target" ];
wantedBy = [ "multi-user.target" ];
environment.DEVICE = name;
path = with pkgs; [ kmod iproute wireguard ];
path = with pkgs; [ kmod iproute wireguard-tools ];

serviceConfig = {
Type = "oneshot";
@@ -279,7 +279,7 @@ in
config = mkIf (cfg.interfaces != {}) {

boot.extraModulePackages = [ kernel.wireguard ];
environment.systemPackages = [ pkgs.wireguard ];
environment.systemPackages = [ pkgs.wireguard-tools ];

systemd.services = mapAttrs' generateUnit cfg.interfaces;

81 changes: 22 additions & 59 deletions pkgs/os-specific/linux/wireguard/default.nix
Original file line number Diff line number Diff line change
@@ -1,73 +1,36 @@
{ stdenv, fetchurl, libmnl, kernel ? null }:
{ stdenv, fetchzip, kernel, wireguard-tools }:

# module requires Linux >= 3.10 https://www.wireguard.io/install/#kernel-requirements
assert kernel != null -> stdenv.lib.versionAtLeast kernel.version "3.10";
assert stdenv.lib.versionAtLeast kernel.version "3.10";

let
stdenv.mkDerivation rec {
name = "wireguard-${version}";

version = "0.0.20180514";

src = fetchurl {
url = "https://git.zx2c4.com/WireGuard/snapshot/WireGuard-${version}.tar.xz";
sha256 = "1nk6yj1gdmpar99zzw39n1v795m6fxsrilg37d02jm780rgbd5g8";
};
inherit (wireguard-tools) src;

meta = with stdenv.lib; {
homepage = https://www.wireguard.com/;
downloadPage = https://git.zx2c4.com/WireGuard/refs/;
description = "A prerelease of an experimental VPN tunnel which is not to be depended upon for security";
maintainers = with maintainers; [ ericsagnes mic92 zx2c4 ];
license = licenses.gpl2;
platforms = platforms.linux;
};

module = stdenv.mkDerivation {
inherit src meta name;
preConfigure = ''
cd src
sed -i '/depmod/,+1d' Makefile
'';

preConfigure = ''
cd src
sed -i '/depmod/,+1d' Makefile
'';
hardeningDisable = [ "pic" ];

hardeningDisable = [ "pic" ];
KERNELDIR = "${kernel.dev}/lib/modules/${kernel.modDirVersion}/build";
INSTALL_MOD_PATH = "\${out}";

KERNELDIR = "${kernel.dev}/lib/modules/${kernel.modDirVersion}/build";
INSTALL_MOD_PATH = "\${out}";
NIX_CFLAGS = ["-Wno-error=cpp"];

NIX_CFLAGS = ["-Wno-error=cpp"];

nativeBuildInputs = kernel.moduleBuildDependencies;

buildPhase = "make module";
};
nativeBuildInputs = kernel.moduleBuildDependencies;

tools = stdenv.mkDerivation {
inherit src meta name;
buildPhase = "make module";

preConfigure = "cd src";

buildInputs = [ libmnl ];

enableParallelBuilding = true;

makeFlags = [
"WITH_BASHCOMPLETION=yes"
"WITH_WGQUICK=yes"
"WITH_SYSTEMDUNITS=yes"
"DESTDIR=$(out)"
"PREFIX=/"
"-C" "tools"
];

buildPhase = "make tools";

postInstall = ''
substituteInPlace $out/lib/systemd/system/wg-quick@.service \
--replace /usr/bin $out/bin
'';
meta = with stdenv.lib; {
homepage = https://www.wireguard.com/;
downloadPage = https://git.zx2c4.com/WireGuard/refs/;
description = " Tools for the WireGuard secure network tunnel";
maintainers = with maintainers; [ ericsagnes mic92 zx2c4 ];
license = licenses.gpl2;
platforms = platforms.linux;
};

in if kernel == null
then tools
else module
}
46 changes: 46 additions & 0 deletions pkgs/tools/networking/wireguard-tools/default.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
{ stdenv, lib, fetchzip, libmnl, useSystemd ? stdenv.isLinux }:

let
inherit (lib) optional optionalString;
in

stdenv.mkDerivation rec {
name = "wireguard-tools-${version}";
version = "0.0.20180514";

src = fetchzip {
url = "https://git.zx2c4.com/WireGuard/snapshot/WireGuard-${version}.tar.xz";
sha256 = "15z0s1i8qyq1fpw8j6rky53ffrpp3f49zn1022jwdslk4g0ncaaj";
};

preConfigure = "cd src";

buildInputs = optional stdenv.isLinux libmnl;

enableParallelBuilding = true;

makeFlags = [
"WITH_BASHCOMPLETION=yes"
"WITH_WGQUICK=yes"
"WITH_SYSTEMDUNITS=${if useSystemd then "yes" else "no"}"
"DESTDIR=$(out)"
"PREFIX=/"
"-C" "tools"
];

buildPhase = "make tools";

postInstall = optionalString useSystemd ''
substituteInPlace $out/lib/systemd/system/wg-quick@.service \
--replace /usr/bin $out/bin
'';

meta = with stdenv.lib; {
homepage = https://www.wireguard.com/;
downloadPage = https://git.zx2c4.com/WireGuard/refs/;
description = " Tools for the WireGuard secure network tunnel";
maintainers = with maintainers; [ ericsagnes mic92 zx2c4 ];
license = licenses.gpl2;
platforms = platforms.unix;
};
}
1 change: 1 addition & 0 deletions pkgs/top-level/aliases.nix
Original file line number Diff line number Diff line change
@@ -228,6 +228,7 @@ mapAliases (rec {
vorbisTools = vorbis-tools; # added 2016-01-26
wineStaging = wine-staging; # added 2018-01-08
winusb = woeusb; # added 2017-12-22
wireguard = wireguard-tools; # added 2018-05-19
x11 = xlibsWrapper; # added 2015-09
xf86_video_nouveau = xorg.xf86videonouveau; # added 2015-09
xlibs = xorg; # added 2015-09
4 changes: 2 additions & 2 deletions pkgs/top-level/all-packages.nix
Original file line number Diff line number Diff line change
@@ -5511,6 +5511,8 @@ with pkgs;

whois = callPackage ../tools/networking/whois { };

wireguard-tools = callPackage ../tools/networking/wireguard-tools { };

woff2 = callPackage ../development/web/woff2 { };

woof = callPackage ../tools/misc/woof { };
@@ -18557,8 +18559,6 @@ with pkgs;
erlang = erlangR18;
};

wireguard = callPackage ../os-specific/linux/wireguard { };

alsamixer.app = callPackage ../applications/window-managers/windowmaker/dockapps/alsamixer.app.nix { };

wllvm = callPackage ../development/tools/wllvm { };