mirror of
https://github.com/TECHNOFAB11/kubenix.git
synced 2025-12-12 16:10:05 +01:00
feat: refactor file structure module interfaces and other
This commit is contained in:
parent
12a1c920c4
commit
eac2d78667
36 changed files with 58 additions and 139 deletions
|
|
@ -10,6 +10,8 @@ let
|
||||||
inherit kubenix;
|
inherit kubenix;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
# evalModules with same interface as lib.evalModules and kubenix as
|
||||||
|
# special argument
|
||||||
evalModules = {
|
evalModules = {
|
||||||
module ? null,
|
module ? null,
|
||||||
modules ? [module],
|
modules ? [module],
|
||||||
|
|
@ -27,8 +29,9 @@ let
|
||||||
modules = import ./modules;
|
modules = import ./modules;
|
||||||
|
|
||||||
kubenix = {
|
kubenix = {
|
||||||
inherit evalModules kubenix;
|
inherit evalModules modules;
|
||||||
|
|
||||||
lib = kubenixLib;
|
lib = kubenixLib;
|
||||||
} // modules;
|
module = modules.module;
|
||||||
|
};
|
||||||
in kubenix
|
in kubenix
|
||||||
|
|
|
||||||
|
|
@ -3,4 +3,5 @@
|
||||||
(import ./extra.nix { inherit pkgs lib; }) // {
|
(import ./extra.nix { inherit pkgs lib; }) // {
|
||||||
k8s = import ./k8s.nix { inherit lib; };
|
k8s = import ./k8s.nix { inherit lib; };
|
||||||
docker = import ./docker.nix { inherit lib pkgs; };
|
docker = import ./docker.nix { inherit lib pkgs; };
|
||||||
|
helm = import ./helm { inherit pkgs; };
|
||||||
}
|
}
|
||||||
|
|
|
||||||
6
lib/helm/default.nix
Normal file
6
lib/helm/default.nix
Normal file
|
|
@ -0,0 +1,6 @@
|
||||||
|
{ pkgs }:
|
||||||
|
|
||||||
|
{
|
||||||
|
chart2json = pkgs.callPackage ./chart2json.nix { };
|
||||||
|
fetch = pkgs.callPackage ./fetchhelm.nix { };
|
||||||
|
}
|
||||||
|
|
@ -1,9 +1,10 @@
|
||||||
{
|
{
|
||||||
|
k8s = ./k8s.nix;
|
||||||
|
istio = ./istio.nix;
|
||||||
submodules = ./submodules.nix;
|
submodules = ./submodules.nix;
|
||||||
k8s = ./k8s;
|
helm = ./helm.nix;
|
||||||
istio = ./istio;
|
docker = ./docker.nix;
|
||||||
testing = ./testing;
|
testing = ./testing.nix;
|
||||||
helm = ./helm;
|
test = ./test.nix;
|
||||||
docker = ./docker;
|
|
||||||
module = ./module.nix;
|
module = ./module.nix;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,7 @@
|
||||||
{ config, lib, pkgs, kubenix, ... }:
|
# helm defines kubenix module with options for using helm charts
|
||||||
|
# with kubenix
|
||||||
|
|
||||||
|
{ config, lib, pkgs, helm, ... }:
|
||||||
|
|
||||||
with lib;
|
with lib;
|
||||||
|
|
||||||
|
|
@ -21,13 +24,11 @@ let
|
||||||
version = last splitted;
|
version = last splitted;
|
||||||
};
|
};
|
||||||
|
|
||||||
chart2json = pkgs.callPackage ./chart2json.nix { };
|
|
||||||
fetchhelm = pkgs.callPackage ./fetchhelm.nix { };
|
|
||||||
|
|
||||||
in {
|
in {
|
||||||
imports = [
|
imports = [ ./k8s.nix ];
|
||||||
kubenix.k8s
|
|
||||||
];
|
# expose helm helper methods as module argument
|
||||||
|
config._module.args.helm = import ../lib/helm { inherit pkgs; };
|
||||||
|
|
||||||
options.kubernetes.helm = {
|
options.kubernetes.helm = {
|
||||||
instances = mkOption {
|
instances = mkOption {
|
||||||
|
|
@ -86,19 +87,13 @@ in {
|
||||||
metadata.namespace = mkDefault config.namespace;
|
metadata.namespace = mkDefault config.namespace;
|
||||||
}];
|
}];
|
||||||
|
|
||||||
config.objects = importJSON (chart2json {
|
config.objects = importJSON (helm.chart2json {
|
||||||
inherit (config) chart name namespace values kubeVersion;
|
inherit (config) chart name namespace values kubeVersion;
|
||||||
});
|
});
|
||||||
}));
|
}));
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
# include helper helm methods as args
|
|
||||||
config._module.args.helm = {
|
|
||||||
fetch = fetchhelm;
|
|
||||||
chart2json = chart2json;
|
|
||||||
};
|
|
||||||
|
|
||||||
config.kubernetes.api = mkMerge (flatten (mapAttrsToList (_: instance:
|
config.kubernetes.api = mkMerge (flatten (mapAttrsToList (_: instance:
|
||||||
map (object: let
|
map (object: let
|
||||||
apiVersion = parseApiVersion object.apiVersion;
|
apiVersion = parseApiVersion object.apiVersion;
|
||||||
|
|
@ -4697,7 +4697,7 @@ let
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
} // (import ./overrides.nix {inherit definitions lib;});
|
} // (import ./istio-overrides.nix {inherit definitions lib;});
|
||||||
in {
|
in {
|
||||||
kubernetes.customResources = [
|
kubernetes.customResources = [
|
||||||
{
|
{
|
||||||
|
|
@ -1,3 +1,5 @@
|
||||||
|
# K8S module defines kubernetes definitions for kubenix
|
||||||
|
|
||||||
{ config, lib, pkgs, k8s, ... }:
|
{ config, lib, pkgs, k8s, ... }:
|
||||||
|
|
||||||
with lib;
|
with lib;
|
||||||
|
|
@ -108,8 +110,8 @@ let
|
||||||
indexOf = lst: value:
|
indexOf = lst: value:
|
||||||
head (filter (v: v != -1) (imap0 (i: v: if v == value then i else -1) lst));
|
head (filter (v: v != -1) (imap0 (i: v: if v == value then i else -1) lst));
|
||||||
in {
|
in {
|
||||||
# expose k8s helper methods through arg in modules
|
# expose k8s helper methods as module argument
|
||||||
config._module.args.k8s = import ../../lib/k8s.nix { inherit lib; };
|
config._module.args.k8s = import ../lib/k8s.nix { inherit lib; };
|
||||||
|
|
||||||
options.kubernetes.version = mkOption {
|
options.kubernetes.version = mkOption {
|
||||||
description = "Kubernetes version to use";
|
description = "Kubernetes version to use";
|
||||||
|
|
@ -1,59 +0,0 @@
|
||||||
{ config, lib, kubenix, ... }:
|
|
||||||
|
|
||||||
with lib;
|
|
||||||
|
|
||||||
let
|
|
||||||
globalConfig = config;
|
|
||||||
in {
|
|
||||||
imports = [ kubenix.submodules ];
|
|
||||||
|
|
||||||
options = {
|
|
||||||
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.k8s ];
|
|
||||||
kubernetes.version = mkDefault config.kubernetes.version;
|
|
||||||
kubernetes.api.defaults =
|
|
||||||
mkIf config.kubernetes.propagateDefaults config.kubernetes.api.defaults;
|
|
||||||
};
|
|
||||||
} {
|
|
||||||
default = ({config, ...}: {
|
|
||||||
kubernetes.api.defaults = [{
|
|
||||||
default.metadata.labels = {
|
|
||||||
"kubenix/module-name" = config.submodule.name;
|
|
||||||
"kubenix/module-version" = config.submodule.version;
|
|
||||||
};
|
|
||||||
}];
|
|
||||||
});
|
|
||||||
}];
|
|
||||||
|
|
||||||
kubernetes.objects = mkMerge (mapAttrsToList (_: submodule:
|
|
||||||
submodule.config.kubernetes.objects
|
|
||||||
) config.submodules.instances);
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
@ -1,11 +1,15 @@
|
||||||
{ config, lib, kubenix, ... }:
|
# module.nix defines default kubenix module with additional helper options
|
||||||
|
# and preincluded kubenix module definitions for kubernetes, docker and
|
||||||
|
# kubenix submodules
|
||||||
|
|
||||||
|
{ config, lib, ... }:
|
||||||
|
|
||||||
with lib;
|
with lib;
|
||||||
|
|
||||||
let
|
let
|
||||||
parentConfig = config;
|
parentConfig = config;
|
||||||
in {
|
in {
|
||||||
imports = with kubenix; [ submodules k8s docker ];
|
imports = [ ./k8s.nix ./docker.nix ./submodules.nix ];
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
kubenix.release = mkOption {
|
kubenix.release = mkOption {
|
||||||
|
|
@ -42,7 +46,7 @@ in {
|
||||||
config = {
|
config = {
|
||||||
submodules.defaults = [{
|
submodules.defaults = [{
|
||||||
default = {
|
default = {
|
||||||
imports = [ kubenix.module ];
|
imports = [ ./module.nix ];
|
||||||
kubernetes.version = mkDefault config.kubernetes.version;
|
kubernetes.version = mkDefault config.kubernetes.version;
|
||||||
kubernetes.api.defaults =
|
kubernetes.api.defaults =
|
||||||
mkIf config.kubernetes.propagateDefaults config.kubernetes.api.defaults;
|
mkIf config.kubernetes.propagateDefaults config.kubernetes.api.defaults;
|
||||||
|
|
|
||||||
|
|
@ -16,13 +16,9 @@ let
|
||||||
version' = replaceStrings ["."] ["_"] version;
|
version' = replaceStrings ["."] ["_"] version;
|
||||||
in nameValuePair "v${version'}" (kubenix.evalModules {
|
in nameValuePair "v${version'}" (kubenix.evalModules {
|
||||||
modules = [
|
modules = [
|
||||||
kubenix.testing
|
kubenix.modules.testing
|
||||||
|
|
||||||
{
|
{
|
||||||
imports = [kubenix.k8s kubenix.submodules];
|
|
||||||
|
|
||||||
kubernetes.version = version;
|
|
||||||
|
|
||||||
testing.throwError = throwError;
|
testing.throwError = throwError;
|
||||||
testing.e2e = e2e;
|
testing.e2e = e2e;
|
||||||
testing.tests = [
|
testing.tests = [
|
||||||
|
|
@ -40,7 +36,7 @@ let
|
||||||
./module.nix
|
./module.nix
|
||||||
];
|
];
|
||||||
testing.defaults = ({kubenix, ...}: {
|
testing.defaults = ({kubenix, ...}: {
|
||||||
imports = [kubenix.k8s];
|
imports = [kubenix.modules.k8s];
|
||||||
kubernetes.version = version;
|
kubernetes.version = version;
|
||||||
_module.args.images = images;
|
_module.args.images = images;
|
||||||
});
|
});
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
{ config, lib, test, pkgs, kubenix, helm, ... }:
|
{ config, lib, pkgs, kubenix, helm, ... }:
|
||||||
|
|
||||||
with lib;
|
with lib;
|
||||||
with kubenix.lib;
|
with kubenix.lib;
|
||||||
|
|
@ -29,9 +29,7 @@ let
|
||||||
finalImageTag = "latest";
|
finalImageTag = "latest";
|
||||||
};
|
};
|
||||||
in {
|
in {
|
||||||
imports = [
|
imports = [ kubenix.modules.test kubenix.modules.helm ];
|
||||||
kubenix.helm
|
|
||||||
];
|
|
||||||
|
|
||||||
test = {
|
test = {
|
||||||
name = "helm-simple";
|
name = "helm-simple";
|
||||||
|
|
|
||||||
|
|
@ -1,12 +1,7 @@
|
||||||
{ config, test, kubenix, k8s, ... }:
|
{ config, kubenix, ... }:
|
||||||
|
|
||||||
with k8s;
|
|
||||||
|
|
||||||
{
|
{
|
||||||
imports = [
|
imports = with kubenix.modules; [ test k8s istio ];
|
||||||
kubenix.k8s
|
|
||||||
kubenix.istio
|
|
||||||
];
|
|
||||||
|
|
||||||
test = {
|
test = {
|
||||||
name = "istio-bookinfo";
|
name = "istio-bookinfo";
|
||||||
|
|
|
||||||
|
|
@ -5,9 +5,7 @@ with lib;
|
||||||
let
|
let
|
||||||
cfg = config.kubernetes.api.customresourcedefinitions.crontabs;
|
cfg = config.kubernetes.api.customresourcedefinitions.crontabs;
|
||||||
in {
|
in {
|
||||||
imports = [
|
imports = with kubenix.modules; [ test k8s ];
|
||||||
kubenix.k8s
|
|
||||||
];
|
|
||||||
|
|
||||||
test = {
|
test = {
|
||||||
name = "k8s-1.13-crd";
|
name = "k8s-1.13-crd";
|
||||||
|
|
|
||||||
|
|
@ -5,9 +5,7 @@ with lib;
|
||||||
let
|
let
|
||||||
cfg = config.kubernetes.api.customresourcedefinitions.crontabs;
|
cfg = config.kubernetes.api.customresourcedefinitions.crontabs;
|
||||||
in {
|
in {
|
||||||
imports = [
|
imports = with kubenix.modules; [ test k8s ];
|
||||||
kubenix.k8s
|
|
||||||
];
|
|
||||||
|
|
||||||
test = {
|
test = {
|
||||||
name = "k8s-crd";
|
name = "k8s-crd";
|
||||||
|
|
|
||||||
|
|
@ -1,15 +1,12 @@
|
||||||
{ config, lib, test, kubenix, k8s, ... }:
|
{ config, lib, kubenix, ... }:
|
||||||
|
|
||||||
with lib;
|
with lib;
|
||||||
with k8s;
|
|
||||||
|
|
||||||
let
|
let
|
||||||
pod1 = config.kubernetes.api.pods.pod1;
|
pod1 = config.kubernetes.api.pods.pod1;
|
||||||
pod2 = config.kubernetes.api.pods.pod2;
|
pod2 = config.kubernetes.api.pods.pod2;
|
||||||
in {
|
in {
|
||||||
imports = [
|
imports = with kubenix.modules; [ test k8s ];
|
||||||
kubenix.k8s
|
|
||||||
];
|
|
||||||
|
|
||||||
test = {
|
test = {
|
||||||
name = "k8s-defaults";
|
name = "k8s-defaults";
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
{ config, lib, pkgs, test, kubenix, images, ... }:
|
{ config, lib, pkgs, kubenix, images, ... }:
|
||||||
|
|
||||||
with lib;
|
with lib;
|
||||||
|
|
||||||
|
|
@ -6,9 +6,7 @@ let
|
||||||
cfg = config.kubernetes.api.deployments.nginx;
|
cfg = config.kubernetes.api.deployments.nginx;
|
||||||
image = images.nginx;
|
image = images.nginx;
|
||||||
in {
|
in {
|
||||||
imports = [
|
imports = [ kubenix.modules.test kubenix.modules.k8s ];
|
||||||
kubenix.k8s
|
|
||||||
];
|
|
||||||
|
|
||||||
test = {
|
test = {
|
||||||
name = "k8s-deployment";
|
name = "k8s-deployment";
|
||||||
|
|
|
||||||
|
|
@ -5,9 +5,7 @@ with lib;
|
||||||
let
|
let
|
||||||
cfg = config.kubernetes.api.customresourcedefinitions.crontabs;
|
cfg = config.kubernetes.api.customresourcedefinitions.crontabs;
|
||||||
in {
|
in {
|
||||||
imports = [
|
imports = with kubenix.modules; [ test k8s ];
|
||||||
kubenix.k8s
|
|
||||||
];
|
|
||||||
|
|
||||||
test = {
|
test = {
|
||||||
name = "k8s-order";
|
name = "k8s-order";
|
||||||
|
|
|
||||||
|
|
@ -1,13 +1,9 @@
|
||||||
{ config, test, kubenix, k8s, ... }:
|
{ config, kubenix, ... }:
|
||||||
|
|
||||||
with k8s;
|
|
||||||
|
|
||||||
let
|
let
|
||||||
cfg = config.kubernetes.api.pods.nginx;
|
cfg = config.kubernetes.api.pods.nginx;
|
||||||
in {
|
in {
|
||||||
imports = [
|
imports = [ kubenix.modules.test kubenix.modules.k8s ];
|
||||||
kubenix.k8s
|
|
||||||
];
|
|
||||||
|
|
||||||
test = {
|
test = {
|
||||||
name = "k8s-simple";
|
name = "k8s-simple";
|
||||||
|
|
|
||||||
|
|
@ -6,9 +6,7 @@ let
|
||||||
cfg = config.submodules.instances.test.config;
|
cfg = config.submodules.instances.test.config;
|
||||||
deployment = cfg.kubernetes.api.deployments.nginx;
|
deployment = cfg.kubernetes.api.deployments.nginx;
|
||||||
in {
|
in {
|
||||||
imports = [
|
imports = [ kubenix.modules.test kubenix.module ];
|
||||||
kubenix.module
|
|
||||||
];
|
|
||||||
|
|
||||||
test = {
|
test = {
|
||||||
name = "module";
|
name = "module";
|
||||||
|
|
|
||||||
|
|
@ -21,9 +21,7 @@ let
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
in {
|
in {
|
||||||
imports = [
|
imports = with kubenix.modules; [ test submodules ];
|
||||||
kubenix.submodules
|
|
||||||
];
|
|
||||||
|
|
||||||
test = {
|
test = {
|
||||||
name = "submodules-defatuls";
|
name = "submodules-defatuls";
|
||||||
|
|
|
||||||
|
|
@ -5,9 +5,7 @@ with lib;
|
||||||
let
|
let
|
||||||
cfg = config.submodules.instances.instance;
|
cfg = config.submodules.instances.instance;
|
||||||
in {
|
in {
|
||||||
imports = [
|
imports = with kubenix.modules; [ test submodules ];
|
||||||
kubenix.submodules
|
|
||||||
];
|
|
||||||
|
|
||||||
test = {
|
test = {
|
||||||
name = "submodules-simple";
|
name = "submodules-simple";
|
||||||
|
|
|
||||||
|
|
@ -16,9 +16,7 @@ let
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
in {
|
in {
|
||||||
imports = [
|
imports = with kubenix.modules; [ test submodules ];
|
||||||
kubenix.submodules
|
|
||||||
];
|
|
||||||
|
|
||||||
test = {
|
test = {
|
||||||
name = "submodules-imports";
|
name = "submodules-imports";
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue