configuration of all my nix based infrastructure
Find a file
2025-12-02 15:18:15 +01:00
.forgejo/workflows forgjo-actions: comment out for now 2025-11-30 03:27:20 +01:00
modules chore: reorganize 2025-12-02 15:18:15 +01:00
secrets security: start setting permissions on secrets properly 2025-12-02 01:18:47 +01:00
.gitattributes hydra: disable lfs until NixOs/hydra#1355 or similar is merged 2025-05-06 10:47:46 +02:00
.gitignore add .gitignore and switch to rebase strategy 2025-05-06 10:36:02 +02:00
.sops.yaml security: start setting permissions on secrets properly 2025-12-02 01:18:47 +01:00
flake.lock chore: update flake 2025-12-02 13:00:34 +01:00
flake.nix security: start setting permissions on secrets properly 2025-12-02 01:18:47 +01:00
LICENSE LICENCE: update 2025-10-28 10:02:38 +01:00
README.md README: a new dawn 2025-12-02 14:44:15 +01:00

Welcome to my infrastructure configuration

My configuration is based on Dendritic Nix and was heavily inspired by github:drupol/infra including taking some parts ad-verbatim.

How does it work?

The two main aspects are github:vic/import-tree and flake-parts

outputs = inputs: inputs.flake-parts.lib.mkFlake { inherit inputs; } (inputs.import-tree ./modules);

this lets us define our starting point in another file. In this case this would be host-machines There are many different approaches to this but I found drupols approach of parsing the module name interesting so I wanted to use it aswell. I extended mine by filtering my rpi configurations to be a bit different.

defining hosts

    flake.modules.nixos."hosts/yggdrasil" = { inputs, ... }: {
      ...

      # here comes the fun part:
      imports = with topLevel.config.flake.modules.nixos; [
        # this is where you add your self named modules that you want to use for this host
        # e.g
        base
        cholli
      ];
      # this will now evaluate thos modules and enable everything set up in them
    };

defining modules

What I quite like is that there is no needed structure in your modules folder. You can reorganize all you want, all that matters is that your modules are name exactly how you import them.

  # There are two types of modules you probably want to choose from
  flake.modules.nixos."<your name here>" # nixos base configuration

  flake.modules.home-manager."<your name here>" # home-manager configuration

  # additionally what I like to do is in your home modules make sure that the appropriate system module is enabled before you do something
  home.file = lib.mkIf osConfig.programs."<program name>".enable { ... };

WM of choice

A friend of mine introduced me to niri and I really like it configuration of that can be found under niri.nix I still use hyprpaper, and hyprlock because I was previously using hyprland and the still work perfectly fine. My bar of choice is waybar it is very minimalistic, and my current runner is fuzzel with I just use with a catppuccin theme.