-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconfigure.nix
81 lines (78 loc) · 2.46 KB
/
configure.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
inputs @ {
deploy-rs,
nixpkgs,
srvos,
...
}:
with nixpkgs.lib; let
flakeLib = import ./flake-lib.nix inputs;
inherit (flakeLib) features overlays nixosModules hardware specialArgs printMachine hostsList;
in
{
projectRoot,
adminKeys,
extraModules ? [],
machinesPath,
builders ? {
enable = false;
path = null;
},
users ? {
enable = false;
path = null;
},
wifi ? {
enable = false;
path = null;
},
}:
if (builtins.length adminKeys == 0)
then (throw "There should be at least one admin key in order to safely generate secrets")
else let
nixosConfigurations = genAttrs (hostsList projectRoot machinesPath) (hostname:
printMachine hostname nixosSystem {
modules =
nixosModules.default
++ [
(projectRoot + "/${machinesPath}/${hostname}.nix")
# Set the hostname from the file name
{networking.hostName = hostname;}
]
++ extraModules;
specialArgs = specialArgs // {inherit cluster;};
});
# TODO helper to get the config. Remove this if possible
hosts = mapAttrs (name: sys: sys.config) nixosConfigurations;
# Cluster object, that contains the cluster configuration
cluster = {
inherit projectRoot machinesPath builders users wifi hosts adminKeys;
secrets =
features.secrets {inherit projectRoot machinesPath builders users wifi hosts adminKeys;}
# * Optionally loads the secrets.nix file in the project root file if it exists
// optionalAttrs (builtins.pathExists (projectRoot + "/secrets.nix")) (import (projectRoot + "/secrets.nix"));
hardware = hardware.recap;
};
# Make all the NixOS configurations deployable by deploy-rs
deploy = {
user = "root";
nodes = builtins.mapAttrs (hostname: machine: let
inherit (machine.config.nixpkgs.hostPlatform) system;
printHostname = builtins.trace "Evaluating deployment: ${hostname} (${system})";
in
printHostname {
inherit hostname;
# hostname = "${hostname}.local";
profiles.system.path = deploy-rs.lib.${system}.activate.nixos machine;
})
nixosConfigurations;
};
in
recursiveUpdate {
inherit
nixosConfigurations
deploy
cluster
nixosModules
overlays
;
}