diff options
author | aszlig <aszlig@nix.build> | 2018-06-04 15:34:21 +0200 |
---|---|---|
committer | aszlig <aszlig@nix.build> | 2018-06-04 15:34:21 +0200 |
commit | 0e7c945e15117e88ac494e29c9828ccea2ec32ee (patch) | |
tree | f5b833ffa4b08dc808f483327c5030a7a3fe8b86 /nixos/modules/system/boot/systemd-lib.nix | |
parent | 0385d69f878a4b9ce4d4735e28dff6ecf7b64507 (diff) | |
download | nixpkgs-0e7c945e15117e88ac494e29c9828ccea2ec32ee.tar nixpkgs-0e7c945e15117e88ac494e29c9828ccea2ec32ee.tar.gz nixpkgs-0e7c945e15117e88ac494e29c9828ccea2ec32ee.tar.bz2 nixpkgs-0e7c945e15117e88ac494e29c9828ccea2ec32ee.tar.lz nixpkgs-0e7c945e15117e88ac494e29c9828ccea2ec32ee.tar.xz nixpkgs-0e7c945e15117e88ac494e29c9828ccea2ec32ee.tar.zst nixpkgs-0e7c945e15117e88ac494e29c9828ccea2ec32ee.zip |
nixos/systemd: Allow to override serviceConfig
This has been reported by @qknight in his Stack Overflow question: https://stackoverflow.com/q/50678639 The correct way to override a single value would be to use something like this: systemd.services.nagios.serviceConfig.Restart = lib.mkForce "no"; However, this doesn't work because the check is applied for the attrsOf type and thus the attribute values might still contain the attribute set created by mkOverride. The unitOption type however did already account for this, but at this stage it's already too late. So now the actual value is unpacked while checking the values of the attribute set, which should allow us to override values in serviceConfig. Signed-off-by: aszlig <aszlig@nix.build> Cc: @edolstra, @qknight
Diffstat (limited to 'nixos/modules/system/boot/systemd-lib.nix')
-rw-r--r-- | nixos/modules/system/boot/systemd-lib.nix | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/nixos/modules/system/boot/systemd-lib.nix b/nixos/modules/system/boot/systemd-lib.nix index ae9ee8811f7..8b37bf8d35d 100644 --- a/nixos/modules/system/boot/systemd-lib.nix +++ b/nixos/modules/system/boot/systemd-lib.nix @@ -78,10 +78,16 @@ in rec { optional (badFields != [ ]) "Systemd ${group} has extra fields [${concatStringsSep " " badFields}]."; - checkUnitConfig = group: checks: v: - let errors = concatMap (c: c group v) checks; in - if errors == [] then true - else builtins.trace (concatStringsSep "\n" errors) false; + checkUnitConfig = group: checks: attrs: let + # We're applied at the top-level type (attrsOf unitOption), so the actual + # unit options might contain attributes from mkOverride that we need to + # convert into single values before checking them. + defs = mapAttrs (const (v: + if v._type or "" == "override" then v.content else v + )) attrs; + errors = concatMap (c: c group defs) checks; + in if errors == [] then true + else builtins.trace (concatStringsSep "\n" errors) false; toOption = x: if x == true then "true" |