Tom Hubrecht
2f06f22ac7
All checks were successful
Check meta / check_meta (pull_request) Successful in 18s
Check meta / check_dns (pull_request) Successful in 16s
build configuration / build_and_cache_storage01 (pull_request) Successful in 1m22s
build configuration / build_and_cache_rescue01 (pull_request) Successful in 1m20s
build configuration / build_and_cache_compute01 (pull_request) Successful in 1m40s
build configuration / build_and_cache_geo01 (pull_request) Successful in 1m4s
build configuration / build_and_cache_krz01 (pull_request) Successful in 2m2s
lint / check (pull_request) Successful in 25s
build configuration / build_and_cache_geo02 (pull_request) Successful in 1m4s
build configuration / build_and_cache_web02 (pull_request) Successful in 1m16s
build configuration / build_and_cache_bridge01 (pull_request) Successful in 1m9s
build configuration / build_and_cache_vault01 (pull_request) Successful in 1m23s
build configuration / build_and_cache_web01 (pull_request) Successful in 1m54s
build configuration / build_and_cache_storage01 (push) Successful in 1m14s
build configuration / build_and_cache_compute01 (push) Successful in 1m33s
build configuration / build_and_cache_krz01 (push) Successful in 2m1s
build configuration / build_and_cache_rescue01 (push) Successful in 1m15s
build configuration / build_and_cache_geo01 (push) Successful in 1m0s
build configuration / build_and_cache_geo02 (push) Successful in 1m4s
build configuration / build_and_cache_vault01 (push) Successful in 1m21s
lint / check (push) Successful in 24s
build configuration / build_and_cache_web02 (push) Successful in 1m7s
build configuration / build_and_cache_bridge01 (push) Successful in 1m5s
build configuration / build_and_cache_web01 (push) Successful in 1m41s
80 lines
1.9 KiB
Nix
80 lines
1.9 KiB
Nix
{ config, ... }:
|
|
|
|
let
|
|
host = "grafana.dgnum.eu";
|
|
port = 3033;
|
|
|
|
file = name: "$__file{${config.age.secrets."grafana-${name}_file".path}}";
|
|
in
|
|
|
|
{
|
|
services = {
|
|
grafana = {
|
|
enable = true;
|
|
|
|
settings = {
|
|
"auth.generic_oauth" = {
|
|
api_url = "https://sso.dgnum.eu/oauth2/openid/grafana_dgn/userinfo";
|
|
auth_url = "https://sso.dgnum.eu/ui/oauth2";
|
|
client_id = "grafana_dgn";
|
|
client_secret = file "oauth_client_secret";
|
|
enabled = true;
|
|
id_token_attribute_name = "sub";
|
|
login_attribute_path = "preferred_username";
|
|
name = "Kanidm";
|
|
scopes = "email,openid,profile";
|
|
token_url = "https://sso.dgnum.eu/oauth2/token";
|
|
use_pkce = true;
|
|
};
|
|
|
|
database = {
|
|
type = "postgres";
|
|
user = "grafana";
|
|
host = "/run/postgresql";
|
|
};
|
|
|
|
security.disable_initial_admin_creation = true;
|
|
|
|
server = {
|
|
domain = host;
|
|
enable_gzip = true;
|
|
enforce_domain = true;
|
|
http_port = port;
|
|
root_url = "https://${host}";
|
|
router_logging = true;
|
|
};
|
|
|
|
smtp = {
|
|
enabled = true;
|
|
from_address = "grafana@infra.dgnum.eu";
|
|
host = "kurisu.lahfa.xyz:587";
|
|
password = file "smtp_password";
|
|
user = "web-services@infra.dgnum.eu";
|
|
};
|
|
|
|
users = {
|
|
default_theme = "system";
|
|
default_language = "en-GB";
|
|
auto_assign_org_role = "Admin";
|
|
};
|
|
};
|
|
};
|
|
|
|
postgresql = {
|
|
ensureDatabases = [ "grafana" ];
|
|
ensureUsers = [
|
|
{
|
|
name = "grafana";
|
|
ensureDBOwnership = true;
|
|
}
|
|
];
|
|
};
|
|
};
|
|
|
|
dgn-web.simpleProxies.grafana = {
|
|
inherit host port;
|
|
proxyWebsockets = true;
|
|
};
|
|
|
|
age-secrets.autoMatch = [ "grafana" ];
|
|
}
|