{ stdenv, lib, autoreconfHook, acl, go, file, git, wget, gnupg1, trousers, squashfsTools, cpio, fetchurl, fetchFromGitHub, iptables, systemd, makeWrapper }: let coreosImageRelease = "835.12.0"; coreosImageSystemdVersion = "225"; # TODO: track https://github.com/coreos/rkt/issues/1758 to allow "host" flavor. stage1Flavours = [ "coreos" "fly" "host" ]; in stdenv.mkDerivation rec { version = "1.0.0"; name = "rkt-${version}"; BUILDDIR="build-${name}"; src = fetchFromGitHub { rev = "v${version}"; owner = "coreos"; repo = "rkt"; sha256 = "1m76hzx550dh35jpb8m46ks04ac3dfy4rg054v035rpwgh50ac6h"; }; stage1BaseImage = fetchurl { url = "http://stable.release.core-os.net/amd64-usr/${coreosImageRelease}/coreos_production_pxe_image.cpio.gz"; sha256 = "0djzgfcqr9yy13i415204ji82lrk8mvdhl9rxjr123j1glf5sdh3"; }; buildInputs = [ autoreconfHook go file git wget gnupg1 trousers squashfsTools cpio acl systemd makeWrapper ]; preConfigure = '' ./autogen.sh configureFlagsArray=( --with-stage1-flavors=${builtins.concatStringsSep "," stage1Flavours} ${if lib.findFirst (p: p == "coreos") null stage1Flavours != null then " --with-coreos-local-pxe-image-path=${stage1BaseImage} --with-coreos-local-pxe-image-systemd-version=v${coreosImageSystemdVersion} " else "" } ); ''; preBuild = '' export BUILDDIR ''; installPhase = '' mkdir -p $out/bin cp -Rv $BUILDDIR/bin/* $out/bin wrapProgram $out/bin/rkt \ --prefix LD_LIBRARY_PATH : ${systemd}/lib \ --prefix PATH : ${iptables}/bin ''; meta = with lib; { description = "A fast, composable, and secure App Container runtime for Linux"; homepage = https://github.com/coreos/rkt; license = licenses.asl20; maintainers = with maintainers; [ ragge steveej ]; platforms = [ "x86_64-linux" ]; }; }