nix-config/flake.nix

89 lines
2.2 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 = {
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
2023-04-08 17:33:59 +02:00
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";
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";
};
2023-01-28 18:41:31 +01:00
flake-utils.url = "github:numtide/flake-utils";
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
templates.url = "git+https://git.lel.lol/patrick/nix-templates.git";
colmena = {
url = "github:zhaofengli/colmena";
inputs.nixpkgs.follows = "nixpkgs";
inputs.flake-utils.follows = "flake-utils";
2023-03-06 07:47:49 +01:00
};
2023-03-08 14:11:46 +01:00
# someday
#impermanence.url = "github:nix-community/impermanence";
nixos-hardware.url = "github:nixos/nixos-hardware";
2023-03-08 14:11:46 +01:00
hyprland.url = "github:hyprwm/Hyprland";
2023-01-25 17:53:02 +01:00
};
outputs = {
self,
nixpkgs,
2023-01-28 18:41:31 +01:00
flake-utils,
colmena,
agenix-rekey,
...
} @ inputs:
2023-01-28 18:41:31 +01:00
{
secrets = {
masterIdentities = [./secrets/NIXOSc.key.pub];
extraEncryptionPubkeys = [./secrets/recipients.txt];
content = import ./nix/secrets.nix inputs;
2023-01-28 18:41:31 +01:00
};
hosts = {
patricknix = {
type = "nixos";
system = "x86_64-linux";
};
};
2023-02-08 19:52:31 +01:00
colmena = import ./nix/colmena.nix inputs;
# all bare metal nodes
colmenaNodes = ((colmena.lib.makeHive self.colmena).introspect (x: x)).nodes;
# todo add microvmNodes
nodes = self.colmenaNodes;
}
// flake-utils.lib.eachDefaultSystem (system: rec {
pkgs = import nixpkgs {
inherit system;
# TODO fix this to only allow specific unfree packages
config.allowUnfree = true;
2023-02-08 19:52:31 +01:00
};
apps = agenix-rekey.defineApps self pkgs self.nodes;
checks = import ./nix/checks.nix inputs system;
devShells.default = import ./nix/dev-shell.nix inputs system;
formatter = pkgs.alejandra;
2023-01-28 18:41:31 +01:00
});
2023-01-25 17:53:02 +01:00
}