Flake lock file updates: • Updated input 'hyprland': 'github:hyprwm/Hyprland/81f4a4f47182c15ee9436d9ab7b2e425a096ce5b' (2023-07-18) → 'github:hyprwm/Hyprland/7091d4e5979720ddb30f540b2d7da48080bf2487' (2023-07-19) • Updated input 'nil': 'github:oxalica/nil/e2fe1b0bebcc810a5e6c24c061d4d8dcc061a8fc' (2023-07-14) → 'github:oxalica/nil/59bcad0b13b5d77668c0c125fef71d7b41406d7a' (2023-07-19) • Updated input 'nix-rfc-92': 'github:obsidiansystems/nix/4f650501586104017d73cbfe41763c0fdf6d9e30' (2023-05-18) → 'github:obsidiansystems/nix/8ee84a8ca182505795d4eafe1dca564fd190d97b' (2023-07-19) • Updated input 'nixpkgs': 'github:NixOS/nixpkgs/53657afe29748b3e462f1f892287b7e254c26d77' (2023-07-17) → 'github:NixOS/nixpkgs/08700de174bc6235043cb4263b643b721d936bdb' (2023-07-18) • Updated input 'unstable': 'github:NixOS/nixpkgs/6cee3b5893090b0f5f0a06b4cf42ca4e60e5d222' (2023-07-16) → 'github:NixOS/nixpkgs/684c17c429c42515bafb3ad775d2a710947f3d67' (2023-07-18) |
||
---|---|---|
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.