2020-04-24 23:36:52 +00:00
|
|
|
{ config, lib, ... }:
|
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
options = {
|
|
|
|
|
|
|
|
services.timesyncd = {
|
|
|
|
enable = mkOption {
|
|
|
|
default = !config.boot.isContainer;
|
2021-12-06 16:07:01 +00:00
|
|
|
defaultText = literalExpression "!config.boot.isContainer";
|
2020-04-24 23:36:52 +00:00
|
|
|
type = types.bool;
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2020-04-24 23:36:52 +00:00
|
|
|
Enables the systemd NTP client daemon.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
servers = mkOption {
|
|
|
|
default = config.networking.timeServers;
|
2021-12-06 16:07:01 +00:00
|
|
|
defaultText = literalExpression "config.networking.timeServers";
|
2021-02-05 17:12:51 +00:00
|
|
|
type = types.listOf types.str;
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2020-04-24 23:36:52 +00:00
|
|
|
The set of NTP servers from which to synchronise.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
extraConfig = mkOption {
|
|
|
|
default = "";
|
|
|
|
type = types.lines;
|
|
|
|
example = ''
|
|
|
|
PollIntervalMaxSec=180
|
|
|
|
'';
|
2022-08-12 12:06:08 +00:00
|
|
|
description = lib.mdDoc ''
|
2020-04-24 23:36:52 +00:00
|
|
|
Extra config options for systemd-timesyncd. See
|
2022-08-12 12:06:08 +00:00
|
|
|
[
|
|
|
|
timesyncd.conf(5)](https://www.freedesktop.org/software/systemd/man/timesyncd.conf.html) for available options.
|
2020-04-24 23:36:52 +00:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
config = mkIf config.services.timesyncd.enable {
|
|
|
|
|
|
|
|
systemd.additionalUpstreamSystemUnits = [ "systemd-timesyncd.service" ];
|
|
|
|
|
|
|
|
systemd.services.systemd-timesyncd = {
|
|
|
|
wantedBy = [ "sysinit.target" ];
|
2020-06-18 07:06:33 +00:00
|
|
|
aliases = [ "dbus-org.freedesktop.timesync1.service" ];
|
2020-04-24 23:36:52 +00:00
|
|
|
restartTriggers = [ config.environment.etc."systemd/timesyncd.conf".source ];
|
2023-11-16 04:20:00 +00:00
|
|
|
|
|
|
|
preStart = (
|
|
|
|
# Ensure that we have some stored time to prevent
|
|
|
|
# systemd-timesyncd to resort back to the fallback time. If
|
|
|
|
# the file doesn't exist we assume that our current system
|
|
|
|
# clock is good enough to provide an initial value.
|
|
|
|
''
|
|
|
|
if ! [ -f /var/lib/systemd/timesync/clock ]; then
|
|
|
|
test -d /var/lib/systemd/timesync || mkdir -p /var/lib/systemd/timesync
|
|
|
|
touch /var/lib/systemd/timesync/clock
|
|
|
|
fi
|
|
|
|
'' +
|
|
|
|
# workaround an issue of systemd-timesyncd not starting due to upstream systemd reverting their dynamic users changes
|
|
|
|
# - https://github.com/NixOS/nixpkgs/pull/61321#issuecomment-492423742
|
|
|
|
# - https://github.com/systemd/systemd/issues/12131
|
|
|
|
(lib.optionalString (versionOlder config.system.stateVersion "19.09") ''
|
|
|
|
if [ -L /var/lib/systemd/timesync ]; then
|
|
|
|
rm /var/lib/systemd/timesync
|
|
|
|
mv /var/lib/private/systemd/timesync /var/lib/systemd/timesync
|
|
|
|
fi
|
|
|
|
'')
|
|
|
|
);
|
2020-04-24 23:36:52 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
environment.etc."systemd/timesyncd.conf".text = ''
|
|
|
|
[Time]
|
|
|
|
NTP=${concatStringsSep " " config.services.timesyncd.servers}
|
|
|
|
${config.services.timesyncd.extraConfig}
|
|
|
|
'';
|
|
|
|
|
|
|
|
users.users.systemd-timesync = {
|
|
|
|
uid = config.ids.uids.systemd-timesync;
|
|
|
|
group = "systemd-timesync";
|
|
|
|
};
|
|
|
|
users.groups.systemd-timesync.gid = config.ids.gids.systemd-timesync;
|
|
|
|
};
|
|
|
|
}
|