mirror of
https://github.com/TECHNOFAB11/kubenix.git
synced 2025-12-12 16:10:05 +01:00
feat: refactor kubenix.k8s-submodule to kubenix.all module
This commit is contained in:
parent
03e1f4c1c4
commit
fbaed4ec00
6 changed files with 78 additions and 6 deletions
71
modules/all.nix
Normal file
71
modules/all.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.all ];
|
||||||
|
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.push = mkMerge (mapAttrsToList (_: submodule:
|
||||||
|
submodule.config.docker.push
|
||||||
|
) config.submodules.instances);
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
@ -1,9 +1,9 @@
|
||||||
{
|
{
|
||||||
submodules = ./submodules.nix;
|
submodules = ./submodules.nix;
|
||||||
k8s = ./k8s;
|
k8s = ./k8s;
|
||||||
k8s-submodules = ./k8s/submodule.nix;
|
|
||||||
istio = ./istio;
|
istio = ./istio;
|
||||||
testing = ./testing;
|
testing = ./testing;
|
||||||
helm = ./helm;
|
helm = ./helm;
|
||||||
docker = ./docker;
|
docker = ./docker;
|
||||||
|
all = ./all.nix;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -191,6 +191,7 @@ in {
|
||||||
|
|
||||||
submodules.instances = mkOption {
|
submodules.instances = mkOption {
|
||||||
description = "Attribute set of submodule instances";
|
description = "Attribute set of submodule instances";
|
||||||
|
default = {};
|
||||||
type = types.attrsOf (types.submodule ({name, config, ...}: let
|
type = types.attrsOf (types.submodule ({name, config, ...}: let
|
||||||
# submodule associated with
|
# submodule associated with
|
||||||
submodule = findSubmodule {
|
submodule = findSubmodule {
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
{pkgs ? import <nixpkgs> {}}:
|
{ pkgs ? import <nixpkgs> {} }:
|
||||||
|
|
||||||
let
|
let
|
||||||
kubenix = import ./. { inherit pkgs; };
|
kubenix = import ./. { inherit pkgs; };
|
||||||
|
|
|
||||||
|
|
@ -8,12 +8,12 @@ let
|
||||||
image = images.nginx;
|
image = images.nginx;
|
||||||
in {
|
in {
|
||||||
imports = [
|
imports = [
|
||||||
kubenix.k8s-submodules
|
kubenix.all
|
||||||
];
|
];
|
||||||
|
|
||||||
test = {
|
test = {
|
||||||
name = "k8s-submodules";
|
name = "all";
|
||||||
description = "Simple k8s submodule test";
|
description = "Test testing all submodule";
|
||||||
assertions = [{
|
assertions = [{
|
||||||
message = "Namespace not propagated";
|
message = "Namespace not propagated";
|
||||||
assertion = deployment.metadata.namespace == "test";
|
assertion = deployment.metadata.namespace == "test";
|
||||||
|
|
@ -30,7 +30,6 @@ let
|
||||||
./k8s/deployment.nix
|
./k8s/deployment.nix
|
||||||
./k8s/crd.nix
|
./k8s/crd.nix
|
||||||
./k8s/1.13/crd.nix
|
./k8s/1.13/crd.nix
|
||||||
./k8s/submodule.nix
|
|
||||||
./k8s/defaults.nix
|
./k8s/defaults.nix
|
||||||
./k8s/order.nix
|
./k8s/order.nix
|
||||||
./helm/simple.nix
|
./helm/simple.nix
|
||||||
|
|
@ -38,6 +37,7 @@ let
|
||||||
./submodules/simple.nix
|
./submodules/simple.nix
|
||||||
./submodules/defaults.nix
|
./submodules/defaults.nix
|
||||||
./submodules/versioning.nix
|
./submodules/versioning.nix
|
||||||
|
./all.nix
|
||||||
];
|
];
|
||||||
testing.defaults = ({kubenix, ...}: {
|
testing.defaults = ({kubenix, ...}: {
|
||||||
imports = [kubenix.k8s];
|
imports = [kubenix.k8s];
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue