Merge pull request 'Inventory: add concrete use-case examples' (#1650) from hsjobeki/clan-core:hsjobeki-main into main
All checks were successful
buildbot/nix-build .#checks.aarch64-darwin.nixos-test_install_machine Build done.
buildbot/nix-build .#checks.aarch64-darwin.nixos-test-backup Build done.
buildbot/nix-build .#checks.aarch64-darwin.nixos-iso-installer Build done.
buildbot/nix-build .#checks.aarch64-darwin.nixos-flash-installer Build done.
buildbot/nix-build .#checks.aarch64-linux.nixos-test_install_machine Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-app-no-breakpoints Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-dep-fakeroot Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-dep-git Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-dep-nix Build done.
deploy / deploy-docs (push) Successful in 21s
buildbot/nix-build .#checks.aarch64-linux.nixos-test-backup Build done.
buildbot/nix-build .#checks.aarch64-linux.nixos-flash-installer Build done.
buildbot/nix-build .#checks.x86_64-linux.check-for-breakpoints Build done.
buildbot/nix-build .#checks.x86_64-linux.package-gui-installer-archlinux Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-app-pytest Build done.
buildbot/nix-build .#checks.x86_64-linux.package-gui-installer-apk Build done.
buildbot/nix-build .#checks.x86_64-linux.package-gui-installer-deb Build done.
buildbot/nix-build .#checks.x86_64-linux.package-gui-installer-rpm Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-dep-bash Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-dep-e2fsprogs Build done.
buildbot/nix-build .#checks.x86_64-linux."clan-dep-python3.11-qemu" Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-dep-rsync Build done.
buildbot/nix-build .#checks.x86_64-linux.devShell-webview-ui Build done.
buildbot/nix-build .#checks.x86_64-linux.devShell-default Build done.
buildbot/nix-build .#checks.x86_64-linux.inventory-schema-checks Build done.
buildbot/nix-build .#checks.x86_64-linux.lib-jsonschema-example-valid Build done.
buildbot/nix-build .#checks.x86_64-linux.devShell-clan-cli Build done.
buildbot/nix-build .#checks.x86_64-linux.deltachat Build done.
buildbot/nix-build .#checks.x86_64-linux.borgbackup Build done.
buildbot/nix-build .#checks.x86_64-linux.nixos-test-backup Build done.
buildbot/nix-build .#checks.x86_64-linux.module-schema Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-dep-openssh Build done.
buildbot/nix-build .#checks.x86_64-linux."clan-dep-python3.11-mypy" Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-dep-sops Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-dep-sshpass Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-dep-tor Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-dep-zbar Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-pytest-with-core Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-pytest-without-core Build done.
buildbot/nix-build .#checks.x86_64-linux.clan-dep-age Build done.
buildbot/nix-build .#checks.aarch64-linux.nixos-iso-installer Build done.
buildbot/nix-build .#checks.x86_64-linux.devShell-clan-app Build done.
buildbot/nix-build .#checks.x86_64-linux.container Build done.
buildbot/nix-build .#checks.x86_64-linux.devShell-inventory-schema Build done.
buildbot/nix-build .#checks.x86_64-linux.devShell-docs Build done.
buildbot/nix-build .#checks.x86_64-linux.matrix-synapse Build done.
buildbot/nix-build .#checks.x86_64-linux.package-clan-cli Build done.
buildbot/nix-build .#checks.x86_64-linux.package-clan-cli-docs Build done.
buildbot/nix-build .#checks.x86_64-linux.package-clan-ts-api Build done.
buildbot/nix-build .#checks.x86_64-linux.package-default Build done.
buildbot/nix-build .#checks.x86_64-linux.nixos-test_install_machine Build done.
buildbot/nix-build .#checks.x86_64-linux.flash Build done.
buildbot/nix-build .#checks.x86_64-linux.lib-jsonschema-nix-unit-tests Build done.
buildbot/nix-build .#checks.x86_64-linux.package-inventory-schema Build done.
buildbot/nix-build .#checks.x86_64-linux.package-clan-app Build done.
buildbot/nix-build .#checks.x86_64-linux.package-moonlight-sunshine-accept Build done.
buildbot/nix-build .#checks.x86_64-linux.package-editor Build done.
buildbot/nix-build .#checks.x86_64-linux.package-tea-create-pr Build done.
buildbot/nix-build .#checks.x86_64-linux.package-webview-ui Build done.
buildbot/nix-build .#checks.x86_64-linux.package-impure-checks Build done.
buildbot/nix-build .#checks.x86_64-linux.package-merge-after-ci Build done.
buildbot/nix-build .#checks.x86_64-linux.package-function-schema Build done.
buildbot/nix-build .#checks.x86_64-linux.nixos-flash-installer Build done.
buildbot/nix-build .#checks.x86_64-linux.package-iso-installer Build done.
buildbot/nix-build .#checks.x86_64-linux.template-minimal Build done.
buildbot/nix-build .#checks.x86_64-linux.test-backups Build done.
buildbot/nix-build .#checks.x86_64-linux.package-gui-install-test-ubuntu-22-04 Build done.
buildbot/nix-eval Build done.
buildbot/nix-build .#checks.x86_64-linux.package-zerotier-members Build done.
buildbot/nix-build .#checks.x86_64-linux.package-zerotierone Build done.
buildbot/nix-build .#checks.x86_64-linux.package-zt-tcp-relay Build done.
buildbot/nix-build .#checks.x86_64-linux.package-pending-reviews Build done.
buildbot/nix-build .#checks.x86_64-linux.package-deploy-docs Build done.
buildbot/nix-build .#checks.x86_64-linux.package-docs Build done.
buildbot/nix-build .#checks.x86_64-linux.renderClanOptions Build done.
buildbot/nix-build .#checks.x86_64-linux.postgresql Build done.
buildbot/nix-build .#checks.x86_64-linux.package-module-docs Build done.
buildbot/nix-build .#checks.x86_64-linux.secrets Build done.
buildbot/nix-build .#checks.x86_64-linux.nixos-iso-installer Build done.
buildbot/nix-build .#checks.x86_64-linux.package-module-schema Build done.
buildbot/nix-build .#checks.x86_64-linux.treefmt Build done.
buildbot/nix-build .#checks.x86_64-linux.syncthing Build done.
buildbot/nix-build .#checks.x86_64-linux.wayland-proxy-virtwl Build done.
buildbot/nix-build .#checks.x86_64-linux.zt-tcp-relay Build done.
buildbot/nix-build .#checks.x86_64-linux.test-installation Build done.
checks / checks-impure (push) Successful in 2m8s

This commit is contained in:
clan-bot 2024-06-24 14:03:46 +00:00
commit 37311f8145
8 changed files with 56 additions and 35 deletions

View File

@ -5,6 +5,7 @@
... ...
}: }:
{ {
evalClanModules = import ./eval-clan-modules { inherit clan-core nixpkgs lib; };
jsonschema = import ./jsonschema { inherit lib; }; jsonschema = import ./jsonschema { inherit lib; };
modules = import ./description.nix { inherit clan-core lib; }; modules = import ./description.nix { inherit clan-core lib; };
buildClan = import ./build-clan { inherit clan-core lib nixpkgs; }; buildClan = import ./build-clan { inherit clan-core lib nixpkgs; };

View File

@ -0,0 +1,34 @@
{
nixpkgs,
clan-core,
lib,
}:
let
inherit (import nixpkgs { system = "x86_64-linux"; }) pkgs;
inherit (clan-core) clanModules;
baseModule = {
imports = (import (pkgs.path + "/nixos/modules/module-list.nix")) ++ [
{
nixpkgs.hostPlatform = "x86_64-linux";
clan.core.clanName = "dummy";
}
];
};
# This function takes a list of module names and evaluates them
# evalClanModules :: [ String ] -> { config, options, ... }
evalClanModules =
modulenames:
let
evaled = lib.evalModules {
modules = [
baseModule
clan-core.nixosModules.clanCore
] ++ (map (name: clanModules.${name}) modulenames);
};
in
evaled;
in
evalClanModules

View File

@ -7,7 +7,7 @@
{ {
imports = [ ./jsonschema/flake-module.nix ]; imports = [ ./jsonschema/flake-module.nix ];
flake.lib = import ./default.nix { flake.lib = import ./default.nix {
inherit lib; inherit lib inputs;
inherit (inputs) nixpkgs; inherit (inputs) nixpkgs;
clan-core = self; clan-core = self;
}; };

View File

@ -47,7 +47,7 @@ rec {
let let
evaled = lib.evalModules { modules = [ module ]; }; evaled = lib.evalModules { modules = [ module ]; };
in in
parseOptions evaled.options; { "$schema" = "http://json-schema.org/draft-07/schema#"; } // parseOptions evaled.options;
# parses a set of evaluated nixos options to a jsonschema # parses a set of evaluated nixos options to a jsonschema
parseOptions = parseOptions =
@ -66,6 +66,7 @@ rec {
// { // {
type = "object"; type = "object";
inherit properties; inherit properties;
additionalProperties = false;
}; };
# parses and evaluated nixos option to a jsonschema property definition # parses and evaluated nixos option to a jsonschema property definition

View File

@ -1,5 +1,7 @@
{ {
"$schema": "http://json-schema.org/draft-07/schema#",
"type": "object", "type": "object",
"additionalProperties": false,
"properties": { "properties": {
"name": { "name": {
"type": "string", "type": "string",
@ -38,6 +40,7 @@
}, },
"services": { "services": {
"type": "object", "type": "object",
"additionalProperties": false,
"properties": { "properties": {
"opt": { "opt": {
"type": "string", "type": "string",
@ -59,9 +62,8 @@
"type": "string" "type": "string"
} }
}, },
"required": [ "required": ["repo"],
"repo" "additionalProperties": false,
],
"type": "object" "type": "object"
}, },
"default": {}, "default": {},

View File

@ -278,6 +278,7 @@ in
expr = slib.parseOption (evalType (lib.types.submodule subModule) { }); expr = slib.parseOption (evalType (lib.types.submodule subModule) { });
expected = { expected = {
type = "object"; type = "object";
additionalProperties = false;
properties = { properties = {
opt = { opt = {
type = "boolean"; type = "boolean";
@ -301,6 +302,7 @@ in
expr = slib.parseOption (evalType (lib.types.submodule subModule) { }); expr = slib.parseOption (evalType (lib.types.submodule subModule) { });
expected = { expected = {
type = "object"; type = "object";
additionalProperties = false;
properties = { properties = {
opt = { opt = {
type = "boolean"; type = "boolean";
@ -331,6 +333,7 @@ in
type = "object"; type = "object";
additionalProperties = { additionalProperties = {
type = "object"; type = "object";
additionalProperties = false;
properties = { properties = {
opt = { opt = {
type = "boolean"; type = "boolean";
@ -363,6 +366,7 @@ in
type = "array"; type = "array";
items = { items = {
type = "object"; type = "object";
additionalProperties = false;
properties = { properties = {
opt = { opt = {
type = "boolean"; type = "boolean";

View File

@ -4,16 +4,9 @@
lib ? (import <nixpkgs> { }).lib, lib ? (import <nixpkgs> { }).lib,
slib ? import ./. { inherit lib; }, slib ? import ./. { inherit lib; },
}: }:
let
evaledOptions =
let
evaledConfig = lib.evalModules { modules = [ ./example-interface.nix ]; };
in
evaledConfig.options;
in
{ {
testParseOptions = { testParseOptions = {
expr = slib.parseOptions evaledOptions; expr = slib.parseModule ./example-interface.nix;
expected = builtins.fromJSON (builtins.readFile ./example-schema.json); expected = builtins.fromJSON (builtins.readFile ./example-schema.json);
}; };
@ -26,8 +19,10 @@ in
{ {
expr = slib.parseOptions evaled.options; expr = slib.parseOptions evaled.options;
expected = { expected = {
additionalProperties = false;
properties = { properties = {
foo = { foo = {
additionalProperties = false;
properties = { properties = {
bar = { bar = {
type = "boolean"; type = "boolean";

View File

@ -10,37 +10,21 @@
# borgbackup = self.clanModules.borgbackup; # borgbackup = self.clanModules.borgbackup;
# }; # };
baseModule = {
imports = (import (pkgs.path + "/nixos/modules/module-list.nix")) ++ [
{
nixpkgs.hostPlatform = "x86_64-linux";
clan.core.clanName = "dummy";
}
];
};
optionsFromModule = optionsFromModule =
modulename: module: mName:
let let
evaled = lib.evalModules { eval = self.lib.evalClanModules [ mName ];
modules = [
module
baseModule
self.nixosModules.clanCore
];
};
in in
# Filter out "injected" options that are not part of the module if (eval.options.clan ? "${mName}") then eval.options.clan.${mName} else { };
if (evaled.options.clan ? "${modulename}") then evaled.options.clan.${modulename} else { };
clanModuleSchemas = lib.mapAttrs ( clanModuleSchemas = lib.mapAttrs (
modulename: module: self.lib.jsonschema.parseOptions (optionsFromModule modulename module) modulename: _: self.lib.jsonschema.parseOptions (optionsFromModule modulename)
) clanModules; ) clanModules;
clanModuleFunctionSchemas = lib.mapAttrsFlatten (modulename: module: { clanModuleFunctionSchemas = lib.mapAttrsFlatten (modulename: _: {
name = modulename; name = modulename;
description = self.lib.modules.getShortDescription modulename; description = self.lib.modules.getShortDescription modulename;
parameters = self.lib.jsonschema.parseOptions (optionsFromModule modulename module); parameters = self.lib.jsonschema.parseOptions (optionsFromModule modulename);
}) clanModules; }) clanModules;
in in
rec { rec {