infrastructure/flake.nix

185 lines
5.5 KiB
Nix
Raw Normal View History

2022-12-19 22:35:54 +00:00
{
2022-12-20 10:33:21 +00:00
description = "Laureηt's infrastructure";
2022-12-19 22:35:54 +00:00
2024-01-12 16:02:47 +00:00
# TODO: luks encrypt cesium (dropbear ?)
# TODO: setup disko sur silicium
2023-11-29 14:40:36 +00:00
2022-12-19 22:35:54 +00:00
inputs = {
# core stuff
nixpkgs = {
2024-01-16 16:39:00 +00:00
url = "github:NixOS/nixpkgs/nixos-unstable";
# url = "git+file:///home/laurent/Documents/github.com/NixOS/nixpkgs?shallow=1";
};
2023-11-29 14:40:36 +00:00
home-manager = {
url = "github:nix-community/home-manager";
inputs.nixpkgs.follows = "nixpkgs";
2023-04-23 13:38:34 +00:00
};
systems = {
url = "github:nix-systems/default-linux";
};
2023-04-23 13:38:34 +00:00
# modules
flake-parts = {
url = "github:hercules-ci/flake-parts";
inputs.nixpkgs-lib.follows = "nixpkgs";
};
agenix = {
2024-01-13 14:55:00 +00:00
url = "github:ryantm/agenix";
2023-08-27 13:59:18 +00:00
inputs.nixpkgs.follows = "nixpkgs";
2024-01-13 14:55:00 +00:00
inputs.home-manager.follows = "home-manager";
inputs.systems.follows = "systems";
};
disko = {
url = "github:nix-community/disko";
inputs.nixpkgs.follows = "nixpkgs";
};
nixos-anywhere = {
url = "github:nix-community/nixos-anywhere";
inputs.nixpkgs.follows = "nixpkgs";
inputs.flake-parts.follows = "flake-parts";
};
treefmt-nix = {
url = "github:numtide/treefmt-nix";
inputs.nixpkgs.follows = "nixpkgs";
};
lanzaboote = {
url = "github:nix-community/lanzaboote";
# inputs.nixpkgs.follows = "nixpkgs"; # leads to many recompilations
};
nixos-hardware = {
url = "github:nixos/nixos-hardware";
};
2024-01-12 19:39:28 +00:00
impermanence = {
url = "github:nix-community/impermanence";
};
2024-06-15 14:39:17 +00:00
# home stuff
wallpaper = {
url = "https://images.unsplash.com/photo-1482686115713-0fbcaced6e28";
flake = false;
};
2024-06-15 14:39:17 +00:00
catppuccin = {
2024-06-17 21:37:27 +00:00
url = "github:catppuccin/nix";
2024-03-31 14:30:34 +00:00
};
2024-01-12 16:02:47 +00:00
# cesium nginx sites
website = {
url = "git+https://git.fainsin.bzh/Laurent/website";
inputs.nixpkgs.follows = "nixpkgs";
inputs.flake-parts.follows = "flake-parts";
inputs.systems.follows = "systems";
};
resume = {
url = "git+https://git.fainsin.bzh/Laurent/resume";
inputs.nixpkgs.follows = "nixpkgs";
inputs.flake-parts.follows = "flake-parts";
inputs.systems.follows = "systems";
};
projet-intelligence-artificielle-multimedia = {
url = "git+https://git.fainsin.bzh/ENSEEIHT/projet-intelligence-artificielle-multimedia";
inputs.nixpkgs.follows = "nixpkgs";
inputs.flake-parts.follows = "flake-parts";
inputs.systems.follows = "systems";
};
projet-modelisation-geometrique = {
url = "git+https://git.fainsin.bzh/ENSEEIHT/projet-modelisation-geometrique";
inputs.nixpkgs.follows = "nixpkgs";
inputs.flake-parts.follows = "flake-parts";
inputs.systems.follows = "systems";
};
projet-systemes-algorithmes-repartis = {
url = "git+https://git.fainsin.bzh/ENSEEIHT/projet-systemes-algorithmes-repartis";
inputs.nixpkgs.follows = "nixpkgs";
inputs.flake-parts.follows = "flake-parts";
inputs.systems.follows = "systems";
};
projet-audionumerique = {
url = "git+https://git.fainsin.bzh/ENSEEIHT/projet-audionumerique";
inputs.nixpkgs.follows = "nixpkgs";
inputs.flake-parts.follows = "flake-parts";
inputs.systems.follows = "systems";
};
projet-oral-japonais = {
url = "git+https://git.fainsin.bzh/ENSEEIHT/projet-oral-japonais";
inputs.nixpkgs.follows = "nixpkgs";
inputs.flake-parts.follows = "flake-parts";
inputs.systems.follows = "systems";
};
projet-oral-anglais = {
url = "git+https://git.fainsin.bzh/ENSEEIHT/projet-oral-anglais";
inputs.nixpkgs.follows = "nixpkgs";
inputs.flake-parts.follows = "flake-parts";
inputs.systems.follows = "systems";
};
TP-calcul-parallele = {
url = "git+https://git.fainsin.bzh/ENSEEIHT/TP-calcul-parallele";
inputs.nixpkgs.follows = "nixpkgs";
inputs.flake-parts.follows = "flake-parts";
inputs.systems.follows = "systems";
};
TP-reinforcement-learning = {
url = "git+https://git.fainsin.bzh/ENSEEIHT/TP-reinforcement-learning";
inputs.nixpkgs.follows = "nixpkgs";
inputs.flake-parts.follows = "flake-parts";
inputs.systems.follows = "systems";
};
TP-traitement-audio-visuel = {
url = "git+https://git.fainsin.bzh/ENSEEIHT/TP-traitement-audio-visuel";
inputs.nixpkgs.follows = "nixpkgs";
inputs.flake-parts.follows = "flake-parts";
inputs.systems.follows = "systems";
};
2022-12-19 22:35:54 +00:00
};
2022-12-21 19:29:15 +00:00
2023-08-12 18:23:45 +00:00
nixConfig = {
extra-substituters = [
"https://nix-community.cachix.org"
];
2023-08-12 18:23:45 +00:00
extra-trusted-public-keys = [
"nix-community.cachix.org-1:mB9FSh9qf2dCimDSUo8Zy7bkq5CX+/rkCWyvRCYg3Fs="
];
};
outputs = {
agenix,
flake-parts,
treefmt-nix,
...
} @ inputs:
flake-parts.lib.mkFlake {inherit inputs;} {
2023-12-29 22:37:51 +00:00
systems = import inputs.systems;
imports = [
flake-parts.flakeModules.easyOverlay
treefmt-nix.flakeModule
];
perSystem = {
pkgs,
system,
...
}: rec {
formatter = pkgs.alejandra;
treefmt = {
projectRootFile = "flake.nix";
programs = {
alejandra.enable = true;
deadnix.enable = true;
};
};
2023-03-19 14:13:24 +00:00
devShells.default = pkgs.mkShell {
packages = [
formatter # defined above
pkgs.git # version control
pkgs.sbctl # secure boot utils
2024-04-24 07:57:48 +00:00
agenix.packages.${system}.agenix # secrets
2023-03-19 14:13:24 +00:00
];
};
};
2022-12-19 22:35:54 +00:00
flake.nixosConfigurations = import ./hosts {inherit inputs;};
};
2022-12-19 22:35:54 +00:00
}