diff options
Diffstat (limited to 'modules/server/secrets.nix')
| -rw-r--r-- | modules/server/secrets.nix | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/modules/server/secrets.nix b/modules/server/secrets.nix new file mode 100644 index 0000000..c0290cd --- /dev/null +++ b/modules/server/secrets.nix @@ -0,0 +1,25 @@ +{ + config, + lib, + self, + ... +}: let + cfg = config.getchoo.server.secrets; + inherit (lib) mkEnableOption mkIf; +in { + options.getchoo.server.secrets = { + enable = mkEnableOption "enable secret management"; + }; + + config.age = let + baseDir = "${self}/secrets/hosts/${config.networking.hostName}"; + in + mkIf cfg.enable { + identityPaths = ["/etc/age/key"]; + + secrets = { + rootPassword.file = "${baseDir}/rootPassword.age"; + userPassword.file = "${baseDir}/userPassword.age"; + }; + }; +} |
