mirror of
https://github.com/NixOS/nixpkgs.git
synced 2024-12-15 18:23:09 +00:00
efe792bb20
networkmanager: Apply several fixes for OWE
214 lines
5.3 KiB
Nix
214 lines
5.3 KiB
Nix
{ lib
|
|
, stdenv
|
|
, fetchurl
|
|
, substituteAll
|
|
, intltool
|
|
, pkg-config
|
|
, fetchpatch
|
|
, dbus
|
|
, gnome
|
|
, systemd
|
|
, libuuid
|
|
, polkit
|
|
, gnutls
|
|
, ppp
|
|
, dhcpcd
|
|
, iptables
|
|
, nftables
|
|
, python3
|
|
, vala
|
|
, libgcrypt
|
|
, dnsmasq
|
|
, bluez5
|
|
, readline
|
|
, libselinux
|
|
, audit
|
|
, gobject-introspection
|
|
, modemmanager
|
|
, openresolv
|
|
, libndp
|
|
, newt
|
|
, libsoup
|
|
, ethtool
|
|
, gnused
|
|
, iputils
|
|
, kmod
|
|
, jansson
|
|
, gtk-doc
|
|
, libxslt
|
|
, docbook_xsl
|
|
, docbook_xml_dtd_412
|
|
, docbook_xml_dtd_42
|
|
, docbook_xml_dtd_43
|
|
, openconnect
|
|
, curl
|
|
, meson
|
|
, ninja
|
|
, libpsl
|
|
, mobile-broadband-provider-info
|
|
, runtimeShell
|
|
}:
|
|
|
|
let
|
|
pythonForDocs = python3.withPackages (pkgs: with pkgs; [ pygobject3 ]);
|
|
in
|
|
stdenv.mkDerivation rec {
|
|
pname = "networkmanager";
|
|
version = "1.38.2";
|
|
|
|
src = fetchurl {
|
|
url = "mirror://gnome/sources/NetworkManager/${lib.versions.majorMinor version}/NetworkManager-${version}.tar.xz";
|
|
sha256 = "sha256-nP/SrcaGUTFt8tL4oJ4XF7sdDC6jic/HIaAQnbmzWCY=";
|
|
};
|
|
|
|
outputs = [ "out" "dev" "devdoc" "man" "doc" ];
|
|
|
|
# Right now we hardcode quite a few paths at build time. Probably we should
|
|
# patch networkmanager to allow passing these path in config file. This will
|
|
# remove unneeded build-time dependencies.
|
|
mesonFlags = [
|
|
# System paths
|
|
"--sysconfdir=/etc"
|
|
"--localstatedir=/var"
|
|
"-Dsystemdsystemunitdir=${placeholder "out"}/etc/systemd/system"
|
|
# to enable link-local connections
|
|
"-Dudev_dir=${placeholder "out"}/lib/udev"
|
|
"-Ddbus_conf_dir=${placeholder "out"}/share/dbus-1/system.d"
|
|
"-Dkernel_firmware_dir=/run/current-system/firmware"
|
|
|
|
# Platform
|
|
"-Dsession_tracking=systemd"
|
|
"-Dlibaudit=yes-disabled-by-default"
|
|
"-Dpolkit_agent_helper_1=/run/wrappers/bin/polkit-agent-helper-1"
|
|
|
|
# Features
|
|
# Allow using iwd when configured to do so
|
|
"-Diwd=true"
|
|
"-Dpppd=${ppp}/bin/pppd"
|
|
"-Diptables=${iptables}/bin/iptables"
|
|
"-Dnft=${nftables}/bin/nft"
|
|
"-Dmodem_manager=true"
|
|
"-Dnmtui=true"
|
|
"-Ddnsmasq=${dnsmasq}/bin/dnsmasq"
|
|
"-Dqt=false"
|
|
|
|
# Handlers
|
|
"-Dresolvconf=${openresolv}/bin/resolvconf"
|
|
|
|
# DHCP clients
|
|
# ISC DHCP client has reached it's end of life, so stop using it
|
|
"-Ddhclient=no"
|
|
"-Ddhcpcd=${dhcpcd}/bin/dhcpcd"
|
|
"-Ddhcpcanon=no"
|
|
|
|
# Miscellaneous
|
|
"-Ddocs=true"
|
|
# We don't use firewalld in NixOS
|
|
"-Dfirewalld_zone=false"
|
|
"-Dtests=no"
|
|
"-Dcrypto=gnutls"
|
|
];
|
|
|
|
patches = [
|
|
(substituteAll {
|
|
src = ./fix-paths.patch;
|
|
inherit iputils kmod openconnect ethtool gnused systemd;
|
|
inherit runtimeShell;
|
|
})
|
|
|
|
# Meson does not support using different directories during build and
|
|
# for installation like Autotools did with flags passed to make install.
|
|
./fix-install-paths.patch
|
|
|
|
(fetchpatch {
|
|
# Prevent downgrade to plain network on Enhanced Open profiles
|
|
url = "https://gitlab.freedesktop.org/NetworkManager/NetworkManager/-/commit/b7946e50acc0d20d31b0c1098fdadc2f105ba799.patch";
|
|
hash = "sha256-CdZiubfqhJQ5w4+s9O8C5WI9Ls/paONzDX4rX6yEmS0=";
|
|
})
|
|
(fetchpatch {
|
|
# Treat OWE BSSIDs as valid candidates for open profiles
|
|
url = "https://gitlab.freedesktop.org/NetworkManager/NetworkManager/-/commit/dd80cdcc1bd5e2535b8e4a1d1d0c62f1d3328a7c.patch";
|
|
hash = "sha256-QMZvWN3g8K+UH6y05+RkCmF+gHHU4pB+UXfU770AUis=";
|
|
})
|
|
(fetchpatch {
|
|
# Allow distinguishing pure OWE networks from those with transition mode enabled
|
|
url = "https://gitlab.freedesktop.org/NetworkManager/NetworkManager/-/commit/13ea8d2e7dddd8279c82230594cea533ca349dd3.patch";
|
|
hash = "sha256-BiINGzX/Zp8pwdbMiDScrZvrHtH7coXkZm1HScFuFWA=";
|
|
})
|
|
];
|
|
|
|
buildInputs = [
|
|
systemd
|
|
libselinux
|
|
audit
|
|
libpsl
|
|
libuuid
|
|
polkit
|
|
ppp
|
|
libndp
|
|
curl
|
|
mobile-broadband-provider-info
|
|
bluez5
|
|
dnsmasq
|
|
gobject-introspection
|
|
modemmanager
|
|
readline
|
|
newt
|
|
libsoup
|
|
jansson
|
|
];
|
|
|
|
propagatedBuildInputs = [ gnutls libgcrypt ];
|
|
|
|
nativeBuildInputs = [
|
|
meson
|
|
ninja
|
|
intltool
|
|
pkg-config
|
|
vala
|
|
gobject-introspection
|
|
dbus
|
|
# Docs
|
|
gtk-doc
|
|
libxslt
|
|
docbook_xsl
|
|
docbook_xml_dtd_412
|
|
docbook_xml_dtd_42
|
|
docbook_xml_dtd_43
|
|
pythonForDocs
|
|
];
|
|
|
|
doCheck = false; # requires /sys, the net
|
|
|
|
postPatch = ''
|
|
patchShebangs ./tools
|
|
patchShebangs libnm/generate-setting-docs.py
|
|
'';
|
|
|
|
preBuild = ''
|
|
# Our gobject-introspection patches make the shared library paths absolute
|
|
# in the GIR files. When building docs, the library is not yet installed,
|
|
# though, so we need to replace the absolute path with a local one during build.
|
|
# We are using a symlink that will be overridden during installation.
|
|
mkdir -p ${placeholder "out"}/lib
|
|
ln -s $PWD/src/libnm-client-impl/libnm.so.0 ${placeholder "out"}/lib/libnm.so.0
|
|
'';
|
|
|
|
passthru = {
|
|
updateScript = gnome.updateScript {
|
|
packageName = "NetworkManager";
|
|
attrPath = "networkmanager";
|
|
versionPolicy = "odd-unstable";
|
|
};
|
|
};
|
|
|
|
meta = with lib; {
|
|
homepage = "https://wiki.gnome.org/Projects/NetworkManager";
|
|
description = "Network configuration and management tool";
|
|
license = licenses.gpl2Plus;
|
|
changelog = "https://gitlab.freedesktop.org/NetworkManager/NetworkManager/-/raw/${version}/NEWS";
|
|
maintainers = teams.freedesktop.members ++ (with maintainers; [ domenkozar obadz maxeaubrey ]);
|
|
platforms = platforms.linux;
|
|
};
|
|
}
|