2014-04-14 14:26:48 +00:00
|
|
|
|
{ config, lib, pkgs, utils, ... }:
|
2012-06-02 00:15:07 +00:00
|
|
|
|
|
2013-01-01 13:42:43 +00:00
|
|
|
|
with utils;
|
2014-05-05 19:52:33 +00:00
|
|
|
|
with lib;
|
2014-04-14 14:26:48 +00:00
|
|
|
|
with import ./systemd-unit-options.nix { inherit config lib; };
|
2015-04-20 09:31:17 +00:00
|
|
|
|
with import ./systemd-lib.nix { inherit config lib pkgs; };
|
2012-06-02 00:15:07 +00:00
|
|
|
|
|
|
|
|
|
let
|
|
|
|
|
|
2013-01-16 11:33:18 +00:00
|
|
|
|
cfg = config.systemd;
|
2012-06-18 03:31:21 +00:00
|
|
|
|
|
2013-01-16 12:17:57 +00:00
|
|
|
|
systemd = cfg.package;
|
2012-06-02 00:15:07 +00:00
|
|
|
|
|
2014-04-17 22:38:40 +00:00
|
|
|
|
upstreamSystemUnits =
|
2012-06-14 22:44:56 +00:00
|
|
|
|
[ # Targets.
|
2012-06-02 00:15:07 +00:00
|
|
|
|
"basic.target"
|
2013-01-08 16:26:51 +00:00
|
|
|
|
"sysinit.target"
|
2012-06-02 00:15:07 +00:00
|
|
|
|
"sockets.target"
|
2012-06-14 22:44:56 +00:00
|
|
|
|
"graphical.target"
|
|
|
|
|
"multi-user.target"
|
|
|
|
|
"network.target"
|
2014-12-02 01:19:06 +00:00
|
|
|
|
"network-pre.target"
|
2013-07-16 09:55:12 +00:00
|
|
|
|
"network-online.target"
|
2012-06-14 22:44:56 +00:00
|
|
|
|
"nss-lookup.target"
|
|
|
|
|
"nss-user-lookup.target"
|
|
|
|
|
"time-sync.target"
|
2012-08-10 22:56:12 +00:00
|
|
|
|
#"cryptsetup.target"
|
2012-08-14 22:14:48 +00:00
|
|
|
|
"sigpwr.target"
|
2013-03-27 12:58:12 +00:00
|
|
|
|
"timers.target"
|
|
|
|
|
"paths.target"
|
2014-04-15 22:59:26 +00:00
|
|
|
|
"rpcbind.target"
|
2012-06-14 22:44:56 +00:00
|
|
|
|
|
2013-01-21 20:01:48 +00:00
|
|
|
|
# Rescue mode.
|
2013-01-08 17:24:06 +00:00
|
|
|
|
"rescue.target"
|
|
|
|
|
"rescue.service"
|
|
|
|
|
|
2012-06-15 17:09:22 +00:00
|
|
|
|
# Udev.
|
2012-07-16 21:47:11 +00:00
|
|
|
|
"systemd-udevd-control.socket"
|
|
|
|
|
"systemd-udevd-kernel.socket"
|
2014-04-17 16:52:31 +00:00
|
|
|
|
"systemd-udevd.service"
|
2012-06-15 17:09:22 +00:00
|
|
|
|
"systemd-udev-settle.service"
|
|
|
|
|
"systemd-udev-trigger.service"
|
|
|
|
|
|
2014-04-17 16:52:31 +00:00
|
|
|
|
# Consoles.
|
|
|
|
|
"getty.target"
|
|
|
|
|
"getty@.service"
|
|
|
|
|
"serial-getty@.service"
|
|
|
|
|
"container-getty@.service"
|
|
|
|
|
"systemd-vconsole-setup.service"
|
|
|
|
|
|
2012-08-14 22:14:48 +00:00
|
|
|
|
# Hardware (started by udev when a relevant device is plugged in).
|
|
|
|
|
"sound.target"
|
|
|
|
|
"bluetooth.target"
|
|
|
|
|
"printer.target"
|
|
|
|
|
"smartcard.target"
|
|
|
|
|
|
2012-06-14 22:44:56 +00:00
|
|
|
|
# Login stuff.
|
|
|
|
|
"systemd-logind.service"
|
|
|
|
|
"autovt@.service"
|
2012-10-18 15:54:07 +00:00
|
|
|
|
#"systemd-vconsole-setup.service"
|
2012-06-14 22:44:56 +00:00
|
|
|
|
"systemd-user-sessions.service"
|
2012-06-15 17:09:22 +00:00
|
|
|
|
"dbus-org.freedesktop.login1.service"
|
2014-04-16 08:48:14 +00:00
|
|
|
|
"dbus-org.freedesktop.machine1.service"
|
2016-01-17 23:46:21 +00:00
|
|
|
|
"org.freedesktop.login1.busname"
|
|
|
|
|
"org.freedesktop.machine1.busname"
|
2012-06-15 18:51:48 +00:00
|
|
|
|
"user@.service"
|
2012-06-14 22:44:56 +00:00
|
|
|
|
|
|
|
|
|
# Journal.
|
|
|
|
|
"systemd-journald.socket"
|
|
|
|
|
"systemd-journald.service"
|
2012-07-20 16:02:42 +00:00
|
|
|
|
"systemd-journal-flush.service"
|
2014-04-17 17:05:29 +00:00
|
|
|
|
"systemd-journal-gatewayd.socket"
|
|
|
|
|
"systemd-journal-gatewayd.service"
|
2015-05-11 12:41:41 +00:00
|
|
|
|
"systemd-journald-audit.socket"
|
2014-08-23 21:28:03 +00:00
|
|
|
|
"systemd-journald-dev-log.socket"
|
2012-07-16 21:47:11 +00:00
|
|
|
|
"syslog.socket"
|
2012-06-02 00:15:07 +00:00
|
|
|
|
|
2012-06-14 22:44:56 +00:00
|
|
|
|
# SysV init compatibility.
|
|
|
|
|
"systemd-initctl.socket"
|
|
|
|
|
"systemd-initctl.service"
|
|
|
|
|
|
2012-08-06 20:52:08 +00:00
|
|
|
|
# Kernel module loading.
|
2014-04-17 16:52:31 +00:00
|
|
|
|
"systemd-modules-load.service"
|
|
|
|
|
"kmod-static-nodes.service"
|
2012-08-06 20:52:08 +00:00
|
|
|
|
|
2012-06-02 00:15:07 +00:00
|
|
|
|
# Filesystems.
|
2012-07-16 21:47:11 +00:00
|
|
|
|
"systemd-fsck@.service"
|
|
|
|
|
"systemd-fsck-root.service"
|
2012-06-14 22:44:56 +00:00
|
|
|
|
"systemd-remount-fs.service"
|
2012-06-02 00:15:07 +00:00
|
|
|
|
"local-fs.target"
|
|
|
|
|
"local-fs-pre.target"
|
|
|
|
|
"remote-fs.target"
|
|
|
|
|
"remote-fs-pre.target"
|
|
|
|
|
"swap.target"
|
2012-06-14 22:44:56 +00:00
|
|
|
|
"dev-hugepages.mount"
|
2012-06-02 00:15:07 +00:00
|
|
|
|
"dev-mqueue.mount"
|
2014-04-15 22:59:26 +00:00
|
|
|
|
"proc-sys-fs-binfmt_misc.mount"
|
2014-04-28 07:13:57 +00:00
|
|
|
|
"sys-fs-fuse-connections.mount"
|
|
|
|
|
"sys-kernel-config.mount"
|
2012-06-14 22:44:56 +00:00
|
|
|
|
"sys-kernel-debug.mount"
|
|
|
|
|
|
2014-04-15 22:59:26 +00:00
|
|
|
|
# Maintaining state across reboots.
|
|
|
|
|
"systemd-random-seed.service"
|
2014-04-18 17:37:15 +00:00
|
|
|
|
"systemd-backlight@.service"
|
2015-10-07 19:48:30 +00:00
|
|
|
|
"systemd-rfkill.service"
|
2014-04-15 22:59:26 +00:00
|
|
|
|
|
2012-06-14 22:44:56 +00:00
|
|
|
|
# Hibernate / suspend.
|
|
|
|
|
"hibernate.target"
|
|
|
|
|
"suspend.target"
|
|
|
|
|
"sleep.target"
|
2013-03-27 12:58:12 +00:00
|
|
|
|
"hybrid-sleep.target"
|
2012-07-20 19:40:50 +00:00
|
|
|
|
"systemd-hibernate.service"
|
|
|
|
|
"systemd-suspend.service"
|
2013-03-27 12:58:12 +00:00
|
|
|
|
"systemd-hybrid-sleep.service"
|
2012-06-02 00:15:07 +00:00
|
|
|
|
|
|
|
|
|
# Reboot stuff.
|
|
|
|
|
"reboot.target"
|
2012-07-16 21:47:11 +00:00
|
|
|
|
"systemd-reboot.service"
|
2012-06-02 00:15:07 +00:00
|
|
|
|
"poweroff.target"
|
2012-07-16 21:47:11 +00:00
|
|
|
|
"systemd-poweroff.service"
|
2012-06-02 00:15:07 +00:00
|
|
|
|
"halt.target"
|
2012-07-16 21:47:11 +00:00
|
|
|
|
"systemd-halt.service"
|
2012-06-02 00:15:07 +00:00
|
|
|
|
"shutdown.target"
|
|
|
|
|
"umount.target"
|
|
|
|
|
"final.target"
|
2012-08-14 22:14:48 +00:00
|
|
|
|
"kexec.target"
|
2013-09-16 15:15:42 +00:00
|
|
|
|
"systemd-kexec.service"
|
2014-04-15 22:59:26 +00:00
|
|
|
|
"systemd-update-utmp.service"
|
2012-06-14 22:44:56 +00:00
|
|
|
|
|
2012-06-19 21:02:54 +00:00
|
|
|
|
# Password entry.
|
|
|
|
|
"systemd-ask-password-console.path"
|
|
|
|
|
"systemd-ask-password-console.service"
|
|
|
|
|
"systemd-ask-password-wall.path"
|
|
|
|
|
"systemd-ask-password-wall.service"
|
2014-04-15 22:59:26 +00:00
|
|
|
|
|
|
|
|
|
# Slices / containers.
|
|
|
|
|
"slices.target"
|
|
|
|
|
"-.slice"
|
|
|
|
|
"system.slice"
|
|
|
|
|
"user.slice"
|
|
|
|
|
"machine.slice"
|
|
|
|
|
"systemd-machined.service"
|
2014-04-17 11:23:06 +00:00
|
|
|
|
|
|
|
|
|
# Temporary file creation / cleanup.
|
|
|
|
|
"systemd-tmpfiles-clean.service"
|
2014-04-17 14:10:48 +00:00
|
|
|
|
"systemd-tmpfiles-clean.timer"
|
2014-04-17 11:23:06 +00:00
|
|
|
|
"systemd-tmpfiles-setup.service"
|
|
|
|
|
"systemd-tmpfiles-setup-dev.service"
|
2014-04-17 16:52:31 +00:00
|
|
|
|
|
|
|
|
|
# Misc.
|
2016-01-17 23:46:21 +00:00
|
|
|
|
"org.freedesktop.systemd1.busname"
|
2014-04-17 16:52:31 +00:00
|
|
|
|
"systemd-sysctl.service"
|
2015-12-06 13:30:18 +00:00
|
|
|
|
"dbus-org.freedesktop.timedate1.service"
|
|
|
|
|
"dbus-org.freedesktop.locale1.service"
|
|
|
|
|
"dbus-org.freedesktop.hostname1.service"
|
2016-01-17 23:46:21 +00:00
|
|
|
|
"org.freedesktop.timedate1.busname"
|
|
|
|
|
"org.freedesktop.locale1.busname"
|
|
|
|
|
"org.freedesktop.hostname1.busname"
|
2015-12-06 13:30:18 +00:00
|
|
|
|
"systemd-timedated.service"
|
|
|
|
|
"systemd-localed.service"
|
|
|
|
|
"systemd-hostnamed.service"
|
2015-12-21 11:09:38 +00:00
|
|
|
|
"systemd-binfmt.service"
|
2013-01-21 20:01:48 +00:00
|
|
|
|
]
|
2014-07-25 18:05:57 +00:00
|
|
|
|
++ cfg.additionalUpstreamSystemUnits;
|
2012-06-02 00:15:07 +00:00
|
|
|
|
|
2014-04-17 22:38:40 +00:00
|
|
|
|
upstreamSystemWants =
|
2013-03-27 12:58:12 +00:00
|
|
|
|
[ #"basic.target.wants"
|
2012-06-14 22:44:56 +00:00
|
|
|
|
"sysinit.target.wants"
|
|
|
|
|
"sockets.target.wants"
|
|
|
|
|
"local-fs.target.wants"
|
|
|
|
|
"multi-user.target.wants"
|
2013-03-27 12:58:12 +00:00
|
|
|
|
"timers.target.wants"
|
2012-06-14 22:44:56 +00:00
|
|
|
|
];
|
|
|
|
|
|
2014-04-17 22:38:40 +00:00
|
|
|
|
upstreamUserUnits =
|
|
|
|
|
[ "basic.target"
|
|
|
|
|
"default.target"
|
|
|
|
|
"exit.target"
|
|
|
|
|
"paths.target"
|
|
|
|
|
"shutdown.target"
|
|
|
|
|
"sockets.target"
|
|
|
|
|
"systemd-exit.service"
|
|
|
|
|
"timers.target"
|
|
|
|
|
];
|
|
|
|
|
|
2012-10-15 20:01:30 +00:00
|
|
|
|
makeJobScript = name: text:
|
2015-12-31 07:50:58 +00:00
|
|
|
|
let mkScriptName = s: (replaceChars [ "\\" ] [ "-" ] (shellEscape s) );
|
|
|
|
|
x = pkgs.writeTextFile { name = "unit-script"; executable = true; destination = "/bin/${mkScriptName name}"; inherit text; };
|
|
|
|
|
in "${x}/bin/${mkScriptName name}";
|
2012-07-19 21:41:42 +00:00
|
|
|
|
|
2012-10-09 19:14:15 +00:00
|
|
|
|
unitConfig = { name, config, ... }: {
|
|
|
|
|
config = {
|
|
|
|
|
unitConfig =
|
2014-03-12 17:35:50 +00:00
|
|
|
|
optionalAttrs (config.requires != [])
|
|
|
|
|
{ Requires = toString config.requires; }
|
|
|
|
|
// optionalAttrs (config.wants != [])
|
|
|
|
|
{ Wants = toString config.wants; }
|
|
|
|
|
// optionalAttrs (config.after != [])
|
|
|
|
|
{ After = toString config.after; }
|
|
|
|
|
// optionalAttrs (config.before != [])
|
|
|
|
|
{ Before = toString config.before; }
|
|
|
|
|
// optionalAttrs (config.bindsTo != [])
|
|
|
|
|
{ BindsTo = toString config.bindsTo; }
|
|
|
|
|
// optionalAttrs (config.partOf != [])
|
|
|
|
|
{ PartOf = toString config.partOf; }
|
|
|
|
|
// optionalAttrs (config.conflicts != [])
|
|
|
|
|
{ Conflicts = toString config.conflicts; }
|
2014-11-19 21:11:30 +00:00
|
|
|
|
// optionalAttrs (config.requisite != [])
|
|
|
|
|
{ Requisite = toString config.requisite; }
|
2014-03-12 17:35:50 +00:00
|
|
|
|
// optionalAttrs (config.restartTriggers != [])
|
|
|
|
|
{ X-Restart-Triggers = toString config.restartTriggers; }
|
|
|
|
|
// optionalAttrs (config.description != "") {
|
2012-10-09 19:14:15 +00:00
|
|
|
|
Description = config.description;
|
2015-11-16 14:07:10 +00:00
|
|
|
|
} // optionalAttrs (config.onFailure != []) {
|
|
|
|
|
OnFailure = toString config.onFailure;
|
2012-10-09 19:14:15 +00:00
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
2012-08-06 15:45:59 +00:00
|
|
|
|
serviceConfig = { name, config, ... }: {
|
2013-11-18 14:45:24 +00:00
|
|
|
|
config = mkMerge
|
2014-04-17 16:52:31 +00:00
|
|
|
|
[ { # Default path for systemd services. Should be quite minimal.
|
2013-11-18 14:45:24 +00:00
|
|
|
|
path =
|
|
|
|
|
[ pkgs.coreutils
|
|
|
|
|
pkgs.findutils
|
|
|
|
|
pkgs.gnugrep
|
|
|
|
|
pkgs.gnused
|
|
|
|
|
systemd
|
|
|
|
|
];
|
|
|
|
|
environment.PATH = config.path;
|
2014-04-17 16:52:31 +00:00
|
|
|
|
}
|
2013-11-18 14:45:24 +00:00
|
|
|
|
(mkIf (config.preStart != "")
|
|
|
|
|
{ serviceConfig.ExecStartPre = makeJobScript "${name}-pre-start" ''
|
|
|
|
|
#! ${pkgs.stdenv.shell} -e
|
|
|
|
|
${config.preStart}
|
|
|
|
|
'';
|
|
|
|
|
})
|
|
|
|
|
(mkIf (config.script != "")
|
|
|
|
|
{ serviceConfig.ExecStart = makeJobScript "${name}-start" ''
|
|
|
|
|
#! ${pkgs.stdenv.shell} -e
|
|
|
|
|
${config.script}
|
|
|
|
|
'' + " " + config.scriptArgs;
|
|
|
|
|
})
|
|
|
|
|
(mkIf (config.postStart != "")
|
|
|
|
|
{ serviceConfig.ExecStartPost = makeJobScript "${name}-post-start" ''
|
|
|
|
|
#! ${pkgs.stdenv.shell} -e
|
|
|
|
|
${config.postStart}
|
|
|
|
|
'';
|
|
|
|
|
})
|
2014-09-16 03:03:20 +00:00
|
|
|
|
(mkIf (config.reload != "")
|
|
|
|
|
{ serviceConfig.ExecReload = makeJobScript "${name}-reload" ''
|
|
|
|
|
#! ${pkgs.stdenv.shell} -e
|
|
|
|
|
${config.reload}
|
|
|
|
|
'';
|
|
|
|
|
})
|
2013-11-26 17:24:55 +00:00
|
|
|
|
(mkIf (config.preStop != "")
|
|
|
|
|
{ serviceConfig.ExecStop = makeJobScript "${name}-pre-stop" ''
|
|
|
|
|
#! ${pkgs.stdenv.shell} -e
|
|
|
|
|
${config.preStop}
|
|
|
|
|
'';
|
|
|
|
|
})
|
2013-11-18 14:45:24 +00:00
|
|
|
|
(mkIf (config.postStop != "")
|
|
|
|
|
{ serviceConfig.ExecStopPost = makeJobScript "${name}-post-stop" ''
|
|
|
|
|
#! ${pkgs.stdenv.shell} -e
|
|
|
|
|
${config.postStop}
|
|
|
|
|
'';
|
|
|
|
|
})
|
|
|
|
|
];
|
2012-08-06 15:45:59 +00:00
|
|
|
|
};
|
|
|
|
|
|
2012-12-28 12:29:53 +00:00
|
|
|
|
mountConfig = { name, config, ... }: {
|
|
|
|
|
config = {
|
|
|
|
|
mountConfig =
|
|
|
|
|
{ What = config.what;
|
|
|
|
|
Where = config.where;
|
|
|
|
|
} // optionalAttrs (config.type != "") {
|
|
|
|
|
Type = config.type;
|
|
|
|
|
} // optionalAttrs (config.options != "") {
|
|
|
|
|
Options = config.options;
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
2013-09-23 20:56:05 +00:00
|
|
|
|
automountConfig = { name, config, ... }: {
|
|
|
|
|
config = {
|
|
|
|
|
automountConfig =
|
|
|
|
|
{ Where = config.where;
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
2014-04-17 16:52:31 +00:00
|
|
|
|
commonUnitText = def: ''
|
2014-03-12 17:20:57 +00:00
|
|
|
|
[Unit]
|
|
|
|
|
${attrsToSection def.unitConfig}
|
|
|
|
|
'';
|
|
|
|
|
|
2012-10-01 22:58:11 +00:00
|
|
|
|
targetToUnit = name: def:
|
2013-04-19 20:28:00 +00:00
|
|
|
|
{ inherit (def) wantedBy requiredBy enable;
|
2012-10-01 22:58:11 +00:00
|
|
|
|
text =
|
|
|
|
|
''
|
|
|
|
|
[Unit]
|
|
|
|
|
${attrsToSection def.unitConfig}
|
|
|
|
|
'';
|
|
|
|
|
};
|
2012-06-18 19:28:31 +00:00
|
|
|
|
|
2012-10-01 22:58:11 +00:00
|
|
|
|
serviceToUnit = name: def:
|
2013-04-19 20:28:00 +00:00
|
|
|
|
{ inherit (def) wantedBy requiredBy enable;
|
2014-03-12 17:20:57 +00:00
|
|
|
|
text = commonUnitText def +
|
2012-06-18 19:28:31 +00:00
|
|
|
|
''
|
|
|
|
|
[Service]
|
2012-10-30 16:27:14 +00:00
|
|
|
|
${let env = cfg.globalEnvironment // def.environment;
|
2014-07-30 08:28:05 +00:00
|
|
|
|
in concatMapStrings (n:
|
2014-12-07 20:44:20 +00:00
|
|
|
|
let s = optionalString (env."${n}" != null)
|
|
|
|
|
"Environment=\"${n}=${env.${n}}\"\n";
|
2014-07-30 08:28:05 +00:00
|
|
|
|
in if stringLength s >= 2048 then throw "The value of the environment variable ‘${n}’ in systemd service ‘${name}.service’ is too long." else s) (attrNames env)}
|
2014-03-17 14:02:53 +00:00
|
|
|
|
${if def.reloadIfChanged then ''
|
|
|
|
|
X-ReloadIfChanged=true
|
|
|
|
|
'' else if !def.restartIfChanged then ''
|
|
|
|
|
X-RestartIfChanged=false
|
|
|
|
|
'' else ""}
|
2013-01-05 00:05:25 +00:00
|
|
|
|
${optionalString (!def.stopIfChanged) "X-StopIfChanged=false"}
|
2012-10-01 20:27:42 +00:00
|
|
|
|
${attrsToSection def.serviceConfig}
|
2012-06-18 19:28:31 +00:00
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2012-10-01 22:58:11 +00:00
|
|
|
|
socketToUnit = name: def:
|
2013-04-19 20:28:00 +00:00
|
|
|
|
{ inherit (def) wantedBy requiredBy enable;
|
2014-03-12 17:20:57 +00:00
|
|
|
|
text = commonUnitText def +
|
2012-10-01 22:58:11 +00:00
|
|
|
|
''
|
|
|
|
|
[Socket]
|
|
|
|
|
${attrsToSection def.socketConfig}
|
2013-05-14 14:07:55 +00:00
|
|
|
|
${concatStringsSep "\n" (map (s: "ListenStream=${s}") def.listenStreams)}
|
2012-10-01 22:58:11 +00:00
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2013-03-02 00:03:13 +00:00
|
|
|
|
timerToUnit = name: def:
|
2013-04-19 20:28:00 +00:00
|
|
|
|
{ inherit (def) wantedBy requiredBy enable;
|
2014-03-12 17:20:57 +00:00
|
|
|
|
text = commonUnitText def +
|
2013-03-02 00:03:13 +00:00
|
|
|
|
''
|
|
|
|
|
[Timer]
|
|
|
|
|
${attrsToSection def.timerConfig}
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2014-03-31 10:23:27 +00:00
|
|
|
|
pathToUnit = name: def:
|
|
|
|
|
{ inherit (def) wantedBy requiredBy enable;
|
|
|
|
|
text = commonUnitText def +
|
|
|
|
|
''
|
|
|
|
|
[Path]
|
|
|
|
|
${attrsToSection def.pathConfig}
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2012-12-28 12:29:53 +00:00
|
|
|
|
mountToUnit = name: def:
|
2013-04-19 20:28:00 +00:00
|
|
|
|
{ inherit (def) wantedBy requiredBy enable;
|
2014-03-12 17:20:57 +00:00
|
|
|
|
text = commonUnitText def +
|
2012-12-28 12:29:53 +00:00
|
|
|
|
''
|
|
|
|
|
[Mount]
|
|
|
|
|
${attrsToSection def.mountConfig}
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2013-09-23 20:56:05 +00:00
|
|
|
|
automountToUnit = name: def:
|
|
|
|
|
{ inherit (def) wantedBy requiredBy enable;
|
2014-03-12 17:20:57 +00:00
|
|
|
|
text = commonUnitText def +
|
2013-09-23 20:56:05 +00:00
|
|
|
|
''
|
|
|
|
|
[Automount]
|
|
|
|
|
${attrsToSection def.automountConfig}
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2012-06-02 00:15:07 +00:00
|
|
|
|
in
|
|
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
2012-06-14 22:44:56 +00:00
|
|
|
|
###### interface
|
|
|
|
|
|
|
|
|
|
options = {
|
|
|
|
|
|
2013-01-16 12:17:57 +00:00
|
|
|
|
systemd.package = mkOption {
|
|
|
|
|
default = pkgs.systemd;
|
2016-01-17 18:34:55 +00:00
|
|
|
|
defaultText = "pkgs.systemd";
|
2013-01-16 12:17:57 +00:00
|
|
|
|
type = types.package;
|
|
|
|
|
description = "The systemd package.";
|
|
|
|
|
};
|
|
|
|
|
|
2013-01-16 11:33:18 +00:00
|
|
|
|
systemd.units = mkOption {
|
2012-06-18 19:28:31 +00:00
|
|
|
|
description = "Definition of systemd units.";
|
2012-06-18 03:31:21 +00:00
|
|
|
|
default = {};
|
|
|
|
|
type = types.attrsOf types.optionSet;
|
2013-11-18 12:18:58 +00:00
|
|
|
|
options = { name, config, ... }:
|
2014-04-17 21:35:05 +00:00
|
|
|
|
{ options = concreteUnitOptions;
|
2013-11-18 12:18:58 +00:00
|
|
|
|
config = {
|
2014-03-12 23:18:17 +00:00
|
|
|
|
unit = mkDefault (makeUnit name config);
|
2013-11-18 12:18:58 +00:00
|
|
|
|
};
|
2012-06-18 03:31:21 +00:00
|
|
|
|
};
|
2012-06-18 19:28:31 +00:00
|
|
|
|
};
|
|
|
|
|
|
2013-01-16 11:33:18 +00:00
|
|
|
|
systemd.packages = mkOption {
|
2012-08-21 15:28:47 +00:00
|
|
|
|
default = [];
|
|
|
|
|
type = types.listOf types.package;
|
|
|
|
|
description = "Packages providing systemd units.";
|
|
|
|
|
};
|
|
|
|
|
|
2013-01-16 11:33:18 +00:00
|
|
|
|
systemd.targets = mkOption {
|
2012-10-01 22:58:11 +00:00
|
|
|
|
default = {};
|
|
|
|
|
type = types.attrsOf types.optionSet;
|
2014-04-17 21:35:05 +00:00
|
|
|
|
options = [ targetOptions unitConfig ];
|
2012-10-01 22:58:11 +00:00
|
|
|
|
description = "Definition of systemd target units.";
|
|
|
|
|
};
|
|
|
|
|
|
2013-01-16 11:33:18 +00:00
|
|
|
|
systemd.services = mkOption {
|
2012-06-18 19:28:31 +00:00
|
|
|
|
default = {};
|
|
|
|
|
type = types.attrsOf types.optionSet;
|
2012-10-09 19:14:15 +00:00
|
|
|
|
options = [ serviceOptions unitConfig serviceConfig ];
|
2012-10-01 22:58:11 +00:00
|
|
|
|
description = "Definition of systemd service units.";
|
|
|
|
|
};
|
|
|
|
|
|
2013-01-16 11:33:18 +00:00
|
|
|
|
systemd.sockets = mkOption {
|
2012-10-01 22:58:11 +00:00
|
|
|
|
default = {};
|
|
|
|
|
type = types.attrsOf types.optionSet;
|
2012-10-09 19:14:15 +00:00
|
|
|
|
options = [ socketOptions unitConfig ];
|
2012-10-01 22:58:11 +00:00
|
|
|
|
description = "Definition of systemd socket units.";
|
2012-06-14 22:44:56 +00:00
|
|
|
|
};
|
|
|
|
|
|
2013-03-02 00:03:13 +00:00
|
|
|
|
systemd.timers = mkOption {
|
|
|
|
|
default = {};
|
|
|
|
|
type = types.attrsOf types.optionSet;
|
|
|
|
|
options = [ timerOptions unitConfig ];
|
|
|
|
|
description = "Definition of systemd timer units.";
|
|
|
|
|
};
|
|
|
|
|
|
2014-03-31 10:23:27 +00:00
|
|
|
|
systemd.paths = mkOption {
|
|
|
|
|
default = {};
|
|
|
|
|
type = types.attrsOf types.optionSet;
|
|
|
|
|
options = [ pathOptions unitConfig ];
|
|
|
|
|
description = "Definition of systemd path units.";
|
|
|
|
|
};
|
|
|
|
|
|
2013-01-16 11:33:18 +00:00
|
|
|
|
systemd.mounts = mkOption {
|
2012-12-28 12:29:53 +00:00
|
|
|
|
default = [];
|
|
|
|
|
type = types.listOf types.optionSet;
|
|
|
|
|
options = [ mountOptions unitConfig mountConfig ];
|
|
|
|
|
description = ''
|
|
|
|
|
Definition of systemd mount units.
|
|
|
|
|
This is a list instead of an attrSet, because systemd mandates the names to be derived from
|
|
|
|
|
the 'where' attribute.
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2013-09-23 20:56:05 +00:00
|
|
|
|
systemd.automounts = mkOption {
|
|
|
|
|
default = [];
|
|
|
|
|
type = types.listOf types.optionSet;
|
|
|
|
|
options = [ automountOptions unitConfig automountConfig ];
|
|
|
|
|
description = ''
|
|
|
|
|
Definition of systemd automount units.
|
|
|
|
|
This is a list instead of an attrSet, because systemd mandates the names to be derived from
|
|
|
|
|
the 'where' attribute.
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2015-09-26 16:34:36 +00:00
|
|
|
|
systemd.generators = mkOption {
|
|
|
|
|
type = types.attrsOf types.path;
|
|
|
|
|
default = {};
|
|
|
|
|
example = { "systemd-gpt-auto-generator" = "/dev/null"; };
|
|
|
|
|
description = ''
|
|
|
|
|
Definition of systemd generators.
|
|
|
|
|
For each <literal>NAME = VALUE</literal> pair of the attrSet, a link is generated from
|
|
|
|
|
<literal>/etc/systemd/system-generators/NAME</literal> to <literal>VALUE</literal>.
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2016-03-24 14:27:47 +00:00
|
|
|
|
systemd.generator-packages = mkOption {
|
|
|
|
|
default = [];
|
|
|
|
|
type = types.listOf types.package;
|
|
|
|
|
example = literalExample "[ pkgs.systemd-cryptsetup-generator ]";
|
|
|
|
|
description = "Packages providing systemd generators.";
|
|
|
|
|
};
|
|
|
|
|
|
2013-01-16 11:33:18 +00:00
|
|
|
|
systemd.defaultUnit = mkOption {
|
2012-06-18 03:31:21 +00:00
|
|
|
|
default = "multi-user.target";
|
2013-10-30 10:02:04 +00:00
|
|
|
|
type = types.str;
|
2012-06-18 03:31:21 +00:00
|
|
|
|
description = "Default unit started when the system boots.";
|
|
|
|
|
};
|
2012-07-19 21:32:50 +00:00
|
|
|
|
|
2016-07-19 07:42:53 +00:00
|
|
|
|
systemd.ctrlAltDelUnit = mkOption {
|
|
|
|
|
default = "reboot.target";
|
|
|
|
|
type = types.str;
|
|
|
|
|
example = "poweroff.target";
|
|
|
|
|
description = ''
|
|
|
|
|
Target that should be started when Ctrl-Alt-Delete is pressed.
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2013-01-16 11:33:18 +00:00
|
|
|
|
systemd.globalEnvironment = mkOption {
|
2012-10-30 16:27:14 +00:00
|
|
|
|
type = types.attrs;
|
|
|
|
|
default = {};
|
|
|
|
|
example = { TZ = "CET"; };
|
|
|
|
|
description = ''
|
|
|
|
|
Environment variables passed to <emphasis>all</emphasis> systemd units.
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2013-11-15 18:49:01 +00:00
|
|
|
|
systemd.extraConfig = mkOption {
|
|
|
|
|
default = "";
|
|
|
|
|
type = types.lines;
|
|
|
|
|
example = "DefaultLimitCORE=infinity";
|
|
|
|
|
description = ''
|
|
|
|
|
Extra config options for systemd. See man systemd-system.conf for
|
|
|
|
|
available options.
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2012-07-19 21:32:50 +00:00
|
|
|
|
services.journald.console = mkOption {
|
|
|
|
|
default = "";
|
2013-10-30 10:02:04 +00:00
|
|
|
|
type = types.str;
|
2012-11-02 13:10:06 +00:00
|
|
|
|
description = "If non-empty, write log messages to the specified TTY device.";
|
2012-07-19 21:32:50 +00:00
|
|
|
|
};
|
2012-08-06 15:45:59 +00:00
|
|
|
|
|
2012-12-16 19:28:45 +00:00
|
|
|
|
services.journald.rateLimitInterval = mkOption {
|
|
|
|
|
default = "10s";
|
2013-10-30 10:02:04 +00:00
|
|
|
|
type = types.str;
|
2012-12-16 19:28:45 +00:00
|
|
|
|
description = ''
|
|
|
|
|
Configures the rate limiting interval that is applied to all
|
|
|
|
|
messages generated on the system. This rate limiting is applied
|
|
|
|
|
per-service, so that two services which log do not interfere with
|
|
|
|
|
each other's limit. The value may be specified in the following
|
|
|
|
|
units: s, min, h, ms, us. To turn off any kind of rate limiting,
|
|
|
|
|
set either value to 0.
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
services.journald.rateLimitBurst = mkOption {
|
|
|
|
|
default = 100;
|
2015-06-15 16:11:32 +00:00
|
|
|
|
type = types.int;
|
2012-12-16 19:28:45 +00:00
|
|
|
|
description = ''
|
|
|
|
|
Configures the rate limiting burst limit (number of messages per
|
|
|
|
|
interval) that is applied to all messages generated on the system.
|
|
|
|
|
This rate limiting is applied per-service, so that two services
|
|
|
|
|
which log do not interfere with each other's limit.
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2013-11-29 10:57:42 +00:00
|
|
|
|
services.journald.extraConfig = mkOption {
|
|
|
|
|
default = "";
|
|
|
|
|
type = types.lines;
|
|
|
|
|
example = "Storage=volatile";
|
|
|
|
|
description = ''
|
|
|
|
|
Extra config options for systemd-journald. See man journald.conf
|
|
|
|
|
for available options.
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2014-02-01 13:50:20 +00:00
|
|
|
|
services.journald.enableHttpGateway = mkOption {
|
|
|
|
|
default = false;
|
|
|
|
|
type = types.bool;
|
|
|
|
|
description = ''
|
2014-04-17 17:05:29 +00:00
|
|
|
|
Whether to enable the HTTP gateway to the journal.
|
2014-02-01 13:50:20 +00:00
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2013-02-24 10:54:01 +00:00
|
|
|
|
services.logind.extraConfig = mkOption {
|
|
|
|
|
default = "";
|
2013-11-15 20:56:45 +00:00
|
|
|
|
type = types.lines;
|
2013-02-24 10:54:01 +00:00
|
|
|
|
example = "HandleLidSwitch=ignore";
|
|
|
|
|
description = ''
|
|
|
|
|
Extra config options for systemd-logind. See man logind.conf for
|
|
|
|
|
available options.
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2014-04-17 14:10:48 +00:00
|
|
|
|
systemd.tmpfiles.rules = mkOption {
|
|
|
|
|
type = types.listOf types.str;
|
|
|
|
|
default = [];
|
|
|
|
|
example = [ "d /tmp 1777 root root 10d" ];
|
|
|
|
|
description = ''
|
|
|
|
|
Rules for creating and cleaning up temporary files
|
|
|
|
|
automatically. See
|
|
|
|
|
<citerefentry><refentrytitle>tmpfiles.d</refentrytitle><manvolnum>5</manvolnum></citerefentry>
|
|
|
|
|
for the exact format. You should not use this option to create
|
|
|
|
|
files required by systemd services, since there is no
|
|
|
|
|
guarantee that <command>systemd-tmpfiles</command> runs when
|
|
|
|
|
the system is reconfigured using
|
|
|
|
|
<command>nixos-rebuild</command>.
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2014-04-17 22:38:40 +00:00
|
|
|
|
systemd.user.units = mkOption {
|
|
|
|
|
description = "Definition of systemd per-user units.";
|
|
|
|
|
default = {};
|
|
|
|
|
type = types.attrsOf types.optionSet;
|
|
|
|
|
options = { name, config, ... }:
|
|
|
|
|
{ options = concreteUnitOptions;
|
|
|
|
|
config = {
|
|
|
|
|
unit = mkDefault (makeUnit name config);
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
systemd.user.services = mkOption {
|
|
|
|
|
default = {};
|
|
|
|
|
type = types.attrsOf types.optionSet;
|
|
|
|
|
options = [ serviceOptions unitConfig serviceConfig ];
|
|
|
|
|
description = "Definition of systemd per-user service units.";
|
|
|
|
|
};
|
|
|
|
|
|
2014-12-30 04:46:36 +00:00
|
|
|
|
systemd.user.timers = mkOption {
|
|
|
|
|
default = {};
|
|
|
|
|
type = types.attrsOf types.optionSet;
|
|
|
|
|
options = [ timerOptions unitConfig ];
|
|
|
|
|
description = "Definition of systemd per-user timer units.";
|
|
|
|
|
};
|
|
|
|
|
|
2014-06-20 18:34:21 +00:00
|
|
|
|
systemd.user.sockets = mkOption {
|
|
|
|
|
default = {};
|
|
|
|
|
type = types.attrsOf types.optionSet;
|
|
|
|
|
options = [ socketOptions unitConfig ];
|
|
|
|
|
description = "Definition of systemd per-user socket units.";
|
|
|
|
|
};
|
|
|
|
|
|
2014-07-25 18:05:57 +00:00
|
|
|
|
systemd.additionalUpstreamSystemUnits = mkOption {
|
|
|
|
|
default = [ ];
|
|
|
|
|
type = types.listOf types.str;
|
|
|
|
|
example = [ "debug-shell.service" "systemd-quotacheck.service" ];
|
|
|
|
|
description = ''
|
|
|
|
|
Additional units shipped with systemd that shall be enabled.
|
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2012-06-14 22:44:56 +00:00
|
|
|
|
};
|
|
|
|
|
|
2012-08-06 15:45:59 +00:00
|
|
|
|
|
2012-06-02 00:15:07 +00:00
|
|
|
|
###### implementation
|
|
|
|
|
|
2015-04-19 19:05:12 +00:00
|
|
|
|
config = {
|
2012-06-02 00:15:07 +00:00
|
|
|
|
|
2014-04-22 21:23:05 +00:00
|
|
|
|
warnings = concatLists (mapAttrsToList (name: service:
|
|
|
|
|
optional (service.serviceConfig.Type or "" == "oneshot" && service.serviceConfig.Restart or "no" != "no")
|
|
|
|
|
"Service ‘${name}.service’ with ‘Type=oneshot’ must have ‘Restart=no’") cfg.services);
|
2014-04-10 04:55:17 +00:00
|
|
|
|
|
2014-04-17 22:38:40 +00:00
|
|
|
|
system.build.units = cfg.units;
|
2012-06-16 04:19:43 +00:00
|
|
|
|
|
2012-06-02 00:15:07 +00:00
|
|
|
|
environment.systemPackages = [ systemd ];
|
2012-08-06 15:45:59 +00:00
|
|
|
|
|
2016-03-24 14:27:47 +00:00
|
|
|
|
environment.etc = let
|
2016-03-25 11:45:54 +00:00
|
|
|
|
# generate contents for /etc/systemd/system-generators from
|
|
|
|
|
# systemd.generators and systemd.generator-packages
|
|
|
|
|
generators = pkgs.runCommand "system-generators" { packages = cfg.generator-packages; } ''
|
|
|
|
|
mkdir -p $out
|
|
|
|
|
for package in $packages
|
|
|
|
|
do
|
|
|
|
|
ln -s $package/lib/systemd/system-generators/* $out/
|
|
|
|
|
done;
|
|
|
|
|
${concatStrings (mapAttrsToList (generator: target: "ln -s ${target} $out/${generator};\n") cfg.generators)}
|
|
|
|
|
'';
|
2016-03-24 14:27:47 +00:00
|
|
|
|
in ({
|
2015-09-26 16:34:36 +00:00
|
|
|
|
"systemd/system".source = generateUnits "system" cfg.units upstreamSystemUnits upstreamSystemWants;
|
2014-04-17 22:38:40 +00:00
|
|
|
|
|
2015-09-26 16:34:36 +00:00
|
|
|
|
"systemd/user".source = generateUnits "user" cfg.user.units upstreamUserUnits [];
|
2013-05-09 14:21:42 +00:00
|
|
|
|
|
2015-09-26 16:34:36 +00:00
|
|
|
|
"systemd/system.conf".text = ''
|
2013-05-09 14:21:42 +00:00
|
|
|
|
[Manager]
|
2013-11-15 18:49:01 +00:00
|
|
|
|
${config.systemd.extraConfig}
|
2013-05-09 14:21:42 +00:00
|
|
|
|
'';
|
|
|
|
|
|
2015-09-26 16:34:36 +00:00
|
|
|
|
"systemd/journald.conf".text = ''
|
2013-05-09 14:21:42 +00:00
|
|
|
|
[Journal]
|
|
|
|
|
RateLimitInterval=${config.services.journald.rateLimitInterval}
|
|
|
|
|
RateLimitBurst=${toString config.services.journald.rateLimitBurst}
|
|
|
|
|
${optionalString (config.services.journald.console != "") ''
|
|
|
|
|
ForwardToConsole=yes
|
|
|
|
|
TTYPath=${config.services.journald.console}
|
|
|
|
|
''}
|
2013-11-29 10:57:42 +00:00
|
|
|
|
${config.services.journald.extraConfig}
|
2013-05-09 14:21:42 +00:00
|
|
|
|
'';
|
|
|
|
|
|
2015-09-26 16:34:36 +00:00
|
|
|
|
"systemd/logind.conf".text = ''
|
2013-05-09 14:21:42 +00:00
|
|
|
|
[Login]
|
2016-06-06 10:51:51 +00:00
|
|
|
|
KillUserProcesses=no
|
2013-05-09 14:21:42 +00:00
|
|
|
|
${config.services.logind.extraConfig}
|
|
|
|
|
'';
|
2012-06-14 22:44:56 +00:00
|
|
|
|
|
2015-09-26 16:34:36 +00:00
|
|
|
|
"systemd/sleep.conf".text = ''
|
2013-05-09 14:25:24 +00:00
|
|
|
|
[Sleep]
|
|
|
|
|
'';
|
|
|
|
|
|
2015-09-26 16:34:36 +00:00
|
|
|
|
"tmpfiles.d/systemd.conf".source = "${systemd}/example/tmpfiles.d/systemd.conf";
|
|
|
|
|
"tmpfiles.d/x11.conf".source = "${systemd}/example/tmpfiles.d/x11.conf";
|
|
|
|
|
|
|
|
|
|
"tmpfiles.d/nixos.conf".text = ''
|
|
|
|
|
# This file is created automatically and should not be modified.
|
|
|
|
|
# Please change the option ‘systemd.tmpfiles.rules’ instead.
|
|
|
|
|
|
|
|
|
|
${concatStringsSep "\n" cfg.tmpfiles.rules}
|
|
|
|
|
'';
|
2016-03-25 11:45:54 +00:00
|
|
|
|
|
|
|
|
|
"systemd/system-generators" = { source = generators; };
|
|
|
|
|
});
|
2015-09-26 16:34:36 +00:00
|
|
|
|
|
2016-03-07 01:38:53 +00:00
|
|
|
|
services.dbus.enable = true;
|
|
|
|
|
|
2013-07-19 19:18:44 +00:00
|
|
|
|
system.activationScripts.systemd = stringAfter [ "groups" ]
|
2012-11-29 17:51:44 +00:00
|
|
|
|
''
|
2013-07-20 15:07:26 +00:00
|
|
|
|
mkdir -m 0755 -p /var/lib/udev
|
2015-05-13 16:19:34 +00:00
|
|
|
|
|
|
|
|
|
if ! [ -e /etc/machine-id ]; then
|
|
|
|
|
${systemd}/bin/systemd-machine-id-setup
|
|
|
|
|
fi
|
2015-09-03 09:29:46 +00:00
|
|
|
|
|
|
|
|
|
# Keep a persistent journal. Note that systemd-tmpfiles will
|
|
|
|
|
# set proper ownership/permissions.
|
|
|
|
|
mkdir -m 0700 -p /var/log/journal
|
2012-11-29 17:51:44 +00:00
|
|
|
|
'';
|
|
|
|
|
|
2015-05-11 13:54:16 +00:00
|
|
|
|
users.extraUsers.systemd-network.uid = config.ids.uids.systemd-network;
|
|
|
|
|
users.extraGroups.systemd-network.gid = config.ids.gids.systemd-network;
|
|
|
|
|
users.extraUsers.systemd-resolve.uid = config.ids.uids.systemd-resolve;
|
|
|
|
|
users.extraGroups.systemd-resolve.gid = config.ids.gids.systemd-resolve;
|
|
|
|
|
|
2012-11-01 22:32:12 +00:00
|
|
|
|
# Target for ‘charon send-keys’ to hook into.
|
2014-02-11 12:00:10 +00:00
|
|
|
|
users.extraGroups.keys.gid = config.ids.gids.keys;
|
|
|
|
|
|
2013-01-16 11:33:18 +00:00
|
|
|
|
systemd.targets.keys =
|
2012-11-01 22:32:12 +00:00
|
|
|
|
{ description = "Security Keys";
|
2014-02-26 18:35:04 +00:00
|
|
|
|
unitConfig.X-StopOnReconfiguration = true;
|
2012-11-01 22:32:12 +00:00
|
|
|
|
};
|
|
|
|
|
|
2014-11-26 19:19:31 +00:00
|
|
|
|
systemd.targets.network-online.after = [ "ip-up.target" ];
|
|
|
|
|
|
2014-12-02 01:19:06 +00:00
|
|
|
|
systemd.targets.network-pre = {
|
|
|
|
|
wantedBy = [ "network.target" ];
|
|
|
|
|
before = [ "network.target" ];
|
|
|
|
|
};
|
|
|
|
|
|
2014-12-02 01:17:46 +00:00
|
|
|
|
systemd.targets.remote-fs-pre = {
|
|
|
|
|
wantedBy = [ "remote-fs.target" ];
|
|
|
|
|
before = [ "remote-fs.target" ];
|
|
|
|
|
};
|
|
|
|
|
|
2013-01-16 11:33:18 +00:00
|
|
|
|
systemd.units =
|
2013-01-08 17:24:06 +00:00
|
|
|
|
mapAttrs' (n: v: nameValuePair "${n}.target" (targetToUnit n v)) cfg.targets
|
2012-10-01 22:58:11 +00:00
|
|
|
|
// mapAttrs' (n: v: nameValuePair "${n}.service" (serviceToUnit n v)) cfg.services
|
2012-12-28 12:29:53 +00:00
|
|
|
|
// mapAttrs' (n: v: nameValuePair "${n}.socket" (socketToUnit n v)) cfg.sockets
|
2013-03-02 00:03:13 +00:00
|
|
|
|
// mapAttrs' (n: v: nameValuePair "${n}.timer" (timerToUnit n v)) cfg.timers
|
2014-03-31 10:23:27 +00:00
|
|
|
|
// mapAttrs' (n: v: nameValuePair "${n}.path" (pathToUnit n v)) cfg.paths
|
2012-12-28 12:29:53 +00:00
|
|
|
|
// listToAttrs (map
|
2013-01-01 13:42:43 +00:00
|
|
|
|
(v: let n = escapeSystemdPath v.where;
|
2013-09-23 20:56:05 +00:00
|
|
|
|
in nameValuePair "${n}.mount" (mountToUnit n v)) cfg.mounts)
|
|
|
|
|
// listToAttrs (map
|
|
|
|
|
(v: let n = escapeSystemdPath v.where;
|
|
|
|
|
in nameValuePair "${n}.automount" (automountToUnit n v)) cfg.automounts);
|
2012-06-14 22:44:56 +00:00
|
|
|
|
|
2014-04-17 22:38:40 +00:00
|
|
|
|
systemd.user.units =
|
2014-12-30 04:46:36 +00:00
|
|
|
|
mapAttrs' (n: v: nameValuePair "${n}.service" (serviceToUnit n v)) cfg.user.services
|
|
|
|
|
// mapAttrs' (n: v: nameValuePair "${n}.socket" (socketToUnit n v)) cfg.user.sockets
|
|
|
|
|
// mapAttrs' (n: v: nameValuePair "${n}.timer" (timerToUnit n v)) cfg.user.timers;
|
2014-04-17 22:38:40 +00:00
|
|
|
|
|
2014-04-30 11:53:12 +00:00
|
|
|
|
system.requiredKernelConfig = map config.lib.kernelConfig.isEnabled
|
|
|
|
|
[ "DEVTMPFS" "CGROUPS" "INOTIFY_USER" "SIGNALFD" "TIMERFD" "EPOLL" "NET"
|
|
|
|
|
"SYSFS" "PROC_FS" "FHANDLE" "DMIID" "AUTOFS4_FS" "TMPFS_POSIX_ACL"
|
|
|
|
|
"TMPFS_XATTR" "SECCOMP"
|
|
|
|
|
];
|
2012-11-29 17:51:44 +00:00
|
|
|
|
|
2013-07-19 19:18:44 +00:00
|
|
|
|
users.extraGroups.systemd-journal.gid = config.ids.gids.systemd-journal;
|
2014-02-01 13:50:20 +00:00
|
|
|
|
users.extraUsers.systemd-journal-gateway.uid = config.ids.uids.systemd-journal-gateway;
|
|
|
|
|
users.extraGroups.systemd-journal-gateway.gid = config.ids.gids.systemd-journal-gateway;
|
2013-07-19 19:18:44 +00:00
|
|
|
|
|
2013-10-09 12:28:35 +00:00
|
|
|
|
# Generate timer units for all services that have a ‘startAt’ value.
|
|
|
|
|
systemd.timers =
|
|
|
|
|
mapAttrs (name: service:
|
|
|
|
|
{ wantedBy = [ "timers.target" ];
|
|
|
|
|
timerConfig.OnCalendar = service.startAt;
|
|
|
|
|
})
|
2016-07-06 16:50:05 +00:00
|
|
|
|
(filterAttrs (name: service: service.enable && service.startAt != "") cfg.services);
|
2013-10-09 12:28:35 +00:00
|
|
|
|
|
2015-08-21 06:45:13 +00:00
|
|
|
|
# Generate timer units for all services that have a ‘startAt’ value.
|
|
|
|
|
systemd.user.timers =
|
|
|
|
|
mapAttrs (name: service:
|
|
|
|
|
{ wantedBy = [ "timers.target" ];
|
|
|
|
|
timerConfig.OnCalendar = service.startAt;
|
|
|
|
|
})
|
|
|
|
|
(filterAttrs (name: service: service.startAt != "") cfg.user.services);
|
|
|
|
|
|
2014-04-17 17:05:29 +00:00
|
|
|
|
systemd.sockets.systemd-journal-gatewayd.wantedBy =
|
|
|
|
|
optional config.services.journald.enableHttpGateway "sockets.target";
|
|
|
|
|
|
2014-04-17 10:03:04 +00:00
|
|
|
|
# Provide the systemd-user PAM service, required to run systemd
|
|
|
|
|
# user instances.
|
|
|
|
|
security.pam.services.systemd-user =
|
|
|
|
|
{ # Ensure that pam_systemd gets included. This is special-cased
|
|
|
|
|
# in systemd to provide XDG_RUNTIME_DIR.
|
|
|
|
|
startSession = true;
|
|
|
|
|
};
|
|
|
|
|
|
2015-05-11 10:39:37 +00:00
|
|
|
|
# Some overrides to upstream units.
|
|
|
|
|
systemd.services."systemd-backlight@".restartIfChanged = false;
|
|
|
|
|
systemd.services."systemd-rfkill@".restartIfChanged = false;
|
2014-05-20 09:10:20 +00:00
|
|
|
|
systemd.services."user@".restartIfChanged = false;
|
2014-07-17 18:59:25 +00:00
|
|
|
|
systemd.services.systemd-journal-flush.restartIfChanged = false;
|
2015-05-11 10:39:37 +00:00
|
|
|
|
systemd.services.systemd-random-seed.restartIfChanged = false;
|
|
|
|
|
systemd.services.systemd-remount-fs.restartIfChanged = false;
|
|
|
|
|
systemd.services.systemd-update-utmp.restartIfChanged = false;
|
|
|
|
|
systemd.services.systemd-user-sessions.restartIfChanged = false; # Restart kills all active sessions.
|
2016-06-28 07:02:44 +00:00
|
|
|
|
systemd.services.systemd-logind.restartTriggers = [ config.environment.etc."systemd/logind.conf".source ];
|
|
|
|
|
systemd.services.systemd-logind.stopIfChanged = false;
|
2015-05-11 10:39:37 +00:00
|
|
|
|
systemd.targets.local-fs.unitConfig.X-StopOnReconfiguration = true;
|
|
|
|
|
systemd.targets.remote-fs.unitConfig.X-StopOnReconfiguration = true;
|
2015-12-21 11:09:38 +00:00
|
|
|
|
systemd.services.systemd-binfmt.wants = [ "proc-sys-fs-binfmt_misc.automount" ];
|
2014-07-11 21:33:40 +00:00
|
|
|
|
|
2015-05-11 13:48:45 +00:00
|
|
|
|
# Don't bother with certain units in containers.
|
|
|
|
|
systemd.services.systemd-remount-fs.unitConfig.ConditionVirtualization = "!container";
|
|
|
|
|
systemd.services.systemd-random-seed.unitConfig.ConditionVirtualization = "!container";
|
|
|
|
|
|
2015-04-19 19:05:12 +00:00
|
|
|
|
};
|
2014-11-19 21:11:30 +00:00
|
|
|
|
|
2015-10-14 16:05:50 +00:00
|
|
|
|
# FIXME: Remove these eventually.
|
|
|
|
|
imports =
|
|
|
|
|
[ (mkRenamedOptionModule [ "boot" "systemd" "sockets" ] [ "systemd" "sockets" ])
|
|
|
|
|
(mkRenamedOptionModule [ "boot" "systemd" "targets" ] [ "systemd" "targets" ])
|
|
|
|
|
(mkRenamedOptionModule [ "boot" "systemd" "services" ] [ "systemd" "services" ])
|
|
|
|
|
];
|
|
|
|
|
|
2012-06-02 00:15:07 +00:00
|
|
|
|
}
|