mirror of
https://github.com/TECHNOFAB11/kubenix.git
synced 2025-12-12 16:10:05 +01:00
style: fmt
This commit is contained in:
parent
e575c23570
commit
348d922b18
6 changed files with 148 additions and 222 deletions
|
|
@ -1,6 +1,7 @@
|
||||||
{ system ? builtins.currentSystem }:
|
{ system ? builtins.currentSystem }:
|
||||||
let
|
let
|
||||||
in (
|
in
|
||||||
|
(
|
||||||
(import ./compat.nix).flake-compat {
|
(import ./compat.nix).flake-compat {
|
||||||
src = ./.;
|
src = ./.;
|
||||||
inherit system;
|
inherit system;
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,7 @@
|
||||||
{ system ? builtins.currentSystem }:
|
{ system ? builtins.currentSystem }:
|
||||||
let
|
let
|
||||||
in (
|
in
|
||||||
|
(
|
||||||
(import ./compat.nix).flake-compat {
|
(import ./compat.nix).flake-compat {
|
||||||
src = ./.;
|
src = ./.;
|
||||||
inherit system;
|
inherit system;
|
||||||
|
|
|
||||||
|
|
@ -5,11 +5,13 @@ with lib;
|
||||||
|
|
||||||
let
|
let
|
||||||
getDefaults = resource: group: version: kind:
|
getDefaults = resource: group: version: kind:
|
||||||
catAttrs "default" (filter (default:
|
catAttrs "default" (filter
|
||||||
(default.resource == null || default.resource == resource)
|
(default:
|
||||||
&& (default.group == null || default.group == group)
|
(default.resource == null || default.resource == resource)
|
||||||
&& (default.version == null || default.version == version)
|
&& (default.group == null || default.group == group)
|
||||||
&& (default.kind == null || default.kind == kind)) config.defaults);
|
&& (default.version == null || default.version == version)
|
||||||
|
&& (default.kind == null || default.kind == kind))
|
||||||
|
config.defaults);
|
||||||
|
|
||||||
types = lib.types // rec {
|
types = lib.types // rec {
|
||||||
str = mkOptionType {
|
str = mkOptionType {
|
||||||
|
|
@ -34,7 +36,8 @@ let
|
||||||
else
|
else
|
||||||
let coerced = coerceFunc val; in assert finalType.check coerced; coerced;
|
let coerced = coerceFunc val; in assert finalType.check coerced; coerced;
|
||||||
|
|
||||||
in finalType.merge loc (map (def: def // { value = coerceVal def.value; }) defs);
|
in
|
||||||
|
finalType.merge loc (map (def: def // { value = coerceVal def.value; }) defs);
|
||||||
getSubOptions = finalType.getSubOptions;
|
getSubOptions = finalType.getSubOptions;
|
||||||
getSubModules = finalType.getSubModules;
|
getSubModules = finalType.getSubModules;
|
||||||
substSubModules = m: coercedTo coercedType coerceFunc (finalType.substSubModules m);
|
substSubModules = m: coercedTo coercedType coerceFunc (finalType.substSubModules m);
|
||||||
|
|
@ -46,11 +49,15 @@ let
|
||||||
mkOptionDefault = mkOverride 1001;
|
mkOptionDefault = mkOverride 1001;
|
||||||
|
|
||||||
mergeValuesByKey = mergeKey: values:
|
mergeValuesByKey = mergeKey: values:
|
||||||
listToAttrs (map (value:
|
listToAttrs (map
|
||||||
nameValuePair (if isAttrs value.${mergeKey} then
|
(value:
|
||||||
toString value.${mergeKey}.content
|
nameValuePair
|
||||||
else
|
(if isAttrs value.${mergeKey} then
|
||||||
(toString value.${mergeKey})) value) values);
|
toString value.${mergeKey}.content
|
||||||
|
else
|
||||||
|
(toString value.${mergeKey}))
|
||||||
|
value)
|
||||||
|
values);
|
||||||
|
|
||||||
submoduleOf = ref:
|
submoduleOf = ref:
|
||||||
types.submodule ({ name, ... }: {
|
types.submodule ({ name, ... }: {
|
||||||
|
|
@ -63,7 +70,8 @@ let
|
||||||
let
|
let
|
||||||
convertName = name:
|
convertName = name:
|
||||||
if definitions."${ref}".options.${mergeKey}.type == types.int then toInt name else name;
|
if definitions."${ref}".options.${mergeKey}.type == types.int then toInt name else name;
|
||||||
in {
|
in
|
||||||
|
{
|
||||||
options = definitions."${ref}".options;
|
options = definitions."${ref}".options;
|
||||||
config = definitions."${ref}".config // {
|
config = definitions."${ref}".config // {
|
||||||
${mergeKey} = mkOverride 1002 (convertName name);
|
${mergeKey} = mkOverride 1002 (convertName name);
|
||||||
|
|
@ -72,7 +80,8 @@ let
|
||||||
|
|
||||||
submoduleForDefinition = ref: resource: kind: group: version:
|
submoduleForDefinition = ref: resource: kind: group: version:
|
||||||
let apiVersion = if group == "core" then version else "${group}/${version}";
|
let apiVersion = if group == "core" then version else "${group}/${version}";
|
||||||
in types.submodule ({ name, ... }: {
|
in
|
||||||
|
types.submodule ({ name, ... }: {
|
||||||
imports = getDefaults resource group version kind;
|
imports = getDefaults resource group version kind;
|
||||||
options = definitions."${ref}".options;
|
options = definitions."${ref}".options;
|
||||||
config = mkMerge [
|
config = mkMerge [
|
||||||
|
|
@ -12772,8 +12781,8 @@ let
|
||||||
Host is the fully qualified domain name of a network host, as defined by RFC 3986. Note the following deviations from the "host" part of the URI as defined in RFC 3986: 1. IPs are not allowed. Currently an IngressRuleValue can only apply to
|
Host is the fully qualified domain name of a network host, as defined by RFC 3986. Note the following deviations from the "host" part of the URI as defined in RFC 3986: 1. IPs are not allowed. Currently an IngressRuleValue can only apply to
|
||||||
the IP in the Spec of the parent Ingress.
|
the IP in the Spec of the parent Ingress.
|
||||||
2. The `:` delimiter is not respected because ports are not allowed.
|
2. The `:` delimiter is not respected because ports are not allowed.
|
||||||
Currently the port of an Ingress is implicitly :80 for http and
|
Currently the port of an Ingress is implicitly :80 for http and
|
||||||
:443 for https.
|
:443 for https.
|
||||||
Both these may change in the future. Incoming requests are matched against the host before the IngressRuleValue. If the host is unspecified, the Ingress routes all traffic based on the specified IngressRuleValue.
|
Both these may change in the future. Incoming requests are matched against the host before the IngressRuleValue. If the host is unspecified, the Ingress routes all traffic based on the specified IngressRuleValue.
|
||||||
|
|
||||||
Host can be "precise" which is a domain name without the terminating dot of a network host (e.g. "foo.bar.com") or "wildcard", which is a domain name prefixed with a single wildcard label (e.g. "*.foo.com"). The wildcard character '*' must appear by itself as the first DNS label and matches only a single label. You cannot have a wildcard label by itself (e.g. Host == "*"). Requests will be matched against the Host field in the following way: 1. If Host is precise, the request matches this rule if the http host header is equal to Host. 2. If Host is a wildcard, then the request matches this rule if the http host header is to equal to the suffix (removing the first label) of the wildcard rule.'';
|
Host can be "precise" which is a domain name without the terminating dot of a network host (e.g. "foo.bar.com") or "wildcard", which is a domain name prefixed with a single wildcard label (e.g. "*.foo.com"). The wildcard character '*' must appear by itself as the first DNS label and matches only a single label. You cannot have a wildcard label by itself (e.g. Host == "*"). Requests will be matched against the Host field in the following way: 1. If Host is precise, the request matches this rule if the http host header is equal to Host. 2. If Host is a wildcard, then the request matches this rule if the http host header is to equal to the suffix (removing the first label) of the wildcard rule.'';
|
||||||
|
|
@ -13665,8 +13674,8 @@ let
|
||||||
Host is the fully qualified domain name of a network host, as defined by RFC 3986. Note the following deviations from the "host" part of the URI as defined in RFC 3986: 1. IPs are not allowed. Currently an IngressRuleValue can only apply to
|
Host is the fully qualified domain name of a network host, as defined by RFC 3986. Note the following deviations from the "host" part of the URI as defined in RFC 3986: 1. IPs are not allowed. Currently an IngressRuleValue can only apply to
|
||||||
the IP in the Spec of the parent Ingress.
|
the IP in the Spec of the parent Ingress.
|
||||||
2. The `:` delimiter is not respected because ports are not allowed.
|
2. The `:` delimiter is not respected because ports are not allowed.
|
||||||
Currently the port of an Ingress is implicitly :80 for http and
|
Currently the port of an Ingress is implicitly :80 for http and
|
||||||
:443 for https.
|
:443 for https.
|
||||||
Both these may change in the future. Incoming requests are matched against the host before the IngressRuleValue. If the host is unspecified, the Ingress routes all traffic based on the specified IngressRuleValue.
|
Both these may change in the future. Incoming requests are matched against the host before the IngressRuleValue. If the host is unspecified, the Ingress routes all traffic based on the specified IngressRuleValue.
|
||||||
|
|
||||||
Host can be "precise" which is a domain name without the terminating dot of a network host (e.g. "foo.bar.com") or "wildcard", which is a domain name prefixed with a single wildcard label (e.g. "*.foo.com"). The wildcard character '*' must appear by itself as the first DNS label and matches only a single label. You cannot have a wildcard label by itself (e.g. Host == "*"). Requests will be matched against the Host field in the following way: 1. If Host is precise, the request matches this rule if the http host header is equal to Host. 2. If Host is a wildcard, then the request matches this rule if the http host header is to equal to the suffix (removing the first label) of the wildcard rule.'';
|
Host can be "precise" which is a domain name without the terminating dot of a network host (e.g. "foo.bar.com") or "wildcard", which is a domain name prefixed with a single wildcard label (e.g. "*.foo.com"). The wildcard character '*' must appear by itself as the first DNS label and matches only a single label. You cannot have a wildcard label by itself (e.g. Host == "*"). Requests will be matched against the Host field in the following way: 1. If Host is precise, the request matches this rule if the http host header is equal to Host. 2. If Host is a wildcard, then the request matches this rule if the http host header is to equal to the suffix (removing the first label) of the wildcard rule.'';
|
||||||
|
|
@ -14219,8 +14228,8 @@ let
|
||||||
Host is the fully qualified domain name of a network host, as defined by RFC 3986. Note the following deviations from the "host" part of the URI as defined in RFC 3986: 1. IPs are not allowed. Currently an IngressRuleValue can only apply to
|
Host is the fully qualified domain name of a network host, as defined by RFC 3986. Note the following deviations from the "host" part of the URI as defined in RFC 3986: 1. IPs are not allowed. Currently an IngressRuleValue can only apply to
|
||||||
the IP in the Spec of the parent Ingress.
|
the IP in the Spec of the parent Ingress.
|
||||||
2. The `:` delimiter is not respected because ports are not allowed.
|
2. The `:` delimiter is not respected because ports are not allowed.
|
||||||
Currently the port of an Ingress is implicitly :80 for http and
|
Currently the port of an Ingress is implicitly :80 for http and
|
||||||
:443 for https.
|
:443 for https.
|
||||||
Both these may change in the future. Incoming requests are matched against the host before the IngressRuleValue. If the host is unspecified, the Ingress routes all traffic based on the specified IngressRuleValue.
|
Both these may change in the future. Incoming requests are matched against the host before the IngressRuleValue. If the host is unspecified, the Ingress routes all traffic based on the specified IngressRuleValue.
|
||||||
|
|
||||||
Host can be "precise" which is a domain name without the terminating dot of a network host (e.g. "foo.bar.com") or "wildcard", which is a domain name prefixed with a single wildcard label (e.g. "*.foo.com"). The wildcard character '*' must appear by itself as the first DNS label and matches only a single label. You cannot have a wildcard label by itself (e.g. Host == "*"). Requests will be matched against the Host field in the following way: 1. If Host is precise, the request matches this rule if the http host header is equal to Host. 2. If Host is a wildcard, then the request matches this rule if the http host header is to equal to the suffix (removing the first label) of the wildcard rule.'';
|
Host can be "precise" which is a domain name without the terminating dot of a network host (e.g. "foo.bar.com") or "wildcard", which is a domain name prefixed with a single wildcard label (e.g. "*.foo.com"). The wildcard character '*' must appear by itself as the first DNS label and matches only a single label. You cannot have a wildcard label by itself (e.g. Host == "*"). Requests will be matched against the Host field in the following way: 1. If Host is precise, the request matches this rule if the http host header is equal to Host. 2. If Host is a wildcard, then the request matches this rule if the http host header is to equal to the suffix (removing the first label) of the wildcard rule.'';
|
||||||
|
|
@ -18038,9 +18047,7 @@ let
|
||||||
config = { "labelSelectorPath" = mkOverride 1002 null; };
|
config = { "labelSelectorPath" = mkOverride 1002 null; };
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.CustomResourceSubresourceStatus" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.CustomResourceSubresourceStatus" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.CustomResourceSubresources" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.CustomResourceSubresources" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -18097,9 +18104,7 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSON" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSON" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSONSchemaProps" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSONSchemaProps" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -18378,15 +18383,9 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSONSchemaPropsOrArray" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSONSchemaPropsOrArray" = { };
|
||||||
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSONSchemaPropsOrBool" = { };
|
||||||
};
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSONSchemaPropsOrStringArray" = { };
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSONSchemaPropsOrBool" = {
|
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSONSchemaPropsOrStringArray" = {
|
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.ServiceReference" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.ServiceReference" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -18875,9 +18874,7 @@ let
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.CustomResourceSubresourceStatus" =
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.CustomResourceSubresourceStatus" =
|
||||||
{
|
{ };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.CustomResourceSubresources" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.CustomResourceSubresources" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -18934,9 +18931,7 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSON" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSON" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSONSchemaProps" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSONSchemaProps" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -19215,15 +19210,9 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSONSchemaPropsOrArray" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSONSchemaPropsOrArray" = { };
|
||||||
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSONSchemaPropsOrBool" = { };
|
||||||
};
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSONSchemaPropsOrStringArray" = { };
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSONSchemaPropsOrBool" = {
|
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSONSchemaPropsOrStringArray" = {
|
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.ServiceReference" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.ServiceReference" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -19292,9 +19281,7 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apimachinery.pkg.api.resource.Quantity" = {
|
"io.k8s.apimachinery.pkg.api.resource.Quantity" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.APIGroup" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.APIGroup" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -19536,9 +19523,7 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.FieldsV1" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.FieldsV1" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.GroupVersionForDiscovery" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.GroupVersionForDiscovery" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -19680,9 +19665,7 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.MicroTime" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.MicroTime" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.ObjectMeta" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.ObjectMeta" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -19846,9 +19829,7 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.Patch" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.Patch" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.Preconditions" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.Preconditions" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -20018,9 +19999,7 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.Time" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.Time" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.WatchEvent" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.WatchEvent" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -20042,12 +20021,8 @@ let
|
||||||
config = { };
|
config = { };
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apimachinery.pkg.runtime.RawExtension" = {
|
"io.k8s.apimachinery.pkg.runtime.RawExtension" = { };
|
||||||
|
"io.k8s.apimachinery.pkg.util.intstr.IntOrString" = { };
|
||||||
};
|
|
||||||
"io.k8s.apimachinery.pkg.util.intstr.IntOrString" = {
|
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apimachinery.pkg.version.Info" = {
|
"io.k8s.apimachinery.pkg.version.Info" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -20470,7 +20445,8 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
in {
|
in
|
||||||
|
{
|
||||||
# all resource versions
|
# all resource versions
|
||||||
options = {
|
options = {
|
||||||
resources = {
|
resources = {
|
||||||
|
|
|
||||||
|
|
@ -5,11 +5,13 @@ with lib;
|
||||||
|
|
||||||
let
|
let
|
||||||
getDefaults = resource: group: version: kind:
|
getDefaults = resource: group: version: kind:
|
||||||
catAttrs "default" (filter (default:
|
catAttrs "default" (filter
|
||||||
(default.resource == null || default.resource == resource)
|
(default:
|
||||||
&& (default.group == null || default.group == group)
|
(default.resource == null || default.resource == resource)
|
||||||
&& (default.version == null || default.version == version)
|
&& (default.group == null || default.group == group)
|
||||||
&& (default.kind == null || default.kind == kind)) config.defaults);
|
&& (default.version == null || default.version == version)
|
||||||
|
&& (default.kind == null || default.kind == kind))
|
||||||
|
config.defaults);
|
||||||
|
|
||||||
types = lib.types // rec {
|
types = lib.types // rec {
|
||||||
str = mkOptionType {
|
str = mkOptionType {
|
||||||
|
|
@ -34,7 +36,8 @@ let
|
||||||
else
|
else
|
||||||
let coerced = coerceFunc val; in assert finalType.check coerced; coerced;
|
let coerced = coerceFunc val; in assert finalType.check coerced; coerced;
|
||||||
|
|
||||||
in finalType.merge loc (map (def: def // { value = coerceVal def.value; }) defs);
|
in
|
||||||
|
finalType.merge loc (map (def: def // { value = coerceVal def.value; }) defs);
|
||||||
getSubOptions = finalType.getSubOptions;
|
getSubOptions = finalType.getSubOptions;
|
||||||
getSubModules = finalType.getSubModules;
|
getSubModules = finalType.getSubModules;
|
||||||
substSubModules = m: coercedTo coercedType coerceFunc (finalType.substSubModules m);
|
substSubModules = m: coercedTo coercedType coerceFunc (finalType.substSubModules m);
|
||||||
|
|
@ -46,11 +49,15 @@ let
|
||||||
mkOptionDefault = mkOverride 1001;
|
mkOptionDefault = mkOverride 1001;
|
||||||
|
|
||||||
mergeValuesByKey = mergeKey: values:
|
mergeValuesByKey = mergeKey: values:
|
||||||
listToAttrs (map (value:
|
listToAttrs (map
|
||||||
nameValuePair (if isAttrs value.${mergeKey} then
|
(value:
|
||||||
toString value.${mergeKey}.content
|
nameValuePair
|
||||||
else
|
(if isAttrs value.${mergeKey} then
|
||||||
(toString value.${mergeKey})) value) values);
|
toString value.${mergeKey}.content
|
||||||
|
else
|
||||||
|
(toString value.${mergeKey}))
|
||||||
|
value)
|
||||||
|
values);
|
||||||
|
|
||||||
submoduleOf = ref:
|
submoduleOf = ref:
|
||||||
types.submodule ({ name, ... }: {
|
types.submodule ({ name, ... }: {
|
||||||
|
|
@ -63,7 +70,8 @@ let
|
||||||
let
|
let
|
||||||
convertName = name:
|
convertName = name:
|
||||||
if definitions."${ref}".options.${mergeKey}.type == types.int then toInt name else name;
|
if definitions."${ref}".options.${mergeKey}.type == types.int then toInt name else name;
|
||||||
in {
|
in
|
||||||
|
{
|
||||||
options = definitions."${ref}".options;
|
options = definitions."${ref}".options;
|
||||||
config = definitions."${ref}".config // {
|
config = definitions."${ref}".config // {
|
||||||
${mergeKey} = mkOverride 1002 (convertName name);
|
${mergeKey} = mkOverride 1002 (convertName name);
|
||||||
|
|
@ -72,7 +80,8 @@ let
|
||||||
|
|
||||||
submoduleForDefinition = ref: resource: kind: group: version:
|
submoduleForDefinition = ref: resource: kind: group: version:
|
||||||
let apiVersion = if group == "core" then version else "${group}/${version}";
|
let apiVersion = if group == "core" then version else "${group}/${version}";
|
||||||
in types.submodule ({ name, ... }: {
|
in
|
||||||
|
types.submodule ({ name, ... }: {
|
||||||
imports = getDefaults resource group version kind;
|
imports = getDefaults resource group version kind;
|
||||||
options = definitions."${ref}".options;
|
options = definitions."${ref}".options;
|
||||||
config = mkMerge [
|
config = mkMerge [
|
||||||
|
|
@ -1145,9 +1154,7 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.api.apiserverinternal.v1alpha1.StorageVersionSpec" = {
|
"io.k8s.api.apiserverinternal.v1alpha1.StorageVersionSpec" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.api.apiserverinternal.v1alpha1.StorageVersionStatus" = {
|
"io.k8s.api.apiserverinternal.v1alpha1.StorageVersionStatus" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -13140,8 +13147,8 @@ let
|
||||||
Host is the fully qualified domain name of a network host, as defined by RFC 3986. Note the following deviations from the "host" part of the URI as defined in RFC 3986: 1. IPs are not allowed. Currently an IngressRuleValue can only apply to
|
Host is the fully qualified domain name of a network host, as defined by RFC 3986. Note the following deviations from the "host" part of the URI as defined in RFC 3986: 1. IPs are not allowed. Currently an IngressRuleValue can only apply to
|
||||||
the IP in the Spec of the parent Ingress.
|
the IP in the Spec of the parent Ingress.
|
||||||
2. The `:` delimiter is not respected because ports are not allowed.
|
2. The `:` delimiter is not respected because ports are not allowed.
|
||||||
Currently the port of an Ingress is implicitly :80 for http and
|
Currently the port of an Ingress is implicitly :80 for http and
|
||||||
:443 for https.
|
:443 for https.
|
||||||
Both these may change in the future. Incoming requests are matched against the host before the IngressRuleValue. If the host is unspecified, the Ingress routes all traffic based on the specified IngressRuleValue.
|
Both these may change in the future. Incoming requests are matched against the host before the IngressRuleValue. If the host is unspecified, the Ingress routes all traffic based on the specified IngressRuleValue.
|
||||||
|
|
||||||
Host can be "precise" which is a domain name without the terminating dot of a network host (e.g. "foo.bar.com") or "wildcard", which is a domain name prefixed with a single wildcard label (e.g. "*.foo.com"). The wildcard character '*' must appear by itself as the first DNS label and matches only a single label. You cannot have a wildcard label by itself (e.g. Host == "*"). Requests will be matched against the Host field in the following way: 1. If Host is precise, the request matches this rule if the http host header is equal to Host. 2. If Host is a wildcard, then the request matches this rule if the http host header is to equal to the suffix (removing the first label) of the wildcard rule.'';
|
Host can be "precise" which is a domain name without the terminating dot of a network host (e.g. "foo.bar.com") or "wildcard", which is a domain name prefixed with a single wildcard label (e.g. "*.foo.com"). The wildcard character '*' must appear by itself as the first DNS label and matches only a single label. You cannot have a wildcard label by itself (e.g. Host == "*"). Requests will be matched against the Host field in the following way: 1. If Host is precise, the request matches this rule if the http host header is equal to Host. 2. If Host is a wildcard, then the request matches this rule if the http host header is to equal to the suffix (removing the first label) of the wildcard rule.'';
|
||||||
|
|
@ -14588,8 +14595,8 @@ let
|
||||||
Host is the fully qualified domain name of a network host, as defined by RFC 3986. Note the following deviations from the "host" part of the URI as defined in RFC 3986: 1. IPs are not allowed. Currently an IngressRuleValue can only apply to
|
Host is the fully qualified domain name of a network host, as defined by RFC 3986. Note the following deviations from the "host" part of the URI as defined in RFC 3986: 1. IPs are not allowed. Currently an IngressRuleValue can only apply to
|
||||||
the IP in the Spec of the parent Ingress.
|
the IP in the Spec of the parent Ingress.
|
||||||
2. The `:` delimiter is not respected because ports are not allowed.
|
2. The `:` delimiter is not respected because ports are not allowed.
|
||||||
Currently the port of an Ingress is implicitly :80 for http and
|
Currently the port of an Ingress is implicitly :80 for http and
|
||||||
:443 for https.
|
:443 for https.
|
||||||
Both these may change in the future. Incoming requests are matched against the host before the IngressRuleValue. If the host is unspecified, the Ingress routes all traffic based on the specified IngressRuleValue.
|
Both these may change in the future. Incoming requests are matched against the host before the IngressRuleValue. If the host is unspecified, the Ingress routes all traffic based on the specified IngressRuleValue.
|
||||||
|
|
||||||
Host can be "precise" which is a domain name without the terminating dot of a network host (e.g. "foo.bar.com") or "wildcard", which is a domain name prefixed with a single wildcard label (e.g. "*.foo.com"). The wildcard character '*' must appear by itself as the first DNS label and matches only a single label. You cannot have a wildcard label by itself (e.g. Host == "*"). Requests will be matched against the Host field in the following way: 1. If Host is precise, the request matches this rule if the http host header is equal to Host. 2. If Host is a wildcard, then the request matches this rule if the http host header is to equal to the suffix (removing the first label) of the wildcard rule.'';
|
Host can be "precise" which is a domain name without the terminating dot of a network host (e.g. "foo.bar.com") or "wildcard", which is a domain name prefixed with a single wildcard label (e.g. "*.foo.com"). The wildcard character '*' must appear by itself as the first DNS label and matches only a single label. You cannot have a wildcard label by itself (e.g. Host == "*"). Requests will be matched against the Host field in the following way: 1. If Host is precise, the request matches this rule if the http host header is equal to Host. 2. If Host is a wildcard, then the request matches this rule if the http host header is to equal to the suffix (removing the first label) of the wildcard rule.'';
|
||||||
|
|
@ -15142,8 +15149,8 @@ let
|
||||||
Host is the fully qualified domain name of a network host, as defined by RFC 3986. Note the following deviations from the "host" part of the URI as defined in RFC 3986: 1. IPs are not allowed. Currently an IngressRuleValue can only apply to
|
Host is the fully qualified domain name of a network host, as defined by RFC 3986. Note the following deviations from the "host" part of the URI as defined in RFC 3986: 1. IPs are not allowed. Currently an IngressRuleValue can only apply to
|
||||||
the IP in the Spec of the parent Ingress.
|
the IP in the Spec of the parent Ingress.
|
||||||
2. The `:` delimiter is not respected because ports are not allowed.
|
2. The `:` delimiter is not respected because ports are not allowed.
|
||||||
Currently the port of an Ingress is implicitly :80 for http and
|
Currently the port of an Ingress is implicitly :80 for http and
|
||||||
:443 for https.
|
:443 for https.
|
||||||
Both these may change in the future. Incoming requests are matched against the host before the IngressRuleValue. If the host is unspecified, the Ingress routes all traffic based on the specified IngressRuleValue.
|
Both these may change in the future. Incoming requests are matched against the host before the IngressRuleValue. If the host is unspecified, the Ingress routes all traffic based on the specified IngressRuleValue.
|
||||||
|
|
||||||
Host can be "precise" which is a domain name without the terminating dot of a network host (e.g. "foo.bar.com") or "wildcard", which is a domain name prefixed with a single wildcard label (e.g. "*.foo.com"). The wildcard character '*' must appear by itself as the first DNS label and matches only a single label. You cannot have a wildcard label by itself (e.g. Host == "*"). Requests will be matched against the Host field in the following way: 1. If Host is precise, the request matches this rule if the http host header is equal to Host. 2. If Host is a wildcard, then the request matches this rule if the http host header is to equal to the suffix (removing the first label) of the wildcard rule.'';
|
Host can be "precise" which is a domain name without the terminating dot of a network host (e.g. "foo.bar.com") or "wildcard", which is a domain name prefixed with a single wildcard label (e.g. "*.foo.com"). The wildcard character '*' must appear by itself as the first DNS label and matches only a single label. You cannot have a wildcard label by itself (e.g. Host == "*"). Requests will be matched against the Host field in the following way: 1. If Host is precise, the request matches this rule if the http host header is equal to Host. 2. If Host is a wildcard, then the request matches this rule if the http host header is to equal to the suffix (removing the first label) of the wildcard rule.'';
|
||||||
|
|
@ -19062,9 +19069,7 @@ let
|
||||||
config = { "labelSelectorPath" = mkOverride 1002 null; };
|
config = { "labelSelectorPath" = mkOverride 1002 null; };
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.CustomResourceSubresourceStatus" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.CustomResourceSubresourceStatus" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.CustomResourceSubresources" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.CustomResourceSubresources" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -19121,9 +19126,7 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSON" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSON" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSONSchemaProps" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSONSchemaProps" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -19402,15 +19405,9 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSONSchemaPropsOrArray" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSONSchemaPropsOrArray" = { };
|
||||||
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSONSchemaPropsOrBool" = { };
|
||||||
};
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSONSchemaPropsOrStringArray" = { };
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSONSchemaPropsOrBool" = {
|
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSONSchemaPropsOrStringArray" = {
|
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.ServiceReference" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.ServiceReference" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -19899,9 +19896,7 @@ let
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.CustomResourceSubresourceStatus" =
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.CustomResourceSubresourceStatus" =
|
||||||
{
|
{ };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.CustomResourceSubresources" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.CustomResourceSubresources" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -19958,9 +19953,7 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSON" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSON" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSONSchemaProps" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSONSchemaProps" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -20239,15 +20232,9 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSONSchemaPropsOrArray" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSONSchemaPropsOrArray" = { };
|
||||||
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSONSchemaPropsOrBool" = { };
|
||||||
};
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSONSchemaPropsOrStringArray" = { };
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSONSchemaPropsOrBool" = {
|
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSONSchemaPropsOrStringArray" = {
|
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.ServiceReference" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.ServiceReference" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -20316,9 +20303,7 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apimachinery.pkg.api.resource.Quantity" = {
|
"io.k8s.apimachinery.pkg.api.resource.Quantity" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.APIGroup" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.APIGroup" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -20596,9 +20581,7 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.FieldsV1" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.FieldsV1" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.GroupVersionForDiscovery" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.GroupVersionForDiscovery" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -20740,9 +20723,7 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.MicroTime" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.MicroTime" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.ObjectMeta" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.ObjectMeta" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -20906,9 +20887,7 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.Patch" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.Patch" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.Preconditions" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.Preconditions" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -21078,9 +21057,7 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.Time" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.Time" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.WatchEvent" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.WatchEvent" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -21102,12 +21079,8 @@ let
|
||||||
config = { };
|
config = { };
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apimachinery.pkg.runtime.RawExtension" = {
|
"io.k8s.apimachinery.pkg.runtime.RawExtension" = { };
|
||||||
|
"io.k8s.apimachinery.pkg.util.intstr.IntOrString" = { };
|
||||||
};
|
|
||||||
"io.k8s.apimachinery.pkg.util.intstr.IntOrString" = {
|
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apimachinery.pkg.version.Info" = {
|
"io.k8s.apimachinery.pkg.version.Info" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -21530,7 +21503,8 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
in {
|
in
|
||||||
|
{
|
||||||
# all resource versions
|
# all resource versions
|
||||||
options = {
|
options = {
|
||||||
resources = {
|
resources = {
|
||||||
|
|
|
||||||
|
|
@ -5,11 +5,13 @@ with lib;
|
||||||
|
|
||||||
let
|
let
|
||||||
getDefaults = resource: group: version: kind:
|
getDefaults = resource: group: version: kind:
|
||||||
catAttrs "default" (filter (default:
|
catAttrs "default" (filter
|
||||||
(default.resource == null || default.resource == resource)
|
(default:
|
||||||
&& (default.group == null || default.group == group)
|
(default.resource == null || default.resource == resource)
|
||||||
&& (default.version == null || default.version == version)
|
&& (default.group == null || default.group == group)
|
||||||
&& (default.kind == null || default.kind == kind)) config.defaults);
|
&& (default.version == null || default.version == version)
|
||||||
|
&& (default.kind == null || default.kind == kind))
|
||||||
|
config.defaults);
|
||||||
|
|
||||||
types = lib.types // rec {
|
types = lib.types // rec {
|
||||||
str = mkOptionType {
|
str = mkOptionType {
|
||||||
|
|
@ -34,7 +36,8 @@ let
|
||||||
else
|
else
|
||||||
let coerced = coerceFunc val; in assert finalType.check coerced; coerced;
|
let coerced = coerceFunc val; in assert finalType.check coerced; coerced;
|
||||||
|
|
||||||
in finalType.merge loc (map (def: def // { value = coerceVal def.value; }) defs);
|
in
|
||||||
|
finalType.merge loc (map (def: def // { value = coerceVal def.value; }) defs);
|
||||||
getSubOptions = finalType.getSubOptions;
|
getSubOptions = finalType.getSubOptions;
|
||||||
getSubModules = finalType.getSubModules;
|
getSubModules = finalType.getSubModules;
|
||||||
substSubModules = m: coercedTo coercedType coerceFunc (finalType.substSubModules m);
|
substSubModules = m: coercedTo coercedType coerceFunc (finalType.substSubModules m);
|
||||||
|
|
@ -46,11 +49,15 @@ let
|
||||||
mkOptionDefault = mkOverride 1001;
|
mkOptionDefault = mkOverride 1001;
|
||||||
|
|
||||||
mergeValuesByKey = mergeKey: values:
|
mergeValuesByKey = mergeKey: values:
|
||||||
listToAttrs (map (value:
|
listToAttrs (map
|
||||||
nameValuePair (if isAttrs value.${mergeKey} then
|
(value:
|
||||||
toString value.${mergeKey}.content
|
nameValuePair
|
||||||
else
|
(if isAttrs value.${mergeKey} then
|
||||||
(toString value.${mergeKey})) value) values);
|
toString value.${mergeKey}.content
|
||||||
|
else
|
||||||
|
(toString value.${mergeKey}))
|
||||||
|
value)
|
||||||
|
values);
|
||||||
|
|
||||||
submoduleOf = ref:
|
submoduleOf = ref:
|
||||||
types.submodule ({ name, ... }: {
|
types.submodule ({ name, ... }: {
|
||||||
|
|
@ -63,7 +70,8 @@ let
|
||||||
let
|
let
|
||||||
convertName = name:
|
convertName = name:
|
||||||
if definitions."${ref}".options.${mergeKey}.type == types.int then toInt name else name;
|
if definitions."${ref}".options.${mergeKey}.type == types.int then toInt name else name;
|
||||||
in {
|
in
|
||||||
|
{
|
||||||
options = definitions."${ref}".options;
|
options = definitions."${ref}".options;
|
||||||
config = definitions."${ref}".config // {
|
config = definitions."${ref}".config // {
|
||||||
${mergeKey} = mkOverride 1002 (convertName name);
|
${mergeKey} = mkOverride 1002 (convertName name);
|
||||||
|
|
@ -72,7 +80,8 @@ let
|
||||||
|
|
||||||
submoduleForDefinition = ref: resource: kind: group: version:
|
submoduleForDefinition = ref: resource: kind: group: version:
|
||||||
let apiVersion = if group == "core" then version else "${group}/${version}";
|
let apiVersion = if group == "core" then version else "${group}/${version}";
|
||||||
in types.submodule ({ name, ... }: {
|
in
|
||||||
|
types.submodule ({ name, ... }: {
|
||||||
imports = getDefaults resource group version kind;
|
imports = getDefaults resource group version kind;
|
||||||
options = definitions."${ref}".options;
|
options = definitions."${ref}".options;
|
||||||
config = mkMerge [
|
config = mkMerge [
|
||||||
|
|
@ -1145,9 +1154,7 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.api.apiserverinternal.v1alpha1.StorageVersionSpec" = {
|
"io.k8s.api.apiserverinternal.v1alpha1.StorageVersionSpec" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.api.apiserverinternal.v1alpha1.StorageVersionStatus" = {
|
"io.k8s.api.apiserverinternal.v1alpha1.StorageVersionStatus" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -13478,8 +13485,8 @@ let
|
||||||
Host is the fully qualified domain name of a network host, as defined by RFC 3986. Note the following deviations from the "host" part of the URI as defined in RFC 3986: 1. IPs are not allowed. Currently an IngressRuleValue can only apply to
|
Host is the fully qualified domain name of a network host, as defined by RFC 3986. Note the following deviations from the "host" part of the URI as defined in RFC 3986: 1. IPs are not allowed. Currently an IngressRuleValue can only apply to
|
||||||
the IP in the Spec of the parent Ingress.
|
the IP in the Spec of the parent Ingress.
|
||||||
2. The `:` delimiter is not respected because ports are not allowed.
|
2. The `:` delimiter is not respected because ports are not allowed.
|
||||||
Currently the port of an Ingress is implicitly :80 for http and
|
Currently the port of an Ingress is implicitly :80 for http and
|
||||||
:443 for https.
|
:443 for https.
|
||||||
Both these may change in the future. Incoming requests are matched against the host before the IngressRuleValue. If the host is unspecified, the Ingress routes all traffic based on the specified IngressRuleValue.
|
Both these may change in the future. Incoming requests are matched against the host before the IngressRuleValue. If the host is unspecified, the Ingress routes all traffic based on the specified IngressRuleValue.
|
||||||
|
|
||||||
Host can be "precise" which is a domain name without the terminating dot of a network host (e.g. "foo.bar.com") or "wildcard", which is a domain name prefixed with a single wildcard label (e.g. "*.foo.com"). The wildcard character '*' must appear by itself as the first DNS label and matches only a single label. You cannot have a wildcard label by itself (e.g. Host == "*"). Requests will be matched against the Host field in the following way: 1. If Host is precise, the request matches this rule if the http host header is equal to Host. 2. If Host is a wildcard, then the request matches this rule if the http host header is to equal to the suffix (removing the first label) of the wildcard rule.'';
|
Host can be "precise" which is a domain name without the terminating dot of a network host (e.g. "foo.bar.com") or "wildcard", which is a domain name prefixed with a single wildcard label (e.g. "*.foo.com"). The wildcard character '*' must appear by itself as the first DNS label and matches only a single label. You cannot have a wildcard label by itself (e.g. Host == "*"). Requests will be matched against the Host field in the following way: 1. If Host is precise, the request matches this rule if the http host header is equal to Host. 2. If Host is a wildcard, then the request matches this rule if the http host header is to equal to the suffix (removing the first label) of the wildcard rule.'';
|
||||||
|
|
@ -14405,8 +14412,8 @@ let
|
||||||
Host is the fully qualified domain name of a network host, as defined by RFC 3986. Note the following deviations from the "host" part of the URI as defined in RFC 3986: 1. IPs are not allowed. Currently an IngressRuleValue can only apply to
|
Host is the fully qualified domain name of a network host, as defined by RFC 3986. Note the following deviations from the "host" part of the URI as defined in RFC 3986: 1. IPs are not allowed. Currently an IngressRuleValue can only apply to
|
||||||
the IP in the Spec of the parent Ingress.
|
the IP in the Spec of the parent Ingress.
|
||||||
2. The `:` delimiter is not respected because ports are not allowed.
|
2. The `:` delimiter is not respected because ports are not allowed.
|
||||||
Currently the port of an Ingress is implicitly :80 for http and
|
Currently the port of an Ingress is implicitly :80 for http and
|
||||||
:443 for https.
|
:443 for https.
|
||||||
Both these may change in the future. Incoming requests are matched against the host before the IngressRuleValue. If the host is unspecified, the Ingress routes all traffic based on the specified IngressRuleValue.
|
Both these may change in the future. Incoming requests are matched against the host before the IngressRuleValue. If the host is unspecified, the Ingress routes all traffic based on the specified IngressRuleValue.
|
||||||
|
|
||||||
Host can be "precise" which is a domain name without the terminating dot of a network host (e.g. "foo.bar.com") or "wildcard", which is a domain name prefixed with a single wildcard label (e.g. "*.foo.com"). The wildcard character '*' must appear by itself as the first DNS label and matches only a single label. You cannot have a wildcard label by itself (e.g. Host == "*"). Requests will be matched against the Host field in the following way: 1. If Host is precise, the request matches this rule if the http host header is equal to Host. 2. If Host is a wildcard, then the request matches this rule if the http host header is to equal to the suffix (removing the first label) of the wildcard rule.'';
|
Host can be "precise" which is a domain name without the terminating dot of a network host (e.g. "foo.bar.com") or "wildcard", which is a domain name prefixed with a single wildcard label (e.g. "*.foo.com"). The wildcard character '*' must appear by itself as the first DNS label and matches only a single label. You cannot have a wildcard label by itself (e.g. Host == "*"). Requests will be matched against the Host field in the following way: 1. If Host is precise, the request matches this rule if the http host header is equal to Host. 2. If Host is a wildcard, then the request matches this rule if the http host header is to equal to the suffix (removing the first label) of the wildcard rule.'';
|
||||||
|
|
@ -15001,8 +15008,8 @@ let
|
||||||
Host is the fully qualified domain name of a network host, as defined by RFC 3986. Note the following deviations from the "host" part of the URI as defined in RFC 3986: 1. IPs are not allowed. Currently an IngressRuleValue can only apply to
|
Host is the fully qualified domain name of a network host, as defined by RFC 3986. Note the following deviations from the "host" part of the URI as defined in RFC 3986: 1. IPs are not allowed. Currently an IngressRuleValue can only apply to
|
||||||
the IP in the Spec of the parent Ingress.
|
the IP in the Spec of the parent Ingress.
|
||||||
2. The `:` delimiter is not respected because ports are not allowed.
|
2. The `:` delimiter is not respected because ports are not allowed.
|
||||||
Currently the port of an Ingress is implicitly :80 for http and
|
Currently the port of an Ingress is implicitly :80 for http and
|
||||||
:443 for https.
|
:443 for https.
|
||||||
Both these may change in the future. Incoming requests are matched against the host before the IngressRuleValue. If the host is unspecified, the Ingress routes all traffic based on the specified IngressRuleValue.
|
Both these may change in the future. Incoming requests are matched against the host before the IngressRuleValue. If the host is unspecified, the Ingress routes all traffic based on the specified IngressRuleValue.
|
||||||
|
|
||||||
Host can be "precise" which is a domain name without the terminating dot of a network host (e.g. "foo.bar.com") or "wildcard", which is a domain name prefixed with a single wildcard label (e.g. "*.foo.com"). The wildcard character '*' must appear by itself as the first DNS label and matches only a single label. You cannot have a wildcard label by itself (e.g. Host == "*"). Requests will be matched against the Host field in the following way: 1. If Host is precise, the request matches this rule if the http host header is equal to Host. 2. If Host is a wildcard, then the request matches this rule if the http host header is to equal to the suffix (removing the first label) of the wildcard rule.'';
|
Host can be "precise" which is a domain name without the terminating dot of a network host (e.g. "foo.bar.com") or "wildcard", which is a domain name prefixed with a single wildcard label (e.g. "*.foo.com"). The wildcard character '*' must appear by itself as the first DNS label and matches only a single label. You cannot have a wildcard label by itself (e.g. Host == "*"). Requests will be matched against the Host field in the following way: 1. If Host is precise, the request matches this rule if the http host header is equal to Host. 2. If Host is a wildcard, then the request matches this rule if the http host header is to equal to the suffix (removing the first label) of the wildcard rule.'';
|
||||||
|
|
@ -19285,9 +19292,7 @@ let
|
||||||
config = { "labelSelectorPath" = mkOverride 1002 null; };
|
config = { "labelSelectorPath" = mkOverride 1002 null; };
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.CustomResourceSubresourceStatus" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.CustomResourceSubresourceStatus" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.CustomResourceSubresources" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.CustomResourceSubresources" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -19344,9 +19349,7 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSON" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSON" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSONSchemaProps" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSONSchemaProps" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -19625,15 +19628,9 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSONSchemaPropsOrArray" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSONSchemaPropsOrArray" = { };
|
||||||
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSONSchemaPropsOrBool" = { };
|
||||||
};
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSONSchemaPropsOrStringArray" = { };
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSONSchemaPropsOrBool" = {
|
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.JSONSchemaPropsOrStringArray" = {
|
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.ServiceReference" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1.ServiceReference" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -20122,9 +20119,7 @@ let
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.CustomResourceSubresourceStatus" =
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.CustomResourceSubresourceStatus" =
|
||||||
{
|
{ };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.CustomResourceSubresources" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.CustomResourceSubresources" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -20181,9 +20176,7 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSON" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSON" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSONSchemaProps" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSONSchemaProps" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -20462,15 +20455,9 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSONSchemaPropsOrArray" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSONSchemaPropsOrArray" = { };
|
||||||
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSONSchemaPropsOrBool" = { };
|
||||||
};
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSONSchemaPropsOrStringArray" = { };
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSONSchemaPropsOrBool" = {
|
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.JSONSchemaPropsOrStringArray" = {
|
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.ServiceReference" = {
|
"io.k8s.apiextensions-apiserver.pkg.apis.apiextensions.v1beta1.ServiceReference" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -20539,9 +20526,7 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apimachinery.pkg.api.resource.Quantity" = {
|
"io.k8s.apimachinery.pkg.api.resource.Quantity" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.APIGroup" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.APIGroup" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -20819,9 +20804,7 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.FieldsV1" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.FieldsV1" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.GroupVersionForDiscovery" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.GroupVersionForDiscovery" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -20963,9 +20946,7 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.MicroTime" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.MicroTime" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.ObjectMeta" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.ObjectMeta" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -21129,9 +21110,7 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.Patch" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.Patch" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.Preconditions" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.Preconditions" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -21301,9 +21280,7 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.Time" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.Time" = { };
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apimachinery.pkg.apis.meta.v1.WatchEvent" = {
|
"io.k8s.apimachinery.pkg.apis.meta.v1.WatchEvent" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -21325,12 +21302,8 @@ let
|
||||||
config = { };
|
config = { };
|
||||||
|
|
||||||
};
|
};
|
||||||
"io.k8s.apimachinery.pkg.runtime.RawExtension" = {
|
"io.k8s.apimachinery.pkg.runtime.RawExtension" = { };
|
||||||
|
"io.k8s.apimachinery.pkg.util.intstr.IntOrString" = { };
|
||||||
};
|
|
||||||
"io.k8s.apimachinery.pkg.util.intstr.IntOrString" = {
|
|
||||||
|
|
||||||
};
|
|
||||||
"io.k8s.apimachinery.pkg.version.Info" = {
|
"io.k8s.apimachinery.pkg.version.Info" = {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
|
|
@ -21753,7 +21726,8 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
in {
|
in
|
||||||
|
{
|
||||||
# all resource versions
|
# all resource versions
|
||||||
options = {
|
options = {
|
||||||
resources = {
|
resources = {
|
||||||
|
|
|
||||||
|
|
@ -5,7 +5,7 @@ with import ../../lib/docker { inherit lib pkgs; };
|
||||||
let
|
let
|
||||||
testing = config.testing;
|
testing = config.testing;
|
||||||
|
|
||||||
allImages = unique ( flatten (map (t: t.evaled.config.docker.export or [ ]) testing.tests));
|
allImages = unique (flatten (map (t: t.evaled.config.docker.export or [ ]) testing.tests));
|
||||||
|
|
||||||
cfg = config.testing.docker;
|
cfg = config.testing.docker;
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue