2e4849b841
For interactive SSH access to a system without a (working) keyboard and monitor, without rebuilding the image itself.
45 lines
1.1 KiB
Nix
45 lines
1.1 KiB
Nix
# This module contains the basic configuration for building a NixOS
|
|
# installation CD.
|
|
|
|
{ config, lib, options, pkgs, ... }:
|
|
|
|
with lib;
|
|
|
|
{
|
|
imports =
|
|
[ ./iso-image.nix
|
|
|
|
# Profiles of this basic installation CD.
|
|
../../profiles/all-hardware.nix
|
|
../../profiles/base.nix
|
|
../../profiles/installation-device.nix
|
|
];
|
|
|
|
# Adds terminus_font for people with HiDPI displays
|
|
console.packages = options.console.packages.default ++ [ pkgs.terminus_font ];
|
|
|
|
# ISO naming.
|
|
isoImage.isoName = "${config.isoImage.isoBaseName}-${config.system.nixos.label}-${pkgs.stdenv.hostPlatform.system}.iso";
|
|
|
|
# EFI booting
|
|
isoImage.makeEfiBootable = true;
|
|
|
|
# USB booting
|
|
isoImage.makeUsbBootable = true;
|
|
|
|
# Add Memtest86+ to the CD.
|
|
boot.loader.grub.memtest86.enable = true;
|
|
|
|
boot.postBootCommands = ''
|
|
for o in $(</proc/cmdline); do
|
|
case "$o" in
|
|
live.nixos.passwd=*)
|
|
set -- $(IFS==; echo $o)
|
|
echo "nixos:$2" | ${pkgs.shadow}/bin/chpasswd
|
|
;;
|
|
esac
|
|
done
|
|
'';
|
|
|
|
system.stateVersion = mkDefault "18.03";
|
|
}
|