mirror of
https://github.com/TECHNOFAB11/kubenix.git
synced 2025-12-12 16:10:05 +01:00
feat: rename kubenix.all to kubenix.module
This commit is contained in:
parent
a6cea15f34
commit
e260ad9bb4
4 changed files with 6 additions and 6 deletions
71
modules/module.nix
Normal file
71
modules/module.nix
Normal file
|
|
@ -0,0 +1,71 @@
|
|||
{ config, lib, kubenix, ... }:
|
||||
|
||||
with lib;
|
||||
|
||||
let
|
||||
parentConfig = config;
|
||||
in {
|
||||
imports = with kubenix; [ submodules k8s docker ];
|
||||
|
||||
options = {
|
||||
kubenix.release = mkOption {
|
||||
description = "Name of the release";
|
||||
type = types.str;
|
||||
default = "default";
|
||||
};
|
||||
|
||||
kubernetes.propagateDefaults = mkOption {
|
||||
description = "Whether to propagate child defaults to submodules";
|
||||
type = types.bool;
|
||||
default = true;
|
||||
};
|
||||
|
||||
submodules.instances = mkOption {
|
||||
type = types.attrsOf (types.submodule ({config, ...}: {
|
||||
options = {
|
||||
namespace = mkOption {
|
||||
description = "Default kubernetes namespace";
|
||||
type = types.str;
|
||||
default = "default";
|
||||
};
|
||||
};
|
||||
|
||||
config.config = {
|
||||
kubernetes.api.defaults = [{
|
||||
default.metadata.namespace = mkDefault config.namespace;
|
||||
}];
|
||||
};
|
||||
}));
|
||||
};
|
||||
};
|
||||
|
||||
config = {
|
||||
submodules.defaults = [{
|
||||
default = {
|
||||
imports = [ kubenix.module ];
|
||||
kubernetes.version = mkDefault config.kubernetes.version;
|
||||
kubernetes.api.defaults =
|
||||
mkIf config.kubernetes.propagateDefaults config.kubernetes.api.defaults;
|
||||
};
|
||||
} {
|
||||
default = ({config, ...}: {
|
||||
kubenix.release = parentConfig.kubenix.release;
|
||||
kubernetes.api.defaults = [{
|
||||
default.metadata.labels = {
|
||||
"kubenix/module-name" = config.submodule.name;
|
||||
"kubenix/module-version" = config.submodule.version;
|
||||
"kubenix/release" = config.kubenix.release;
|
||||
};
|
||||
}];
|
||||
});
|
||||
}];
|
||||
|
||||
kubernetes.objects = mkMerge (mapAttrsToList (_: submodule:
|
||||
submodule.config.kubernetes.objects
|
||||
) config.submodules.instances);
|
||||
|
||||
docker.export = mkMerge (mapAttrsToList (_: submodule:
|
||||
submodule.config.docker.export
|
||||
) config.submodules.instances);
|
||||
};
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue