mirror of
https://github.com/JulienMalka/snowfield.git
synced 2025-03-30 08:40:52 +02:00
feat: expose nixosConfigurations to machines
This commit is contained in:
parent
d7e0225487
commit
73ff334895
2 changed files with 60 additions and 57 deletions
115
default.nix
115
default.nix
|
@ -24,69 +24,70 @@ let
|
||||||
value = import inputs.nixpkgs { system = plat; };
|
value = import inputs.nixpkgs { system = plat; };
|
||||||
}) machines_plats
|
}) machines_plats
|
||||||
);
|
);
|
||||||
in
|
self = rec {
|
||||||
rec {
|
|
||||||
|
|
||||||
nixosModules = builtins.listToAttrs (
|
nixosModules = builtins.listToAttrs (
|
||||||
map (x: {
|
map (x: {
|
||||||
name = x;
|
name = x;
|
||||||
value = import (./modules + "/${x}");
|
value = import (./modules + "/${x}");
|
||||||
}) (builtins.attrNames (builtins.readDir ./modules))
|
}) (builtins.attrNames (builtins.readDir ./modules))
|
||||||
);
|
);
|
||||||
|
|
||||||
nixosConfigurations = builtins.mapAttrs (
|
nixosConfigurations = builtins.mapAttrs (
|
||||||
name: value:
|
name: value:
|
||||||
(mkMachine {
|
(mkMachine {
|
||||||
inherit name;
|
inherit name self;
|
||||||
host-config = value;
|
host-config = value;
|
||||||
modules = nixosModules;
|
modules = nixosModules;
|
||||||
nixpkgs = lib.snowfield.${name}.nixpkgs_version;
|
nixpkgs = lib.snowfield.${name}.nixpkgs_version;
|
||||||
system = lib.snowfield.${name}.arch;
|
system = lib.snowfield.${name}.arch;
|
||||||
home-manager = lib.snowfield.${name}.hm_version;
|
home-manager = lib.snowfield.${name}.hm_version;
|
||||||
})
|
})
|
||||||
) (lib.importConfig ./machines);
|
) (lib.importConfig ./machines);
|
||||||
|
|
||||||
colmena = {
|
colmena = {
|
||||||
meta = {
|
meta = {
|
||||||
nodeNixpkgs = builtins.mapAttrs (
|
nodeNixpkgs = builtins.mapAttrs (
|
||||||
n: _: import lib.luj.machines.${n}.nixpkgs_version
|
n: _: import lib.luj.machines.${n}.nixpkgs_version
|
||||||
) nixosConfigurations;
|
) nixosConfigurations;
|
||||||
nodeSpecialArgs = builtins.mapAttrs (
|
nodeSpecialArgs = builtins.mapAttrs (
|
||||||
n: v: v._module.specialArgs // { lib = mkLibForMachine n; }
|
n: v: v._module.specialArgs // { lib = mkLibForMachine n; }
|
||||||
) nixosConfigurations;
|
) nixosConfigurations;
|
||||||
};
|
};
|
||||||
} // builtins.mapAttrs (_: v: { imports = v._module.args.modules; }) nixosConfigurations;
|
} // builtins.mapAttrs (_: v: { imports = v._module.args.modules; }) nixosConfigurations;
|
||||||
|
|
||||||
packages = builtins.listToAttrs (
|
packages = builtins.listToAttrs (
|
||||||
builtins.map (plat: {
|
builtins.map (plat: {
|
||||||
name = plat;
|
name = plat;
|
||||||
value =
|
value =
|
||||||
lib.filterAttrs
|
lib.filterAttrs
|
||||||
(
|
|
||||||
_name: value:
|
|
||||||
(
|
(
|
||||||
!lib.hasAttrByPath [
|
_name: value:
|
||||||
"meta"
|
(
|
||||||
"platforms"
|
!lib.hasAttrByPath [
|
||||||
] value
|
"meta"
|
||||||
|
"platforms"
|
||||||
|
] value
|
||||||
|
)
|
||||||
|
|| builtins.elem plat value.meta.platforms
|
||||||
)
|
)
|
||||||
|| builtins.elem plat value.meta.platforms
|
(
|
||||||
)
|
builtins.listToAttrs (
|
||||||
(
|
builtins.map (e: {
|
||||||
builtins.listToAttrs (
|
name = e;
|
||||||
builtins.map (e: {
|
value = nixpkgs_plats.${plat}.callPackage (./packages + "/${e}") { };
|
||||||
name = e;
|
}) (builtins.attrNames (builtins.readDir ./packages))
|
||||||
value = nixpkgs_plats.${plat}.callPackage (./packages + "/${e}") { };
|
)
|
||||||
}) (builtins.attrNames (builtins.readDir ./packages))
|
);
|
||||||
)
|
}) machines_plats
|
||||||
);
|
);
|
||||||
}) machines_plats
|
|
||||||
);
|
|
||||||
|
|
||||||
inherit (lib.luj) machines;
|
inherit (lib.luj) machines;
|
||||||
|
|
||||||
checks = {
|
checks = {
|
||||||
inherit packages;
|
inherit packages;
|
||||||
machines = lib.mapAttrs (_: v: v.config.system.build.toplevel) nixosConfigurations;
|
machines = lib.mapAttrs (_: v: v.config.system.build.toplevel) nixosConfigurations;
|
||||||
|
};
|
||||||
};
|
};
|
||||||
}
|
in
|
||||||
|
self
|
||||||
|
|
|
@ -14,6 +14,7 @@ in
|
||||||
nixpkgs ? inputs.nixpkgs,
|
nixpkgs ? inputs.nixpkgs,
|
||||||
system ? "x86_64-linux",
|
system ? "x86_64-linux",
|
||||||
home-manager ? inputs.home-manager,
|
home-manager ? inputs.home-manager,
|
||||||
|
self,
|
||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
pkgs = import nixpkgs { inherit system; };
|
pkgs = import nixpkgs { inherit system; };
|
||||||
|
@ -23,6 +24,7 @@ import "${nixpkgs}/nixos/lib/eval-config.nix" {
|
||||||
lib = pkgs.lib.extend (import ./default.nix inputs);
|
lib = pkgs.lib.extend (import ./default.nix inputs);
|
||||||
specialArgs = {
|
specialArgs = {
|
||||||
inherit inputs;
|
inherit inputs;
|
||||||
|
inherit (self) nixosConfigurations;
|
||||||
};
|
};
|
||||||
modules = builtins.attrValues modules ++ [
|
modules = builtins.attrValues modules ++ [
|
||||||
../machines/base.nix
|
../machines/base.nix
|
||||||
|
|
Loading…
Add table
Reference in a new issue