2009-05-29 16:25:56 +02:00
|
|
|
# This module defines the global list of uids and gids. We keep a
|
2013-08-10 23:07:13 +02:00
|
|
|
# central list to prevent id collisions.
|
2009-05-29 16:25:56 +02:00
|
|
|
|
2014-05-05 20:58:51 +02:00
|
|
|
{ config, pkgs, lib, ... }:
|
2009-05-29 16:25:56 +02:00
|
|
|
|
2013-09-04 13:05:09 +02:00
|
|
|
{
|
2009-05-29 16:25:56 +02:00
|
|
|
options = {
|
|
|
|
|
2014-05-05 20:58:51 +02:00
|
|
|
ids.uids = lib.mkOption {
|
2013-10-30 17:37:45 +01:00
|
|
|
internal = true;
|
2009-05-29 16:25:56 +02:00
|
|
|
description = ''
|
|
|
|
The user IDs used in NixOS.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2014-05-05 20:58:51 +02:00
|
|
|
ids.gids = lib.mkOption {
|
2013-10-30 17:37:45 +01:00
|
|
|
internal = true;
|
2009-05-29 16:25:56 +02:00
|
|
|
description = ''
|
|
|
|
The group IDs used in NixOS.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2011-09-14 20:20:50 +02:00
|
|
|
|
2013-09-04 13:05:09 +02:00
|
|
|
config = {
|
2007-06-08 17:41:12 +02:00
|
|
|
|
2013-09-04 13:05:09 +02:00
|
|
|
ids.uids = {
|
|
|
|
root = 0;
|
|
|
|
nscd = 1;
|
|
|
|
sshd = 2;
|
|
|
|
ntp = 3;
|
|
|
|
messagebus = 4; # D-Bus
|
|
|
|
haldaemon = 5;
|
|
|
|
nagios = 6;
|
|
|
|
vsftpd = 7;
|
|
|
|
ftp = 8;
|
|
|
|
bitlbee = 9;
|
|
|
|
avahi = 10;
|
|
|
|
atd = 12;
|
|
|
|
zabbix = 13;
|
|
|
|
postfix = 14;
|
|
|
|
dovecot = 15;
|
|
|
|
tomcat = 16;
|
|
|
|
pulseaudio = 22; # must match `pulseaudio' GID
|
|
|
|
gpsd = 23;
|
|
|
|
polkituser = 28;
|
|
|
|
uptimed = 29;
|
|
|
|
ddclient = 30;
|
|
|
|
davfs2 = 31;
|
|
|
|
privoxy = 32;
|
|
|
|
osgi = 34;
|
|
|
|
tor = 35;
|
|
|
|
cups = 36;
|
2014-04-29 10:51:42 +02:00
|
|
|
foldingathome = 37;
|
2013-09-04 13:05:09 +02:00
|
|
|
sabnzbd = 38;
|
|
|
|
kdm = 39;
|
2014-04-29 10:51:42 +02:00
|
|
|
ghostone = 40;
|
2013-09-04 13:05:09 +02:00
|
|
|
git = 41;
|
2014-04-29 10:51:42 +02:00
|
|
|
fourstore = 42;
|
|
|
|
fourstorehttp = 43;
|
2013-09-04 13:05:09 +02:00
|
|
|
virtuoso = 44;
|
|
|
|
rtkit = 45;
|
|
|
|
dovecot2 = 46;
|
|
|
|
dovenull2 = 47;
|
|
|
|
unbound = 48;
|
|
|
|
prayer = 49;
|
|
|
|
mpd = 50;
|
|
|
|
clamav = 51;
|
|
|
|
fprot = 52;
|
|
|
|
bind = 53;
|
|
|
|
wwwrun = 54;
|
|
|
|
spamd = 56;
|
|
|
|
nslcd = 58;
|
|
|
|
nginx = 60;
|
|
|
|
chrony = 61;
|
|
|
|
smtpd = 63;
|
|
|
|
smtpq = 64;
|
|
|
|
supybot = 65;
|
|
|
|
iodined = 66;
|
|
|
|
graphite = 68;
|
|
|
|
statsd = 69;
|
|
|
|
transmission = 70;
|
|
|
|
postgres = 71;
|
|
|
|
smbguest = 74;
|
|
|
|
varnish = 75;
|
2014-05-02 07:43:27 +02:00
|
|
|
datadog = 76;
|
2013-09-04 13:05:09 +02:00
|
|
|
lighttpd = 77;
|
|
|
|
lightdm = 78;
|
|
|
|
freenet = 79;
|
|
|
|
ircd = 80;
|
|
|
|
bacula = 81;
|
|
|
|
almir = 82;
|
|
|
|
deluge = 83;
|
|
|
|
mysql = 84;
|
|
|
|
rabbitmq = 85;
|
|
|
|
activemq = 86;
|
|
|
|
gnunet = 87;
|
|
|
|
oidentd = 88;
|
|
|
|
quassel = 89;
|
|
|
|
amule = 90;
|
|
|
|
minidlna = 91;
|
|
|
|
elasticsearch = 92;
|
2013-09-17 11:22:31 +02:00
|
|
|
tcpcryptd = 93; # tcpcryptd uses a hard-coded uid. We patch it in Nixpkgs to match this choice.
|
2013-10-02 15:14:35 +02:00
|
|
|
zope2 = 94;
|
2013-10-05 23:07:22 +02:00
|
|
|
firebird = 95;
|
2013-10-28 18:14:01 +01:00
|
|
|
redis = 96;
|
2013-10-29 15:55:25 +01:00
|
|
|
haproxy = 97;
|
2013-11-07 11:25:14 +01:00
|
|
|
mongodb = 98;
|
2013-11-28 22:21:50 +01:00
|
|
|
openldap = 99;
|
2013-12-13 10:05:36 +01:00
|
|
|
memcached = 100;
|
2014-01-13 00:18:05 +01:00
|
|
|
cgminer = 101;
|
2014-02-07 23:08:15 +01:00
|
|
|
munin = 102;
|
2014-02-11 14:19:06 +01:00
|
|
|
logcheck = 103;
|
2014-02-20 18:34:54 +01:00
|
|
|
nix-ssh = 104;
|
2014-02-21 12:40:05 +01:00
|
|
|
dictd = 105;
|
2014-02-27 14:33:30 +01:00
|
|
|
couchdb = 106;
|
2014-03-07 20:09:59 +01:00
|
|
|
searx = 107;
|
2014-03-12 08:32:56 +01:00
|
|
|
kippo = 108;
|
2014-02-10 21:07:12 +01:00
|
|
|
jenkins = 109;
|
2014-03-15 00:16:59 +01:00
|
|
|
systemd-journal-gateway = 110;
|
2014-03-13 09:45:57 +01:00
|
|
|
notbit = 111;
|
2014-03-20 03:04:35 +01:00
|
|
|
ngircd = 112;
|
2014-02-21 20:05:12 +01:00
|
|
|
btsync = 113;
|
2014-03-29 10:48:33 +01:00
|
|
|
minecraft = 114;
|
2014-04-01 19:20:33 +02:00
|
|
|
monetdb = 115;
|
2014-04-05 20:23:29 +02:00
|
|
|
rippled = 116;
|
2014-04-05 21:18:14 +02:00
|
|
|
murmur = 117;
|
2014-04-02 18:01:25 +02:00
|
|
|
foundationdb = 118;
|
|
|
|
newrelic = 119;
|
|
|
|
starbound = 120;
|
2014-04-29 10:45:06 +02:00
|
|
|
hydra = 122;
|
|
|
|
spiped = 123;
|
2014-03-29 01:40:30 +01:00
|
|
|
teamspeak = 124;
|
2014-05-27 22:54:43 +02:00
|
|
|
influxdb = 125;
|
2014-06-12 11:20:43 +02:00
|
|
|
nsd = 126;
|
2014-06-26 05:32:45 +02:00
|
|
|
gitolite = 127;
|
2014-07-03 18:30:11 +02:00
|
|
|
znc = 128;
|
2014-07-15 16:16:58 +02:00
|
|
|
polipo = 129;
|
2014-07-28 19:52:32 +02:00
|
|
|
mopidy = 130;
|
2014-08-05 23:00:30 +02:00
|
|
|
unifi = 131;
|
2014-04-02 18:21:00 +02:00
|
|
|
gdm = 132;
|
2014-06-25 10:28:53 +02:00
|
|
|
dhcpd = 133;
|
2014-07-10 20:08:38 +02:00
|
|
|
siproxd = 134;
|
2014-07-09 00:43:26 +02:00
|
|
|
mlmmj = 135;
|
2014-08-16 23:53:26 +02:00
|
|
|
neo4j = 136;
|
2014-08-23 17:04:34 +02:00
|
|
|
riemann = 137;
|
2014-08-23 17:39:45 +02:00
|
|
|
riemanndash = 138;
|
2014-06-27 08:45:04 +02:00
|
|
|
radvd = 139;
|
2014-08-24 17:43:45 +02:00
|
|
|
zookeeper = 140;
|
2014-07-03 00:59:35 +02:00
|
|
|
dnsmasq = 141;
|
2014-09-01 08:53:00 +02:00
|
|
|
uhub = 142;
|
2011-04-15 18:10:17 +02:00
|
|
|
|
2014-04-29 10:45:06 +02:00
|
|
|
# When adding a uid, make sure it doesn't match an existing gid. And don't use uids above 399!
|
2008-03-06 18:11:22 +01:00
|
|
|
|
2013-09-04 13:05:09 +02:00
|
|
|
nixbld = 30000; # start of range of uids
|
|
|
|
nobody = 65534;
|
|
|
|
};
|
|
|
|
|
|
|
|
ids.gids = {
|
|
|
|
root = 0;
|
|
|
|
wheel = 1;
|
|
|
|
kmem = 2;
|
|
|
|
tty = 3;
|
|
|
|
messagebus = 4; # D-Bus
|
|
|
|
haldaemon = 5;
|
|
|
|
disk = 6;
|
|
|
|
vsftpd = 7;
|
|
|
|
ftp = 8;
|
|
|
|
bitlbee = 9;
|
|
|
|
avahi = 10;
|
|
|
|
atd = 12;
|
|
|
|
postfix = 13;
|
|
|
|
postdrop = 14;
|
|
|
|
dovecot = 15;
|
|
|
|
audio = 17;
|
|
|
|
floppy = 18;
|
|
|
|
uucp = 19;
|
|
|
|
lp = 20;
|
|
|
|
tomcat = 21;
|
|
|
|
pulseaudio = 22; # must match `pulseaudio' UID
|
|
|
|
gpsd = 23;
|
|
|
|
cdrom = 24;
|
|
|
|
tape = 25;
|
|
|
|
video = 26;
|
|
|
|
dialout = 27;
|
2013-11-09 16:29:18 +01:00
|
|
|
#polkituser = 28; # currently unused, polkitd doesn't need a group
|
2013-09-04 13:05:09 +02:00
|
|
|
utmp = 29;
|
|
|
|
davfs2 = 31;
|
|
|
|
privoxy = 32;
|
|
|
|
disnix = 33;
|
|
|
|
osgi = 34;
|
|
|
|
ghostOne = 40;
|
|
|
|
git = 41;
|
2014-04-29 10:51:42 +02:00
|
|
|
fourstore = 42;
|
|
|
|
fourstorehttpd = 43;
|
2013-09-04 13:05:09 +02:00
|
|
|
virtuoso = 44;
|
|
|
|
dovecot2 = 46;
|
|
|
|
prayer = 49;
|
|
|
|
mpd = 50;
|
|
|
|
clamav = 51;
|
|
|
|
fprot = 52;
|
|
|
|
wwwrun = 54;
|
|
|
|
adm = 55;
|
|
|
|
spamd = 56;
|
|
|
|
networkmanager = 57;
|
|
|
|
nslcd = 58;
|
|
|
|
scanner = 59;
|
|
|
|
nginx = 60;
|
|
|
|
systemd-journal = 62;
|
|
|
|
smtpd = 63;
|
|
|
|
smtpq = 64;
|
|
|
|
supybot = 65;
|
|
|
|
iodined = 66;
|
|
|
|
libvirtd = 67;
|
|
|
|
graphite = 68;
|
|
|
|
transmission = 70;
|
|
|
|
postgres = 71;
|
|
|
|
vboxusers = 72;
|
|
|
|
vboxsf = 73;
|
|
|
|
smbguest = 74;
|
|
|
|
varnish = 75;
|
2014-05-02 07:43:27 +02:00
|
|
|
datadog = 76;
|
2013-09-04 13:05:09 +02:00
|
|
|
lighttpd = 77;
|
|
|
|
lightdm = 78;
|
|
|
|
freenet = 79;
|
|
|
|
ircd = 80;
|
|
|
|
bacula = 81;
|
|
|
|
almir = 82;
|
|
|
|
deluge = 83;
|
|
|
|
mysql = 84;
|
|
|
|
rabbitmq = 85;
|
|
|
|
activemq = 86;
|
|
|
|
gnunet = 87;
|
|
|
|
oidentd = 88;
|
|
|
|
quassel = 89;
|
|
|
|
amule = 90;
|
|
|
|
minidlna = 91;
|
2013-10-29 15:55:25 +01:00
|
|
|
haproxy = 92;
|
2013-11-28 22:21:50 +01:00
|
|
|
openldap = 93;
|
2014-01-04 01:13:26 +01:00
|
|
|
connman = 94;
|
2014-02-07 23:08:15 +01:00
|
|
|
munin = 95;
|
2014-02-11 13:00:10 +01:00
|
|
|
keys = 96;
|
2014-02-21 12:40:05 +01:00
|
|
|
dictd = 105;
|
2014-02-27 14:33:30 +01:00
|
|
|
couchdb = 106;
|
2014-03-07 20:09:59 +01:00
|
|
|
searx = 107;
|
2014-03-12 08:32:56 +01:00
|
|
|
kippo = 108;
|
2014-02-10 21:07:12 +01:00
|
|
|
jenkins = 109;
|
2014-03-15 00:16:59 +01:00
|
|
|
systemd-journal-gateway = 110;
|
2014-03-13 09:45:57 +01:00
|
|
|
notbit = 111;
|
2014-04-01 19:41:37 +02:00
|
|
|
monetdb = 115;
|
2014-04-02 18:01:25 +02:00
|
|
|
foundationdb = 118;
|
|
|
|
newrelic = 119;
|
|
|
|
starbound = 120;
|
nixos: add grsecurity module (#1875)
This module implements a significant refactoring in grsecurity
configuration for NixOS, making it far more usable by default and much
easier to configure.
- New security.grsecurity NixOS attributes.
- All grsec kernels supported
- Allows default 'auto' grsec configuration, or custom config
- Supports custom kernel options through kernelExtraConfig
- Defaults to high-security - user must choose kernel, server/desktop
mode, and any virtualisation software. That's all.
- kptr_restrict is fixed under grsecurity (it's unwriteable)
- grsecurity patch creation is now significantly abstracted
- only need revision, version, and SHA1
- kernel version requirements are asserted for sanity
- built kernels can have the uname specify the exact grsec version
for development or bug reports. Off by default (requires
`security.grsecurity.config.verboseVersion = true;`)
- grsecurity sysctl support
- By default, disabled.
- For people who enable it, NixOS deploys a 'grsec-lock' systemd
service which runs at startup. You are expected to configure sysctl
through NixOS like you regularly would, which will occur before the
service is started. As a result, changing sysctl settings requires
a reboot.
- New default group: 'grsecurity'
- Root is a member by default
- GRKERNSEC_PROC_GID is implicitly set to the 'grsecurity' GID,
making it possible to easily add users to this group for /proc
access
- AppArmor is now automatically enabled where it wasn't before, despite
implying features.apparmor = true
The most trivial example of enabling grsecurity in your kernel is by
specifying:
security.grsecurity.enable = true;
security.grsecurity.testing = true; # testing 3.13 kernel
security.grsecurity.config.system = "desktop"; # or "server"
This specifies absolutely no virtualisation support. In general, you
probably at least want KVM host support, which is a little more work.
So:
security.grsecurity.enable = true;
security.grsecurity.stable = true; # enable stable 3.2 kernel
security.grsecurity.config = {
system = "server";
priority = "security";
virtualisationConfig = "host";
virtualisationSoftware = "kvm";
hardwareVirtualisation = true;
}
This module has primarily been tested on Hetzner EX40 & VQ7 servers
using NixOps.
Signed-off-by: Austin Seipp <aseipp@pobox.com>
2014-04-06 21:18:12 +02:00
|
|
|
grsecurity = 121;
|
2014-04-15 09:28:01 +02:00
|
|
|
hydra = 122;
|
2014-04-15 10:21:53 +02:00
|
|
|
spiped = 123;
|
2014-03-29 01:40:30 +01:00
|
|
|
teamspeak = 124;
|
2014-05-27 22:54:43 +02:00
|
|
|
influxdb = 125;
|
2014-06-12 11:20:43 +02:00
|
|
|
nsd = 126;
|
2014-07-04 13:48:26 +02:00
|
|
|
firebird = 127;
|
2014-07-03 18:30:11 +02:00
|
|
|
znc = 128;
|
2014-07-15 16:16:58 +02:00
|
|
|
polipo = 129;
|
2014-07-28 19:52:32 +02:00
|
|
|
mopidy = 130;
|
2014-07-28 00:00:59 +02:00
|
|
|
docker = 131;
|
2014-04-02 18:21:00 +02:00
|
|
|
gdm = 132;
|
2014-08-12 19:24:08 +02:00
|
|
|
tss = 133;
|
2014-07-10 20:08:38 +02:00
|
|
|
siproxd = 134;
|
2014-07-09 00:43:26 +02:00
|
|
|
mlmmj = 135;
|
2014-08-23 17:04:34 +02:00
|
|
|
riemann = 137;
|
2014-08-23 17:39:45 +02:00
|
|
|
riemanndash = 138;
|
2014-09-01 08:53:00 +02:00
|
|
|
uhub = 142;
|
2014-09-02 13:16:13 +02:00
|
|
|
pulse-access = 143;
|
2007-06-08 17:41:12 +02:00
|
|
|
|
2014-04-29 10:45:06 +02:00
|
|
|
# When adding a gid, make sure it doesn't match an existing uid. And don't use gids above 399!
|
2011-04-15 18:10:17 +02:00
|
|
|
|
2013-09-04 13:05:09 +02:00
|
|
|
users = 100;
|
|
|
|
nixbld = 30000;
|
|
|
|
nogroup = 65534;
|
|
|
|
};
|
2009-08-11 11:17:30 +02:00
|
|
|
|
2007-06-08 17:41:12 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|