mirror of
https://github.com/NixOS/nixpkgs.git
synced 2025-01-03 19:43:30 +00:00
195d155a1c
- Introduce more possible options by using the krb format generator. - Enforce package choice is using a correct package. - Use meta attribute to decide implementation, allows for overriding the package. - Make necessary changes to the format, to allow for multiple ACL files in heimdal. - Add systemd target and slice for both implementations. - Move state to `/var/lib` - Add documentation
47 lines
1.1 KiB
Nix
47 lines
1.1 KiB
Nix
import ../make-test-python.nix ({pkgs, ...}: {
|
|
name = "kerberos_server-mit";
|
|
|
|
nodes.machine = { config, libs, pkgs, ...}:
|
|
{ services.kerberos_server =
|
|
{ enable = true;
|
|
settings.realms = {
|
|
"FOO.BAR".acl = [{principal = "admin"; access = ["add" "cpw"];}];
|
|
};
|
|
};
|
|
security.krb5 = {
|
|
enable = true;
|
|
package = pkgs.krb5;
|
|
settings = {
|
|
libdefaults = {
|
|
default_realm = "FOO.BAR";
|
|
};
|
|
realms = {
|
|
"FOO.BAR" = {
|
|
admin_server = "machine";
|
|
kdc = "machine";
|
|
};
|
|
};
|
|
};
|
|
};
|
|
users.extraUsers.alice = { isNormalUser = true; };
|
|
};
|
|
|
|
testScript = ''
|
|
machine.succeed(
|
|
"kdb5_util create -s -r FOO.BAR -P master_key",
|
|
"systemctl restart kadmind.service kdc.service",
|
|
)
|
|
|
|
for unit in ["kadmind", "kdc"]:
|
|
machine.wait_for_unit(f"{unit}.service")
|
|
|
|
machine.succeed(
|
|
"kadmin.local add_principal -pw admin_pw admin",
|
|
"kadmin -p admin -w admin_pw addprinc -pw alice_pw alice",
|
|
"echo alice_pw | sudo -u alice kinit",
|
|
)
|
|
'';
|
|
|
|
meta.maintainers = [ pkgs.lib.maintainers.dblsaiko ];
|
|
})
|