nixos-config

❄️ NixOS configuration for personal use.

GPL-3.0 License

Stars
2
Committers
3

❄️ NixOS configuration ❄️

⭐ Star us on GitHub — it motivates us a lot!

🚀 About

My personal NixOS configuration file.

It contains hardware/software configurations for setting up my personal/work machines.

[!IMPORTANT] As of this moment, I haven't yet reached the point of deploying VMs using Nix, meaning that this configuration IS INTENDED TO BE USED FOR PERSONAL USE ONLY.

Please don't try to copy-paste the configuration on your own machine and try to understand it first for the following reasons:

  1. It simply won't work, due to the difference in hardware configuration between my machines and yours (for example gpu drivers, device IDs)
  2. You won't learn much doing that, and later when you want to change something in your config it'll be harder for you to achieve that
  3. This config structure is made by my personal taste, not yours ... and if some certain functionalities are either missing or badly implemented - then you would need to fork my repo and make your desired change in your version. Nevertheless, I'm more than open to suggestions for improvements, so please feel free to open an issue!

🏝️ Environment

Type Program
Editor NeoVim
Launcher Rofi
Shell Zsh
Status Bar i3status-rust
Terminal Alacritty
Window Manager I3WM
File Manager Nautilus
GTK Theme Kanagawa
GTK Icon Theme Rose-pine
Terminal Font OxProto Nerd Font

🧪 Used Nix features

  1. home-manager
  2. flakes

🏗️ Structure

.
├── archive
├── assets
├── config.nix
├── flake.lock
├── flake.nix
├── flakes
├── home
├── hosts
├── LICENSE
├── Makefile
├── programs
├── README.md
├── TODO.md
└── wallpaper.jpg
  • archive: not used in building the system. It stores the initial configuration of NixOS when first installed. (you can ignore this part)
  • assets: used for storing media files, related to markdown documentation
  • config.nix: An attribute set, containing all of the user and host specific configuration, that is consumed by the home and hosts module
  • flake.lock: auto generated file, when building the system along with an argument of --flake. Used for pinning down the specific versions of the Nix dependencies, that are listed under flake.nix
  • flake.nix: file for declaring all of the Nix specific dependencies/features (flake-parts, home-manager, nixpkgs, etc.). It is also the entry point for importing the user/system flakes
  • flakes: used for storing all of the modularized flakes, that is consumed by flake-parts
  • home: used for storing all the user environments (Joe's PC, Jane's PC, etc.)
  • hosts: used for storing the hardware specifications of the hosts machines
  • Makefile: automation script for aliasing Nix CLI commands in a more user-friendly way
  • programs: contains the user/system type of packages
  • wallpaper.jpg: background photo for i3wm

🧑‍💻 Commands

[!WARNING] Before starting to execute make commands, make sure to change the value of DEFAULT_USER to your preffered username, located in Makefile.

Command Description
make help Show available commands with their description
make home-update Build your home configuration
make sys-update-wl Build your system configuration for work laptop (Thinkpad p53)
make sys-update-pd Build your system configuration for personal desktop (AMD)
make flake-upgrade Upgrade flake dependencies
make flake-check Validate flake.nix
make flake-meta Output the flake input dependencies in a tree format
make clean Remove user generations
make clean-su Remove system generations
make show-gen Show all user generations
make deduplicate Optimize system libraries

🌱 Setup

[!CAUTION] The hardware specific configuration is most likely not going to properly work on your system, so please make sure after you install my configuration and immediately change the bootloader and file system values (located at config.nix) with your appropriate values!

  1. Work laptop
nixos-rebuild switch --flake github:iliyan-kostov9/nixos-config#hosts-work-laptop
  1. Desktop PC
nixos-rebuild switch --flake github:iliyan-kostov9/nixos-config#hosts-personal-desktop

Afterwards enter config.nix and change the values of the file system and bootloader to the ones you currently have. You can also change the default username to your preferred one.

🤝 Acknowledgments

This configuration structure was inspired by contributions from the Nix community:

🔍️ References

This section helped me better understand Nix package manager and Nix language. Please have a read on them!

📚 Docs

📄 Package and template links

🎨 Assets

📃 License

This product is licensed under GNU General Public License