mirror of
https://github.com/SebastianWendel/nixpkgs.git
synced 2024-09-21 04:49:01 +02:00
57 lines
2.1 KiB
Nix
57 lines
2.1 KiB
Nix
# Note that these schemas are defined by RFC-0125.
|
|
# This document is considered a stable API, and is depended upon by external tooling.
|
|
# Changes to the structure of the document, or the semantics of the values should go through an RFC.
|
|
#
|
|
# See: https://github.com/NixOS/rfcs/pull/125
|
|
{ config, pkgs, lib, children }:
|
|
let
|
|
schemas = {
|
|
v1 = rec {
|
|
filename = "boot.v1.json";
|
|
json =
|
|
pkgs.writeText filename
|
|
(builtins.toJSON
|
|
{
|
|
schemaVersion = 1;
|
|
|
|
kernel = "${config.boot.kernelPackages.kernel}/${config.system.boot.loader.kernelFile}";
|
|
kernelParams = config.boot.kernelParams;
|
|
initrd = "${config.system.build.initialRamdisk}/${config.system.boot.loader.initrdFile}";
|
|
initrdSecrets = "${config.system.build.initialRamdiskSecretAppender}/bin/append-initrd-secrets";
|
|
label = "NixOS ${config.system.nixos.codeName} ${config.system.nixos.label} (Linux ${config.boot.kernelPackages.kernel.modDirVersion})";
|
|
});
|
|
|
|
generator =
|
|
let
|
|
specialisationLoader = (lib.mapAttrsToList
|
|
(childName: childToplevel: lib.escapeShellArgs [ "--slurpfile" childName "${childToplevel}/bootspec/${filename}" ])
|
|
children);
|
|
in
|
|
''
|
|
mkdir -p $out/bootspec
|
|
|
|
${pkgs.jq}/bin/jq '
|
|
.toplevel = $toplevel |
|
|
.init = $init
|
|
' \
|
|
--sort-keys \
|
|
--arg toplevel "$out" \
|
|
--arg init "$out/init" \
|
|
< ${json} \
|
|
| ${pkgs.jq}/bin/jq \
|
|
--sort-keys \
|
|
'.specialisation = ($ARGS.named | map_values(. | first))' \
|
|
${lib.concatStringsSep " " specialisationLoader} \
|
|
> $out/bootspec/${filename}
|
|
'';
|
|
};
|
|
};
|
|
in
|
|
{
|
|
# This will be run as a part of the `systemBuilder` in ./top-level.nix. This
|
|
# means `$out` points to the output of `config.system.build.toplevel` and can
|
|
# be used for a variety of things (though, for now, it's only used to report
|
|
# the path of the `toplevel` itself and the `init` executable).
|
|
writer = schemas.v1.generator;
|
|
}
|