2021-12-05 19:40:24 +00:00
|
|
|
|
{ config, lib, options, pkgs, ... }:
|
2012-04-10 20:56:38 +00:00
|
|
|
|
|
2014-04-14 14:26:48 +00:00
|
|
|
|
with lib;
|
2012-04-10 20:56:38 +00:00
|
|
|
|
|
2015-09-18 13:46:47 +00:00
|
|
|
|
let
|
2017-04-01 00:00:00 +00:00
|
|
|
|
cfg = config.system.nixos;
|
2021-12-05 19:40:24 +00:00
|
|
|
|
opt = options.system.nixos;
|
2015-09-18 13:46:47 +00:00
|
|
|
|
in
|
|
|
|
|
|
2012-04-10 20:56:38 +00:00
|
|
|
|
{
|
2019-12-10 01:51:19 +00:00
|
|
|
|
imports = [
|
|
|
|
|
(mkRenamedOptionModule [ "system" "nixosVersion" ] [ "system" "nixos" "version" ])
|
|
|
|
|
(mkRenamedOptionModule [ "system" "nixosVersionSuffix" ] [ "system" "nixos" "versionSuffix" ])
|
|
|
|
|
(mkRenamedOptionModule [ "system" "nixosRevision" ] [ "system" "nixos" "revision" ])
|
|
|
|
|
(mkRenamedOptionModule [ "system" "nixosLabel" ] [ "system" "nixos" "label" ])
|
|
|
|
|
];
|
2012-04-10 20:56:38 +00:00
|
|
|
|
|
2018-07-25 20:22:54 +00:00
|
|
|
|
options.system = {
|
2013-01-16 13:40:41 +00:00
|
|
|
|
|
2018-07-25 20:22:54 +00:00
|
|
|
|
nixos.version = mkOption {
|
2013-10-23 14:59:33 +00:00
|
|
|
|
internal = true;
|
2013-10-30 10:02:04 +00:00
|
|
|
|
type = types.str;
|
2016-07-28 16:27:03 +00:00
|
|
|
|
description = "The full NixOS version (e.g. <literal>16.03.1160.f2d4ee1</literal>).";
|
2012-04-10 20:56:38 +00:00
|
|
|
|
};
|
2012-05-17 21:10:42 +00:00
|
|
|
|
|
2018-07-25 20:22:54 +00:00
|
|
|
|
nixos.release = mkOption {
|
2015-07-30 11:36:57 +00:00
|
|
|
|
readOnly = true;
|
2015-07-27 17:46:36 +00:00
|
|
|
|
type = types.str;
|
2018-04-26 08:31:05 +00:00
|
|
|
|
default = trivial.release;
|
2016-07-28 16:27:03 +00:00
|
|
|
|
description = "The NixOS release (e.g. <literal>16.03</literal>).";
|
2015-07-27 17:46:36 +00:00
|
|
|
|
};
|
|
|
|
|
|
2018-07-25 20:22:54 +00:00
|
|
|
|
nixos.versionSuffix = mkOption {
|
2013-10-23 14:59:33 +00:00
|
|
|
|
internal = true;
|
2013-10-30 10:02:04 +00:00
|
|
|
|
type = types.str;
|
2018-04-26 08:31:05 +00:00
|
|
|
|
default = trivial.versionSuffix;
|
2016-07-28 16:27:03 +00:00
|
|
|
|
description = "The NixOS version suffix (e.g. <literal>1160.f2d4ee1</literal>).";
|
2013-01-16 13:40:41 +00:00
|
|
|
|
};
|
|
|
|
|
|
2018-07-25 20:22:54 +00:00
|
|
|
|
nixos.revision = mkOption {
|
2013-10-24 17:58:34 +00:00
|
|
|
|
internal = true;
|
2020-02-10 14:25:44 +00:00
|
|
|
|
type = types.nullOr types.str;
|
|
|
|
|
default = trivial.revisionWithDefault null;
|
2016-07-28 16:27:03 +00:00
|
|
|
|
description = "The Git revision from which this NixOS configuration was built.";
|
2013-10-24 17:58:34 +00:00
|
|
|
|
};
|
|
|
|
|
|
2018-07-25 20:22:54 +00:00
|
|
|
|
nixos.codeName = mkOption {
|
2015-07-30 11:36:57 +00:00
|
|
|
|
readOnly = true;
|
2013-10-30 10:02:04 +00:00
|
|
|
|
type = types.str;
|
2019-02-03 20:10:12 +00:00
|
|
|
|
default = trivial.codeName;
|
2016-07-28 16:27:03 +00:00
|
|
|
|
description = "The NixOS release code name (e.g. <literal>Emu</literal>).";
|
2013-07-17 11:34:40 +00:00
|
|
|
|
};
|
|
|
|
|
|
2017-04-01 00:00:00 +00:00
|
|
|
|
stateVersion = mkOption {
|
|
|
|
|
type = types.str;
|
|
|
|
|
default = cfg.release;
|
2021-12-05 19:40:24 +00:00
|
|
|
|
defaultText = literalExpression "config.${opt.release}";
|
2017-04-01 00:00:00 +00:00
|
|
|
|
description = ''
|
|
|
|
|
Every once in a while, a new NixOS release may change
|
|
|
|
|
configuration defaults in a way incompatible with stateful
|
|
|
|
|
data. For instance, if the default version of PostgreSQL
|
|
|
|
|
changes, the new version will probably be unable to read your
|
2020-01-07 21:27:03 +00:00
|
|
|
|
existing databases. To prevent such breakage, you should set the
|
2017-04-01 00:00:00 +00:00
|
|
|
|
value of this option to the NixOS release with which you want
|
2020-01-07 21:27:03 +00:00
|
|
|
|
to be compatible. The effect is that NixOS will use
|
2017-04-01 00:00:00 +00:00
|
|
|
|
defaults corresponding to the specified release (such as using
|
|
|
|
|
an older version of PostgreSQL).
|
2020-01-07 21:27:03 +00:00
|
|
|
|
It‘s perfectly fine and recommended to leave this value at the
|
|
|
|
|
release version of the first install of this system.
|
|
|
|
|
Changing this option will not upgrade your system. In fact it
|
|
|
|
|
is meant to stay constant exactly when you upgrade your system.
|
|
|
|
|
You should only bump this option, if you are sure that you can
|
|
|
|
|
or have migrated all state on your system which is affected
|
|
|
|
|
by this option.
|
2017-04-01 00:00:00 +00:00
|
|
|
|
'';
|
|
|
|
|
};
|
|
|
|
|
|
2015-09-18 13:46:47 +00:00
|
|
|
|
defaultChannel = mkOption {
|
2013-10-24 13:09:00 +00:00
|
|
|
|
internal = true;
|
2013-10-30 10:02:04 +00:00
|
|
|
|
type = types.str;
|
2020-04-01 01:11:51 +00:00
|
|
|
|
default = "https://nixos.org/channels/nixos-unstable";
|
2013-10-24 13:09:00 +00:00
|
|
|
|
description = "Default NixOS channel to which the root user is subscribed.";
|
|
|
|
|
};
|
|
|
|
|
|
2019-09-13 16:58:40 +00:00
|
|
|
|
configurationRevision = mkOption {
|
|
|
|
|
type = types.nullOr types.str;
|
|
|
|
|
default = null;
|
|
|
|
|
description = "The Git revision of the top-level flake from which this configuration was built.";
|
|
|
|
|
};
|
|
|
|
|
|
2012-05-17 21:10:42 +00:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
config = {
|
|
|
|
|
|
2017-04-01 00:00:00 +00:00
|
|
|
|
system.nixos = {
|
2015-09-18 16:50:48 +00:00
|
|
|
|
# These defaults are set here rather than up there so that
|
|
|
|
|
# changing them would not rebuild the manual
|
2017-04-01 00:00:00 +00:00
|
|
|
|
version = mkDefault (cfg.release + cfg.versionSuffix);
|
2015-09-18 13:46:47 +00:00
|
|
|
|
};
|
2013-07-17 11:34:40 +00:00
|
|
|
|
|
2012-05-17 21:10:42 +00:00
|
|
|
|
# Generate /etc/os-release. See
|
2017-01-07 16:28:11 +00:00
|
|
|
|
# https://www.freedesktop.org/software/systemd/man/os-release.html for the
|
2012-05-17 21:10:42 +00:00
|
|
|
|
# format.
|
2019-08-13 21:52:01 +00:00
|
|
|
|
environment.etc.os-release.text =
|
2013-10-31 22:01:07 +00:00
|
|
|
|
''
|
|
|
|
|
NAME=NixOS
|
|
|
|
|
ID=nixos
|
2021-07-29 14:12:23 +00:00
|
|
|
|
VERSION="${cfg.release} (${cfg.codeName})"
|
2017-04-01 00:00:00 +00:00
|
|
|
|
VERSION_CODENAME=${toLower cfg.codeName}
|
2021-07-29 14:12:23 +00:00
|
|
|
|
VERSION_ID="${cfg.release}"
|
|
|
|
|
BUILD_ID="${cfg.version}"
|
2019-12-02 19:04:44 +00:00
|
|
|
|
PRETTY_NAME="NixOS ${cfg.release} (${cfg.codeName})"
|
2019-01-05 05:03:39 +00:00
|
|
|
|
LOGO="nix-snowflake"
|
2017-02-25 21:15:45 +00:00
|
|
|
|
HOME_URL="https://nixos.org/"
|
2020-04-21 22:16:22 +00:00
|
|
|
|
DOCUMENTATION_URL="https://nixos.org/learn.html"
|
|
|
|
|
SUPPORT_URL="https://nixos.org/community.html"
|
2017-02-25 21:15:45 +00:00
|
|
|
|
BUG_REPORT_URL="https://github.com/NixOS/nixpkgs/issues"
|
2013-10-31 22:01:07 +00:00
|
|
|
|
'';
|
2013-01-16 13:40:41 +00:00
|
|
|
|
|
2012-04-10 20:56:38 +00:00
|
|
|
|
};
|
|
|
|
|
|
2021-11-18 23:26:27 +00:00
|
|
|
|
# uses version info nixpkgs, which requires a full nixpkgs path
|
|
|
|
|
meta.buildDocsInSandbox = false;
|
2012-04-10 20:56:38 +00:00
|
|
|
|
}
|