diff options
author | Eelco Dolstra <eelco.dolstra@logicblox.com> | 2014-04-29 10:43:38 +0200 |
---|---|---|
committer | Eelco Dolstra <eelco.dolstra@logicblox.com> | 2014-04-29 10:43:38 +0200 |
commit | 05468f9b7893b4cdfdf093b271d54606a3457174 (patch) | |
tree | 51bda22eede8d5009b41b6ba95e3f0f4471f3c3f /nixos | |
parent | 2dfbe554213a007fc01ebd1a86d8637de8fe7191 (diff) | |
download | nixlib-05468f9b7893b4cdfdf093b271d54606a3457174.tar nixlib-05468f9b7893b4cdfdf093b271d54606a3457174.tar.gz nixlib-05468f9b7893b4cdfdf093b271d54606a3457174.tar.bz2 nixlib-05468f9b7893b4cdfdf093b271d54606a3457174.tar.lz nixlib-05468f9b7893b4cdfdf093b271d54606a3457174.tar.xz nixlib-05468f9b7893b4cdfdf093b271d54606a3457174.tar.zst nixlib-05468f9b7893b4cdfdf093b271d54606a3457174.zip |
Bring back the isSystemUser option
Diffstat (limited to 'nixos')
-rw-r--r-- | nixos/modules/config/users-groups.nix | 19 |
1 files changed, 16 insertions, 3 deletions
diff --git a/nixos/modules/config/users-groups.nix b/nixos/modules/config/users-groups.nix index 8b8f6bd909e3..7daab98f7be6 100644 --- a/nixos/modules/config/users-groups.nix +++ b/nixos/modules/config/users-groups.nix @@ -55,13 +55,27 @@ let type = with types; nullOr int; default = null; description = '' - The account UID. If the <literal>mutableUsers</literal> option + The account UID. If the <option>mutableUsers</option> option is false, the UID cannot be null. Otherwise, the UID might be null, in which case a free UID is picked on activation (by the useradd command). ''; }; + isSystemUser = mkOption { + type = types.bool; + default = false; + description = '' + Indicates if the user is a system user or not. This option + only has an effect if <option>mutableUsers</option> is + <literal>true</literal> and <option>uid</option> is + <option>null</option>, in which case it determines whether + the user's UID is allocated in the range for system users + (below 500) or in the range for normal users (starting at + 1000). + ''; + }; + group = mkOption { type = types.str; default = "nogroup"; @@ -459,17 +473,16 @@ in { ''; groupadd = n: g: '' if [ -z "$(getent group "${g.name}")" ]; then - echo "Adding group ${g.name}" ${pkgs.shadow}/sbin/groupadd "${g.name}" fi ''; useradd = n: u: '' if ! id "${u.name}" &>/dev/null; then - echo "Adding user ${u.name}" ${pkgs.shadow}/sbin/useradd \ -g "${u.group}" \ -s "${u.shell}" \ -d "${u.home}" \ + ${optionalString u.isSystemUser "--system"} \ "${u.name}" echo "${u.name}:x" | ${pkgs.shadow}/sbin/chpasswd -e fi |