* Move the uid/gid mappings into a module. This allows other modules

to use it through config.ids.{uids,gids} rather than `import
  relative-path/ids.nix'.

svn path=/nixos/branches/modular-nixos/; revision=15796
This commit is contained in:
Eelco Dolstra 2009-05-29 14:25:56 +00:00
parent c4f50d85cb
commit dba1d48b78
22 changed files with 83 additions and 64 deletions

View File

@ -41,7 +41,7 @@ in
###### implementation ###### implementation
let let
ids = import ../../system/ids.nix; ids = config.ids;
# User accounts to be created/updated by NixOS. # User accounts to be created/updated by NixOS.
users = users =

View File

@ -1,6 +1,32 @@
{ # This module defines the global list of uids and gids. We keep a
# central list to prevent id collissions.
uids = { {config, pkgs, ...}:
let
options = {
ids.uids = pkgs.lib.mkOption {
description = ''
The user IDs used in NixOS.
'';
};
ids.gids = pkgs.lib.mkOption {
description = ''
The group IDs used in NixOS.
'';
};
};
in
{
require = options;
ids.uids = {
root = 0; root = 0;
nscd = 1; nscd = 1;
sshd = 2; sshd = 2;
@ -25,7 +51,7 @@
nobody = 65534; nobody = 65534;
}; };
gids = { ids.gids = {
root = 0; root = 0;
wheel = 1; wheel = 1;
kmem = 2; kmem = 2;

View File

@ -14,6 +14,7 @@
./installer/tools/nixos-checkout.nix ./installer/tools/nixos-checkout.nix
./installer/tools/tools.nix ./installer/tools/tools.nix
./misc/assertions.nix ./misc/assertions.nix
./misc/ids.nix
./misc/locate.nix ./misc/locate.nix
./programs/bash/bash.nix ./programs/bash/bash.nix
./programs/info.nix ./programs/info.nix

View File

@ -34,7 +34,7 @@ let
# not used (e.g., doesn't own any devices). # not used (e.g., doesn't own any devices).
group = { group = {
name = "audio"; name = "audio";
gid = (import ../../../system/ids.nix).gids.audio; gid = config.ids.gids.audio;
}; };
job = { job = {

View File

@ -4,8 +4,8 @@
let let
inherit (pkgs.lib) mkOption mkIf; inherit (pkgs.lib) mkOption mkIf;
uid = (import ../../../system/ids.nix).uids.pulseaudio; uid = config.ids.uids.pulseaudio;
gid = (import ../../../system/ids.nix).gids.pulseaudio; gid = config.ids.gids.pulseaudio;
options = { options = {
services = { services = {
@ -36,8 +36,6 @@ in
###### implementation ###### implementation
# For some reason, PulseAudio wants UID == GID.
assert uid == gid;
mkIf config.services.pulseaudio.enable { mkIf config.services.pulseaudio.enable {
require = [ require = [
@ -51,7 +49,8 @@ mkIf config.services.pulseaudio.enable {
users = { users = {
extraUsers = [ extraUsers = [
{ name = "pulse"; { name = "pulse";
inherit uid; # For some reason, PulseAudio wants UID == GID.
uid = assert uid == gid; uid;
group = "pulse"; group = "pulse";
description = "PulseAudio system-wide daemon"; description = "PulseAudio system-wide daemon";
home = "/var/run/pulse"; home = "/var/run/pulse";

View File

@ -36,13 +36,13 @@ let
user = { user = {
name = "haldaemon"; name = "haldaemon";
uid = (import ../../../system/ids.nix).uids.haldaemon; uid = config.ids.uids.haldaemon;
description = "HAL daemon user"; description = "HAL daemon user";
}; };
group = { group = {
name = "haldaemon"; name = "haldaemon";
gid = (import ../../../system/ids.nix).gids.haldaemon; gid = config.ids.gids.haldaemon;
}; };
fdi = fdi =

View File

@ -44,7 +44,6 @@ let
startingDependency = if config.services.gw6c.enable then "gw6c" else "network-interfaces"; startingDependency = if config.services.gw6c.enable then "gw6c" else "network-interfaces";
cfg = config.services.dovecot; cfg = config.services.dovecot;
idList = import ../../../system/ids.nix;
dovecotConf = dovecotConf =
'' ''
@ -112,13 +111,13 @@ mkIf config.services.dovecot.enable {
users = { users = {
extraUsers = [{ extraUsers = [{
name = cfg.user; name = cfg.user;
uid = idList.uids.dovecot; uid = config.ids.uids.dovecot;
description = "Dovecot user"; description = "Dovecot user";
group = cfg.group; group = cfg.group;
}]; }];
extraGroups = [{ extraGroups = [{
name = cfg.group; name = cfg.group;
gid = idList.gids.dovecot; gid = config.ids.gids.dovecot;
}]; }];
}; };

View File

@ -156,7 +156,6 @@ let
user = cfg.user; user = cfg.user;
group = cfg.group; group = cfg.group;
setgidGroup = cfg.setgidGroup; setgidGroup = cfg.setgidGroup;
idList = import ../../../system/ids.nix;
optionalString = pkgs.lib.optionalString; optionalString = pkgs.lib.optionalString;
concatStringsSep = pkgs.lib.concatStringsSep; concatStringsSep = pkgs.lib.concatStringsSep;
@ -270,17 +269,17 @@ mkIf config.services.postfix.enable {
extraUsers = [ extraUsers = [
{ name = user; { name = user;
description = "Postfix mail server user"; description = "Postfix mail server user";
uid = idList.uids.postfix; uid = config.ids.uids.postfix;
group = group; group = group;
} }
]; ];
extraGroups = [ extraGroups = [
{ name = group; { name = group;
gid = idList.gids.postfix; gid = config.ids.gids.postfix;
} }
{ name = setgidGroup; { name = setgidGroup;
gid = idList.gids.postdrop; gid = config.ids.gids.postdrop;
} }
]; ];
}; };

View File

@ -137,7 +137,7 @@ let
user = { user = {
name = nagiosUser; name = nagiosUser;
uid = (import ../../../../system/ids.nix).uids.nagios; uid = config.ids.uids.nagios;
description = "Nagios monitoring daemon"; description = "Nagios monitoring daemon";
home = nagiosState; home = nagiosState;
}; };

View File

@ -52,7 +52,7 @@ let
user = { user = {
name = "zabbix"; name = "zabbix";
uid = (import ../../../system/ids.nix).uids.zabbix; uid = config.ids.uids.zabbix;
description = "Zabbix daemon user"; description = "Zabbix daemon user";
}; };

View File

@ -42,7 +42,7 @@ let
user = { user = {
name = "zabbix"; name = "zabbix";
uid = (import ../../../system/ids.nix).uids.zabbix; uid = config.ids.uids.zabbix;
description = "Zabbix daemon user"; description = "Zabbix daemon user";
}; };

View File

@ -93,14 +93,14 @@ let
user = { user = {
name = "avahi"; name = "avahi";
uid = (import ../system/ids.nix).uids.avahi; uid = config.ids.uids.avahi;
description = "`avahi-daemon' privilege separation user"; description = "`avahi-daemon' privilege separation user";
home = "/var/empty"; home = "/var/empty";
}; };
group = { group = {
name = "avahi"; name = "avahi";
gid = (import ../system/ids.nix).gids.avahi; gid = config.ids.gids.avahi;
}; };
job = { job = {

View File

@ -41,15 +41,13 @@ in
###### implementation ###### implementation
let let
bitlbeeUid = (import ../system/ids.nix).uids.bitlbee; bitlbeeUid = config.ids.uids.bitlbee;
inherit (config.services.bitlbee) portNumber interface; inherit (config.services.bitlbee) portNumber interface;
in in
mkIf config.services.bitlbee.enable { mkIf config.services.bitlbee.enable {
require = [ require = options;
options
];
users = { users = {
extraUsers = [ extraUsers = [
@ -62,32 +60,31 @@ mkIf config.services.bitlbee.enable {
extraGroups = [ extraGroups = [
{ name = "bitlbee"; { name = "bitlbee";
gid = (import ../system/ids.nix).gids.bitlbee; gid = config.ids.gids.bitlbee;
} }
]; ];
}; };
services = { services.extraJobs = [{
extraJobs = [{ name = "bitlbee";
name = "bitlbee";
job = '' job = ''
description "BitlBee IRC to other chat networks gateway" description "BitlBee IRC to other chat networks gateway"
start on network-interfaces/started start on network-interfaces/started
stop on network-interfaces/stop stop on network-interfaces/stop
start script start script
if ! test -d /var/lib/bitlbee if ! test -d /var/lib/bitlbee
then then
mkdir -p /var/lib/bitlbee mkdir -p /var/lib/bitlbee
fi fi
end script end script
respawn ${pkgs.bitlbee}/sbin/bitlbee -F -p ${toString portNumber} \ respawn ${pkgs.bitlbee}/sbin/bitlbee -F -p ${toString portNumber} \
-i ${interface} -u bitlbee -i ${interface} -u bitlbee
''; '';
}];
}];
}; environment.systemPackages = pkgs.bitlbee;
} }

View File

@ -154,7 +154,7 @@ mkIf config.services.gnunet.enable {
users = { users = {
extraUsers = [ extraUsers = [
{ name = "gnunetd"; { name = "gnunetd";
uid = (import ../system/ids.nix).uids.gnunetd; uid = config.ids.uids.gnunetd;
description = "GNUnet Daemon User"; description = "GNUnet Daemon User";
home = "/var/empty"; home = "/var/empty";
} }

View File

@ -72,7 +72,7 @@ mkIf config.services.ntp.enable {
users = [ users = [
{ name = ntpUser; { name = ntpUser;
uid = (import ../../../system/ids.nix).uids.ntp; uid = config.ids.uids.ntp;
description = "NTP daemon user"; description = "NTP daemon user";
home = stateDir; home = stateDir;
} }

View File

@ -37,8 +37,8 @@ in
###### implementation ###### implementation
let uid = (import ../../../system/ids.nix).uids.portmap; let uid = config.ids.uids.portmap;
gid = (import ../../../system/ids.nix).gids.portmap; gid = config.ids.gids.portmap;
in in
mkIf config.services.portmap.enable { mkIf config.services.portmap.enable {

View File

@ -85,8 +85,6 @@ let
''; '';
sshdUid = (import ../../../../system/ids.nix).uids.sshd;
# !!! is this assertion evaluated anywhere??? # !!! is this assertion evaluated anywhere???
assertion = cfg.permitRootLogin == "yes" || assertion = cfg.permitRootLogin == "yes" ||
cfg.permitRootLogin == "without-password" || cfg.permitRootLogin == "without-password" ||
@ -104,7 +102,7 @@ mkIf config.services.sshd.enable {
users = { users = {
extraUsers = [ extraUsers = [
{ name = "sshd"; { name = "sshd";
uid = (import ../../../../system/ids.nix).uids.sshd; uid = config.ids.uids.sshd;
description = "SSH privilege separation user"; description = "SSH privilege separation user";
home = "/var/empty"; home = "/var/empty";
} }

View File

@ -95,13 +95,13 @@ mkIf config.services.vsftpd.enable {
users = { users = {
extraUsers = [ extraUsers = [
{ name = "vsftpd"; { name = "vsftpd";
uid = (import ../../../system/ids.nix).uids.vsftpd; uid = config.ids.uids.vsftpd;
description = "VSFTPD user"; description = "VSFTPD user";
home = "/homeless-shelter"; home = "/homeless-shelter";
} }
] ++ pkgs.lib.optional anonymousUser ] ++ pkgs.lib.optional anonymousUser
{ name = "ftp"; { name = "ftp";
uid = (import ../../../system/ids.nix).uids.ftp; uid = config.ids.uids.ftp;
group = "ftp"; group = "ftp";
description = "Anonymous ftp user"; description = "Anonymous ftp user";
home = "/home/ftp"; home = "/home/ftp";
@ -109,7 +109,7 @@ mkIf config.services.vsftpd.enable {
extraGroups = [ extraGroups = [
{ name = "ftp"; { name = "ftp";
gid = (import ../../../system/ids.nix).gids.ftp; gid = config.ids.gids.ftp;
} }
]; ];

View File

@ -37,14 +37,14 @@ let
user = { user = {
name = "atd"; name = "atd";
uid = (import ../../../system/ids.nix).uids.atd; uid = config.ids.uids.atd;
description = "atd user"; description = "atd user";
home = "/var/empty"; home = "/var/empty";
}; };
group = { group = {
name = "atd"; name = "atd";
gid = (import ../../../system/ids.nix).gids.atd; gid = config.ids.gids.atd;
}; };
job = '' job = ''

View File

@ -55,7 +55,7 @@ let
user = { user = {
name = "messagebus"; name = "messagebus";
uid = (import ../../../system/ids.nix).uids.messagebus; uid = config.ids.uids.messagebus;
description = "D-Bus system message bus daemon user"; description = "D-Bus system message bus daemon user";
home = homeDir; home = homeDir;
}; };

View File

@ -13,7 +13,7 @@ in
users = [ users = [
{ name = "nscd"; { name = "nscd";
uid = (import ../../../system/ids.nix).uids.nscd; uid = config.ids.uids.nscd;
description = "Name service cache daemon user"; description = "Name service cache daemon user";
} }
]; ];

View File

@ -73,13 +73,13 @@ mkIf config.services.tomcat.enable {
groups = [ groups = [
{ name = "tomcat"; { name = "tomcat";
gid = (import ../../../system/ids.nix).gids.tomcat; gid = config.ids.gids.tomcat;
} }
]; ];
users = [ users = [
{ name = "tomcat"; { name = "tomcat";
uid = (import ../../../system/ids.nix).uids.tomcat; uid = config.ids.uids.tomcat;
description = "Tomcat user"; description = "Tomcat user";
home = "/homeless-shelter"; home = "/homeless-shelter";
} }