nix-config/flake.nix

206 lines
5.3 KiB
Nix
Raw Normal View History

2023-01-25 17:53:02 +01:00
{
2023-04-08 17:33:59 +02:00
description = "patricks tolle nix config";
inputs = {
2023-09-05 21:00:29 +02:00
nixpkgs-wayland = {
url = "github:nix-community/nixpkgs-wayland";
inputs.nixpkgs.follows = "nixpkgs";
};
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
2023-04-08 17:33:59 +02:00
2023-12-22 01:45:26 +01:00
nixos-extra-modules = {
url = "github:oddlama/nixos-extra-modules";
inputs.nixpkgs.follows = "nixpkgs";
};
2024-01-11 15:41:03 +01:00
microvm = {
url = "github:astro/microvm.nix";
inputs.nixpkgs.follows = "nixpkgs";
inputs.flake-utils.follows = "flake-utils";
};
2023-12-22 01:45:26 +01:00
# to prevent multiple instances of systems
systems.url = "github:nix-systems/default";
2023-08-30 14:25:52 +02:00
disko = {
url = "github:nix-community/disko";
inputs.nixpkgs.follows = "nixpkgs";
};
2023-08-30 16:38:30 +02:00
nixos-generators = {
url = "github:nix-community/nixos-generators";
inputs.nixpkgs.follows = "nixpkgs";
};
home-manager = {
url = "github:nix-community/home-manager";
# should use system nixpkgs instead of their own
inputs.nixpkgs.follows = "nixpkgs";
};
2023-04-08 17:33:59 +02:00
agenix = {
url = "github:ryantm/agenix";
2023-05-19 06:54:56 +02:00
inputs.home-manager.follows = "home-manager";
inputs.nixpkgs.follows = "nixpkgs";
};
2023-01-28 18:41:31 +01:00
# Bin zu faul des zu kopieren
agenix-rekey = {
url = "github:oddlama/agenix-rekey";
inputs.nixpkgs.follows = "nixpkgs";
inputs.flake-utils.follows = "flake-utils";
};
flake-utils = {
url = "github:numtide/flake-utils";
inputs.systems.follows = "systems";
};
pre-commit-hooks = {
url = "github:cachix/pre-commit-hooks.nix";
inputs.nixpkgs.follows = "nixpkgs";
inputs.flake-utils.follows = "flake-utils";
};
2023-03-06 07:47:49 +01:00
2024-03-14 23:08:42 +01:00
nixos-nftables-firewall = {
url = "github:thelegy/nixos-nftables-firewall";
inputs.nixpkgs.follows = "nixpkgs";
};
2024-04-11 23:11:53 +02:00
templates.url = "git+https://git.lel.lol/patrick/nix-templates.git";
2024-04-12 12:07:01 +02:00
nix-topology.url = "github:oddlama/nix-topology";
2023-05-26 17:30:37 +02:00
impermanence.url = "github:nix-community/impermanence";
nixos-hardware.url = "github:nixos/nixos-hardware";
devshell = {
url = "github:numtide/devshell";
inputs.nixpkgs.follows = "nixpkgs";
};
2024-04-11 23:11:53 +02:00
2023-09-18 13:04:44 +02:00
nix-index-database = {
url = "github:nix-community/nix-index-database";
inputs.nixpkgs.follows = "nixpkgs";
};
2023-09-22 20:57:08 +02:00
2023-09-21 01:43:10 +02:00
lanzaboote = {
url = "github:nix-community/lanzaboote/v0.3.0";
inputs.nixpkgs.follows = "nixpkgs";
};
2023-09-22 20:57:08 +02:00
stylix.url = "github:danth/stylix";
2023-10-13 16:55:01 +02:00
spicetify-nix.url = "github:the-argus/spicetify-nix";
2023-10-25 00:21:15 +02:00
nixvim = {
url = "github:nix-community/nixvim";
inputs.nixpkgs.follows = "nixpkgs";
};
2023-01-25 17:53:02 +01:00
};
outputs = {
self,
nixpkgs,
2023-01-28 18:41:31 +01:00
flake-utils,
agenix-rekey,
2023-08-30 16:38:30 +02:00
nixos-generators,
2023-09-20 14:19:13 +02:00
pre-commit-hooks,
2023-09-25 21:28:30 +02:00
devshell,
2023-10-25 00:21:15 +02:00
nixvim,
2024-01-11 15:41:03 +01:00
nixos-extra-modules,
2024-04-12 12:07:01 +02:00
nix-topology,
...
2023-08-30 16:38:30 +02:00
} @ inputs: let
inherit (nixpkgs) lib;
stateVersion = "23.05";
in
2024-04-12 12:07:01 +02:00
rec {
2023-05-27 07:12:18 +02:00
secretsConfig = {
# This should be a link to one of the age public keys is './keys'
masterIdentities = ["/run/decrypt.key.pub"];
extraEncryptionPubkeys = [./secrets/recipients.txt];
2023-01-28 18:41:31 +01:00
};
agenix-rekey = agenix-rekey.configure {
userFlake = self;
inherit (self) nodes pkgs;
};
2023-08-30 16:38:30 +02:00
inherit stateVersion;
2023-09-20 14:37:21 +02:00
inherit
(import ./nix/hosts.nix inputs)
hosts
nixosConfigurations
2023-09-26 22:25:58 +02:00
minimalConfigurations
2023-12-18 02:11:24 +01:00
guestConfigurations
2023-09-20 14:37:21 +02:00
;
2023-12-18 02:11:24 +01:00
nodes = self.nixosConfigurations // self.guestConfigurations;
2023-08-30 16:38:30 +02:00
inherit
(lib.foldl' lib.recursiveUpdate {}
(lib.mapAttrsToList
(import ./nix/generate-installer-package.nix inputs)
2023-09-26 22:25:58 +02:00
self.minimalConfigurations))
2023-08-30 16:38:30 +02:00
packages
;
}
// flake-utils.lib.eachDefaultSystem (system: rec {
2024-01-15 02:13:46 +01:00
apps.setupHetznerStorageBoxes = import (nixos-extra-modules + "/apps/setup-hetzner-storage-boxes.nix") {
inherit pkgs;
nixosConfigurations = self.nodes;
decryptIdentity = builtins.head self.secretsConfig.masterIdentities;
};
pkgs = import nixpkgs {
2023-09-05 21:00:29 +02:00
overlays =
import ./lib inputs
2023-09-18 14:36:41 +02:00
++ import ./pkgs
2023-09-05 21:00:29 +02:00
++ [
2023-09-30 18:08:54 +02:00
# nixpkgs-wayland.overlay
2024-01-11 15:41:03 +01:00
nixos-extra-modules.overlays.default
2024-04-12 12:07:01 +02:00
nix-topology.overlays.default
2023-09-25 21:28:30 +02:00
devshell.overlays.default
agenix-rekey.overlays.default
2023-10-25 00:21:15 +02:00
nixvim.overlays.default
2023-09-05 21:00:29 +02:00
];
inherit system;
config.allowUnfree = true;
2023-02-08 19:52:31 +01:00
};
2023-08-30 16:38:30 +02:00
2024-04-12 12:07:01 +02:00
topology = import nix-topology {
inherit pkgs;
modules = [
./nix/topology.nix
{inherit (self) nixosConfigurations;}
];
};
2023-08-30 16:38:30 +02:00
images.live-iso = nixos-generators.nixosGenerate {
inherit pkgs;
modules = [
./nix/installer-configuration.nix
2024-04-11 23:11:53 +02:00
./config/basic/ssh.nix
2023-08-30 16:38:30 +02:00
];
format =
{
x86_64-linux = "install-iso";
aarch64-linux = "sd-aarch64-installer";
}
.${system};
};
2023-09-20 14:19:13 +02:00
checks.pre-commit-check =
pre-commit-hooks.lib.${system}.run
{
src = lib.cleanSource ./.;
hooks = {
alejandra.enable = true;
2023-12-22 01:30:46 +01:00
deadnix.enable = true;
2023-09-20 14:19:13 +02:00
statix.enable = true;
2024-04-12 12:07:01 +02:00
hunspell.enable = true;
2023-09-20 14:19:13 +02:00
};
};
devShell = import ./nix/devshell.nix inputs system;
formatter = pkgs.alejandra;
2023-01-28 18:41:31 +01:00
});
2023-01-25 17:53:02 +01:00
}