Laptop, desktop, and home lab flake featuring Hyprland, Sway, declarative containers, a reverse proxy, and more.
Find a file
github-actions[bot] 7e8fbbf187 flake.lock: Update
Flake lock file updates:

• Updated input 'disko':
    'github:nix-community/disko/3b778f10eb275573da9f5c8a7a49e774200b87e5?narHash=sha256-FegyBabjV4868aJUbvFtqH0zKDEtUpeCAfnB1vWXeBg%3D' (2024-10-14)
  → 'github:nix-community/disko/a6a3179ddf396dfc28a078e2f169354d0c137125?narHash=sha256-MuojlSnwAJAwfhgmW8ZtZrwm2Sko4fqubCvReqbUzYw%3D' (2024-10-18)
• Updated input 'home-manager':
    'github:nix-community/home-manager/e1aec543f5caf643ca0d94b6a633101942fd065f?narHash=sha256-ZHFrGNWDDriZ4m8CA/5kDa250SG1LiiLPApv1p/JF0o%3D' (2024-10-14)
  → 'github:nix-community/home-manager/122f70545b29ccb922e655b08acfe05bfb44ec68?narHash=sha256-KVyQq%2Bez/oB30/WbdNgVD8g/bda34z8NiU187QKQb74%3D' (2024-10-19)
• Updated input 'jovian':
    'github:Jovian-Experiments/Jovian-NixOS/e4f4d7832cc559389b93798c1f0d615e3816f4ef?narHash=sha256-3IXvY30zzFq7lHFujMupPz3TiPXo8o8qiIjkXUvznCI%3D' (2024-10-11)
  → 'github:Jovian-Experiments/Jovian-NixOS/bb69165ff372ddbd3228a03513922acd783040e8?narHash=sha256-DdKal%2BZhB9QD/tnEwFg4cZ4j4YnrkvSljBxnyG%2B3eE0%3D' (2024-10-17)
• Updated input 'nix-gaming':
    'github:fufexan/nix-gaming/2c8d8bb698899ac978f0ccc7b88cf2229593dacc?narHash=sha256-pjYeBH3eGhjIYyaHJbSOsPZZkbfJ07dO55NAxv7FUNY%3D' (2024-10-14)
  → 'github:fufexan/nix-gaming/5646c9455e9edf9ef59998fc79b82c5d5818ce77?narHash=sha256-NZ0GGy0OMCVzEsdaqLnefGtXsUnjgoCI2pleIvAUvfI%3D' (2024-10-19)
• Updated input 'nixpkgs':
    'github:nixos/nixpkgs/5633bcff0c6162b9e4b5f1264264611e950c8ec7?narHash=sha256-9UTxR8eukdg%2BXZeHgxW5hQA9fIKHsKCdOIUycTryeVw%3D' (2024-10-09)
  → 'github:nixos/nixpkgs/4c2fcb090b1f3e5b47eaa7bd33913b574a11e0a0?narHash=sha256-/uilDXvCIEs3C9l73JTACm4quuHUsIHcns1c%2BcHUJwA%3D' (2024-10-18)
• Updated input 'nur':
    'github:nix-community/NUR/2a2df9f3b51412ac6e70860bc3af4484a66a24ff?narHash=sha256-%2BUyRru47QPULDQ%2BS0bFyxRgljSpdeitLi2fZJxHrNdI%3D' (2024-10-15)
  → 'github:nix-community/NUR/7661490458a1d3882813e7426c72b749dd52657f?narHash=sha256-STDv/8AfBc0gPGl/BqPthyECqV9g0iy85W0Y98P/0eI%3D' (2024-10-19)
