Files
nixos/utils/pkgs/sysbox.nix

66 lines
1.3 KiB
Nix

{ stdenv
, lib
, fetchurl
, dpkg
, libredirect
, makeWrapper
, gzip
, fuse
, lsb-release
, rsync
, iptables
, jq
, kmod
}:
stdenv.mkDerivation rec {
pname = "sysbox";
version = "0.6.2-0";
src = fetchurl {
url = "https://downloads.nestybox.com/sysbox/releases/v0.6.2/sysbox-ce_${version}.linux_amd64.deb";
sha256 = "sha256-/Sh/LztaBytiw3j54e7uqizK0iu0jLOB0w2MhVxRtAE=";
};
nativeBuildInputs = [ dpkg makeWrapper ];
unpackPhase = ''
runHook preUnpack
dpkg -x $src ./src
runHook postUnpack
'';
installPhase = ''
runHook preInstall
mkdir -p "$out"
cp -r src/* "$out"
mv "$out/usr/"* "$out/"
rmdir "$out/usr"
for f in "$out/lib/systemd/system/"*.service; do
substituteInPlace "$f" \
--replace "/usr/" "$out/"
done
for p in "$out/bin/"*; do
wrapProgram "$p" \
--set NIX_REDIRECTS "/usr/share=$out/share:/usr/bin=$out/bin" \
--prefix PATH : "${lib.makeBinPath [ fuse rsync iptables lsb-release jq kmod ]}"
done
runHook postInstall
'';
meta = with lib; {
description = "Improves container isolation";
homepage = "https://github.com/nestybox/sysbox";
license = licenses.asl20;
platforms = with platforms; [ "x86_64-linux" ];
mainProgram = "sysbox-runc";
};
}