2021-04-21 20:46:01 +00:00
|
|
|
{ lib
|
|
|
|
, stdenv
|
2020-04-15 22:26:09 +00:00
|
|
|
, fetchFromGitHub
|
|
|
|
, pkg-config
|
|
|
|
, installShellFiles
|
2020-05-14 07:36:01 +00:00
|
|
|
, buildGoModule
|
2020-04-15 22:26:09 +00:00
|
|
|
, gpgme
|
|
|
|
, lvm2
|
|
|
|
, btrfs-progs
|
2020-05-13 11:37:47 +00:00
|
|
|
, libapparmor
|
2020-04-15 22:26:09 +00:00
|
|
|
, libseccomp
|
2020-05-13 11:37:47 +00:00
|
|
|
, libselinux
|
2020-04-15 22:26:09 +00:00
|
|
|
, systemd
|
2019-02-08 12:38:46 +00:00
|
|
|
, go-md2man
|
2020-04-23 02:01:49 +00:00
|
|
|
, nixosTests
|
2022-10-20 00:33:31 +00:00
|
|
|
, python3
|
2023-02-18 10:58:23 +00:00
|
|
|
, makeWrapper
|
|
|
|
, symlinkJoin
|
|
|
|
, extraPackages ? [ ]
|
|
|
|
, runc
|
|
|
|
, crun
|
|
|
|
, conmon
|
|
|
|
, slirp4netns
|
|
|
|
, fuse-overlayfs
|
|
|
|
, util-linux
|
|
|
|
, iptables
|
|
|
|
, iproute2
|
|
|
|
, catatonit
|
|
|
|
, gvproxy
|
|
|
|
, aardvark-dns
|
|
|
|
, netavark
|
2023-02-09 22:24:43 +00:00
|
|
|
, testers
|
|
|
|
, podman
|
2018-12-10 12:49:11 +00:00
|
|
|
}:
|
2023-02-18 10:58:23 +00:00
|
|
|
let
|
|
|
|
# do not add qemu to this wrapper, store paths get written to the podman vm config and break when GCed
|
2018-12-10 12:49:11 +00:00
|
|
|
|
2023-02-18 10:58:23 +00:00
|
|
|
binPath = lib.makeBinPath ([
|
|
|
|
] ++ lib.optionals stdenv.isLinux [
|
|
|
|
runc
|
|
|
|
crun
|
|
|
|
conmon
|
|
|
|
slirp4netns
|
|
|
|
fuse-overlayfs
|
|
|
|
util-linux
|
|
|
|
iptables
|
|
|
|
iproute2
|
|
|
|
] ++ extraPackages);
|
|
|
|
|
|
|
|
helpersBin = symlinkJoin {
|
|
|
|
name = "podman-helper-binary-wrapper";
|
|
|
|
|
|
|
|
# this only works for some binaries, others may need to be be added to `binPath` or in the modules
|
|
|
|
paths = [
|
|
|
|
gvproxy
|
|
|
|
] ++ lib.optionals stdenv.isLinux [
|
|
|
|
aardvark-dns
|
|
|
|
catatonit # added here for the pause image and also set in `containersConf` for `init_path`
|
|
|
|
netavark
|
|
|
|
];
|
|
|
|
};
|
|
|
|
in
|
2020-05-14 07:36:01 +00:00
|
|
|
buildGoModule rec {
|
2019-08-15 12:41:18 +00:00
|
|
|
pname = "podman";
|
2023-02-23 22:21:45 +00:00
|
|
|
version = "4.4.2";
|
2018-12-18 09:53:40 +00:00
|
|
|
|
2018-12-10 12:49:11 +00:00
|
|
|
src = fetchFromGitHub {
|
2020-04-15 22:26:09 +00:00
|
|
|
owner = "containers";
|
2020-07-16 02:21:46 +00:00
|
|
|
repo = "podman";
|
2020-04-15 22:26:09 +00:00
|
|
|
rev = "v${version}";
|
2023-02-23 22:21:45 +00:00
|
|
|
hash = "sha256-337PFsPGm7pUgnFeNJKwT+/7AdbWSfCx4kXyAvHyWJQ=";
|
2018-12-10 12:49:11 +00:00
|
|
|
};
|
2018-12-18 09:53:40 +00:00
|
|
|
|
2022-12-12 01:44:50 +00:00
|
|
|
patches = [
|
|
|
|
# we intentionally don't build and install the helper so we shouldn't display messages to users about it
|
|
|
|
./rm-podman-mac-helper-msg.patch
|
|
|
|
];
|
|
|
|
|
2023-02-08 21:30:58 +00:00
|
|
|
vendorHash = null;
|
2018-12-18 09:53:40 +00:00
|
|
|
|
2020-08-04 00:26:27 +00:00
|
|
|
doCheck = false;
|
|
|
|
|
2023-02-18 10:58:23 +00:00
|
|
|
outputs = [ "out" "man" ];
|
2019-02-08 12:38:46 +00:00
|
|
|
|
2023-02-18 10:58:23 +00:00
|
|
|
nativeBuildInputs = [ pkg-config go-md2man installShellFiles makeWrapper python3 ];
|
2018-12-18 09:53:40 +00:00
|
|
|
|
2021-01-15 05:42:41 +00:00
|
|
|
buildInputs = lib.optionals stdenv.isLinux [
|
2020-05-13 11:37:47 +00:00
|
|
|
btrfs-progs
|
|
|
|
gpgme
|
|
|
|
libapparmor
|
|
|
|
libseccomp
|
|
|
|
libselinux
|
|
|
|
lvm2
|
|
|
|
systemd
|
|
|
|
];
|
2018-12-10 12:49:11 +00:00
|
|
|
|
2023-02-18 10:58:23 +00:00
|
|
|
HELPER_BINARIES_DIR = "${PREFIX}/libexec/podman"; # used in buildPhase & installPhase
|
|
|
|
PREFIX = "${placeholder "out"}";
|
|
|
|
|
2018-12-10 12:49:11 +00:00
|
|
|
buildPhase = ''
|
2021-03-31 06:52:07 +00:00
|
|
|
runHook preBuild
|
2018-12-10 12:49:11 +00:00
|
|
|
patchShebangs .
|
2022-02-17 00:56:18 +00:00
|
|
|
${if stdenv.isDarwin then ''
|
|
|
|
make podman-remote # podman-mac-helper uses FHS paths
|
|
|
|
'' else ''
|
2023-02-18 10:58:23 +00:00
|
|
|
make bin/podman bin/rootlessport bin/quadlet
|
2022-02-17 00:56:18 +00:00
|
|
|
''}
|
2020-06-26 23:58:45 +00:00
|
|
|
make docs
|
2021-03-31 06:52:07 +00:00
|
|
|
runHook postBuild
|
2018-12-10 12:49:11 +00:00
|
|
|
'';
|
2018-12-18 09:53:40 +00:00
|
|
|
|
2021-03-31 06:52:07 +00:00
|
|
|
installPhase = ''
|
|
|
|
runHook preInstall
|
2022-02-17 00:56:18 +00:00
|
|
|
${if stdenv.isDarwin then ''
|
2023-02-18 10:58:23 +00:00
|
|
|
install bin/darwin/podman -Dt $out/bin
|
2022-02-17 00:56:18 +00:00
|
|
|
'' else ''
|
2023-02-18 10:58:23 +00:00
|
|
|
make install.bin install.systemd
|
2022-02-17 00:56:18 +00:00
|
|
|
''}
|
2023-02-18 10:58:23 +00:00
|
|
|
make install.completions install.man
|
|
|
|
mkdir -p ${HELPER_BINARIES_DIR}
|
|
|
|
ln -s ${helpersBin}/bin/* ${HELPER_BINARIES_DIR}
|
|
|
|
wrapProgram $out/bin/podman \
|
|
|
|
--prefix PATH : ${lib.escapeShellArg binPath}
|
2021-03-31 06:52:07 +00:00
|
|
|
runHook postInstall
|
2018-12-10 12:49:11 +00:00
|
|
|
'';
|
|
|
|
|
2021-05-26 15:56:20 +00:00
|
|
|
postFixup = lib.optionalString stdenv.isLinux ''
|
2023-02-18 10:58:23 +00:00
|
|
|
RPATH=$(patchelf --print-rpath $out/bin/.podman-wrapped)
|
|
|
|
patchelf --set-rpath "${lib.makeLibraryPath [ systemd ]}":$RPATH $out/bin/.podman-wrapped
|
2021-05-26 15:56:20 +00:00
|
|
|
'';
|
|
|
|
|
2021-05-25 08:15:22 +00:00
|
|
|
passthru.tests = {
|
2023-02-09 22:40:57 +00:00
|
|
|
version = testers.testVersion {
|
|
|
|
package = podman;
|
|
|
|
command = "HOME=$TMPDIR podman --version";
|
|
|
|
};
|
|
|
|
} // lib.optionalAttrs stdenv.isLinux {
|
2021-05-25 08:15:22 +00:00
|
|
|
inherit (nixosTests) podman;
|
|
|
|
# related modules
|
2021-05-31 07:40:04 +00:00
|
|
|
inherit (nixosTests)
|
|
|
|
podman-tls-ghostunnel
|
|
|
|
;
|
2022-05-03 09:38:29 +00:00
|
|
|
oci-containers-podman = nixosTests.oci-containers.podman;
|
2021-05-25 08:15:22 +00:00
|
|
|
};
|
2020-04-23 02:01:49 +00:00
|
|
|
|
2021-01-11 07:54:33 +00:00
|
|
|
meta = with lib; {
|
2020-03-12 00:43:26 +00:00
|
|
|
homepage = "https://podman.io/";
|
2018-12-10 12:49:11 +00:00
|
|
|
description = "A program for managing pods, containers and container images";
|
2022-02-17 00:56:18 +00:00
|
|
|
changelog = "https://github.com/containers/podman/blob/v${version}/RELEASE_NOTES.md";
|
2018-12-10 12:49:11 +00:00
|
|
|
license = licenses.asl20;
|
2020-04-03 10:11:25 +00:00
|
|
|
maintainers = with maintainers; [ marsam ] ++ teams.podman.members;
|
2018-12-10 12:49:11 +00:00
|
|
|
};
|
|
|
|
}
|