73 lines
2.1 KiB
Nix
73 lines
2.1 KiB
Nix
test:
|
|
{ pkgs, self, ... }:
|
|
let
|
|
inherit (pkgs) lib;
|
|
inherit (lib) mkOption flip mapAttrs;
|
|
inherit (lib.types) path raw;
|
|
inherit (self.clanLib.inventory) buildInventory;
|
|
nixos-lib = import (pkgs.path + "/nixos/lib") { };
|
|
in
|
|
(nixos-lib.runTest (
|
|
{ config, ... }:
|
|
let
|
|
serviceConfigs = buildInventory {
|
|
inventory = config.inventory.inventory;
|
|
# TODO: make directory argument optional in buildInventory
|
|
directory = config.inventory.directory;
|
|
};
|
|
in
|
|
{
|
|
imports = [ test ];
|
|
options = {
|
|
inventory.inventory = mkOption {
|
|
description = "Inventory of machines and services";
|
|
type = raw;
|
|
};
|
|
inventory.directory = mkOption {
|
|
description = "Directory which contains the vars";
|
|
type = path;
|
|
};
|
|
};
|
|
config = {
|
|
nodes = flip mapAttrs serviceConfigs.machines (
|
|
machineName: attrs: {
|
|
imports = attrs.machineImports ++ [ self.nixosModules.clanCore ];
|
|
clan.core.settings.directory = "${config.inventory.directory}";
|
|
clan.core.settings.machine.name = machineName;
|
|
}
|
|
);
|
|
hostPkgs = pkgs;
|
|
# speed-up evaluation
|
|
defaults = (
|
|
{ config, ... }:
|
|
{
|
|
imports = [
|
|
./minify.nix
|
|
];
|
|
documentation.enable = lib.mkDefault false;
|
|
nix.settings.min-free = 0;
|
|
system.stateVersion = config.system.nixos.release;
|
|
boot.initrd.systemd.enable = false;
|
|
|
|
# setup for sops
|
|
sops.age.keyFile = "/run/age-key.txt";
|
|
system.activationScripts =
|
|
{
|
|
setupSecrets.deps = [ "age-key" ];
|
|
age-key.text = ''
|
|
echo AGE-SECRET-KEY-1PL0M9CWRCG3PZ9DXRTTLMCVD57U6JDFE8K7DNVQ35F4JENZ6G3MQ0RQLRV > /run/age-key.txt
|
|
'';
|
|
}
|
|
// lib.optionalAttrs (lib.filterAttrs (_: v: v.neededForUsers) config.sops.secrets != { }) {
|
|
setupSecretsForUsers.deps = [ "age-key" ];
|
|
};
|
|
}
|
|
);
|
|
|
|
_module.args = { inherit self; };
|
|
# to accept external dependencies such as disko
|
|
node.specialArgs.self = self;
|
|
};
|
|
}
|
|
)).config.result
|