Repo for nix configuration files
Find a file
2023-08-15 11:17:58 +09:00
desktops Testing 2023-08-15 10:15:49 +09:00
home-manager Theming and docs 2023-08-15 11:05:06 +09:00
hosts Test 2023-08-15 11:17:58 +09:00
keys Update pubkeys 2023-07-05 13:09:33 +09:00
modules test 2023-08-14 20:49:57 +09:00
secrets Testing 2023-07-05 19:49:29 +09:00
services Rearrange and update 2023-07-12 23:41:12 +09:00
software test 2023-07-06 12:35:33 +09:00
users Test 2023-08-15 11:17:58 +09:00
.sops.yaml add machine to sops 2023-07-05 13:12:30 +09:00
configuration.nix test 2023-08-14 19:58:30 +09:00
flake.nix test 2023-08-14 21:42:32 +09:00
README.md Test 2023-08-15 11:17:58 +09:00

NixOS Configuration Repository

Repo for nix configuration files

To Do List

[ ] tmux config / theming [ ] waybar config / theming [ ] hyprland config / theming [ ] powerline config / theming [ ] nvidia drivers [ ] other things I'm probably forgetting


Information

Home Manager

  • Home Manager Documentation - Link
  • Home Manager Options Search - Link

NixOS

  • NixOS Documentation - Stable - Link
  • NixOS Packages / Options Search - Link
  • Nix User Repository (NUR) Search - Link
  • Tons of good examples here - Link
  • Track a Nixpkgs PR - Link
  • NixOS Flakes Intro Guide - Link

Theming

  • To change system-wide themes, you need to change the following:

gnome

  1. desktops/gnome.nix - Change the imports at the bottom.
  2. users/albert/gnome-dconf.nix - Change the theme variants in the following:
    • org/gnome/shell/extensions/nightthemeswitcher/gtk-variants
    • org/gnome/shell/extensions/nightthemeswitcher/icon-variants
    • org/gnome/shell/extensions/nightthemeswitcher/shell-variants

neovim

  1. home-manager/neovim.nix - Change the following:
    • plugins = with pkgs.vimPlugins - Add your theme under "Themes"
    • extraConfig - Change the colorscheme and AirlineTheme sections

tmux / powerline

  1. WIP

hyprland / waybar

  1. WIP

Firefox

  1. home-manager/firefox.nix - Change the entry under "# Theming"

GPG Keys

  1. Import the user private key: gpg import gpg/users/albert/privkey.asc

  2. Mark it as trusted: gpg --edit-key albert@sysctl.io, then type trust, then 5

  3. Import your GPG key albert.key

  4. Add it to your GPG Keyring via gpg --import albert.key

  5. Mark it as ultimately trusted via gpg --edit-key albert@sysctl.io, then type trust, then 5

  6. Repeat this step for all users who need a GPG key assigned

SOPS Secrets

  1. To edit a file: cd to /path/to/nix-files/ and run:
    • nix-shell -p sops --run "sops secrets/secret_file.yml
    • New shell alias: sops secrets/secret_file.yml
  2. Ensure your GPG keys are set up.

Lanzaboote / SecureBoot

  • Instructions here - Link
  1. Create your keys: sbctl create-keys
  2. Verify your machine is ready for SecureBoot: sbctl verify - Everything except *-bzImage.efi are signed
  3. Enter Secureboot Setup mode in your EFI Settings on the motherboard (F10)
    • Security -> SecureBoot -> Set to Enabled and "Reset to Setup Mode" and exit
  4. Enroll the keys: sbctl enroll-keys --microsoft
    • If you wish, you acan select --tpm-eventlog, but checksums will change later (ie, at a kernel rebuild)
  5. Reboot and verify you are activated: bootctl status

Other