Modular NixOS configuration.
Find a file
caem 393071371b
Mark the vendored ags configuration files as such
This is actually so that GitHub doesn't increase the Soyscript
percentage in the language summary, because that is embarassing.
2024-05-30 19:46:24 +02:00
assets Add screenshot 2024-05-26 01:04:56 +02:00
machines/workstation Add Minecraft 2024-05-30 19:34:57 +02:00
packages Update the ags configuration 2024-05-30 19:45:14 +02:00
users/hu Update the ags configuration 2024-05-30 19:45:14 +02:00
.gitattributes Mark the vendored ags configuration files as such 2024-05-30 19:46:24 +02:00
.gitignore Replace legacy configuration with the new 2024-04-04 01:41:19 +02:00
flake.lock Update flake.lock 2024-05-30 19:34:12 +02:00
flake.nix Refactor the entire configuration 2024-05-24 21:33:00 +02:00
README.md Add screenshot 2024-05-26 01:04:56 +02:00

nixos-system-config

My NixOS configuration.

About

This is the NixOS configuration that I daily drive on my system. Feel free to use, modify and share this configuration to your heart's content, no attribution required.

Screenshots

Wallpaper modified with gruvbox-factory.

Screeenshot

Layout

├── assets                              ; Images used by the config and repo
│   └── wallpaper.png
├── flake.lock
├── flake.nix                           ; Entry point
├── machines                            ; Machine specific configuration
│   └── workstation
│       ├── configuration.nix
│       ├── hardware-configuration.nix  ; Modified hardware configuration
│       └── persist.nix                 ; Impermanence configuration
├── packages                            ; Sets of packages to install and configure
│   ├── sets
│   │   ├── games.nix
│   │   └── ...
│   └── wm                              ; Package sets and basic config for WM and DE
│       ├── hyprland.nix
│       └── ...
├── README.md
├── secrets                             ; Git ignored folder to store confidentials
│   └── hu
│       └── pass                        ; Hashed password file for user
└── users
    └── hu                              ; User specific configuration
        ├── packages                    ; Package configurations
        │   ├── firefox.nix             ; Configurations can be for NixOS or home-manager
        │   ├── ...
        │   └── zsh
        │       ├── config              ; Non-nix package config directory
        │       │   └── conf.d
        │       ├── zsh-home.nix        ; For home-manager
        │       └── zsh.nix             ; For NixOS
        ├── persist.nix                 ; Impermanence configuration for the user
        └── user.nix

Installing

This configuration uses impermanence with btrfs snapshots so you'll have to partition your system in a certain way.

First you'll need this partition layout, assuming you're installing on nvme0n1.

DEVICE              FILESYSTEM      PURPOSE
/dev/nvme0n1
├─/dev/nvme0n1p1    vfat            EFI partition
└─/dev/nvme0n1p2    btrfs           Partition to house all the subvolumes

Inside of the btrfs root volume we're going to need 2 subvolumes.

SUBVOLUME           MOUNT           PURPOSE
root                /               Impermanent data
nix                 /nix            Permanent data

You'll also need to create a read-only snapshot of the root subvolume and call it root-blank.

After you've mounted all the subvolumes and EFI partition (/boot) in /mnt clone this repository in to /mnt/nix/config. Adjust all the block ids of the partitions in hardware-configuration.nix and create a hashed password using mkpasswd and store it in the secrets/{user} directory as pass.

Finally, in the config directory run nixos-install --flake '.#', reboot and you're done.