settei/hosts/kazuki/vault.nix

50 lines
1.2 KiB
Nix

{ config, pkgs, ... }:
{
age.secrets.vault-cert-env = {
file = ../../secrets/vault-cert-env.age;
owner = config.services.nginx.user;
};
services.vaultwarden = {
enable = true;
# TODO: Remove with next version bump
webVaultPackage = pkgs.vaultwarden.webvault.override { python3 = pkgs.python311; };
config = {
ROCKET_PORT = 60001;
};
};
users.users.nginx.extraGroups = [ "acme" ];
networking.firewall.allowedTCPPorts = [
80
443
8448
2222
];
services.nginx = {
enable = true;
recommendedProxySettings = true;
recommendedGzipSettings = true;
recommendedOptimisation = true;
recommendedTlsSettings = true;
virtualHosts."vault.rabulinski.com" = {
forceSSL = true;
enableACME = true;
acmeRoot = null;
locations."/" = {
proxyPass = "http://vaultwarden";
proxyWebsockets = true;
};
};
upstreams.vaultwarden.servers = {
"localhost:${toString config.services.vaultwarden.config.ROCKET_PORT}" = { };
};
};
security.acme.certs."vault.rabulinski.com" = {
dnsProvider = "cloudflare";
credentialsFile = config.age.secrets.vault-cert-env.path;
};
}