{ config, lib, pkgs, ... }: let cfg = config.services.podman; toml = pkgs.formats.toml { }; json = pkgs.formats.json { }; inherit (lib) mkOption types; podmanPackage = (pkgs.podman.override { inherit (cfg) extraPackages; }); net-conflist = pkgs.runCommand "87-podman-bridge.conflist" { nativeBuildInputs = [ pkgs.jq ]; extraPlugins = builtins.toJSON cfg.defaultNetwork.extraPlugins; jqScript = '' . + { "plugins": (.plugins + $extraPlugins) } ''; } '' jq <${cfg.package}/etc/cni/net.d/87-podman-bridge.conflist \ --argjson extraPlugins "$extraPlugins" \ "$jqScript" \ >$out ''; in { imports = [ ./podman-dnsname.nix #./podman-network-socket.nix (lib.mkRenamedOptionModule [ "virtualisation" "podman" "libpod" ] [ "virtualisation" "containers" "containersConf" ]) ]; meta = { maintainers = lib.teams.podman.members; }; options.services.podman = { enable = mkOption { type = types.bool; default = false; description = '' This option enables Podman, a daemonless container engine for developing, managing, and running OCI Containers on your Linux System. It is a drop-in replacement for the docker command. ''; }; enableNvidia = mkOption { type = types.bool; default = false; description = '' Enable use of NVidia GPUs from within podman containers. ''; }; extraPackages = mkOption { type = with types; listOf package; default = [ ]; example = lib.literalExample '' [ pkgs.gvisor ] ''; description = '' Extra packages to be installed in the Podman wrapper. ''; }; package = lib.mkOption { type = types.package; default = podmanPackage; internal = true; description = '' The final Podman package (including extra packages). ''; }; defaultNetwork.extraPlugins = lib.mkOption { type = types.listOf json.type; default = [ ]; description = '' Extra CNI plugin configurations to add to podman's default network. ''; }; }; config = lib.mkIf cfg.enable { home.packages = [ cfg.package ]; xdg.configFile."cni/net.d/87-podman-bridge.conflist".source = net-conflist; virtualisation.containers = { enable = true; # Enable common /etc/containers configuration containersConf.settings = lib.optionalAttrs cfg.enableNvidia { engine = { conmon_env_vars = [ "PATH=${lib.makeBinPath [ pkgs.nvidia-podman ]}" ]; runtimes.nvidia = [ "${pkgs.nvidia-podman}/bin/nvidia-container-runtime" ]; }; }; }; systemd.user = { services.podman = { Unit = { Description = "Podman API Service"; Requires = "podman.socket"; After = "podman.socket"; Documentation = "man:podman-system-service(1)"; StartLimitIntervalSec = 0; }; Service = { Type = "exec"; KillMode = "process"; Environment = "LOGGING=\" --log-level=info\""; ExecStart = [ "" "${cfg.package}/bin/podman $LOGGING system service" ]; }; Install = { WantedBy = [ "multi-user.target" ]; }; }; sockets.podman = { Unit = { Description = "Podman API Socket"; Documentation = "man:podman-system-service(1)"; }; Socket = { ListenStream = "%t/podman/podman.sock"; SocketMode = 0660; }; Install.WantedBy = [ "sockets.target" ]; }; }; }; }