2023-09-02 16:26:45 +00:00
|
|
|
{ nixpkgs, self, lib }:
|
2023-08-29 13:00:03 +00:00
|
|
|
{ directory # The directory containing the machines subdirectory
|
|
|
|
, specialArgs ? { } # Extra arguments to pass to nixosSystem i.e. useful to make self available
|
|
|
|
, machines ? { } # allows to include machine-specific modules i.e. machines.${name} = { ... }
|
|
|
|
}:
|
|
|
|
let
|
2023-09-03 13:18:29 +00:00
|
|
|
machinesDirs = lib.optionalAttrs (builtins.pathExists "${directory}/machines") (builtins.readDir (directory + /machines));
|
2023-08-29 13:00:03 +00:00
|
|
|
|
|
|
|
machineSettings = machineName:
|
2023-09-03 13:18:29 +00:00
|
|
|
lib.optionalAttrs (builtins.pathExists "${directory}/machines/${machineName}/settings.json")
|
2023-09-03 13:55:57 +00:00
|
|
|
(builtins.fromJSON
|
|
|
|
(builtins.readFile (directory + /machines/${machineName}/settings.json)));
|
2023-08-29 13:00:03 +00:00
|
|
|
|
2023-09-20 16:08:47 +00:00
|
|
|
nixosConfiguration = { system ? "x86_64-linux", name }: nixpkgs.lib.nixosSystem {
|
|
|
|
modules = [
|
|
|
|
self.nixosModules.clanCore
|
|
|
|
(machineSettings name)
|
|
|
|
(machines.${name} or { })
|
|
|
|
{
|
|
|
|
clanCore.machineName = name;
|
|
|
|
clanCore.clanDir = directory;
|
|
|
|
# TODO: remove this once we have a hardware-config mechanism
|
|
|
|
nixpkgs.hostPlatform = lib.mkDefault system;
|
|
|
|
}
|
|
|
|
];
|
|
|
|
inherit specialArgs;
|
|
|
|
};
|
|
|
|
|
2023-09-27 15:25:17 +00:00
|
|
|
allMachines = machinesDirs // machines;
|
2023-09-20 16:08:47 +00:00
|
|
|
|
2023-09-27 15:25:17 +00:00
|
|
|
supportedSystems = [
|
2023-09-20 16:08:47 +00:00
|
|
|
"x86_64-linux"
|
|
|
|
"aarch64-linux"
|
|
|
|
"riscv64-linux"
|
|
|
|
"x86_64-darwin"
|
|
|
|
"aarch64-darwin"
|
|
|
|
];
|
|
|
|
|
2023-09-27 15:25:17 +00:00
|
|
|
nixosConfigurations = lib.mapAttrs (name: _: nixosConfiguration { inherit name; }) allMachines;
|
|
|
|
|
|
|
|
# This instantiates nixos for each system that we support:
|
|
|
|
# clanInternals.machinesForAllSystems.<system>.<machine>
|
|
|
|
# We need this to build nixos secret generators for each system
|
|
|
|
machinesForAllSystems = builtins.listToAttrs
|
|
|
|
(builtins.map
|
|
|
|
(system: lib.nameValuePair system
|
|
|
|
(lib.mapAttrs (name: _: nixosConfiguration { inherit name system; }) allMachines))
|
|
|
|
supportedSystems);
|
|
|
|
in
|
|
|
|
{
|
|
|
|
inherit nixosConfigurations;
|
|
|
|
|
2023-09-20 16:08:47 +00:00
|
|
|
clanInternals = {
|
|
|
|
machines = lib.mapAttrs
|
2023-09-27 15:25:17 +00:00
|
|
|
(_: lib.mapAttrs (_: machine: {
|
|
|
|
inherit (machine.config.system.clan) uploadSecrets generateSecrets;
|
|
|
|
inherit (machine.config.clan.networking) deploymentAddress;
|
|
|
|
}))
|
|
|
|
machinesForAllSystems;
|
2023-09-20 16:08:47 +00:00
|
|
|
};
|
2023-09-27 15:25:17 +00:00
|
|
|
}
|