Go to file
2021-12-26 16:02:57 +08:00
hosts Add modules.desktop.wine option 2021-12-25 22:31:12 +08:00
lib Make miscellaneous updates :) 2021-12-26 16:02:57 +08:00
modules Make miscellaneous updates :) 2021-12-26 16:02:57 +08:00
pkgs gnome-shell-extension-desktop-cube: init at 5 2021-12-21 14:27:13 +08:00
secrets Improve backup service 2021-12-19 17:37:22 +08:00
shells Add shell for Hugo development 2021-12-16 17:16:31 +08:00
users Make miscellaneous updates :) 2021-12-26 16:02:57 +08:00
.editorconfig Update package set and documentation 2021-11-29 18:27:56 +08:00
.gitignore Rewrite as a flake 2021-11-25 19:55:30 +08:00
.gitmodules Move the dotfiles to 'foo-dogsquared' user 2021-12-06 18:41:14 +08:00
flake.lock Update flake config and inputs 2021-12-18 17:41:45 +08:00
flake.nix Update flake and users config 2021-12-19 17:39:18 +08:00
Makefile Update our host and user config 2021-12-02 22:02:29 +08:00
README.adoc Update documentation 2021-12-21 14:29:27 +08:00

This is my NixOS config as a Nix flake.

I finally have some time trying to grok flakes and redo my NixOS config from scratch after leaving it for some time (because I have work and have to quickly set things up without me trying to debug how NixOS works). Here is the result.

Installation

Since this uses Nix flakes, you should have Nix v2.4 and above installed.

This primarily uses Nix flakes so you can have a preview of whats available in my config.

nix flake show github:foo-dogsquared/nixos-config

It should export my NixOS configurations of my different hosts (of only one so far excluding VMs and VPSs ;p) among other things. To install it, run the nixos-install --flake github:foo-dogsquared/nixos-config#ni. (Please see the respective appropriate host README for more information.)

Project structure

My NixOS config should look like the following:

nixos-config
├── hosts/
├── lib/
├── modules/
├── pkgs/
├── secrets/
├── shells/
├── users/
├── flake.lock
├── flake.nix
└── README.adoc
  • ./hosts/ contain machine-specific configuration. This usually configures like the hardware setup, timezone, and users. Host configurations are also exported in the flakes in outputs.nixosConfigurations.

  • ./modules/ contain my custom modules including NixOS and home-manager modules. For more information, see the related documentation.

  • ./pkgs/ contains my custom packages. It is exported in the flakes at outputs.packages compiled through various systems.

  • ./secrets/ contains my secrets managed with agenix. [1]

  • ./shells/ contains my development shells for interacting with the usual type of projects. Setting this up can bring benefits outside of NixOS (unless youre interacting with projects with any OpenGL-related stuff). [2]

  • ./users/ contains my home-manager configurations and modules. It is exported in the flakes at outputs.homeConfigurations. For more information, see the related documentation.

TODO

In order of priority:

  • ✓ Create custom modules.

  • ✓ Create a themes system similar to this NixOS config.

  • ✓ Create development shells.

  • ✓ Manage secrets with agenix.

  • ✓ Automate backups with NixOS config.

  • ✓ Create custom packages and export it to flakes. (Maybe consider making it to upstream)

  • ✓ Create cluser-wide configs.

  • ✓ Create host-wide configs.

  • ✓ Create user-specific configs with home-manager.

  • Steal Get some ideas from this overengineered template.

  • ✓ Make use of other established utilities such as digga, flake-utils-plus, and home-manager once Im familiar to create my own Nix programs.

Out of scope:

  • Text editor configurations. They are often updated. I dont want to rebuild it every time I change it.

  • Migration of my dotfiles. I still use it on other non-NixOS systems.

Frequently asked questions (FAQ)

  1. Hello! Im new to Nix and NixOS, where should I start?

    Oh no, youve seen the multiple configurations from other systems, didnt you? I hope youre ready for some time understanding because the learning curve is steeper than the Troll Wall. Ive written a blog post regarding my experience with Nix with a bunch of links for getting started. (Un)Fortunately, it is mostly the same experience now that Ive revisited it.

  2. Any requirements for this setup?

    You only need Nix 2.4 installed with the experimental features for Nix command and flakes enabled (i.e., experimental-features = nix-command flakes).

Inspirations

I stole got the ideas from the following projects:


1. It is advised you should minimize SSH keys with passphrases since it is annoying to reenter passwords every time.
2. Since packages brought from Nix shells can only work with the store, a container might be better at some situations.