blob: 2802901b2a29e3ae0d7b84b64b34a777235d5dca (
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
|
{
config,
lib,
secretsDir,
...
}: let
cfg = config.traits.users;
in {
options.traits.users = {
seth = {
manageSecrets =
lib.mkEnableOption "automatic secrets management"
// {
default = config.traits.secrets.enable;
};
};
};
config = lib.mkMerge [
(lib.mkIf (cfg.seth.enable && cfg.seth.manageSecrets) {
age.secrets = {
sethPassword.file = secretsDir + "/sethPassword.age";
};
users.users.seth = {
hashedPasswordFile = lib.mkDefault config.age.secrets.sethPassword.path;
};
})
];
}
|