Compare commits

...

2 commits

Author SHA1 Message Date
d8d079953b redirect proxy 2026-03-06 14:50:37 +07:00
d8857f46f9 update config vaultwarden 2026-03-06 14:44:28 +07:00
2 changed files with 15 additions and 7 deletions

View file

@ -2,11 +2,12 @@
services.vaultwarden = {
enable = true;
config = {
DOMAIN = "pass.proxy.${homelab.domain}";
SIGNUPS_ALLOWED = true;
ROCKET_ADDRESS = "127.0.0.1";
DOMAIN = "https://pass.proxy.${homelab.domain}";
ROCKET_PORT = 8060;
ROCKET_ADDRESS = "127.0.0.1";
ROCKET_LOG = "critical";
DATA_FOLDER = "/mnt/data/vaultwarden";
SIGNUPS_ALLOWED = true;
};
};
}

View file

@ -1,6 +1,6 @@
{ homelab, lib, ... }: let
base = "proxy.${homelab.domain}";
proxy-mappings = {
hosts = {
"dns" = { dest = "http://localhost:8088"; auth = true; };
"ai" = { dest = "http://localhost:8080"; auth = true; };
@ -21,6 +21,10 @@
"cdn" = { dest = "http://localhost:3000"; auth = false; };
"@" = { dest = "http://localhost:5070"; auth = false; };
};
redirects = {
"www" = "https://proxy.${homelab.domain}";
"dash" = "https://${homelab.domain}";
};
in {
users.users.nginx.extraGroups = [ "acme" ];
security.acme = {
@ -46,10 +50,13 @@ in {
useACMEHost = base;
locations."/".return = "404";
};
} // lib.mapAttrs' (subdomain: cfg: lib.nameValuePair (if subdomain == "@" then base else "${subdomain}.${base}") {
} // lib.mapAttrs' (subdomain: cfg: lib.nameValuePair "${subdomain}.${base}" {
useACMEHost = base;
forceSSL = true;
locations."/".return = "301 https://${base}$request_uri";
}) redirects // lib.mapAttrs' (subdomain: cfg: lib.nameValuePair (if subdomain == "@" then base else "${subdomain}.${base}") {
useACMEHost = base;
forceSSL = true;
locations."/" = {
proxyPass = cfg.dest;
proxyWebsockets = true;
@ -69,6 +76,6 @@ in {
client_max_body_size 50000M;
'';
};
}) proxy-mappings;
}) hosts;
};
}