blob: 03ba71016acdf95272fc5359fa100ea71a298533 (
plain) (
blame)
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
|
{ user, lib, nixpkgs, inputs, home-manager, ... }:
let
secrets = import ../secrets;
hosts = [
{ hostname = "phobos"; system = "x86_64-linux"; location = secrets.main_location; }
{ hostname = "luna"; system = "x86_64-linux"; location = secrets.main_location; }
{ hostname = "vm"; system = "x86_64-linux"; location = secrets.main_location; }
];
mkHost = { hostname, system, location }:
let
pkgs = import nixpkgs {
inherit system;
config.allowUnfree = true; # Allow proprietary software
overlays = [
inputs.nur.overlay
(import ../packages)
(import ../overlays)
];
};
extraArgs = { inherit pkgs inputs user secrets hostname location; };
in
nixpkgs.lib.nixosSystem {
inherit system;
specialArgs = extraArgs;
modules = [
./configuration.nix
./${hostname}
home-manager.nixosModules.home-manager
{
home-manager.useGlobalPkgs = true;
home-manager.useUserPackages = true;
home-manager.extraSpecialArgs = extraArgs;
home-manager.users.${user} = {
imports = [ ./home.nix ] ++ [ (import ./${ hostname }/home.nix) ];
};
}
];
};
in
/*
We have a list of sets.
Map each element of the list applying the mkHost function to its elements and returning a set in the listToAttrs format
builtins.listToAttrs on the result
*/
builtins.listToAttrs (map ({ hostname, system, location }: { name = hostname; value = mkHost { inherit hostname system location; }; }) hosts)
|