about summary refs log tree commit diff
path: root/modules/nixos/docker.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/docker.nix
parent2022-11-20 (diff)
2022-12-17
Diffstat (limited to 'modules/nixos/docker.nix')
-rw-r--r--modules/nixos/docker.nix41
1 files changed, 41 insertions, 0 deletions
diff --git a/modules/nixos/docker.nix b/modules/nixos/docker.nix
new file mode 100644
index 0000000..e642030
--- /dev/null
+++ b/modules/nixos/docker.nix
@@ -0,0 +1,41 @@
+{
+  config,
+  inputs,
+  lib,
+  pkgs,
+  ...
+}:
+with lib; let
+  cfg = config.nixfiles.modules.docker;
+in {
+  options.nixfiles.modules.docker.enable = mkEnableOption "Docker";
+
+  config = mkIf cfg.enable {
+    assertions = [
+      {
+        assertion = !config.nixfiles.modules.podman.enable;
+        message = "Pick only one!";
+      }
+    ];
+
+    secrets.containers-auth = {
+      file = "${inputs.self}/secrets/containers-auth";
+      path = "${config.my.home}/.docker/config.json";
+      owner = my.username;
+      inherit (config.my) group;
+    };
+
+    virtualisation.docker.enable = true;
+
+    environment.systemPackages = with pkgs; [docker-compose];
+
+    my.extraGroups = ["docker"];
+
+    hm.programs.bash = {
+      shellAliases.d = "${pkgs.docker}/bin/docker";
+      initExtra = mkAfter ''
+        _complete_alias d _docker docker
+      '';
+    };
+  };
+}

Consider giving Nix/NixOS a try! <3