infrastructure/nixos/postgres.nix
2024-05-26 14:13:33 -07:00

56 lines
1.4 KiB
Nix

{
config,
lib,
...
}: let
inherit (lib.modules) mkIf mkDefault mkAfter;
inherit (lib) versions;
cfg = config.services.postgresql;
in {
services.postgresql = {
enable = mkDefault true;
ensureDatabases = ["hass" "invidious" "dex" "keycloak" "vaultwarden"];
ensureUsers = [
{
name = "hass";
ensureDBOwnership = true;
authentication.int.allow = !config.services.home-assistant.enable;
}
{
name = "invidious";
ensureDBOwnership = true;
authentication.int.allow = !config.services.invidious.enable;
}
{
name = "dex";
ensureDBOwnership = true;
authentication.local.allow = true;
}
{
name = "keycloak";
ensureDBOwnership = true;
authentication.int.allow = !config.services.keycloak.enable;
}
{
name = "vaultwarden";
ensureDBOwnership = true;
authentication.int.allow = !config.services.vaultwarden.enable;
}
];
};
systemd = {
services.postgresql = mkIf cfg.enable {
gensokyo-zone.sharedMounts."postgresql/${versions.major cfg.package.version}".path = cfg.dataDir;
postStart = mkAfter ''
$PSQL -tAf ${config.sops.secrets.postgresql-init.path}
'';
};
};
sops.secrets.postgresql-init = {
sopsFile = mkDefault ./secrets/postgres.yaml;
owner = "postgres";
group = "postgres";
};
}