-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathflake.nix
117 lines (103 loc) · 2.91 KB
/
flake.nix
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
{
description = "Homelab";
inputs = {
nixpkgs.url = "github:nixos/nixpkgs/nixos-unstable";
systems.url = "github:nix-systems/default";
sops-nix.url = "github:Mic92/sops-nix";
srvos = {
# Use fix in issue https://github.com/nix-community/srvos/pull/601
url = "github:nix-community/srvos/7179525bf385263afbf2bdebc75b0060e37ceb7c";
inputs.nixpkgs.follows = "nixpkgs";
};
disko = {
url = "github:nix-community/disko";
inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs = {
self,
nixpkgs,
systems,
sops-nix,
srvos,
disko,
} @ inputs: let
inherit (self) outputs;
lib = nixpkgs.lib;
types = import ./nix/lib/types {inherit lib;};
utilities = import ./nix/lib/utilities {inherit lib types;};
config = import ./nix/lib/config.nix {inherit lib types;};
configJson = config.configJson;
nixosModules.default = {pkgs, ...} @ args: {
imports = [
(import ./nix/modules inputs {inherit disko sops-nix types utilities;})
];
};
# Generate NixOS configurations from inventory
nixosConfigurations = lib.mapAttrs (
_hostname: machine: let
nixSystem = utilities.machines.getSystemForArch machine.arch;
in
nixpkgs.lib.nixosSystem {
system = nixSystem;
specialArgs = {
inherit inputs outputs types utilities configJson nixosModules;
};
modules =
[
srvos.nixosModules.server
./machines/${machine.hostname}
]
++ lib.optionals (machine.site == "hetzner") [
srvos.nixosModules.hardware-hetzner-cloud
];
}
) (lib.filterAttrs (_name: machine: machine.os == "nixos") configJson.machines);
forAllSystems = f:
nixpkgs.lib.genAttrs (import systems) (system:
f {
pkgs = import nixpkgs {
inherit system;
config.allowUnfree = true;
};
inherit system;
});
in {
inherit nixosConfigurations nixosModules;
overlays = import ./nix/overlays {inherit inputs;};
packages = forAllSystems (pkgs: import ./nix/pkgs {inherit pkgs;});
formatter = forAllSystems (pkgs: pkgs.alejandra);
devShells = forAllSystems ({
pkgs,
system,
...
}: {
default = pkgs.mkShell {
env = {
TERRAFORM_BINARY_NAME = "tofu";
};
shellHook = ''
export KUBECONFIG="$HOME/.kube/config"
export SOPS_AGE_KEY_FILE="$HOME/.config/sops/age/keys.txt"
'';
packages = with pkgs; [
fluxcd
sops
just
nodejs_22
yarn
direnv
nodePackages.cdktf-cli
opentofu
nodePackages.cdk8s-cli
kubernetes-helm
k9s
kubectl
kubectl-cnpg
alejandra
commitizen
];
};
});
};
}