2020-04-24 23:36:52 +00:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
let
|
|
|
|
|
|
|
|
tzdir = "${pkgs.tzdata}/share/zoneinfo";
|
2024-09-19 14:19:46 +00:00
|
|
|
nospace = str: lib.filter (c: c == " ") (lib.stringToCharacters str) == [];
|
|
|
|
timezone = lib.types.nullOr (lib.types.addCheck lib.types.str nospace)
|
2020-04-24 23:36:52 +00:00
|
|
|
// { description = "null or string without spaces"; };
|
|
|
|
|
|
|
|
lcfg = config.location;
|
|
|
|
|
|
|
|
in
|
|
|
|
|
|
|
|
{
|
|
|
|
options = {
|
|
|
|
|
|
|
|
time = {
|
|
|
|
|
2024-09-19 14:19:46 +00:00
|
|
|
timeZone = lib.mkOption {
|
2020-04-24 23:36:52 +00:00
|
|
|
default = null;
|
|
|
|
type = timezone;
|
|
|
|
example = "America/New_York";
|
2024-04-21 15:54:59 +00:00
|
|
|
description = ''
|
2022-08-12 12:06:08 +00:00
|
|
|
The time zone used when displaying times and dates. See <https://en.wikipedia.org/wiki/List_of_tz_database_time_zones>
|
2020-04-24 23:36:52 +00:00
|
|
|
for a comprehensive list of possible values for this setting.
|
|
|
|
|
|
|
|
If null, the timezone will default to UTC and can be set imperatively
|
|
|
|
using timedatectl.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2024-09-19 14:19:46 +00:00
|
|
|
hardwareClockInLocalTime = lib.mkOption {
|
2020-04-24 23:36:52 +00:00
|
|
|
default = false;
|
2024-09-19 14:19:46 +00:00
|
|
|
type = lib.types.bool;
|
2024-04-21 15:54:59 +00:00
|
|
|
description = "If set, keep the hardware clock in local time instead of UTC.";
|
2020-04-24 23:36:52 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
location = {
|
|
|
|
|
2024-09-19 14:19:46 +00:00
|
|
|
latitude = lib.mkOption {
|
|
|
|
type = lib.types.float;
|
2024-04-21 15:54:59 +00:00
|
|
|
description = ''
|
2020-04-24 23:36:52 +00:00
|
|
|
Your current latitude, between
|
2022-08-12 12:06:08 +00:00
|
|
|
`-90.0` and `90.0`. Must be provided
|
2020-04-24 23:36:52 +00:00
|
|
|
along with longitude.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2024-09-19 14:19:46 +00:00
|
|
|
longitude = lib.mkOption {
|
|
|
|
type = lib.types.float;
|
2024-04-21 15:54:59 +00:00
|
|
|
description = ''
|
2020-04-24 23:36:52 +00:00
|
|
|
Your current longitude, between
|
2022-08-12 12:06:08 +00:00
|
|
|
between `-180.0` and `180.0`. Must be
|
2020-04-24 23:36:52 +00:00
|
|
|
provided along with latitude.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2024-09-19 14:19:46 +00:00
|
|
|
provider = lib.mkOption {
|
|
|
|
type = lib.types.enum [ "manual" "geoclue2" ];
|
2020-04-24 23:36:52 +00:00
|
|
|
default = "manual";
|
2024-04-21 15:54:59 +00:00
|
|
|
description = ''
|
2020-04-24 23:36:52 +00:00
|
|
|
The location provider to use for determining your location. If set to
|
2022-08-12 12:06:08 +00:00
|
|
|
`manual` you must also provide latitude/longitude.
|
2020-04-24 23:36:52 +00:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
config = {
|
|
|
|
|
|
|
|
environment.sessionVariables.TZDIR = "/etc/zoneinfo";
|
|
|
|
|
2024-09-19 14:19:46 +00:00
|
|
|
services.geoclue2.enable = lib.mkIf (lcfg.provider == "geoclue2") true;
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
# This way services are restarted when tzdata changes.
|
|
|
|
systemd.globalEnvironment.TZDIR = tzdir;
|
|
|
|
|
|
|
|
systemd.services.systemd-timedated.environment = lib.optionalAttrs (config.time.timeZone != null) { NIXOS_STATIC_TIMEZONE = "1"; };
|
|
|
|
|
|
|
|
environment.etc = {
|
|
|
|
zoneinfo.source = tzdir;
|
|
|
|
} // lib.optionalAttrs (config.time.timeZone != null) {
|
|
|
|
localtime.source = "/etc/zoneinfo/${config.time.timeZone}";
|
|
|
|
localtime.mode = "direct-symlink";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|