2024-10-19 19:27:49 +00:00
.github/workflows pkgs: add rofi-bluetooth (#133) 2024-10-19 15:25:56 -04:00
_img README.md: update features and screenshots 2024-08-15 20:46:05 -04:00
common pkgs: add rofi-bluetooth (#133) 2024-10-19 15:25:56 -04:00
disko reuse disko configs where possible 2024-09-23 23:59:07 -04:00
flake clean-install: prompt for host 2024-07-17 11:07:29 -04:00
homeManagerModules easyeffect: add fw13-autogain preset 2024-10-15 23:10:37 -04:00
homes upgrade 24.05 -> unstable; add pacifidlog (#114) 2024-10-14 23:53:48 -04:00
hosts flake: reorg outputs (#132) 2024-10-19 14:43:33 -04:00
hwModules tree-wide: drop petalburg (#129) 2024-10-18 15:44:19 -04:00
nixosModules upgrade 24.05 -> unstable; add pacifidlog (#114) 2024-10-14 23:53:48 -04:00
overlays pkgs: add rofi-bluetooth (#133) 2024-10-19 15:25:56 -04:00
pkgs pkgs: add rofi-bluetooth (#133) 2024-10-19 15:25:56 -04:00
secrets tree-wide: drop petalburg (#129) 2024-10-18 15:44:19 -04:00
userModules tree-wide: drop petalburg (#129) 2024-10-18 15:44:19 -04:00
.envrc flake: add devShelland direnv 2024-09-05 22:41:27 -04:00
.gitignore flake: add devShelland direnv 2024-09-05 22:41:27 -04:00
.gitlab-ci.yml code cleanup (#47) 2024-07-18 21:05:35 -04:00
flake.lock flake.lock: Update 2024-10-19 19:27:49 +00:00
flake.nix pkgs: add rofi-bluetooth (#133) 2024-10-19 15:25:56 -04:00
LICENSE.md hosts: add READMEs (#50) 2024-07-20 19:41:51 -04:00
README.md README: update outputs 2024-10-19 15:09:06 -04:00

nixcfg

My comprehensive NixOS flake for managing my laptop, desktop, gaming handheld, and home lab environments.

Features

  • Hyprland: Dynamic tiling Wayland compositor and window manager.
  • SteamOS UI: Steam Big Picture Mode + gaming optimizations for Lenovo Legion Go.
  • Stylix: Auto-gnerated base16 themes for the whole desktop.
  • Encryption: Encrypted boot drives with Secure Boot and LUKS with TPM decryption.
  • Home Lab: Media, file sharing, and more, split between two PCs with efficient routing via reverse proxy.

Inputs

This flake takes a variety of upstream and third party flakes as inputs:

  • agenix: secrets storage and orchestration.
  • disko: declarative partitions and disk configuration.
  • home-manager: declarative dotfile and user package management.
  • hyprland: great dynamic tiling wayland compositor.
  • iio-hyprland: autorotate daemon for Hyprland.
  • jovian: steam deck UI + optimizations.
  • lanzaboote: secure boot for NixOS.
  • nur: extra packages from the nix user repository.
  • stylix: system-wide color schemes and typography.
  • sway: fantastic, rock-solid tiling compositor for wayland.

Outputs

  • homeManagerModules.aly: my home-manager config.
  • homeManagerModules.default: app modules + everything you need for a competent Hyprland desktop (and a few others).
  • homeManagerModules.dustin: my husband's home-manager config.
  • nixosModules.common: various common modules specific to my hosts.
  • nixosModules.nixos: opinionated desktop, app, and service options.
  • nixosModules.users: basic user configuration options.
  • overlays.default: adds every package output to nixpkgs.
  • overlays.rofi-bluetooth: overlays rofi-bluetooth with custom patches.
  • overlays.tablet: tablet optimizations, mainly for electron apps.

In addition, this flake outputs NixOS configurations, home-manager configurations, and various hardware modules for all of my hosts and users.

Deploying to NixOS

Each hardware configuration is host-specific. If you fork this repository, add a host configuration for your own hardware. Secrets are encrypted with agenix and will not be available without the private decryption keys.

Enabling Flakes

While widely used and considered stable, flakes are still considered experimental. To enable Flakes, add the following lines to your configuration.nix and rebuild.

nix.settings.experimental-features = [ "nix-command" "flakes" ];

Alternatively, pass --experimental-features "nix-command flakes" to nix to temporarily use flakes.

Building Flake

In order to deploy this Flake on your host, run the following command:

sudo nixos-rebuild boot --flake github:alyraffauf/nixcfg#$HOSTNAME

Substitute $HOSTNAME for whichever hostname you have chosen. Reboot to apply the flake's configuration for the chosen host.

Installing from Live USB

If you want to install NixOS from this flake, run the following commands, ideally from a NixOS live environment, providing the hostname associated with a NixOS configuration specified in flake.nix when prompted.

sudo nix --experimental-features "nix-command flakes" run github:alyraffauf/nixcfg