Flake lock file updates: • Updated input 'hyprland': 'github:hyprwm/Hyprland/2e6693fbb650dd2c9b7ad4b6d830899589504bda' (2023-08-03) → 'github:hyprwm/Hyprland/46cf4eb837c39255f24fa32b5a740c28ce1a324f' (2023-08-04) • Updated input 'hyprland/wlroots': 'gitlab:wlroots/wlroots/e8d545a9770a2473db32e0a0bfa757b05d2af4f3' (2023-07-24) → 'gitlab:wlroots/wlroots/c74f89d4f84bfed0284d3908aee5d207698c70c5' (2023-08-03) • Updated input 'nil': 'github:oxalica/nil/6f20ed411520aac06b456e31aab43cf10df231a2' (2023-08-02) → 'github:oxalica/nil/00eae58f256c6c7a09e9c9b72ac9fee5a98a17db' (2023-08-04) • Updated input 'nix-rfc-92': 'github:obsidiansystems/nix/1fe9512a42474bed9983c6dfc252961d89c3b75f' (2023-07-31) → 'github:obsidiansystems/nix/0809f826570cbfaffb6ff511ed3daf32a49349ef' (2023-08-04) • Updated input 'nixpkgs': 'github:NixOS/nixpkgs/bd836ac5e5a7358dea73cb74a013ca32864ccb86' (2023-08-01) → 'github:NixOS/nixpkgs/e9ca92b55bed47696cc7cc25d3f854a1e2e01f86' (2023-08-03) |
||
---|---|---|
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.