nixos-installer/modules
Niklas Gollenstede dd8fc696f4 improve installation scripting:
further improve scripting robustness, add fs.disks.devices.partitionDuringInstallation, ad fs.zfs.datasets.*.recursiveProps, add deploy-system-to-hetzner-vps install script
2023-05-02 02:13:24 +02:00
..
bootloader small fixes, esp. for cross-building 2023-02-05 22:59:39 +01:00
experiments upgrade to 22.11, add extlinux & hetzner-vps: 2022-12-28 16:43:16 +01:00
fs improve installation scripting: 2023-05-02 02:13:24 +02:00
hardware improve installation scripting: 2023-05-02 02:13:24 +02:00
patches improve installation scripting: 2023-05-02 02:13:24 +02:00
services upgrade to 22.11, add extlinux & hetzner-vps: 2022-12-28 16:43:16 +01:00
base.nix.md improve installation scripting: 2023-05-02 02:13:24 +02:00
default.nix init 2022-05-09 14:36:47 +02: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
vm-exec.nix.md improve installation scripting: 2023-05-02 02:13:24 +02:00

NixOS Modules

A NixOS module is a collection of any number of NixOS option definitions and value assignments to those or other options. While the set of imported modules, and thereby that of the defined options, is static (in this case starting with the modules passed to mkNixosSystem in ../flake.nix), the value assignments can generally be contingent on other values (as long as there are no logical loops), making for highly flexible system constructions. Since modules can't be imported (or excluded) dynamically, most modules have an enable option, which, if false, effectively disables whatever that module does.

Ultimately, the goal of a NixOS configuration is to build an operating system, which is basically a structured collection of program and configuration files. To that end, there are a number of pre-defined options (in nixpkgs) that collect programs, create and write configuration files (primarily in /etc), compose a boot loader, etc. Other modules use those options to manipulate how the system is built.

Template

Here is a skeleton structure for writing a new <module>.nix.md:

/*

# TODO: title

TODO: documentation

## Implementation

```nix
#*/# end of MarkDown, beginning of NixOS module:
dirname: inputs: { config, pkgs, lib, ... }: let inherit (inputs.self) lib; in let
    prefix = inputs.config.prefix;
    cfg = config.${prefix}.${TODO: name};
in {

    options.${prefix} = { ${TODO: name} = {
        enable = lib.mkEnableOption "TODO: what";
        # TODO: more options
    }; };

    config = lib.mkIf cfg.enable (lib.mkMerge [ ({
        # TODO: implementation
    }) ]);

}