nixpkgs/pkgs/by-name/lx/lxc/package.nix

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

117 lines
3.0 KiB
Nix
Raw Normal View History

2023-12-27 19:32:57 +00:00
{
lib,
stdenv,
fetchFromGitHub,
dbus,
2023-12-27 19:32:57 +00:00
docbook2x,
libapparmor,
libcap,
libseccomp,
libselinux,
meson,
ninja,
nixosTests,
openssl,
pkg-config,
systemd,
nix-update-script,
}:
stdenv.mkDerivation (finalAttrs: {
pname = "lxc";
2024-09-19 13:59:25 +00:00
version = "6.0.2";
2023-12-27 19:32:57 +00:00
src = fetchFromGitHub {
owner = "lxc";
repo = "lxc";
rev = "refs/tags/v${finalAttrs.version}";
2024-09-19 13:59:25 +00:00
hash = "sha256-qc60oSs2KahQJpSmhrctXpV2Zumv7EvlnGFaOCSCX/E=";
};
2015-08-01 00:08:04 +00:00
nativeBuildInputs = [
2023-12-27 19:32:57 +00:00
docbook2x
meson
ninja
pkg-config
2015-08-01 00:08:04 +00:00
];
2023-12-27 19:32:57 +00:00
2015-03-27 00:54:25 +00:00
buildInputs = [
dbus
2023-12-27 19:32:57 +00:00
libapparmor
libcap
libseccomp
libselinux
openssl
systemd
2015-03-27 00:54:25 +00:00
];
patches = [
# fix docbook2man version detection
./docbook-hack.patch
# Fix hardcoded path of lxc-user-nic
# This is needed to use unprivileged containers
./user-nic.diff
];
2023-12-27 19:32:57 +00:00
mesonFlags = [
"-Dinstall-init-files=true"
2023-12-27 19:32:57 +00:00
"-Dinstall-state-dirs=false"
"-Dspecfile=false"
2024-07-02 03:43:43 +00:00
"-Dtools-multicall=true"
"-Dtools=false"
"-Dusernet-config-path=/etc/lxc/lxc-usernet"
"-Ddistrosysconfdir=${placeholder "out"}/etc/lxc"
"-Dsystemd-unitdir=${placeholder "out"}/lib/systemd/system"
];
# /run/current-system/sw/share
postInstall = ''
substituteInPlace $out/etc/lxc/lxc --replace-fail "$out/etc/lxc" "/etc/lxc"
substituteInPlace $out/libexec/lxc/lxc-net --replace-fail "$out/etc/lxc" "/etc/lxc"
substituteInPlace $out/share/lxc/templates/lxc-download --replace-fail "$out/share" "/run/current-system/sw/share"
substituteInPlace $out/share/lxc/templates/lxc-local --replace-fail "$out/share" "/run/current-system/sw/share"
substituteInPlace $out/share/lxc/templates/lxc-oci --replace-fail "$out/share" "/run/current-system/sw/share"
substituteInPlace $out/share/lxc/config/common.conf --replace-fail "$out/share" "/run/current-system/sw/share"
substituteInPlace $out/share/lxc/config/userns.conf --replace-fail "$out/share" "/run/current-system/sw/share"
substituteInPlace $out/share/lxc/config/oci.common.conf --replace-fail "$out/share" "/run/current-system/sw/share"
'';
2023-12-27 19:32:57 +00:00
enableParallelBuilding = true;
2023-12-27 19:32:57 +00:00
doCheck = true;
2015-08-01 00:08:04 +00:00
2023-12-27 19:32:57 +00:00
passthru = {
tests = {
incus-legacy-init = nixosTests.incus.container-legacy-init;
incus-systemd-init = nixosTests.incus.container-systemd-init;
lxc = nixosTests.lxc;
lxd = nixosTests.lxd.container;
};
2023-12-27 19:32:57 +00:00
updateScript = nix-update-script {
extraArgs = [
"--version-regex"
"v(6.0.*)"
2023-12-27 19:32:57 +00:00
];
};
};
2015-05-17 10:50:01 +00:00
meta = {
homepage = "https://linuxcontainers.org/";
description = "Userspace tools for Linux Containers, a lightweight virtualization system";
license = lib.licenses.gpl2;
longDescription = ''
LXC containers are often considered as something in the middle between a chroot and a
full fledged virtual machine. The goal of LXC is to create an environment as close as
possible to a standard Linux installation but without the need for a separate kernel.
'';
2023-12-02 14:44:34 +00:00
platforms = lib.platforms.linux;
maintainers = lib.teams.lxc.members;
};
})