{ lib , autoreconfHook , bash-completion , bridge-utils , cmake , coreutils , curl , darwin , dbus , dnsmasq , docutils , fetchFromGitLab , fetchurl , gettext , glib , gnutls , iproute2 , iptables , libgcrypt , libpcap , libtasn1 , libxml2 , libxslt , makeWrapper , meson , ninja , perl , perlPackages , polkit , pkg-config , pmutils , python3 , readline , rpcsvc-proto , stdenv , xhtml1 , yajl , writeScript , nixosTests # Linux , acl ? null , attr ? null , audit ? null , dmidecode ? null , fuse ? null , kmod ? null , libapparmor ? null , libcap_ng ? null , libnl ? null , libpciaccess ? null , libtirpc ? null , lvm2 ? null , numactl ? null , numad ? null , parted ? null , systemd ? null , util-linux ? null # Darwin , gmp , libiconv , Carbon , AppKit # Options , enableCeph ? false , ceph , enableGlusterfs ? false , glusterfs , enableIscsi ? false , openiscsi , libiscsi , enableXen ? false , xen , enableZfs ? stdenv.isLinux , zfs }: with lib; let inherit (stdenv) isDarwin isLinux isx86_64; binPath = makeBinPath ([ dnsmasq ] ++ optionals isLinux [ bridge-utils dmidecode dnsmasq iproute2 iptables kmod lvm2 numactl numad pmutils systemd ] ++ optionals enableIscsi [ libiscsi openiscsi ] ++ optionals enableZfs [ zfs ]); in assert enableXen -> isLinux && isx86_64; assert enableCeph -> isLinux; assert enableGlusterfs -> isLinux; assert enableZfs -> isLinux; # if you update, also bump and SysVirt in stdenv.mkDerivation rec { pname = "libvirt"; # NOTE: You must also bump: # # SysVirt in version = "8.7.0"; src = fetchFromGitLab { owner = pname; repo = pname; rev = "v${version}"; sha256 = "sha256-5F6Ibp3k7I1mwv8DNZ7rsW0wOw5q3vHtCUc7jJUNzrs="; fetchSubmodules = true; }; patches = [ ./0001-meson-patch-in-an-install-prefix-for-building-on-nix.patch ]; # remove some broken tests postPatch = '' sed -i '/commandtest/d' tests/meson.build sed -i '/virnetsockettest/d' tests/meson.build # delete only the first occurrence of this sed -i '0,/qemuxml2argvtest/{/qemuxml2argvtest/d;}' tests/meson.build '' + optionalString isLinux '' sed -i 's,define PARTED "parted",define PARTED "${parted}/bin/parted",' \ src/storage/storage_backend_disk.c \ src/storage/storage_util.c '' + optionalString isDarwin '' sed -i '/qemucapabilitiestest/d' tests/meson.build sed -i '/vircryptotest/d' tests/meson.build '' + optionalString (isDarwin && isx86_64) '' sed -i '/qemucaps2xmltest/d' tests/meson.build sed -i '/qemuhotplugtest/d' tests/meson.build sed -i '/virnetdaemontest/d' tests/meson.build ''; strictDeps = true; nativeBuildInputs = [ meson # needs to be first cmake docutils libxml2 # for xmllint libxslt # for xsltproc makeWrapper ninja perl pkg-config util-linux # for mount ] ++ optional (!isDarwin) rpcsvc-proto # NOTE: needed for rpcgen ++ optional isDarwin darwin.developer_cmds; buildInputs = [ bash-completion curl dbus gettext glib gnutls libgcrypt libpcap libtasn1 libxml2 perlPackages.XMLXPath pkg-config python3 readline xhtml1 yajl ] ++ optionals isLinux [ acl attr audit fuse libapparmor libcap_ng libnl libpciaccess libtirpc lvm2 numactl numad parted systemd util-linux ] ++ optionals isDarwin [ AppKit Carbon gmp libiconv ] ++ optionals enableCeph [ ceph ] ++ optionals enableGlusterfs [ glusterfs ] ++ optionals enableIscsi [ libiscsi openiscsi ] ++ optionals enableXen [ xen ] ++ optionals enableZfs [ zfs ]; preConfigure = let overrides = { QEMU_BRIDGE_HELPER = "/run/wrappers/bin/qemu-bridge-helper"; QEMU_PR_HELPER = "/run/libvirt/nix-helpers/qemu-pr-helper"; }; patchBuilder = var: value: '' sed -i meson.build -e "s|conf.set_quoted('${var}',.*|conf.set_quoted('${var}','${value}')|" ''; in '' PATH="${binPath}:$PATH" # the path to qemu-kvm will be stored in VM's .xml and .save files # do not use "''${qemu_kvm}/bin/qemu-kvm" to avoid bound VMs to particular qemu derivations substituteInPlace src/lxc/lxc_conf.c \ --replace 'lxc_path,' '"/run/libvirt/nix-emulators/libvirt_lxc",' substituteInPlace build-aux/meson.build \ --replace "gsed" "sed" \ --replace "gmake" "make" \ --replace "ggrep" "grep" substituteInPlace src/util/virpolkit.h \ --replace '"/usr/bin/pkttyagent"' '"${if isLinux then polkit.bin else "/usr"}/bin/pkttyagent"' patchShebangs . '' + (lib.concatStringsSep "\n" (lib.mapAttrsToList patchBuilder overrides)); mesonAutoFeatures = "disabled"; mesonFlags = let cfg = option: val: "-D${option}=${val}"; feat = option: enable: cfg option (if enable then "enabled" else "disabled"); driver = name: feat "driver_${name}"; storage = name: feat "storage_${name}"; in [ "--sysconfdir=/var/lib" (cfg "install_prefix" (placeholder "out")) (cfg "localstatedir" "/var") (cfg "runstatedir" "/run") (cfg "init_script" (if isDarwin then "none" else "systemd")) (feat "apparmor" isLinux) (feat "attr" isLinux) (feat "audit" isLinux) (feat "bash_completion" true) (feat "blkid" isLinux) (feat "capng" isLinux) (feat "curl" true) (feat "docs" true) (feat "expensive_tests" true) (feat "firewalld" isLinux) (feat "firewalld_zone" isLinux) (feat "fuse" isLinux) (feat "glusterfs" enableGlusterfs) (feat "host_validate" true) (feat "libiscsi" enableIscsi) (feat "libnl" isLinux) (feat "libpcap" true) (feat "libssh2" true) (feat "login_shell" isLinux) (feat "nss" isLinux) (feat "numactl" isLinux) (feat "numad" isLinux) (feat "pciaccess" isLinux) (feat "polkit" isLinux) (feat "readline" true) (feat "secdriver_apparmor" isLinux) (feat "tests" true) (feat "udev" isLinux) (feat "yajl" true) (driver "ch" isLinux) (driver "esx" true) (driver "interface" isLinux) (driver "libvirtd" true) (driver "libxl" enableXen) (driver "lxc" isLinux) (driver "network" true) (driver "openvz" isLinux) (driver "qemu" true) (driver "remote" true) (driver "secrets" true) (driver "test" true) (driver "vbox" true) (driver "vmware" true) (storage "dir" true) (storage "disk" isLinux) (storage "fs" isLinux) (storage "gluster" enableGlusterfs) (storage "iscsi" enableIscsi) (storage "iscsi_direct" enableIscsi) (storage "lvm" isLinux) (storage "mpath" isLinux) (storage "rbd" enableCeph) (storage "scsi" true) (storage "vstorage" isLinux) (storage "zfs" enableZfs) ]; doCheck = true; postInstall = '' substituteInPlace $out/bin/virt-xml-validate \ --replace xmllint ${libxml2}/bin/xmllint substituteInPlace $out/libexec/libvirt-guests.sh \ --replace 'ON_BOOT="start"' 'ON_BOOT=''${ON_BOOT:-start}' \ --replace 'ON_SHUTDOWN="suspend"' 'ON_SHUTDOWN=''${ON_SHUTDOWN:-suspend}' \ --replace "$out/bin" '${gettext}/bin' \ --replace 'lock/subsys' 'lock' \ --replace 'gettext.sh' 'gettext.sh # Added in nixpkgs: gettext() { "${gettext}/bin/gettext" "$@"; } ' '' + optionalString isLinux '' for f in $out/lib/systemd/system/*.service ; do substituteInPlace $f --replace /bin/kill ${coreutils}/bin/kill done rm $out/lib/systemd/system/{virtlockd,virtlogd}.* wrapProgram $out/sbin/libvirtd \ --prefix PATH : /run/libvirt/nix-emulators:${binPath} ''; passthru.updateScript = writeScript "update-libvirt" '' #!/usr/bin/env nix-shell #!nix-shell -i bash -p curl jq common-updater-scripts set -eu -o pipefail libvirtVersion=$(curl https://gitlab.com/api/v4/projects/192693/repository/tags | jq -r '.[].name|select(. | contains("rc") | not)' | head -n1 | sed "s/v//g") sysvirtVersion=$(curl https://gitlab.com/api/v4/projects/192677/repository/tags | jq -r '.[].name|select(. | contains("rc") | not)' | head -n1 | sed "s/v//g") update-source-version ${pname} "$libvirtVersion" update-source-version python3Packages.${pname} "$libvirtVersion" update-source-version perlPackages.SysVirt "$sysvirtVersion" --file="pkgs/top-level/perl-packages.nix" ''; passthru.tests.libvirtd = nixosTests.libvirtd; meta = { homepage = "https://libvirt.org/"; description = "A toolkit to interact with the virtualization capabilities of recent versions of Linux and other OSes"; license = licenses.lgpl2Plus; platforms = platforms.unix; maintainers = with maintainers; [ fpletz globin lovesegfault ]; }; }