Laptop, desktop, and home lab flake featuring Hyprland, Sway, declarative containers, a reverse proxy, and more.
Find a file
2024-07-15 08:22:10 -04:00
.github/workflows github: use magix nix cache 2024-07-15 08:22:10 -04:00
_img README: update screenshot 2024-07-03 16:27:34 -04:00
baseModules restructure flake (#14) 2024-07-09 19:17:53 -04:00
flake flake/clean-install: reformat 2024-07-09 23:34:43 -04:00
homeManagerModules home/hyprland: don't include clamshell script if no laptopMonitors exist 2024-07-15 07:53:04 -04:00
homes aly,dustin: remove unnecessary monitor 2024-07-15 07:45:21 -04:00
hosts home/hyprland: remove monitor + tablet config from module (#30) 2024-07-15 00:14:18 -04:00
nixosModules migrate mkOption to mkPackageOption 2024-07-12 20:50:01 -04:00
secrets drop mandarin (#15) 2024-07-09 20:55:45 -04:00
userModules drop mandarin 2024-07-09 20:29:45 -04:00
.gitignore add .gitignore 2024-04-02 17:48:27 -04:00
.gitlab-ci.yml gitlab: fix repo name 2024-07-10 21:00:11 -04:00
flake.lock switch to latest generation on autoupgrade (#29) 2024-07-14 18:19:05 -04:00
flake.nix use hyprland from nixpkgs (#16) 2024-07-10 18:28:43 -04:00
LICENSE.md Create LICENSE.md 2024-03-09 11:58:37 -05:00
README.md Update NixOS wiki link (#17) 2024-07-13 09:20:12 -04:00

nixcfg

NixOS flake for all mine + my family's hosts, including modules for Hyprland, Sway, GNOME, and more.

Inputs

This flake takes a variety of inputs, first and foremost my other flakes:

  • nixhw: opinionated set of generic (AMD, Intel, Laptop, SSD) and specific (Framework 13, Yoga 9i, Thinkpad T440p) hardware configuration modules for NixOS.
  • raffauflabs: everything (containers, services, nginx, etc) that makes my home lab a home lab.

As well as upstream third-party projects that I use for various tasks:

  • 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.
  • nixvim: helpful neovim modules.
  • nur: extra packages from the nix user repository.

Outputs

  • homeManagerModules.default: app modules + everything you need for a competent Hyprland desktop (and a few others).
  • nixosModules.base: opinionated basic system configuration.
  • nixosModules.nixos: opinionated desktop, app, and service modules.
  • nixosModules.users: basic user configuration for three users.

In addition, this flake outputs NixOS configuration and home-manager configurations for all of my hosts and users, respectively.

Rice

Deploying to NixOS

🔴 Do not deploy this flake unmodified to your machine. It won't work. This is my own NixOS and home-manager flake for my personal devices. 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

🔴 This will erase your computer's disk as specified by the host configuration, installing a fresh copy of NixOS. Backup first!

If you want to install NixOS from this flake, run the following commands, ideally from a NixOS live environment, substituting $HOSTNAME with a NixOS configuration specified in flake.nix.

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