summaryrefslogtreecommitdiff
path: root/modules/nixos/mixins/kanidm.nix
blob: 09730e0e8400b71f35400b9f291349e36c2a83d0 (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_backups = {
            versions = lib.mkDefault 7; # Keep a week's worth of backups
          };
        };
      };
    }

    (lib.mkIf kanidmCfg.enableServer {
      services.nginx.virtualHosts.${kanidmCfg.serverSettings.domain} = {
        locations."/" = {
          proxyPass = kanidmCfg.serverSettings.bindaddress;
        };
      };
    })
  ];
}