mirror of
https://github.com/alyraffauf/nixcfg.git
synced 2025-11-02 00:23:58 -04:00
3
Tips & Tricks
Aly Raffauf edited this page 2024-06-10 19:57:09 -04:00
Table of Contents
Provisioning New Devices
- Create
hosts/$HOSTNAME/default.nixand other host-specific nix modules (e.g.disko.nix,hardware.nix, andhome.nix). - Add host to
nixosConfigurationsinflake.nix. - (OPTIONAL) Generate a
cert.pem,key.pem, and device ID for Syncthing withsyncthing -generate=$HOSTNAME. Find the device ID in the generatedconfig.xmland add it tonixosModules/services/syncthing/default.nix, encrypt the cert and key with agenix, and set them as appropriate in the host configuration. - Install NixOS from this flake. Secrets will not be available on first boot.
- Copy the new system's public SSH key (
/etc/ssh/ssh_host_ed25519_key.pub) to the host configuration (secrets/publicKeys/root_$HOSTNAME.pub). - Add the new public key to
secrets/secrets.nixand rekey all secrets withagenix --rekey. - Rebuild the new system from git. Secrets will be automatically decrypted and immediately available in
/run/agenix/. - (OPTIONAL) Generate a new user SSH key and add it to
nixosModules/users/default.nixin order to enable passwordless logins to other hosts.
Declarative WiFi Connections
WiFi networks can be configured declaratiely in nixosModules/system/wifi.nix using config.networking.networkmanager.ensureProfiles.profiles, provided by nixpkgs.
nm2nix can generate nix code for all WiFi networks currently configured in /etc/NetworkManager/system-connections/ and /run/NetworkManager/system-connections with the following command:
sudo su -c "cd /etc/NetworkManager/system-connections && nix --extra-experimental-features 'nix-command flakes' run github:Janik-Haag/nm2nix | nix --extra-experimental-features 'nix-command flakes' run nixpkgs#nixfmt-rfc-style"
Secrets (passwords, certificates, and identities) are supported, but must be declared and available as variables with agenix. They will be replaced upon activation with envsubst.
In short,
- Manually configure the WiFi network on one device.
- Export configuration to nix with
nm2nix. - Add secrets to
secrets/wifi.ageas variables (e.g.MYPSK=1234567890) - Edit the code generated by
nm2nixto reference$MYPSKinstead of directly declaring the WPA password. - Commit and push changes.
- Rebuild hosts as required to propogate your new WiFi configuration.