250 lines
5.8 KiB
Nix
250 lines
5.8 KiB
Nix
{ lib
|
|
, stdenv
|
|
, fetchurl
|
|
, fetchFromGitLab
|
|
, makeWrapper
|
|
, autoreconfHook
|
|
, fetchpatch
|
|
, coreutils
|
|
, libxml2
|
|
, gnutls
|
|
, perl
|
|
, python3
|
|
, attr
|
|
, glib
|
|
, docutils
|
|
, iproute2
|
|
, readline
|
|
, lvm2
|
|
, util-linux
|
|
, systemd
|
|
, libpciaccess
|
|
, gettext
|
|
, libtasn1
|
|
, iptables
|
|
, libgcrypt
|
|
, yajl
|
|
, pmutils
|
|
, libcap_ng
|
|
, libapparmor
|
|
, dnsmasq
|
|
, libnl
|
|
, libpcap
|
|
, libxslt
|
|
, xhtml1
|
|
, numad
|
|
, numactl
|
|
, perlPackages
|
|
, curl
|
|
, libiconv
|
|
, gmp
|
|
, zfs
|
|
, parted
|
|
, bridge-utils
|
|
, dmidecode
|
|
, dbus
|
|
, libtirpc
|
|
, rpcsvc-proto
|
|
, darwin
|
|
, meson
|
|
, ninja
|
|
, audit
|
|
, cmake
|
|
, bash-completion
|
|
, pkg-config
|
|
, enableXen ? false
|
|
, xen ? null
|
|
, enableIscsi ? false
|
|
, openiscsi
|
|
, enableCeph ? false
|
|
, ceph
|
|
, enableGlusterfs ? false
|
|
, glusterfs
|
|
, Carbon
|
|
, AppKit
|
|
}:
|
|
|
|
with lib;
|
|
|
|
# if you update, also bump <nixpkgs/pkgs/development/python-modules/libvirt/default.nix> and SysVirt in <nixpkgs/pkgs/top-level/perl-packages.nix>
|
|
let
|
|
buildFromTarball = stdenv.isDarwin;
|
|
in
|
|
stdenv.mkDerivation rec {
|
|
pname = "libvirt";
|
|
version = "7.9.0";
|
|
|
|
src =
|
|
if buildFromTarball then
|
|
fetchurl
|
|
{
|
|
url = "https://libvirt.org/sources/${pname}-${version}.tar.xz";
|
|
sha256 = "sha256-gpzytfV0J5xA8ERuEWiBXT82uJcQVgJjyiznAlb3Low=";
|
|
}
|
|
else
|
|
fetchFromGitLab
|
|
{
|
|
owner = pname;
|
|
repo = pname;
|
|
rev = "v${version}";
|
|
sha256 = "sha256-Ua6+EKLES3385fqhH2+qwnwE+X/nmWqIBxCXXE3SVhs=";
|
|
fetchSubmodules = true;
|
|
};
|
|
|
|
patches = [
|
|
./0001-meson-patch-in-an-install-prefix-for-building-on-nix.patch
|
|
./0002-meson-patch-ch-install-prefix.patch
|
|
];
|
|
|
|
nativeBuildInputs = [
|
|
ninja
|
|
meson
|
|
cmake
|
|
makeWrapper
|
|
pkg-config
|
|
docutils
|
|
] ++ optional (!stdenv.isDarwin) [
|
|
rpcsvc-proto
|
|
] ++ optionals stdenv.isDarwin [
|
|
darwin.developer_cmds # needed for rpcgen
|
|
];
|
|
|
|
buildInputs = [
|
|
bash-completion
|
|
pkg-config
|
|
libxml2
|
|
gnutls
|
|
perl
|
|
python3
|
|
readline
|
|
gettext
|
|
libtasn1
|
|
libgcrypt
|
|
yajl
|
|
libxslt
|
|
xhtml1
|
|
perlPackages.XMLXPath
|
|
curl
|
|
libpcap
|
|
glib
|
|
dbus
|
|
] ++ optionals stdenv.isLinux [
|
|
audit
|
|
libpciaccess
|
|
lvm2
|
|
util-linux
|
|
systemd
|
|
libnl
|
|
numad
|
|
zfs
|
|
libapparmor
|
|
libcap_ng
|
|
numactl
|
|
attr
|
|
parted
|
|
libtirpc
|
|
] ++ optionals (enableXen && stdenv.isLinux && stdenv.isx86_64) [
|
|
xen
|
|
] ++ optionals enableIscsi [
|
|
openiscsi
|
|
] ++ optionals enableCeph [
|
|
ceph
|
|
] ++ optionals enableGlusterfs [
|
|
glusterfs
|
|
] ++ optionals stdenv.isDarwin [
|
|
libiconv
|
|
gmp
|
|
Carbon
|
|
AppKit
|
|
];
|
|
|
|
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=${lib.makeBinPath ([ dnsmasq ] ++ optionals stdenv.isLinux [ iproute2 iptables lvm2 systemd numad ] ++ optionals enableIscsi [ openiscsi ])}:$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"
|
|
patchShebangs .
|
|
''
|
|
+ (lib.concatStringsSep "\n" (lib.mapAttrsToList patchBuilder overrides));
|
|
|
|
mesonAutoFeatures = "auto";
|
|
|
|
mesonFlags =
|
|
let
|
|
opt = option: enable: "-D${option}=${if enable then "enabled" else "disabled"}";
|
|
in
|
|
[
|
|
"--sysconfdir=/var/lib"
|
|
"-Dinstall_prefix=${placeholder "out"}"
|
|
"-Dlocalstatedir=/var"
|
|
"-Drunstatedir=/run"
|
|
"-Dlibpcap=enabled"
|
|
"-Ddriver_qemu=enabled"
|
|
"-Ddriver_vmware=enabled"
|
|
"-Ddriver_vbox=enabled"
|
|
"-Ddriver_test=enabled"
|
|
"-Ddriver_esx=enabled"
|
|
"-Ddriver_remote=enabled"
|
|
"-Dpolkit=enabled"
|
|
(opt "storage_iscsi" enableIscsi)
|
|
] ++ optionals stdenv.isLinux [
|
|
(opt "storage_zfs" (zfs != null))
|
|
"-Dattr=enabled"
|
|
"-Dapparmor=enabled"
|
|
"-Dsecdriver_apparmor=enabled"
|
|
"-Dnumad=enabled"
|
|
"-Dstorage_disk=enabled"
|
|
(opt "glusterfs" enableGlusterfs)
|
|
(opt "storage_rbd" enableCeph)
|
|
] ++ optionals stdenv.isDarwin [
|
|
"-Dinit_script=none"
|
|
];
|
|
|
|
postInstall =
|
|
let
|
|
binPath = [ iptables iproute2 pmutils numad numactl bridge-utils dmidecode dnsmasq ] ++ optionals enableIscsi [ openiscsi ];
|
|
in
|
|
''
|
|
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 stdenv.isLinux ''
|
|
substituteInPlace $out/lib/systemd/system/libvirtd.service --replace /bin/kill ${coreutils}/bin/kill
|
|
rm $out/lib/systemd/system/{virtlockd,virtlogd}.*
|
|
wrapProgram $out/sbin/libvirtd \
|
|
--prefix PATH : /run/libvirt/nix-emulators:${makeBinPath binPath}
|
|
'';
|
|
|
|
meta = {
|
|
homepage = "https://libvirt.org/";
|
|
repositories.git = "git://libvirt.org/libvirt.git";
|
|
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 ];
|
|
};
|
|
}
|