feat: refactor file structure module interfaces and other

This commit is contained in:
Jaka Hudoklin 2019-03-07 23:23:07 +01:00
parent 12a1c920c4
commit eac2d78667
No known key found for this signature in database
GPG key ID: 6A08896BFD32BD95
36 changed files with 58 additions and 139 deletions

View file

@ -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

View file

@ -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
View file

@ -0,0 +1,6 @@
{ pkgs }:
{
chart2json = pkgs.callPackage ./chart2json.nix { };
fetch = pkgs.callPackage ./fetchhelm.nix { };
}

View file

@ -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;
} }

View file

@ -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;

View file

@ -4697,7 +4697,7 @@ let
}; };
}; };
} // (import ./overrides.nix {inherit definitions lib;}); } // (import ./istio-overrides.nix {inherit definitions lib;});
in { in {
kubernetes.customResources = [ kubernetes.customResources = [
{ {

View file

@ -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";

View file

@ -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);
};
}

View file

@ -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;

View file

@ -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;
}); });

View file

@ -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";

View file

@ -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";

View file

@ -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";

View file

@ -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";

View file

@ -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";

View file

@ -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";

View file

@ -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";

View file

@ -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";

View file

@ -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";

View file

@ -21,9 +21,7 @@ let
}; };
}; };
in { in {
imports = [ imports = with kubenix.modules; [ test submodules ];
kubenix.submodules
];
test = { test = {
name = "submodules-defatuls"; name = "submodules-defatuls";

View file

@ -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";

View file

@ -16,9 +16,7 @@ let
}; };
}; };
in { in {
imports = [ imports = with kubenix.modules; [ test submodules ];
kubenix.submodules
];
test = { test = {
name = "submodules-imports"; name = "submodules-imports";