summaryrefslogtreecommitdiff
path: root/modules/nixos/podman.nix
diff options
context:
space:
mode:
authorAzat Bahawi <azat@bahawi.net>2022-12-17 16:39:09 +0300
committerAzat Bahawi <azat@bahawi.net>2022-12-17 16:39:09 +0300
commit8f137c28230623259a964484adcf31fe00756594 (patch)
tree82bce6a13fda125087cf6d9dc80aa91d9230d6c4 /modules/nixos/podman.nix
parent3229e56e0d3620ddc735edcfbbefb167efa3b23f (diff)
2022-12-17
Diffstat (limited to 'modules/nixos/podman.nix')
-rw-r--r--modules/nixos/podman.nix41
1 files changed, 41 insertions, 0 deletions
diff --git a/modules/nixos/podman.nix b/modules/nixos/podman.nix
new file mode 100644
index 0000000..1c5378b
--- /dev/null
+++ b/modules/nixos/podman.nix
@@ -0,0 +1,41 @@
+{
+ config,
+ lib,
+ inputs,
+ pkgs,
+ ...
+}:
+with lib; let
+ cfg = config.nixfiles.modules.podman;
+in {
+ options.nixfiles.modules.podman.enable = mkEnableOption "Podman";
+
+ config = mkIf cfg.enable {
+ assertions = [
+ {
+ assertion = !config.nixfiles.modules.docker.enable;
+ message = "Pick only one!";
+ }
+ ];
+
+ secrets.containers-auth = {
+ file = "${inputs.self}/secrets/containers-auth";
+ path = "${config.dirs.config}/containers/auth.json";
+ owner = my.username;
+ inherit (config.my) group;
+ };
+
+ virtualisation.podman.enable = true;
+
+ environment.systemPackages = with pkgs; [podman-compose];
+
+ my.extraGroups = ["podman"];
+
+ hm.programs.bash = {
+ shellAliases.p = "${pkgs.podman}/bin/podman";
+ initExtra = mkAfter ''
+ _complete_alias p __start_podman podman
+ '';
+ };
+ };
+}