NixOS configuration flake for multiple hosts.
| distro | NixOS | 
| packages | nixos-unstable | 
| android | nix-on-droid | 
| package manager | lix | 
| secrets | sops-nixsops | 
| bootloader | systemd-bootuboot | 
| secureboot | lanzaboote | 
| kernel | linux-hardened | 
| auditing | auditd | 
| shell | bash | 
| filesystem | zfs | 
| networking | wpa_supplicant | 
| dns | unbound | 
| audio | pipewirepulseaudio | 
| web server | nginx | 
| media server | jellyfin | 
| display server | wayland | 
| compositor | swayfx | 
| bar | waybar | 
| widgets | eww | 
| launcher | rofi | 
| notifications | dunst | 
| terminal emulator | foot | 
| file manager | thunar | 
| pdf reader | zathura | 
| image viewer | swayimg | 
| media player | mpv | 
| browser | brave | 
| search engine | searxng | 
| bittorrent | qbittorrent-nox | 
| anonymity | i2pdoniux | 
| passwords | vaultwarden | 
| text editor | neovimvscodiumnanomousepadmicro | 
| version control | git | 
| development | rustpythongohaskell | 
| colorscheme | nord | 
| wallpapers | wallpapers | 
| gtk theme | Nordic-darker | 
| gtk icons | Nordzy-dark | 
| gtk cursor | Simp1e-Nord-Dark | 
| font | IBM Plex | 
| sandboxing | firejail | 
| virtualization | qemuvirt-managerdistrobox | 
| optimizations | auto-cpufreqtlppowertop | 
| resource monitor | btophtop | 
| clipboard | cliphist | 
| screenshots | grimshot | 
- 
laptoprole: Laptop configurationTo replicate just the desktop, see rice. 
- 
serverrole: Headless home server configuration
- 
droidrole: nix-on-droid configuration
Three images: minimal, gnome and plasma are included (for installation, recovery, etc.)
See images for more details.
Usage:
$ nixos [command] [args]
When run with no command, equivalent to:
$ nixos tree -I .git -I .local --filesfirst
When run with a command not listed below, the command is dispatched to $NIXOS_DIR:
$ nixos vi modules/common/firewall.nix
| Command | laptop | server | Description | 
|---|---|---|---|
| test | ✔ | ✔ | $ nixos testTest the current configuration. Does not create a boot entry. | 
| switch | ✔ | ✔ | $ nixos switchSwitch to the current configuration. Creates a boot entry. | 
| commit | ✔ | ✘ | $ nixos commitSwitch to and commit the current configuration. Creates a boot entry and a Git commit. | 
| update | ✔ | ✔ | $ nixos updateUpdate flake inputs in flake.lock. | 
| format | ✔ | ✔ | $ nixos formatFormat the flake using nixfmt. | 
| perms | ✔ | ✔ | $ nixos permsApply correct permissions to all files in the flake. | 
| purge | ✔ | ✔ | $ nixos purgeGarbage collect old generations. | 
| repair | ✔ | ✔ | $ nixos repairAttempt to repair the nix store. | 
| edit <vars|sops> | ✔ | ✔ | $ nixos edit varsEdit variables file. $ nixos edit sopsEdit sops-nix secrets. | 
| init <vars|sops> [replace] | ✔ | ✔ | $ nixos init varsInitialize variables. $ nixos init vars replaceReplace current variables. $ nixos init sopsInitialize secrets. $ nixos init sops replaceReplace current secrets. | 
| init lanzaboote <create|enroll> | ✔ | ✘ | $ nixos init lanzaboote createCreate lanzaboote keys. See setup docs. $ nixos init lanzaboote enrollEnroll lanzaboote keys. See setup docs. | 
| init impermanence | ✔ | ✘ | $ nixos init impermanencePopulate the /persistdirectory for impermanence. See setup docs. | 
| serverpush <path> | ✔ | ✘ | $ nixos serverpush /nixosPush the flake to server:/nixos. | 
| help | ✔ | ✔ | $ nixos helpShow this message and exit. | 
See scripts for some detailed examples.
