Flake lock file updates: • Updated input 'hyprland': 'github:hyprwm/Hyprland/5b84b0fb445bc4485510bba516c84141aaeafd04' (2023-05-15) → 'github:hyprwm/Hyprland/642030f959efe7bd2692bf6a4236d4c1b39ee51a' (2023-05-16) • Updated input 'hyprpaper': 'github:hyprwm/hyprpaper/3596630a207a02a0035a0a178a1fdbf2a5f40a30' (2023-05-08) → 'github:hyprwm/hyprpaper/b82254e957cfa60124240e8d94e7368cbf6d392d' (2023-05-16) • Updated input 'hyprpaper/nixpkgs': 'github:NixOS/nixpkgs/9b97ad7b4330aacda9b2343396eb3df8a853b4fc' (2023-01-25) → 'github:NixOS/nixpkgs/1a411f23ba299db155a5b45d5e145b85a7aafc42' (2023-05-02) • Updated input 'nixpkgs': 'github:NixOS/nixpkgs/d41eea2839de7de0f2cbe4aa90fde5db8afcd30a' (2023-05-15) → 'github:NixOS/nixpkgs/55af203d468a6f5032a519cba4f41acf5a74b638' (2023-05-15) • Updated input 'unstable': 'github:NixOS/nixpkgs/0470f36b02ef01d4f43c641bbf07020bcab71bf1' (2023-05-14) → 'github:NixOS/nixpkgs/963006aab35e3e8ebbf6052b6bf4ea712fdd3c28' (2023-05-16) |
||
---|---|---|
home-manager-modules | ||
lib | ||
machines | ||
modules | ||
packages | ||
secrets | ||
users | ||
.sops.yaml | ||
base.nix | ||
flake.lock | ||
flake.nix | ||
LICENSE | ||
README.md |
My NixOS Configurations ❄
This repository contains the configurations of my machines using NixOS.
What is NixOS ?
NixOS is a linux distribution based on the Nix package manager. It allows fully reproducible builds and a declarative configuration style, using a functionnal langage called Nix (yes, it is the same name as the package manager and the OS).
What is a flake ?
This whole repository is a flake. It is an experimental feature of Nix, allowing for pure evaluation of code. Dependency are fully specified and locked.
How does this work ?
Machines
This project manage the configuration of three machines :
- Macintosh, a thinkpad laptop,
- Lisa, a high performance server,
- Newton, a low performance stockage server.
Machines configurations are located in the machines folder, and are using all the custom modules defined in this project.
Modules
This configuration defines a number of custom NixOS and home-manager modules. They are respectively defined in the modules and home-manager-modules folders.
Secrets
Secrets are stored in the secrets folder. They are uncrypted upon system activation using the host ssh key. Secrets are managed using nix-sops.
Inspirations
This project is freely inspired by some really cool projects, including MayNiklas/nixos, pinox/nixos and ncfavier/config.