nixos-installer/lib/setup-scripts
2023-01-03 18:50:07 +01:00
..
add-key.sh upgrade to 22.11, add extlinux & hetzner-vps: 2022-12-28 16:43:16 +01:00
default.nix init 2022-05-09 14:36:47 +02:00
disk.sh fix gptfdisk, integrate some bash aliases 2023-01-03 18:50:07 +01:00
install.sh fix gptfdisk, integrate some bash aliases 2023-01-03 18:50:07 +01:00
keys.sh better CLI argument handling, some small fixes 2022-08-31 08:38:33 +02:00
maintenance.sh fix gptfdisk, integrate some bash aliases 2023-01-03 18:50:07 +01:00
README.md add hardware config for Raspberry PIs, start making scripts more robust, improve compatibility with containers 2022-11-30 13:41:21 +01:00
utils.sh add hardware config for Raspberry PIs, start making scripts more robust, improve compatibility with containers 2022-11-30 13:41:21 +01:00
zfs.sh upgrade to 22.11, add extlinux & hetzner-vps: 2022-12-28 16:43:16 +01:00

Host Setup Scripts

This is a library of bash functions, mostly for NixOS system installation.

The (paths to these) scripts are meant to be (and by default are) set as config.wip.setup.scripts.* (see ../flakes.nix), which makes their functions available in the per-host devShells/apps. Host-specific nix variables are available to the bash functions as @{...} through substituteImplicit with the respective host as root context. Any script passed later in scripts can overwrite the functions of these (earlier) default scripts.

With the functions from here, a simple three-liner is enough to do a completely automated NixOS installation:

function install-system {( set -eu # 1: diskPaths
    prepare-installer "$@"
    do-disk-setup "${argv[0]}"
    install-system-to $mnt
)}

install-system Documentation

For repositories that use the lib.wip.mkSystemsFlake Nix function in their flake.nix, the above bash function performs the automated installation of any nixosConfigurations.$HOSTs (where the host's configurations would usually be placed in the /hosts/ directory of the repository) to the local disk(s) (or image file(s)) $DISK. On a NixOS host or with a Nix multi-user installation, this can be run by root as: # nix run .#"$HOST" -- install-system "$DISK".

Doing an installation on non-NixOS (but Linux), where nix isn't installed for root, the process is a bit of a hack, but works as well. In this case, all nix commands will be run as $SUDO_USER, but this script and some other user-owned (or user-generated) code will (need to) be run as root. If that is acceptable, run with sudo as first argument: $ nix run .#"$HOST" -- sudo install-system "$DISK" (And then maybe sudo bash -c 'chown $SUDO_USER: '"$DISK" afterwards.)

If $DISK points to something in /dev/, then it is directly formatted and written to as block device, otherwise $DISK is (re-)created as raw image and then used as loop device. For hosts that install to multiple disks, pass a :-separated list of <disk-name>=<path> pairs (the name may be omitted only for the "default" disk).

Once done, the disk can be transferred -- or the image be copied -- to the final system, and should boot there. If the host's hardware target allows, a resulting image can also be passed to register-vbox to create a bootable VirtualBox instance for the current user, or to run-qemu to start it in a qemu VM.

The "Installation" section of each host's documentation should contain host specific details, if any.