39 lines
1.1 KiB
Nix
39 lines
1.1 KiB
Nix
{ lib, pkgsFlakes, inputs, modules }:
|
|
let
|
|
inherit (builtins) attrValues mapAttrs;
|
|
inherit (lib) mkDefault;
|
|
|
|
mkSystem =
|
|
name: {
|
|
system,
|
|
nixpkgs ? "unstable",
|
|
config,
|
|
}:
|
|
let
|
|
pkgsFlake = pkgsFlakes.${nixpkgs};
|
|
lib = pkgsFlake.lib;
|
|
# TODO: This is mostly yoinked from nixpkgs/flake.nix master (as of 2022/02/11) since 21.11's version has hacky
|
|
# vm build stuff that breaks our impl. REMOVE WHEN 22.05 IS OUT!
|
|
nixosSystem' = args:
|
|
import "${pkgsFlake}/nixos/lib/eval-config.nix" (args // {
|
|
modules = args.modules ++ [{
|
|
system.nixos.versionSuffix =
|
|
".${lib.substring 0 8 pkgsFlake.lastModifiedDate}.${pkgsFlake.shortRev}";
|
|
system.nixos.revision = pkgsFlake.rev;
|
|
}];
|
|
});
|
|
in
|
|
nixosSystem' {
|
|
inherit lib system;
|
|
specialArgs = { inherit inputs system; };
|
|
modules = attrValues modules ++ [ { networking.hostName = mkDefault name; } config ];
|
|
};
|
|
in
|
|
mapAttrs mkSystem {
|
|
colony = {
|
|
system = "x86_64-linux";
|
|
nixpkgs = "stable";
|
|
config = boxes/colony.nix;
|
|
};
|
|
}
|