blob: 30fef619f6a23d45c5eaee71ce6fb8098c202e8a (
plain) (
tree)
|
|
{ user, lib, nixpkgs, nur, inputs, home-manager, ... }:
let
hosts = [
{ hostname = "phobos"; system = "x86_64-linux"; }
{ hostname = "luna"; system = "x86_64-linux"; }
{ hostname = "vm"; system = "x86_64-linux"; }
];
mkHost = hostname: system:
let
pkgs = import nixpkgs {
inherit system;
config.allowUnfree = true; # Allow proprietary software
overlays = [
nur.overlay
(import ../packages)
(import ../overlays)
];
};
secrets = import ../secrets;
extraArgs = { inherit pkgs inputs user secrets hostname; };
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 }: { name = hostname; value = mkHost hostname system; }) hosts)
|