config | ||
hosts | ||
keys | ||
modules | ||
modules-hm | ||
nix | ||
pkgs | ||
secrets | ||
users | ||
.envrc | ||
.gitignore | ||
flake.lock | ||
flake.nix | ||
README.md | ||
statix.toml | ||
STRUCTURE.md |
Meine wundervolle nix config ❄️
Hosts
Name | Device | Description | |
---|---|---|---|
💻 | patricknix | HP spectre x360 | Patrick's laptop, mainly used for on the go university |
🖥️ | desktopnix | Intel i5-8600K NVIDIA GeForce GTX 1080 32 GiB RAM |
Patrick's desktop, used for most development and gaming |
🖥️ | elisabeth | AMD Ryzen 7 5800X 32 GiB RAM |
Server running most cloud services |
🖥️ | maddy | Hetzner VPS | Static IP server running mail |
User Configuration
This showcases my end user setup, which I dailydrive on all my hosts.
Programm | Description | |
---|---|---|
🐚 Shell | ZSH & Starship | ZSH with FZF autocomplete, starship prompt, sqlite history and histdb-skim for fancy reverse search |
🪟 WM | Sway & i3 | Tiling window managers with similar behaviour for wayland and xorg |
🖼️ Styling | Stylix | globally consistent styling |
📝 Editor | NeoVim | Extensively configured neovim |
🎮 Gaming | Bottles & Steam | Pew, Pew and such |
🌐 Browser | Firefox | Heavily configured Firefox to still my privacy and security needs |
💻 Terminal | Kitty | fast terminal |
🎵 Music | Spotify | Fancy looking spotify using spicetify |
Thunderbird | Best email client there is | |
🎛️ StreamDeck | StreamDeck | More hotkeys = more better |
Service Configuration
These are services I've set up
Programm | Description | |
---|---|---|
💸 Budgeting | FireflyIII | Self Hosted budgeting tool |
🛡️ AdBlock | AdGuard Home | DNS Adblocker |
🔨 Git | Forgejo | Selfhosted GitHub alternative |
📸 Photos | Immich | Selfhosted Google Photos equivalent |
🔒 SSO | Kanidm | Secure single sign on Identity Provider |
Maddy | All in one mail server | |
🎧 Communication | Teamspeak | Selfhosted teamspeak server for secure and always available communication |
🌐 VPN | Netbird | Easy to use peer to peer VPN solution based on wireguard |
🌧️ Cloud | NextCloud | All in one cloud solution providing online File storage as well as notes, contacts and calendar synchronization |
🗄️ Documents | Paperless | Machine learnig supported document organizing plattform |
📁 NAS | Samba | Local network shared storage |
📰 Feedreader | freshRSS | hosted RSS feed aggregator |
🔑 Passwords | Vaultwarden | Self hosted bitwarden server |
🎵 Music | Your Spotify | Spotify listening habits analyzer |
External dependencies
These are notable external flakes which this config depend upon
Name | Usage |
---|---|
NixVim | NeoVim using nix |
MicroVM | Declarative VMs |
Disko | disk partitioning |
nixos-generators | generate installers |
home-manager | user config |
agenix | secret files for nix |
agenix-rekey | secret files that are git commitable |
nixos-nftables-firewall | nftables based firewall |
impermanence | stateless filesystem |
lanzaboote | Secure Boot |
stylix | theming |
spicetify | spotify looking fancy |
How-To
Add additional hosts
- Add host definition to
hosts.toml
- Create host configuration in
hosts/<name>
- Create and fill
default.nix
- Fill
net.nix
- Fill
fs.nix
- Don't forget to add necessary config for filesystems, etc.
- Create and fill
- Generate ISO image using
nix build --print-out-paths --no-link .#images.<target-system>.live-iso
- This might take multiple minutes(~10)
- Alternatively boot an official nixos image connect with password
- Copy ISO to usb using dd
- After booting copy the installer to the live system using
nix copy --to <target> .#nodes.<target-system>.config.system.build.installFromLive
- Run the installer script from the nix store of the live system
- you can get the path using
nix path-info .#nodes.<target-system>.config.system.build.installFromLive
- you can get the path using
- Export all zpools and reboot into system
- Retrieve hostkeys using
ssh-keyscan <host> | grep -o 'ssh-ed25519.*' > host/<target>/secrets/host.pub
- Deploy system
Add secureboot to new systems
- generate keys with
sbct create-keys
- tar the resulting folder using
tar cvf secureboot.tar -C /etc/secureboot .
- Copy the tar to local using scp and encrypt it using rage
rage -e -R ./secrets/recipients.txt secureboot.tar -o <host>/secrets/secureboot.tar.age
- safe the encrypted archive to
hosts/<host>/secrets/secureboot.tar.age
- DO NOT forget to delete the unecrypted archives
- Deploy your system with lanzaboote enabled
- link
/run/secureboot
to/etc/secureboot
- This is necesarry since for your this apply the rekeyed keys are not yet available but already needed for signing the boot files
- link
- ensure the boot files are signed using
sbctl verify
- Now reboot the computer into BIOS and enable secureboot, this may include removing any existing old keys
- bootctl should now read
Secure Boot: disabled (setup)
- you can now enroll your secureboot keys using
sbctl enroll-keys
If you want to be able to boot microsoft signed images append--microsoft
- Time to reboot and pray
Add luks encryption TPM keys
systemd-cryptenroll --tpm2-with-pin={yes/no} --tpm2-device=auto <device>
Deploy from new host
If deploying from a host not containing the necessary nix configuration option append
--nix-option plugin-files "$NIX_PLUGINS"/lib/nix/plugins --nix-option extra-builtins-file ./nix/extra-builtins`