feat(deertopia): Foundational Authelia setup
By 'foundational,' I mean that a demo is working correctly. Work will continue in a follow-up commit integrating existing services with LDAP and Authelia. ♥
This commit is contained in:
@@ -20,7 +20,7 @@ in {
|
||||
|
||||
sydnix.sops.secrets =
|
||||
let e = {
|
||||
mode = "0600";
|
||||
mode = "0440";
|
||||
owner = "lldap";
|
||||
group = "lldap";
|
||||
};
|
||||
@@ -63,39 +63,5 @@ in {
|
||||
enable = true;
|
||||
keysZoneName = "auth_cache";
|
||||
};
|
||||
sydnix.deertopia.nginx.vhosts."ldap".vhost =
|
||||
let consultant = "http://localhost:9090";
|
||||
port = builtins.toString config.services.lldap.settings.http_port;
|
||||
base-dn = config.services.lldap.settings.ldap_base_dn;
|
||||
nginx-bind-user = "nginx-bind-user";
|
||||
in {
|
||||
forceSSL = true;
|
||||
enableACME = true;
|
||||
locations."/".extraConfig = ''
|
||||
auth_request /auth-proxy;
|
||||
error_page 401 =200 /login;
|
||||
proxy_pass ${consultant};
|
||||
'';
|
||||
locations."/login".extraConfig = ''
|
||||
proxy_pass ${consultant}/login;
|
||||
proxy_set_header X-Target $request_uri;
|
||||
'';
|
||||
locations."= /auth-proxy".extraConfig = ''
|
||||
internal;
|
||||
proxy_pass ${consultant};
|
||||
proxy_pass_request_body off;
|
||||
proxy_pass_request_headers off;
|
||||
proxy_set_header Content-Length "";
|
||||
proxy_cache auth_cache;
|
||||
proxy_cache_valid 200 10m;
|
||||
proxy_cache_key "$http_authorization$cookie_nginxauth";
|
||||
# proxy_set_header X-Ldap-URL "ldap://localhost:${port}";
|
||||
# proxy_set_header X-Ldap-BaseDN "cn=people,${base-dn}";
|
||||
# proxy_set_header X-Ldap-BindDN "cn=${nginx-bind-user},${base-dn}";
|
||||
# proxy_set_header X-Ldap-BindPass "secret123";
|
||||
# proxy_set_header X-CookieName "nginxauth";
|
||||
proxy_set_header Cookie nginxauth=$cookie_nginxauth;
|
||||
'';
|
||||
};
|
||||
};
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user