2017-11-06 18:41:34 +01:00
|
|
|
{ pkgs, config, lib, ... } :
|
|
|
|
|
|
|
|
let
|
|
|
|
inherit (lib) mkIf concatStrings concatStringsSep concatMapStrings toList
|
2017-11-13 14:09:35 +01:00
|
|
|
mapAttrs mapAttrsToList attrValues;
|
2017-11-06 18:41:34 +01:00
|
|
|
cfg = config.services.kerberos_server;
|
|
|
|
kerberos = config.krb5.kerberos;
|
|
|
|
stateDir = "/var/lib/krb5kdc";
|
|
|
|
PIDFile = "/run/kdc.pid";
|
|
|
|
aclMap = {
|
|
|
|
add = "a"; cpw = "c"; delete = "d"; get = "i"; list = "l"; modify = "m";
|
|
|
|
all = "*";
|
|
|
|
};
|
2017-11-13 14:09:35 +01:00
|
|
|
aclFiles = mapAttrs
|
|
|
|
(name: {acl, ...}: (pkgs.writeText "${name}.acl" (concatMapStrings (
|
|
|
|
{principal, access, target, ...} :
|
|
|
|
let access_code = map (a: aclMap.${a}) (toList access); in
|
|
|
|
"${principal} ${concatStrings access_code} ${target}\n"
|
|
|
|
) acl))) cfg.realms;
|
|
|
|
kdcConfigs = mapAttrsToList (name: value: ''
|
2017-11-06 18:41:34 +01:00
|
|
|
${name} = {
|
2017-11-13 14:09:35 +01:00
|
|
|
acl_file = ${value}
|
2017-11-06 18:41:34 +01:00
|
|
|
}
|
2017-11-13 14:09:35 +01:00
|
|
|
'') aclFiles;
|
2017-11-06 18:41:34 +01:00
|
|
|
kdcConfFile = pkgs.writeText "kdc.conf" ''
|
|
|
|
[realms]
|
|
|
|
${concatStringsSep "\n" kdcConfigs}
|
|
|
|
'';
|
|
|
|
env = {
|
|
|
|
# What Debian uses, could possibly link directly to Nix store?
|
|
|
|
KRB5_KDC_PROFILE = "/etc/krb5kdc/kdc.conf";
|
|
|
|
};
|
|
|
|
in
|
|
|
|
|
|
|
|
{
|
|
|
|
config = mkIf (cfg.enable && kerberos == pkgs.krb5Full) {
|
|
|
|
systemd.services.kadmind = {
|
|
|
|
description = "Kerberos Administration Daemon";
|
|
|
|
wantedBy = [ "multi-user.target" ];
|
|
|
|
preStart = ''
|
|
|
|
mkdir -m 0755 -p ${stateDir}
|
|
|
|
'';
|
|
|
|
serviceConfig.ExecStart = "${kerberos}/bin/kadmind -nofork";
|
2017-11-13 14:09:35 +01:00
|
|
|
restartTriggers = [ kdcConfFile ];
|
2017-11-06 18:41:34 +01:00
|
|
|
environment = env;
|
|
|
|
};
|
|
|
|
|
|
|
|
systemd.services.kdc = {
|
|
|
|
description = "Key Distribution Center daemon";
|
|
|
|
wantedBy = [ "multi-user.target" ];
|
|
|
|
preStart = ''
|
|
|
|
mkdir -m 0755 -p ${stateDir}
|
|
|
|
'';
|
|
|
|
serviceConfig = {
|
|
|
|
Type = "forking";
|
|
|
|
PIDFile = PIDFile;
|
|
|
|
ExecStart = "${kerberos}/bin/krb5kdc -P ${PIDFile}";
|
|
|
|
};
|
|
|
|
restartTriggers = [ kdcConfFile ];
|
|
|
|
environment = env;
|
|
|
|
};
|
|
|
|
|
|
|
|
environment.etc = {
|
|
|
|
"krb5kdc/kdc.conf".source = kdcConfFile;
|
2017-11-13 14:09:35 +01:00
|
|
|
};
|
2017-11-06 18:41:34 +01:00
|
|
|
environment.variables = env;
|
|
|
|
};
|
|
|
|
}
|