blob: 46d43b3c259086053c9b7d672885ddc3d2695675 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
{ config, lib, ... }:
let
kanidmCfg = config.services.kanidm;
certDirectory = config.security.acme.certs.${kanidmCfg.serverSettings.domain}.directory;
in
{
config = lib.mkMerge [
{
services.kanidm = {
clientSettings = {
uri = lib.mkDefault kanidmCfg.serverSettings.origin;
};
serverSettings = {
tls_chain = certDirectory + "/fullchain.pem";
tls_key = certDirectory + "/key.pem";
domain = lib.mkDefault ("auth." + config.networking.domain);
origin = lib.mkDefault ("https://" + config.services.kanidm.serverSettings.domain);
online_backup = {
versions = lib.mkDefault 7; # Keep a week's worth of backups
};
};
};
}
(lib.mkIf kanidmCfg.enableServer {
services.nginx.virtualHosts.${kanidmCfg.serverSettings.domain} = {
locations."/" = {
proxyPass = "https://" + kanidmCfg.serverSettings.bindaddress;
};
};
})
];
}
|