mirror of
https://github.com/TECHNOFAB11/kubenix.git
synced 2025-12-12 16:10:05 +01:00
fix(modules): pass file where module is defined info for easier debugging
This commit is contained in:
parent
b80d09c088
commit
f2e717b117
1 changed files with 22 additions and 4 deletions
26
modules.nix
26
modules.nix
|
|
@ -1,4 +1,4 @@
|
||||||
{ config, lib, pkgs, k8s, module ? null, ... }:
|
{ config, options, lib, pkgs, k8s, module ? null, ... }:
|
||||||
|
|
||||||
with lib;
|
with lib;
|
||||||
with import ./lib.nix { inherit pkgs lib; };
|
with import ./lib.nix { inherit pkgs lib; };
|
||||||
|
|
@ -48,16 +48,33 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
mkModuleOptions = moduleDefinition: module:
|
mkModuleOptions = moduleDefinition: module:
|
||||||
[
|
let
|
||||||
|
# gets file where module is defined by looking into moduleDefinitions
|
||||||
|
# option.
|
||||||
|
file =
|
||||||
|
elemAt options.kubernetes.moduleDefinitions.files (
|
||||||
|
(findFirst (i: i > 0) 0
|
||||||
|
(imap
|
||||||
|
(i: def: if hasAttr module.module def then i else 0)
|
||||||
|
options.kubernetes.moduleDefinitions.definitions
|
||||||
|
)
|
||||||
|
) - 1
|
||||||
|
);
|
||||||
|
|
||||||
|
injectModuleAttrs = module: attrs: (
|
||||||
|
if isFunction module then args: (applyIfFunction file module args) // attrs
|
||||||
|
else if isAttrs mkOptionDefault.module then module // attrs
|
||||||
|
else module
|
||||||
|
);
|
||||||
|
in [
|
||||||
{
|
{
|
||||||
_file = "${module.name}";
|
|
||||||
_module.args.k8s = k8s;
|
_module.args.k8s = k8s;
|
||||||
_module.args.name = module.name;
|
_module.args.name = module.name;
|
||||||
_module.args.module = module;
|
_module.args.module = module;
|
||||||
}
|
}
|
||||||
./kubernetes.nix
|
./kubernetes.nix
|
||||||
./modules.nix
|
./modules.nix
|
||||||
(moduleDefinition.module)
|
(injectModuleAttrs moduleDefinition.module {_file = file;})
|
||||||
{
|
{
|
||||||
config.kubernetes.defaults.all.metadata.namespace = mkOptionDefault module.namespace;
|
config.kubernetes.defaults.all.metadata.namespace = mkOptionDefault module.namespace;
|
||||||
}
|
}
|
||||||
|
|
@ -201,6 +218,7 @@ in {
|
||||||
);
|
);
|
||||||
|
|
||||||
kubernetes.defaultModuleConfiguration.all = {
|
kubernetes.defaultModuleConfiguration.all = {
|
||||||
|
_file = head options.kubernetes.defaultModuleConfiguration.files;
|
||||||
config.kubernetes.version = mkDefault config.kubernetes.version;
|
config.kubernetes.version = mkDefault config.kubernetes.version;
|
||||||
config.kubernetes.moduleDefinitions = config.kubernetes.moduleDefinitions;
|
config.kubernetes.moduleDefinitions = config.kubernetes.moduleDefinitions;
|
||||||
};
|
};
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue