infrastructure/nixos/postgres.nix

47 lines
1 KiB
Nix

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