feat(whitby): Configure initial Keycloak setup

Trialing this as an alternative to CAS that is a little easier to
configure and can help us delegate authentication to other OIDC
services.

Change-Id: Iad63724d349334910af8fed0b148e4ba428f796b
Reviewed-on: https://cl.tvl.fyi/c/depot/+/4608
Tested-by: BuildkiteCI
Autosubmit: tazjin <mail@tazj.in>
Reviewed-by: lukegb <lukegb@tvl.fyi>
This commit is contained in:
Vincent Ambo 2021-12-25 17:06:15 +03:00 committed by clbot
parent 1ee31d67fc
commit d8a1802b3e
4 changed files with 59 additions and 1 deletions

View file

@ -23,6 +23,7 @@ in {
"${depot.path}/ops/modules/tvl-slapd/default.nix" "${depot.path}/ops/modules/tvl-slapd/default.nix"
"${depot.path}/ops/modules/tvl-sso/default.nix" "${depot.path}/ops/modules/tvl-sso/default.nix"
"${depot.path}/ops/modules/www/atward.tvl.fyi.nix" "${depot.path}/ops/modules/www/atward.tvl.fyi.nix"
"${depot.path}/ops/modules/www/auth.tvl.fyi.nix"
"${depot.path}/ops/modules/www/b.tvl.fyi.nix" "${depot.path}/ops/modules/www/b.tvl.fyi.nix"
"${depot.path}/ops/modules/www/cache.tvl.su.nix" "${depot.path}/ops/modules/www/cache.tvl.su.nix"
"${depot.path}/ops/modules/www/cl.tvl.fyi.nix" "${depot.path}/ops/modules/www/cl.tvl.fyi.nix"
@ -210,6 +211,7 @@ in {
gerrit-queue.file = secretFile "gerrit-queue"; gerrit-queue.file = secretFile "gerrit-queue";
grafana.file = secretFile "grafana"; grafana.file = secretFile "grafana";
irccat.file = secretFile "irccat"; irccat.file = secretFile "irccat";
keycloak-db.file = secretFile "keycloak-db";
nix-cache-priv.file = secretFile "nix-cache-priv"; nix-cache-priv.file = secretFile "nix-cache-priv";
owothia.file = secretFile "owothia"; owothia.file = secretFile "owothia";
panettone.file = secretFile "panettone"; panettone.file = secretFile "panettone";
@ -417,8 +419,9 @@ in {
services.postgresqlBackup = { services.postgresqlBackup = {
enable = true; enable = true;
databases = [ databases = [
"tvldb" "keycloak"
"panettone" "panettone"
"tvldb"
]; ];
}; };
@ -546,9 +549,39 @@ in {
}]; }];
}; };
}; };
# Contains GF_AUTH_GENERIC_OAUTH_CLIENT_SECRET. # Contains GF_AUTH_GENERIC_OAUTH_CLIENT_SECRET.
systemd.services.grafana.serviceConfig.EnvironmentFile = "/run/agenix/grafana"; systemd.services.grafana.serviceConfig.EnvironmentFile = "/run/agenix/grafana";
services.keycloak = {
enable = true;
httpPort = "5925"; # "kycl"
frontendUrl = "https://auth.tvl.fyi/auth/";
database = {
type = "postgresql";
passwordFile = "/run/agenix/keycloak-db";
createLocally = false;
};
# Configure Keycloak to look at forwarded headers from the reverse
# proxy.
extraConfig = {
"subsystem=undertow" = {
"server=default-server" = {
"http-listener=default" = {
proxy-address-forwarding = "true";
};
};
};
};
};
# Allow Keycloak access to the LDAP module by forcing in the JVM
# configuration
systemd.services.keycloak.environment.PREPEND_JAVA_OPTS =
"--add-exports=java.naming/com.sun.jndi.ldap=ALL-UNNAMED";
security.sudo.extraRules = [ security.sudo.extraRules = [
{ {
groups = ["wheel"]; groups = ["wheel"];

View file

@ -0,0 +1,24 @@
{ config, ... }:
{
imports = [
./base.nix
];
config = {
services.nginx.virtualHosts."auth.tvl.fyi" = {
serverName = "auth.tvl.fyi";
enableACME = true;
forceSSL = true;
extraConfig = ''
location / {
proxy_pass http://localhost:${config.services.keycloak.httpPort};
proxy_set_header X-Forwarded-For $remote_addr;
proxy_set_header X-Forwarded-Proto https;
proxy_set_header Host $host;
}
'';
};
};
}

BIN
ops/secrets/keycloak-db.age Normal file

Binary file not shown.

View file

@ -24,6 +24,7 @@ in {
"gerrit-queue.age" = default; "gerrit-queue.age" = default;
"grafana.age" = default; "grafana.age" = default;
"irccat.age" = default; "irccat.age" = default;
"keycloak-db.age" = default;
"nix-cache-priv.age" = default; "nix-cache-priv.age" = default;
"nix-cache-pub.age" = default; "nix-cache-pub.age" = default;
"owothia.age" = default; "owothia.age" = default;