Refactor sops-nix override configuration
This commit is contained in:
parent
1a57b9d49b
commit
83bfad9a1b
|
@ -26,32 +26,46 @@
|
||||||
};
|
};
|
||||||
|
|
||||||
config = {
|
config = {
|
||||||
users.users =
|
virtualisation =
|
||||||
with { inherit (config.virtualisation.vmVariantWithBootLoader.users) sopsPasswordOverride; };
|
let
|
||||||
(lib.mkIf
|
extendVMConfig =
|
||||||
sopsPasswordOverride.enable
|
vmVariant: {
|
||||||
(
|
users.users =
|
||||||
builtins.listToAttrs (
|
with { inherit (vmVariant.users) sopsPasswordOverride; };
|
||||||
builtins.map (
|
(lib.mkIf
|
||||||
name: {
|
sopsPasswordOverride.enable
|
||||||
inherit name;
|
(
|
||||||
|
builtins.listToAttrs (
|
||||||
|
builtins.map (
|
||||||
|
name: {
|
||||||
|
inherit name;
|
||||||
|
|
||||||
value = {
|
value = {
|
||||||
hashedPasswordFile = lib.mkVMOverride null;
|
hashedPasswordFile = lib.mkVMOverride null;
|
||||||
hashedPassword = sopsPasswordOverride.hashedPassword;
|
hashedPassword = sopsPasswordOverride.hashedPassword;
|
||||||
password = sopsPasswordOverride.password;
|
password = sopsPasswordOverride.password;
|
||||||
};
|
};
|
||||||
})
|
})
|
||||||
(builtins.filter
|
(builtins.filter
|
||||||
(
|
(
|
||||||
name:
|
name:
|
||||||
let
|
let
|
||||||
user = config.users.users.${name};
|
user = config.users.users.${name};
|
||||||
in
|
in
|
||||||
(
|
(
|
||||||
(user.hashedPasswordFile != null) &&
|
(user.hashedPasswordFile != null) &&
|
||||||
(lib.strings.hasPrefix "/run/secrets-for-users/" user.hashedPasswordFile)
|
(lib.strings.hasPrefix "/run/secrets-for-users/" user.hashedPasswordFile)
|
||||||
))
|
))
|
||||||
(builtins.attrNames config.users.users)))));
|
(builtins.attrNames config.users.users)))));
|
||||||
|
};
|
||||||
|
|
||||||
|
inherit (config.virtualisation)
|
||||||
|
vmVariant
|
||||||
|
vmVariantWithBootLoader
|
||||||
|
;
|
||||||
|
in {
|
||||||
|
vmVariant = extendVMConfig vmVariant;
|
||||||
|
vmVariantWithBootLoader = extendVMConfig vmVariantWithBootLoader;
|
||||||
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
Loading…
Reference in a new issue