diff options
author | Azat Bahawi <azat@bahawi.net> | 2024-04-21 02:15:42 +0300 |
---|---|---|
committer | Azat Bahawi <azat@bahawi.net> | 2024-04-21 02:15:42 +0300 |
commit | e6ed60548397627bf10f561f9438201dbba0a36e (patch) | |
tree | f9a84c5957d2cc4fcd148065ee9365a0c851ae1c /modules/docker.nix | |
parent | 9ac64328603d44bd272175942d3ea3eaadcabd04 (diff) |
2024-04-21
Diffstat (limited to 'modules/docker.nix')
-rw-r--r-- | modules/docker.nix | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/modules/docker.nix b/modules/docker.nix new file mode 100644 index 0000000..62dc095 --- /dev/null +++ b/modules/docker.nix @@ -0,0 +1,38 @@ +{ + 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 = cfg.enable -> !config.nixfiles.modules.podman.enable; + message = "Pick only one!"; + } + ]; + + nixfiles.modules.common.shell.aliases.d = "docker"; + + 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" ]; + }; +} |