diff --git a/Makefile b/Makefile index d34b4d18..8df35975 100644 --- a/Makefile +++ b/Makefile @@ -3,7 +3,7 @@ # To re-generate a bundle for another specific version without changing the standard setup, you can: # - use the VERSION as arg of the bundle target (e.g make bundle VERSION=0.0.2) # - use environment variables to overwrite this value (e.g export VERSION=0.0.2) -VERSION ?= 0.13.2-alpha.1 +VERSION ?= 0.13.2-alpha.2 # CHANNELS define the bundle channels used in the bundle. # Add a new line here if you would like to change its default config. (E.g CHANNELS = "candidate,fast,stable") @@ -272,7 +272,7 @@ bundle-push: ## Push the bundle image. $(MAKE) docker-push IMG=$(BUNDLE_IMG) .PHONY: opm -OPM = ./bin/opm +OPM = $(LOCALBIN)/opm opm: ## Download opm locally if necessary. ifeq (,$(wildcard $(OPM))) ifeq (,$(shell which opm 2>/dev/null)) @@ -395,6 +395,7 @@ run-ds: manifests generate fmt vet go-generate tmp/certs --server-certificate-path tmp/certs/server \ --ca-certificate-path tmp/certs/ca \ --client-certificate-path tmp/certs/client \ + --metrics-bind-address :8383 --debug run-envoy: ## runs an envoy process in a container that will try to connect to a local discovery service diff --git a/bundle/manifests/marin3r.3scale.net_envoyconfigrevisions.yaml b/bundle/manifests/marin3r.3scale.net_envoyconfigrevisions.yaml index 2ba67f40..e869d2a8 100644 --- a/bundle/manifests/marin3r.3scale.net_envoyconfigrevisions.yaml +++ b/bundle/manifests/marin3r.3scale.net_envoyconfigrevisions.yaml @@ -2,7 +2,7 @@ apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.11.3 + controller-gen.kubebuilder.io/version: v0.14.0 creationTimestamp: null name: envoyconfigrevisions.marin3r.3scale.net spec: @@ -43,20 +43,25 @@ spec: name: v1alpha1 schema: openAPIV3Schema: - description: EnvoyConfigRevision is an internal resource that stores a specific - version of an EnvoyConfig resource. EnvoyConfigRevisions are automatically - created and deleted by the EnvoyConfig controller and are not intended to - be directly used. Use EnvoyConfig objects instead. + description: |- + EnvoyConfigRevision is an internal resource that stores a specific version of an EnvoyConfig + resource. EnvoyConfigRevisions are automatically created and deleted by the EnvoyConfig + controller and are not intended to be directly used. Use EnvoyConfig objects instead. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation - of an object. Servers should convert recognized schemas to the latest - internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: |- + APIVersion defines the versioned schema of this representation of an object. + Servers should convert recognized schemas to the latest internal value, and + may reject unrecognized values. + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources type: string kind: - description: 'Kind is a string value representing the REST resource this - object represents. Servers may infer this from the endpoint the client - submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: |- + Kind is a string value representing the REST resource this object represents. + Servers may infer this from the endpoint the client submits requests to. + Cannot be updated. + In CamelCase. + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds type: string metadata: type: object @@ -74,19 +79,21 @@ spec: suported by the envoy discovery service properties: clusters: - description: 'Clusters is a list of the envoy Cluster resource - type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/cluster/v3/cluster.proto' + description: |- + Clusters is a list of the envoy Cluster resource type. + API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/cluster/v3/cluster.proto items: - description: EnvoyResource holds serialized representation of - an envoy resource + description: |- + EnvoyResource holds serialized representation of an envoy + resource properties: name: - description: 'Name of the envoy resource. DEPRECATED: this - field has no effect and will be removed in an upcoming - release. The name of the resources for discovery purposes - is included in the resource itself. Refer to the envoy - API reference to check how the name is specified for each - resource type.' + description: |- + Name of the envoy resource. + DEPRECATED: this field has no effect and will be removed in an + upcoming release. The name of the resources for discovery purposes + is included in the resource itself. Refer to the envoy API reference + to check how the name is specified for each resource type. type: string value: description: Value is the serialized representation of the @@ -97,19 +104,21 @@ spec: type: object type: array endpoints: - description: 'Endpoints is a list of the envoy ClusterLoadAssignment - resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/endpoint/v3/endpoint.proto' + description: |- + Endpoints is a list of the envoy ClusterLoadAssignment resource type. + API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/endpoint/v3/endpoint.proto items: - description: EnvoyResource holds serialized representation of - an envoy resource + description: |- + EnvoyResource holds serialized representation of an envoy + resource properties: name: - description: 'Name of the envoy resource. DEPRECATED: this - field has no effect and will be removed in an upcoming - release. The name of the resources for discovery purposes - is included in the resource itself. Refer to the envoy - API reference to check how the name is specified for each - resource type.' + description: |- + Name of the envoy resource. + DEPRECATED: this field has no effect and will be removed in an + upcoming release. The name of the resources for discovery purposes + is included in the resource itself. Refer to the envoy API reference + to check how the name is specified for each resource type. type: string value: description: Value is the serialized representation of the @@ -120,19 +129,21 @@ spec: type: object type: array extensionConfigs: - description: 'ExtensionConfigs is a list of the envoy ExtensionConfig - resource type API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/core/v3/extension.proto' + description: |- + ExtensionConfigs is a list of the envoy ExtensionConfig resource type + API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/core/v3/extension.proto items: - description: EnvoyResource holds serialized representation of - an envoy resource + description: |- + EnvoyResource holds serialized representation of an envoy + resource properties: name: - description: 'Name of the envoy resource. DEPRECATED: this - field has no effect and will be removed in an upcoming - release. The name of the resources for discovery purposes - is included in the resource itself. Refer to the envoy - API reference to check how the name is specified for each - resource type.' + description: |- + Name of the envoy resource. + DEPRECATED: this field has no effect and will be removed in an + upcoming release. The name of the resources for discovery purposes + is included in the resource itself. Refer to the envoy API reference + to check how the name is specified for each resource type. type: string value: description: Value is the serialized representation of the @@ -143,19 +154,21 @@ spec: type: object type: array listeners: - description: 'Listeners is a list of the envoy Listener resource - type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/listener/v3/listener.proto' + description: |- + Listeners is a list of the envoy Listener resource type. + API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/listener/v3/listener.proto items: - description: EnvoyResource holds serialized representation of - an envoy resource + description: |- + EnvoyResource holds serialized representation of an envoy + resource properties: name: - description: 'Name of the envoy resource. DEPRECATED: this - field has no effect and will be removed in an upcoming - release. The name of the resources for discovery purposes - is included in the resource itself. Refer to the envoy - API reference to check how the name is specified for each - resource type.' + description: |- + Name of the envoy resource. + DEPRECATED: this field has no effect and will be removed in an + upcoming release. The name of the resources for discovery purposes + is included in the resource itself. Refer to the envoy API reference + to check how the name is specified for each resource type. type: string value: description: Value is the serialized representation of the @@ -166,19 +179,21 @@ spec: type: object type: array routes: - description: 'Routes is a list of the envoy Route resource type. - API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/route/v3/route.proto' + description: |- + Routes is a list of the envoy Route resource type. + API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/route/v3/route.proto items: - description: EnvoyResource holds serialized representation of - an envoy resource + description: |- + EnvoyResource holds serialized representation of an envoy + resource properties: name: - description: 'Name of the envoy resource. DEPRECATED: this - field has no effect and will be removed in an upcoming - release. The name of the resources for discovery purposes - is included in the resource itself. Refer to the envoy - API reference to check how the name is specified for each - resource type.' + description: |- + Name of the envoy resource. + DEPRECATED: this field has no effect and will be removed in an + upcoming release. The name of the resources for discovery purposes + is included in the resource itself. Refer to the envoy API reference + to check how the name is specified for each resource type. type: string value: description: Value is the serialized representation of the @@ -189,19 +204,21 @@ spec: type: object type: array runtimes: - description: 'Runtimes is a list of the envoy Runtime resource - type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/service/runtime/v3/rtds.proto' + description: |- + Runtimes is a list of the envoy Runtime resource type. + API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/service/runtime/v3/rtds.proto items: - description: EnvoyResource holds serialized representation of - an envoy resource + description: |- + EnvoyResource holds serialized representation of an envoy + resource properties: name: - description: 'Name of the envoy resource. DEPRECATED: this - field has no effect and will be removed in an upcoming - release. The name of the resources for discovery purposes - is included in the resource itself. Refer to the envoy - API reference to check how the name is specified for each - resource type.' + description: |- + Name of the envoy resource. + DEPRECATED: this field has no effect and will be removed in an + upcoming release. The name of the resources for discovery purposes + is included in the resource itself. Refer to the envoy API reference + to check how the name is specified for each resource type. type: string value: description: Value is the serialized representation of the @@ -212,19 +229,21 @@ spec: type: object type: array scopedRoutes: - description: 'ScopedRoutes is a list of the envoy ScopeRoute resource - type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/route/v3/scoped_route.proto' + description: |- + ScopedRoutes is a list of the envoy ScopeRoute resource type. + API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/route/v3/scoped_route.proto items: - description: EnvoyResource holds serialized representation of - an envoy resource + description: |- + EnvoyResource holds serialized representation of an envoy + resource properties: name: - description: 'Name of the envoy resource. DEPRECATED: this - field has no effect and will be removed in an upcoming - release. The name of the resources for discovery purposes - is included in the resource itself. Refer to the envoy - API reference to check how the name is specified for each - resource type.' + description: |- + Name of the envoy resource. + DEPRECATED: this field has no effect and will be removed in an + upcoming release. The name of the resources for discovery purposes + is included in the resource itself. Refer to the envoy API reference + to check how the name is specified for each resource type. type: string value: description: Value is the serialized representation of the @@ -238,19 +257,20 @@ spec: description: Secrets is a list of references to Kubernetes Secret objects. items: - description: EnvoySecretResource holds a reference to a k8s - Secret from where to take a secret from. Only Secrets within - the same namespace can be referred. + description: |- + EnvoySecretResource holds a reference to a k8s Secret from where + to take a secret from. Only Secrets within the same namespace can + be referred. properties: name: - description: Name of the envoy tslCerticate secret resource. - The certificate will be fetched from a Kubernetes Secrets - of type 'kubernetes.io/tls' with this same name. + description: |- + Name of the envoy tslCerticate secret resource. The certificate will be fetched + from a Kubernetes Secrets of type 'kubernetes.io/tls' with this same name. type: string ref: - description: 'DEPRECATED: this field is deprecated and it''s - value will be ignored. The ''name'' of the Kubernetes - Secret must match the ''name'' field.' + description: |- + DEPRECATED: this field is deprecated and it's value will be ignored. The 'name' of the + Kubernetes Secret must match the 'name' field. properties: name: description: name is unique within a namespace to reference @@ -268,43 +288,45 @@ spec: type: array type: object nodeID: - description: NodeID holds the envoy identifier for the discovery service - to know which set of resources to send to each of the envoy clients - that connect to it. + description: |- + NodeID holds the envoy identifier for the discovery service to know which set + of resources to send to each of the envoy clients that connect to it. type: string resources: description: Resources holds the different types of resources suported by the envoy discovery service items: - description: Resource holds serialized representation of an envoy + description: |- + Resource holds serialized representation of an envoy resource properties: blueprint: - description: Blueprint specifies a template to generate a configuration - proto. It is currently only supported to generate secret configuration - resources from k8s Secrets + description: |- + Blueprint specifies a template to generate a configuration proto. It is currently + only supported to generate secret configuration resources from k8s Secrets enum: - tlsCertificate - validationContext type: string generateFromEndpointSlices: - description: Specifies a label selector to watch for EndpointSlices - that will be used to generate the endpoint resource + description: |- + Specifies a label selector to watch for EndpointSlices that will + be used to generate the endpoint resource properties: clusterName: type: string selector: - description: A label selector is a label query over a set - of resources. The result of matchLabels and matchExpressions - are ANDed. An empty label selector matches all objects. - A null label selector matches no objects. + description: |- + A label selector is a label query over a set of resources. The result of matchLabels and + matchExpressions are ANDed. An empty label selector matches all objects. A null + label selector matches no objects. properties: matchExpressions: description: matchExpressions is a list of label selector requirements. The requirements are ANDed. items: - description: A label selector requirement is a selector - that contains values, a key, and an operator that + description: |- + A label selector requirement is a selector that contains values, a key, and an operator that relates the key and values. properties: key: @@ -312,17 +334,16 @@ spec: applies to. type: string operator: - description: operator represents a key's relationship - to a set of values. Valid operators are In, - NotIn, Exists and DoesNotExist. + description: |- + operator represents a key's relationship to a set of values. + Valid operators are In, NotIn, Exists and DoesNotExist. type: string values: - description: values is an array of string values. - If the operator is In or NotIn, the values array - must be non-empty. If the operator is Exists - or DoesNotExist, the values array must be empty. - This array is replaced during a strategic merge - patch. + description: |- + values is an array of string values. If the operator is In or NotIn, + the values array must be non-empty. If the operator is Exists or DoesNotExist, + the values array must be empty. This array is replaced during a strategic + merge patch. items: type: string type: array @@ -334,11 +355,10 @@ spec: matchLabels: additionalProperties: type: string - description: matchLabels is a map of {key,value} pairs. - A single {key,value} in the matchLabels map is equivalent - to an element of matchExpressions, whose key field - is "key", the operator is "In", and the values array - contains only "value". The requirements are ANDed. + description: |- + matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels + map is equivalent to an element of matchExpressions, whose key field is "key", the + operator is "In", and the values array contains only "value". The requirements are ANDed. type: object type: object x-kubernetes-map-type: atomic @@ -350,8 +370,9 @@ spec: - targetPort type: object generateFromOpaqueSecret: - description: The name of a Kubernetes Secret of type "Opaque". - It will generate an envoy "generic secret" proto. + description: |- + The name of a Kubernetes Secret of type "Opaque". It will generate an + envoy "generic secret" proto. properties: alias: description: A unique name to refer to the name:key combination @@ -385,9 +406,10 @@ spec: - extensionConfig type: string value: - description: Value is the protobufer message that configures - the resource. The proto must match the envoy configuration - API v3 specification for the given resource type (https://www.envoyproxy.io/docs/envoy/latest/api-docs/xds_protocol#resource-types) + description: |- + Value is the protobufer message that configures the resource. The proto + must match the envoy configuration API v3 specification for the given resource + type (https://www.envoyproxy.io/docs/envoy/latest/api-docs/xds_protocol#resource-types) type: object x-kubernetes-preserve-unknown-fields: true required: @@ -395,9 +417,9 @@ spec: type: object type: array serialization: - description: Serialization specicifies the serialization format used - to describe the resources. "json" and "yaml" are supported. "json" - is used if unset. + description: |- + Serialization specicifies the serialization format used to describe the resources. "json" and "yaml" + are supported. "json" is used if unset. enum: - json - b64json @@ -418,42 +440,42 @@ spec: of an object's state items: description: "Condition contains details for one aspect of the current - state of this API Resource. --- This struct is intended for direct - use as an array at the field path .status.conditions. For example, - \n type FooStatus struct{ // Represents the observations of a - foo's current state. // Known .status.conditions.type are: \"Available\", - \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge - // +listType=map // +listMapKey=type Conditions []metav1.Condition - `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" - protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }" + state of this API Resource.\n---\nThis struct is intended for + direct use as an array at the field path .status.conditions. For + example,\n\n\n\ttype FooStatus struct{\n\t // Represents the + observations of a foo's current state.\n\t // Known .status.conditions.type + are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // + +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t + \ // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" + patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t + \ // other fields\n\t}" properties: lastTransitionTime: - description: lastTransitionTime is the last time the condition - transitioned from one status to another. This should be when - the underlying condition changed. If that is not known, then - using the time when the API field changed is acceptable. + description: |- + lastTransitionTime is the last time the condition transitioned from one status to another. + This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable. format: date-time type: string message: - description: message is a human readable message indicating - details about the transition. This may be an empty string. + description: |- + message is a human readable message indicating details about the transition. + This may be an empty string. maxLength: 32768 type: string observedGeneration: - description: observedGeneration represents the .metadata.generation - that the condition was set based upon. For instance, if .metadata.generation - is currently 12, but the .status.conditions[x].observedGeneration - is 9, the condition is out of date with respect to the current - state of the instance. + description: |- + observedGeneration represents the .metadata.generation that the condition was set based upon. + For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date + with respect to the current state of the instance. format: int64 minimum: 0 type: integer reason: - description: reason contains a programmatic identifier indicating - the reason for the condition's last transition. Producers - of specific condition types may define expected values and - meanings for this field, and whether the values are considered - a guaranteed API. The value should be a CamelCase string. + description: |- + reason contains a programmatic identifier indicating the reason for the condition's last transition. + Producers of specific condition types may define expected values and meanings for this field, + and whether the values are considered a guaranteed API. + The value should be a CamelCase string. This field may not be empty. maxLength: 1024 minLength: 1 @@ -467,11 +489,12 @@ spec: - Unknown type: string type: - description: type of condition in CamelCase or in foo.example.com/CamelCase. - --- Many .condition.type values are consistent across resources - like Available, but because arbitrary conditions can be useful - (see .node.status.conditions), the ability to deconflict is - important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt) + description: |- + type of condition in CamelCase or in foo.example.com/CamelCase. + --- + Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be + useful (see .node.status.conditions), the ability to deconflict is important. + The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt) maxLength: 316 pattern: ^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$ type: string @@ -484,13 +507,15 @@ spec: type: object type: array lastPublishedAt: - description: LastPublishedAt indicates the last time this config review - transitioned to published + description: |- + LastPublishedAt indicates the last time this config review transitioned to + published format: date-time type: string providesVersions: - description: ProvidesVersions keeps track of the version that this - revision publishes in the xDS server for each resource type + description: |- + ProvidesVersions keeps track of the version that this revision + publishes in the xDS server for each resource type properties: clusters: type: string @@ -510,12 +535,14 @@ spec: type: string type: object published: - description: Published signals if the EnvoyConfigRevision is the one - currently published in the xds server cache + description: |- + Published signals if the EnvoyConfigRevision is the one currently published + in the xds server cache type: boolean tainted: - description: Tainted indicates whether the EnvoyConfigRevision is - eligible for publishing or not + description: |- + Tainted indicates whether the EnvoyConfigRevision is eligible for publishing + or not type: boolean type: object type: object diff --git a/bundle/manifests/marin3r.3scale.net_envoyconfigs.yaml b/bundle/manifests/marin3r.3scale.net_envoyconfigs.yaml index da730ad7..24f24c1b 100644 --- a/bundle/manifests/marin3r.3scale.net_envoyconfigs.yaml +++ b/bundle/manifests/marin3r.3scale.net_envoyconfigs.yaml @@ -2,7 +2,7 @@ apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.11.3 + controller-gen.kubebuilder.io/version: v0.14.0 creationTimestamp: null name: envoyconfigs.marin3r.3scale.net spec: @@ -35,20 +35,26 @@ spec: name: v1alpha1 schema: openAPIV3Schema: - description: EnvoyConfig holds the configuration for a given envoy nodeID. - The spec of an EnvoyConfig object holds the Envoy resources that conform - the desired configuration for the given nodeID and that the discovery service - will send to any envoy client that identifies itself with that nodeID. + description: |- + EnvoyConfig holds the configuration for a given envoy nodeID. The spec of an EnvoyConfig + object holds the Envoy resources that conform the desired configuration for the given nodeID + and that the discovery service will send to any envoy client that identifies itself with that + nodeID. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation - of an object. Servers should convert recognized schemas to the latest - internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: |- + APIVersion defines the versioned schema of this representation of an object. + Servers should convert recognized schemas to the latest internal value, and + may reject unrecognized values. + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources type: string kind: - description: 'Kind is a string value representing the REST resource this - object represents. Servers may infer this from the endpoint the client - submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: |- + Kind is a string value representing the REST resource this object represents. + Servers may infer this from the endpoint the client submits requests to. + Cannot be updated. + In CamelCase. + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds type: string metadata: type: object @@ -62,24 +68,26 @@ spec: - v3 type: string envoyResources: - description: EnvoyResources holds the different types of resources - suported by the envoy discovery service DEPRECATED. Use the `resources` - field instead. + description: |- + EnvoyResources holds the different types of resources suported by the envoy discovery service + DEPRECATED. Use the `resources` field instead. properties: clusters: - description: 'Clusters is a list of the envoy Cluster resource - type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/cluster/v3/cluster.proto' + description: |- + Clusters is a list of the envoy Cluster resource type. + API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/cluster/v3/cluster.proto items: - description: EnvoyResource holds serialized representation of - an envoy resource + description: |- + EnvoyResource holds serialized representation of an envoy + resource properties: name: - description: 'Name of the envoy resource. DEPRECATED: this - field has no effect and will be removed in an upcoming - release. The name of the resources for discovery purposes - is included in the resource itself. Refer to the envoy - API reference to check how the name is specified for each - resource type.' + description: |- + Name of the envoy resource. + DEPRECATED: this field has no effect and will be removed in an + upcoming release. The name of the resources for discovery purposes + is included in the resource itself. Refer to the envoy API reference + to check how the name is specified for each resource type. type: string value: description: Value is the serialized representation of the @@ -90,19 +98,21 @@ spec: type: object type: array endpoints: - description: 'Endpoints is a list of the envoy ClusterLoadAssignment - resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/endpoint/v3/endpoint.proto' + description: |- + Endpoints is a list of the envoy ClusterLoadAssignment resource type. + API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/endpoint/v3/endpoint.proto items: - description: EnvoyResource holds serialized representation of - an envoy resource + description: |- + EnvoyResource holds serialized representation of an envoy + resource properties: name: - description: 'Name of the envoy resource. DEPRECATED: this - field has no effect and will be removed in an upcoming - release. The name of the resources for discovery purposes - is included in the resource itself. Refer to the envoy - API reference to check how the name is specified for each - resource type.' + description: |- + Name of the envoy resource. + DEPRECATED: this field has no effect and will be removed in an + upcoming release. The name of the resources for discovery purposes + is included in the resource itself. Refer to the envoy API reference + to check how the name is specified for each resource type. type: string value: description: Value is the serialized representation of the @@ -113,19 +123,21 @@ spec: type: object type: array extensionConfigs: - description: 'ExtensionConfigs is a list of the envoy ExtensionConfig - resource type API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/core/v3/extension.proto' + description: |- + ExtensionConfigs is a list of the envoy ExtensionConfig resource type + API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/core/v3/extension.proto items: - description: EnvoyResource holds serialized representation of - an envoy resource + description: |- + EnvoyResource holds serialized representation of an envoy + resource properties: name: - description: 'Name of the envoy resource. DEPRECATED: this - field has no effect and will be removed in an upcoming - release. The name of the resources for discovery purposes - is included in the resource itself. Refer to the envoy - API reference to check how the name is specified for each - resource type.' + description: |- + Name of the envoy resource. + DEPRECATED: this field has no effect and will be removed in an + upcoming release. The name of the resources for discovery purposes + is included in the resource itself. Refer to the envoy API reference + to check how the name is specified for each resource type. type: string value: description: Value is the serialized representation of the @@ -136,19 +148,21 @@ spec: type: object type: array listeners: - description: 'Listeners is a list of the envoy Listener resource - type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/listener/v3/listener.proto' + description: |- + Listeners is a list of the envoy Listener resource type. + API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/listener/v3/listener.proto items: - description: EnvoyResource holds serialized representation of - an envoy resource + description: |- + EnvoyResource holds serialized representation of an envoy + resource properties: name: - description: 'Name of the envoy resource. DEPRECATED: this - field has no effect and will be removed in an upcoming - release. The name of the resources for discovery purposes - is included in the resource itself. Refer to the envoy - API reference to check how the name is specified for each - resource type.' + description: |- + Name of the envoy resource. + DEPRECATED: this field has no effect and will be removed in an + upcoming release. The name of the resources for discovery purposes + is included in the resource itself. Refer to the envoy API reference + to check how the name is specified for each resource type. type: string value: description: Value is the serialized representation of the @@ -159,19 +173,21 @@ spec: type: object type: array routes: - description: 'Routes is a list of the envoy Route resource type. - API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/route/v3/route.proto' + description: |- + Routes is a list of the envoy Route resource type. + API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/route/v3/route.proto items: - description: EnvoyResource holds serialized representation of - an envoy resource + description: |- + EnvoyResource holds serialized representation of an envoy + resource properties: name: - description: 'Name of the envoy resource. DEPRECATED: this - field has no effect and will be removed in an upcoming - release. The name of the resources for discovery purposes - is included in the resource itself. Refer to the envoy - API reference to check how the name is specified for each - resource type.' + description: |- + Name of the envoy resource. + DEPRECATED: this field has no effect and will be removed in an + upcoming release. The name of the resources for discovery purposes + is included in the resource itself. Refer to the envoy API reference + to check how the name is specified for each resource type. type: string value: description: Value is the serialized representation of the @@ -182,19 +198,21 @@ spec: type: object type: array runtimes: - description: 'Runtimes is a list of the envoy Runtime resource - type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/service/runtime/v3/rtds.proto' + description: |- + Runtimes is a list of the envoy Runtime resource type. + API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/service/runtime/v3/rtds.proto items: - description: EnvoyResource holds serialized representation of - an envoy resource + description: |- + EnvoyResource holds serialized representation of an envoy + resource properties: name: - description: 'Name of the envoy resource. DEPRECATED: this - field has no effect and will be removed in an upcoming - release. The name of the resources for discovery purposes - is included in the resource itself. Refer to the envoy - API reference to check how the name is specified for each - resource type.' + description: |- + Name of the envoy resource. + DEPRECATED: this field has no effect and will be removed in an + upcoming release. The name of the resources for discovery purposes + is included in the resource itself. Refer to the envoy API reference + to check how the name is specified for each resource type. type: string value: description: Value is the serialized representation of the @@ -205,19 +223,21 @@ spec: type: object type: array scopedRoutes: - description: 'ScopedRoutes is a list of the envoy ScopeRoute resource - type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/route/v3/scoped_route.proto' + description: |- + ScopedRoutes is a list of the envoy ScopeRoute resource type. + API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/route/v3/scoped_route.proto items: - description: EnvoyResource holds serialized representation of - an envoy resource + description: |- + EnvoyResource holds serialized representation of an envoy + resource properties: name: - description: 'Name of the envoy resource. DEPRECATED: this - field has no effect and will be removed in an upcoming - release. The name of the resources for discovery purposes - is included in the resource itself. Refer to the envoy - API reference to check how the name is specified for each - resource type.' + description: |- + Name of the envoy resource. + DEPRECATED: this field has no effect and will be removed in an + upcoming release. The name of the resources for discovery purposes + is included in the resource itself. Refer to the envoy API reference + to check how the name is specified for each resource type. type: string value: description: Value is the serialized representation of the @@ -231,19 +251,20 @@ spec: description: Secrets is a list of references to Kubernetes Secret objects. items: - description: EnvoySecretResource holds a reference to a k8s - Secret from where to take a secret from. Only Secrets within - the same namespace can be referred. + description: |- + EnvoySecretResource holds a reference to a k8s Secret from where + to take a secret from. Only Secrets within the same namespace can + be referred. properties: name: - description: Name of the envoy tslCerticate secret resource. - The certificate will be fetched from a Kubernetes Secrets - of type 'kubernetes.io/tls' with this same name. + description: |- + Name of the envoy tslCerticate secret resource. The certificate will be fetched + from a Kubernetes Secrets of type 'kubernetes.io/tls' with this same name. type: string ref: - description: 'DEPRECATED: this field is deprecated and it''s - value will be ignored. The ''name'' of the Kubernetes - Secret must match the ''name'' field.' + description: |- + DEPRECATED: this field is deprecated and it's value will be ignored. The 'name' of the + Kubernetes Secret must match the 'name' field. properties: name: description: name is unique within a namespace to reference @@ -261,43 +282,45 @@ spec: type: array type: object nodeID: - description: NodeID holds the envoy identifier for the discovery service - to know which set of resources to send to each of the envoy clients - that connect to it. + description: |- + NodeID holds the envoy identifier for the discovery service to know which set + of resources to send to each of the envoy clients that connect to it. type: string resources: description: Resources holds the different types of resources suported by the envoy discovery service items: - description: Resource holds serialized representation of an envoy + description: |- + Resource holds serialized representation of an envoy resource properties: blueprint: - description: Blueprint specifies a template to generate a configuration - proto. It is currently only supported to generate secret configuration - resources from k8s Secrets + description: |- + Blueprint specifies a template to generate a configuration proto. It is currently + only supported to generate secret configuration resources from k8s Secrets enum: - tlsCertificate - validationContext type: string generateFromEndpointSlices: - description: Specifies a label selector to watch for EndpointSlices - that will be used to generate the endpoint resource + description: |- + Specifies a label selector to watch for EndpointSlices that will + be used to generate the endpoint resource properties: clusterName: type: string selector: - description: A label selector is a label query over a set - of resources. The result of matchLabels and matchExpressions - are ANDed. An empty label selector matches all objects. - A null label selector matches no objects. + description: |- + A label selector is a label query over a set of resources. The result of matchLabels and + matchExpressions are ANDed. An empty label selector matches all objects. A null + label selector matches no objects. properties: matchExpressions: description: matchExpressions is a list of label selector requirements. The requirements are ANDed. items: - description: A label selector requirement is a selector - that contains values, a key, and an operator that + description: |- + A label selector requirement is a selector that contains values, a key, and an operator that relates the key and values. properties: key: @@ -305,17 +328,16 @@ spec: applies to. type: string operator: - description: operator represents a key's relationship - to a set of values. Valid operators are In, - NotIn, Exists and DoesNotExist. + description: |- + operator represents a key's relationship to a set of values. + Valid operators are In, NotIn, Exists and DoesNotExist. type: string values: - description: values is an array of string values. - If the operator is In or NotIn, the values array - must be non-empty. If the operator is Exists - or DoesNotExist, the values array must be empty. - This array is replaced during a strategic merge - patch. + description: |- + values is an array of string values. If the operator is In or NotIn, + the values array must be non-empty. If the operator is Exists or DoesNotExist, + the values array must be empty. This array is replaced during a strategic + merge patch. items: type: string type: array @@ -327,11 +349,10 @@ spec: matchLabels: additionalProperties: type: string - description: matchLabels is a map of {key,value} pairs. - A single {key,value} in the matchLabels map is equivalent - to an element of matchExpressions, whose key field - is "key", the operator is "In", and the values array - contains only "value". The requirements are ANDed. + description: |- + matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels + map is equivalent to an element of matchExpressions, whose key field is "key", the + operator is "In", and the values array contains only "value". The requirements are ANDed. type: object type: object x-kubernetes-map-type: atomic @@ -343,8 +364,9 @@ spec: - targetPort type: object generateFromOpaqueSecret: - description: The name of a Kubernetes Secret of type "Opaque". - It will generate an envoy "generic secret" proto. + description: |- + The name of a Kubernetes Secret of type "Opaque". It will generate an + envoy "generic secret" proto. properties: alias: description: A unique name to refer to the name:key combination @@ -378,9 +400,10 @@ spec: - extensionConfig type: string value: - description: Value is the protobufer message that configures - the resource. The proto must match the envoy configuration - API v3 specification for the given resource type (https://www.envoyproxy.io/docs/envoy/latest/api-docs/xds_protocol#resource-types) + description: |- + Value is the protobufer message that configures the resource. The proto + must match the envoy configuration API v3 specification for the given resource + type (https://www.envoyproxy.io/docs/envoy/latest/api-docs/xds_protocol#resource-types) type: object x-kubernetes-preserve-unknown-fields: true required: @@ -388,9 +411,9 @@ spec: type: object type: array serialization: - description: Serialization specicifies the serialization format used - to describe the resources. "json" and "yaml" are supported. "json" - is used if unset. + description: |- + Serialization specicifies the serialization format used to describe the resources. "json" and "yaml" + are supported. "json" is used if unset. enum: - json - yaml @@ -402,53 +425,53 @@ spec: description: EnvoyConfigStatus defines the observed state of EnvoyConfig properties: cacheState: - description: CacheState summarizes all the observations about the - EnvoyConfig to give the user a concrete idea on the general status - of the discovery servie cache. It is intended only for human consumption. - Other controllers should relly on conditions to determine the status - of the discovery server cache. + description: |- + CacheState summarizes all the observations about the EnvoyConfig + to give the user a concrete idea on the general status of the discovery servie cache. + It is intended only for human consumption. Other controllers should relly on conditions + to determine the status of the discovery server cache. type: string conditions: description: Conditions represent the latest available observations of an object's state items: description: "Condition contains details for one aspect of the current - state of this API Resource. --- This struct is intended for direct - use as an array at the field path .status.conditions. For example, - \n type FooStatus struct{ // Represents the observations of a - foo's current state. // Known .status.conditions.type are: \"Available\", - \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge - // +listType=map // +listMapKey=type Conditions []metav1.Condition - `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" - protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }" + state of this API Resource.\n---\nThis struct is intended for + direct use as an array at the field path .status.conditions. For + example,\n\n\n\ttype FooStatus struct{\n\t // Represents the + observations of a foo's current state.\n\t // Known .status.conditions.type + are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // + +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t + \ // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" + patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t + \ // other fields\n\t}" properties: lastTransitionTime: - description: lastTransitionTime is the last time the condition - transitioned from one status to another. This should be when - the underlying condition changed. If that is not known, then - using the time when the API field changed is acceptable. + description: |- + lastTransitionTime is the last time the condition transitioned from one status to another. + This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable. format: date-time type: string message: - description: message is a human readable message indicating - details about the transition. This may be an empty string. + description: |- + message is a human readable message indicating details about the transition. + This may be an empty string. maxLength: 32768 type: string observedGeneration: - description: observedGeneration represents the .metadata.generation - that the condition was set based upon. For instance, if .metadata.generation - is currently 12, but the .status.conditions[x].observedGeneration - is 9, the condition is out of date with respect to the current - state of the instance. + description: |- + observedGeneration represents the .metadata.generation that the condition was set based upon. + For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date + with respect to the current state of the instance. format: int64 minimum: 0 type: integer reason: - description: reason contains a programmatic identifier indicating - the reason for the condition's last transition. Producers - of specific condition types may define expected values and - meanings for this field, and whether the values are considered - a guaranteed API. The value should be a CamelCase string. + description: |- + reason contains a programmatic identifier indicating the reason for the condition's last transition. + Producers of specific condition types may define expected values and meanings for this field, + and whether the values are considered a guaranteed API. + The value should be a CamelCase string. This field may not be empty. maxLength: 1024 minLength: 1 @@ -462,11 +485,12 @@ spec: - Unknown type: string type: - description: type of condition in CamelCase or in foo.example.com/CamelCase. - --- Many .condition.type values are consistent across resources - like Available, but because arbitrary conditions can be useful - (see .node.status.conditions), the ability to deconflict is - important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt) + description: |- + type of condition in CamelCase or in foo.example.com/CamelCase. + --- + Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be + useful (see .node.status.conditions), the ability to deconflict is important. + The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt) maxLength: 316 pattern: ^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$ type: string @@ -479,56 +503,66 @@ spec: type: object type: array desiredVersion: - description: DesiredVersion represents the resources version described - in the spec of the EnvoyConfig object + description: |- + DesiredVersion represents the resources version described in + the spec of the EnvoyConfig object type: string publishedVersion: - description: PublishedVersion is the config version currently served - by the envoy discovery service for the give nodeID + description: |- + PublishedVersion is the config version currently + served by the envoy discovery service for the give nodeID type: string revisions: - description: ConfigRevisions is an ordered list of references to EnvoyConfigRevision + description: |- + ConfigRevisions is an ordered list of references to EnvoyConfigRevision objects items: description: ConfigRevisionRef holds a reference to EnvoyConfigRevision object properties: ref: - description: Ref is a reference to the EnvoyConfigRevision object - that holds the configuration matching the Version field. + description: |- + Ref is a reference to the EnvoyConfigRevision object that + holds the configuration matching the Version field. properties: apiVersion: description: API version of the referent. type: string fieldPath: - description: 'If referring to a piece of an object instead - of an entire object, this string should contain a valid - JSON/Go field access statement, such as desiredState.manifest.containers[2]. - For example, if the object reference is to a container - within a pod, this would take on a value like: "spec.containers{name}" - (where "name" refers to the name of the container that - triggered the event) or if no container name is specified - "spec.containers[2]" (container with index 2 in this pod). - This syntax is chosen only to have some well-defined way - of referencing a part of an object. TODO: this design - is not final and this field is subject to change in the - future.' + description: |- + If referring to a piece of an object instead of an entire object, this string + should contain a valid JSON/Go field access statement, such as desiredState.manifest.containers[2]. + For example, if the object reference is to a container within a pod, this would take on a value like: + "spec.containers{name}" (where "name" refers to the name of the container that triggered + the event) or if no container name is specified "spec.containers[2]" (container with + index 2 in this pod). This syntax is chosen only to have some well-defined way of + referencing a part of an object. + TODO: this design is not final and this field is subject to change in the future. type: string kind: - description: 'Kind of the referent. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: |- + Kind of the referent. + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds type: string name: - description: 'Name of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names' + description: |- + Name of the referent. + More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names type: string namespace: - description: 'Namespace of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/' + description: |- + Namespace of the referent. + More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/ type: string resourceVersion: - description: 'Specific resourceVersion to which this reference - is made, if any. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#concurrency-control-and-consistency' + description: |- + Specific resourceVersion to which this reference is made, if any. + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#concurrency-control-and-consistency type: string uid: - description: 'UID of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#uids' + description: |- + UID of the referent. + More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#uids type: string type: object x-kubernetes-map-type: atomic diff --git a/bundle/manifests/marin3r.clusterserviceversion.yaml b/bundle/manifests/marin3r.clusterserviceversion.yaml index 5c3224b5..cf1936b7 100644 --- a/bundle/manifests/marin3r.clusterserviceversion.yaml +++ b/bundle/manifests/marin3r.clusterserviceversion.yaml @@ -173,14 +173,14 @@ metadata: categories: Networking certified: "false" containerImage: quay.io/3scale/marin3r - createdAt: "2024-11-04T10:39:27Z" + createdAt: "2024-11-08T12:30:05Z" description: Lighweight, CRD based Envoy control plane for Kubernetes operators.operatorframework.io/builder: operator-sdk-v1.28.0 operators.operatorframework.io/internal-objects: '["envoyconfigrevisions.marin3r.3scale.net","discoveryservicecertificates.operator.marin3r.3scale.net"]' operators.operatorframework.io/project_layout: go.kubebuilder.io/v3 repository: https://github.com/3scale-ops/marin3r support: Red Hat, Inc. - name: marin3r.v0.13.2-alpha.1 + name: marin3r.v0.13.2-alpha.2 namespace: placeholder spec: apiservicedefinitions: {} @@ -927,7 +927,7 @@ spec: valueFrom: fieldRef: fieldPath: metadata.annotations['olm.targetNamespaces'] - image: quay.io/3scale/marin3r:v0.13.2-alpha.1 + image: quay.io/3scale/marin3r:v0.13.2-alpha.2 livenessProbe: httpGet: path: /healthz @@ -985,7 +985,7 @@ spec: valueFrom: fieldRef: fieldPath: metadata.annotations['olm.targetNamespaces'] - image: quay.io/3scale/marin3r:v0.13.2-alpha.1 + image: quay.io/3scale/marin3r:v0.13.2-alpha.2 livenessProbe: httpGet: path: /healthz @@ -1292,7 +1292,7 @@ spec: maturity: alpha provider: name: Red Hat - version: 0.13.2-alpha.1 + version: 0.13.2-alpha.2 webhookdefinitions: - admissionReviewVersions: - v1 diff --git a/bundle/manifests/operator.marin3r.3scale.net_discoveryservicecertificates.yaml b/bundle/manifests/operator.marin3r.3scale.net_discoveryservicecertificates.yaml index cf9c3836..e30537b3 100644 --- a/bundle/manifests/operator.marin3r.3scale.net_discoveryservicecertificates.yaml +++ b/bundle/manifests/operator.marin3r.3scale.net_discoveryservicecertificates.yaml @@ -2,7 +2,7 @@ apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.11.3 + controller-gen.kubebuilder.io/version: v0.14.0 creationTimestamp: null name: discoveryservicecertificates.operator.marin3r.3scale.net spec: @@ -29,20 +29,25 @@ spec: name: v1alpha1 schema: openAPIV3Schema: - description: DiscoveryServiceCertificate is an internal resource used to create - certificates. This resource is used by the DiscoveryService controller to - create the required certificates for the different components. Direct use - of DiscoveryServiceCertificate objects is discouraged. + description: |- + DiscoveryServiceCertificate is an internal resource used to create certificates. This resource + is used by the DiscoveryService controller to create the required certificates for the different + components. Direct use of DiscoveryServiceCertificate objects is discouraged. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation - of an object. Servers should convert recognized schemas to the latest - internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: |- + APIVersion defines the versioned schema of this representation of an object. + Servers should convert recognized schemas to the latest internal value, and + may reject unrecognized values. + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources type: string kind: - description: 'Kind is a string value representing the REST resource this - object represents. Servers may infer this from the endpoint the client - submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: |- + Kind is a string value representing the REST resource this object represents. + Servers may infer this from the endpoint the client submits requests to. + Cannot be updated. + In CamelCase. + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds type: string metadata: type: object @@ -51,9 +56,9 @@ spec: of DiscoveryServiceCertificate properties: certificateRenewal: - description: CertificateRenewalConfig configures the certificate renewal - process. If unset default behavior is to renew the certificate but - not notify of renewals. + description: |- + CertificateRenewalConfig configures the certificate renewal process. If unset default + behavior is to renew the certificate but not notify of renewals. properties: enabled: description: Enabled is a flag to enable or disable renewal of @@ -66,8 +71,9 @@ spec: description: CommonName is the CommonName of the certificate type: string hosts: - description: Hosts is the list of hosts the certificate is valid for. - Only use when 'IsServerCertificate' is true. If unset, the CommonName + description: |- + Hosts is the list of hosts the certificate is valid for. Only + use when 'IsServerCertificate' is true. If unset, the CommonName field will be used to populate the valid hosts of the certificate. items: type: string @@ -77,8 +83,9 @@ spec: a CA type: boolean secretRef: - description: SecretRef is a reference to the secret that will hold - the certificate and the private key. + description: |- + SecretRef is a reference to the secret that will hold the certificate + and the private key. properties: name: description: name is unique within a namespace to reference a @@ -91,12 +98,14 @@ spec: type: object x-kubernetes-map-type: atomic server: - description: IsServerCertificate is a boolean specifying if the certificate - should be issued with server auth usage enabled + description: |- + IsServerCertificate is a boolean specifying if the certificate should be + issued with server auth usage enabled type: boolean signer: - description: Signer specifies the signer to use to create this certificate. - Supported signers are CertManager and SelfSigned. + description: |- + Signer specifies the signer to use to create this certificate. Supported + signers are CertManager and SelfSigned. properties: caSigned: description: CASigned holds specific configuration for the CASigned @@ -139,51 +148,51 @@ spec: of DiscoveryServiceCertificate properties: certificateHash: - description: CertificateHash stores the current hash of the certificate. - It is used for other controllers to validate if a certificate has - been re-issued. + description: |- + CertificateHash stores the current hash of the certificate. It is used + for other controllers to validate if a certificate has been re-issued. type: string conditions: description: Conditions represent the latest available observations of an object's state items: description: "Condition contains details for one aspect of the current - state of this API Resource. --- This struct is intended for direct - use as an array at the field path .status.conditions. For example, - \n type FooStatus struct{ // Represents the observations of a - foo's current state. // Known .status.conditions.type are: \"Available\", - \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge - // +listType=map // +listMapKey=type Conditions []metav1.Condition - `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" - protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }" + state of this API Resource.\n---\nThis struct is intended for + direct use as an array at the field path .status.conditions. For + example,\n\n\n\ttype FooStatus struct{\n\t // Represents the + observations of a foo's current state.\n\t // Known .status.conditions.type + are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // + +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t + \ // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" + patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t + \ // other fields\n\t}" properties: lastTransitionTime: - description: lastTransitionTime is the last time the condition - transitioned from one status to another. This should be when - the underlying condition changed. If that is not known, then - using the time when the API field changed is acceptable. + description: |- + lastTransitionTime is the last time the condition transitioned from one status to another. + This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable. format: date-time type: string message: - description: message is a human readable message indicating - details about the transition. This may be an empty string. + description: |- + message is a human readable message indicating details about the transition. + This may be an empty string. maxLength: 32768 type: string observedGeneration: - description: observedGeneration represents the .metadata.generation - that the condition was set based upon. For instance, if .metadata.generation - is currently 12, but the .status.conditions[x].observedGeneration - is 9, the condition is out of date with respect to the current - state of the instance. + description: |- + observedGeneration represents the .metadata.generation that the condition was set based upon. + For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date + with respect to the current state of the instance. format: int64 minimum: 0 type: integer reason: - description: reason contains a programmatic identifier indicating - the reason for the condition's last transition. Producers - of specific condition types may define expected values and - meanings for this field, and whether the values are considered - a guaranteed API. The value should be a CamelCase string. + description: |- + reason contains a programmatic identifier indicating the reason for the condition's last transition. + Producers of specific condition types may define expected values and meanings for this field, + and whether the values are considered a guaranteed API. + The value should be a CamelCase string. This field may not be empty. maxLength: 1024 minLength: 1 @@ -197,11 +206,12 @@ spec: - Unknown type: string type: - description: type of condition in CamelCase or in foo.example.com/CamelCase. - --- Many .condition.type values are consistent across resources - like Available, but because arbitrary conditions can be useful - (see .node.status.conditions), the ability to deconflict is - important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt) + description: |- + type of condition in CamelCase or in foo.example.com/CamelCase. + --- + Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be + useful (see .node.status.conditions), the ability to deconflict is important. + The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt) maxLength: 316 pattern: ^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$ type: string @@ -218,7 +228,8 @@ spec: format: date-time type: string notBefore: - description: NotBefore is the time at which the certificate starts + description: |- + NotBefore is the time at which the certificate starts being valid format: date-time type: string diff --git a/bundle/manifests/operator.marin3r.3scale.net_discoveryservices.yaml b/bundle/manifests/operator.marin3r.3scale.net_discoveryservices.yaml index 3e40550f..50daab1c 100644 --- a/bundle/manifests/operator.marin3r.3scale.net_discoveryservices.yaml +++ b/bundle/manifests/operator.marin3r.3scale.net_discoveryservices.yaml @@ -2,7 +2,7 @@ apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.11.3 + controller-gen.kubebuilder.io/version: v0.14.0 creationTimestamp: null name: discoveryservices.operator.marin3r.3scale.net spec: @@ -17,18 +17,24 @@ spec: - name: v1alpha1 schema: openAPIV3Schema: - description: DiscoveryService represents an envoy discovery service server. - Only one instance per namespace is currently supported. + description: |- + DiscoveryService represents an envoy discovery service server. Only one + instance per namespace is currently supported. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation - of an object. Servers should convert recognized schemas to the latest - internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: |- + APIVersion defines the versioned schema of this representation of an object. + Servers should convert recognized schemas to the latest internal value, and + may reject unrecognized values. + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources type: string kind: - description: 'Kind is a string value representing the REST resource this - object represents. Servers may infer this from the endpoint the client - submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: |- + Kind is a string value representing the REST resource this object represents. + Servers may infer this from the endpoint the client submits requests to. + Cannot be updated. + In CamelCase. + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds type: string metadata: type: object @@ -36,9 +42,9 @@ spec: description: DiscoveryServiceSpec defines the desired state of DiscoveryService properties: debug: - description: Debug enables debugging log level for the discovery service - controllers. It is safe to use since secret data is never shown - in the logs. + description: |- + Debug enables debugging log level for the discovery service controllers. It is safe to + use since secret data is never shown in the logs. type: boolean image: description: Image holds the image to use for the discovery service @@ -50,13 +56,14 @@ spec: format: int32 type: integer pkiConfg: - description: PKIConfig has configuration for the PKI that marin3r - manages for the different certificates it requires + description: |- + PKIConfig has configuration for the PKI that marin3r manages for the + different certificates it requires properties: rootCertificateAuthority: - description: CertificateOptions specifies options to generate - the server certificate used both for the xDS server and the - mutating webhook server. + description: |- + CertificateOptions specifies options to generate the server certificate used both + for the xDS server and the mutating webhook server. properties: duration: type: string @@ -67,9 +74,9 @@ spec: - secretName type: object serverCertificate: - description: CertificateOptions specifies options to generate - the server certificate used both for the xDS server and the - mutating webhook server. + description: |- + CertificateOptions specifies options to generate the server certificate used both + for the xDS server and the mutating webhook server. properties: duration: type: string @@ -92,23 +99,30 @@ spec: format: int32 type: integer resources: - description: Resources holds the Resource Requirements to use for - the discovery service Deployment. When not set it defaults to no - resource requests nor limits. CPU and Memory resources are supported. + description: |- + Resources holds the Resource Requirements to use for the discovery service + Deployment. When not set it defaults to no resource requests nor limits. + CPU and Memory resources are supported. properties: claims: - description: "Claims lists the names of resources, defined in - spec.resourceClaims, that are used by this container. \n This - is an alpha field and requires enabling the DynamicResourceAllocation - feature gate. \n This field is immutable. It can only be set - for containers." + description: |- + Claims lists the names of resources, defined in spec.resourceClaims, + that are used by this container. + + + This is an alpha field and requires enabling the + DynamicResourceAllocation feature gate. + + + This field is immutable. It can only be set for containers. items: description: ResourceClaim references one entry in PodSpec.ResourceClaims. properties: name: - description: Name must match the name of one entry in pod.spec.resourceClaims - of the Pod where this field is used. It makes that resource - available inside a container. + description: |- + Name must match the name of one entry in pod.spec.resourceClaims of + the Pod where this field is used. It makes that resource available + inside a container. type: string required: - name @@ -124,8 +138,9 @@ spec: - type: string pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$ x-kubernetes-int-or-string: true - description: 'Limits describes the maximum amount of compute resources - allowed. More info: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/' + description: |- + Limits describes the maximum amount of compute resources allowed. + More info: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ type: object requests: additionalProperties: @@ -134,11 +149,11 @@ spec: - type: string pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$ x-kubernetes-int-or-string: true - description: 'Requests describes the minimum amount of compute - resources required. If Requests is omitted for a container, - it defaults to Limits if that is explicitly specified, otherwise - to an implementation-defined value. Requests cannot exceed Limits. - More info: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/' + description: |- + Requests describes the minimum amount of compute resources required. + If Requests is omitted for a container, it defaults to Limits if that is explicitly specified, + otherwise to an implementation-defined value. Requests cannot exceed Limits. + More info: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ type: object type: object serviceConfig: @@ -173,9 +188,10 @@ spec: format: int32 type: integer collisionCount: - description: Count of hash collisions for the Deployment. The - Deployment controller uses this field as a collision avoidance - mechanism when it needs to create the name for the newest ReplicaSet. + description: |- + Count of hash collisions for the Deployment. The Deployment controller uses this + field as a collision avoidance mechanism when it needs to create the name for the + newest ReplicaSet. format: int32 type: integer conditions: @@ -228,11 +244,10 @@ spec: format: int32 type: integer unavailableReplicas: - description: Total number of unavailable pods targeted by this - deployment. This is the total number of pods that are still - required for the deployment to have 100% available capacity. - They may either be pods that are running but not yet available - or pods that still have not been created. + description: |- + Total number of unavailable pods targeted by this deployment. This is the total number of + pods that are still required for the deployment to have 100% available capacity. They may + either be pods that are running but not yet available or pods that still have not been created. format: int32 type: integer updatedReplicas: diff --git a/bundle/manifests/operator.marin3r.3scale.net_envoydeployments.yaml b/bundle/manifests/operator.marin3r.3scale.net_envoydeployments.yaml index f9e8cacc..f8c18ddd 100644 --- a/bundle/manifests/operator.marin3r.3scale.net_envoydeployments.yaml +++ b/bundle/manifests/operator.marin3r.3scale.net_envoydeployments.yaml @@ -2,7 +2,7 @@ apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: - controller-gen.kubebuilder.io/version: v0.11.3 + controller-gen.kubebuilder.io/version: v0.14.0 creationTimestamp: null name: envoydeployments.operator.marin3r.3scale.net spec: @@ -17,18 +17,24 @@ spec: - name: v1alpha1 schema: openAPIV3Schema: - description: EnvoyDeployment is a resource to deploy and manage a Kubernetes - Deployment of Envoy Pods. + description: |- + EnvoyDeployment is a resource to deploy and manage a Kubernetes Deployment + of Envoy Pods. properties: apiVersion: - description: 'APIVersion defines the versioned schema of this representation - of an object. Servers should convert recognized schemas to the latest - internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + description: |- + APIVersion defines the versioned schema of this representation of an object. + Servers should convert recognized schemas to the latest internal value, and + may reject unrecognized values. + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources type: string kind: - description: 'Kind is a string value representing the REST resource this - object represents. Servers may infer this from the endpoint the client - submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + description: |- + Kind is a string value representing the REST resource this object represents. + Servers may infer this from the endpoint the client submits requests to. + Cannot be updated. + In CamelCase. + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds type: string metadata: type: object @@ -51,22 +57,20 @@ spec: pod. properties: preferredDuringSchedulingIgnoredDuringExecution: - description: The scheduler will prefer to schedule pods to - nodes that satisfy the affinity expressions specified by - this field, but it may choose a node that violates one or - more of the expressions. The node that is most preferred - is the one with the greatest sum of weights, i.e. for each - node that meets all of the scheduling requirements (resource - request, requiredDuringScheduling affinity expressions, - etc.), compute a sum by iterating through the elements of - this field and adding "weight" to the sum if the node matches - the corresponding matchExpressions; the node(s) with the - highest sum are the most preferred. + description: |- + The scheduler will prefer to schedule pods to nodes that satisfy + the affinity expressions specified by this field, but it may choose + a node that violates one or more of the expressions. The node that is + most preferred is the one with the greatest sum of weights, i.e. + for each node that meets all of the scheduling requirements (resource + request, requiredDuringScheduling affinity expressions, etc.), + compute a sum by iterating through the elements of this field and adding + "weight" to the sum if the node matches the corresponding matchExpressions; the + node(s) with the highest sum are the most preferred. items: - description: An empty preferred scheduling term matches - all objects with implicit weight 0 (i.e. it's a no-op). - A null preferred scheduling term matches no objects (i.e. - is also a no-op). + description: |- + An empty preferred scheduling term matches all objects with implicit weight 0 + (i.e. it's a no-op). A null preferred scheduling term matches no objects (i.e. is also a no-op). properties: preference: description: A node selector term, associated with the @@ -76,30 +80,26 @@ spec: description: A list of node selector requirements by node's labels. items: - description: A node selector requirement is a - selector that contains values, a key, and an - operator that relates the key and values. + description: |- + A node selector requirement is a selector that contains values, a key, and an operator + that relates the key and values. properties: key: description: The label key that the selector applies to. type: string operator: - description: Represents a key's relationship - to a set of values. Valid operators are - In, NotIn, Exists, DoesNotExist. Gt, and - Lt. + description: |- + Represents a key's relationship to a set of values. + Valid operators are In, NotIn, Exists, DoesNotExist. Gt, and Lt. type: string values: - description: An array of string values. If - the operator is In or NotIn, the values - array must be non-empty. If the operator - is Exists or DoesNotExist, the values array - must be empty. If the operator is Gt or - Lt, the values array must have a single - element, which will be interpreted as an - integer. This array is replaced during a - strategic merge patch. + description: |- + An array of string values. If the operator is In or NotIn, + the values array must be non-empty. If the operator is Exists or DoesNotExist, + the values array must be empty. If the operator is Gt or Lt, the values + array must have a single element, which will be interpreted as an integer. + This array is replaced during a strategic merge patch. items: type: string type: array @@ -112,30 +112,26 @@ spec: description: A list of node selector requirements by node's fields. items: - description: A node selector requirement is a - selector that contains values, a key, and an - operator that relates the key and values. + description: |- + A node selector requirement is a selector that contains values, a key, and an operator + that relates the key and values. properties: key: description: The label key that the selector applies to. type: string operator: - description: Represents a key's relationship - to a set of values. Valid operators are - In, NotIn, Exists, DoesNotExist. Gt, and - Lt. + description: |- + Represents a key's relationship to a set of values. + Valid operators are In, NotIn, Exists, DoesNotExist. Gt, and Lt. type: string values: - description: An array of string values. If - the operator is In or NotIn, the values - array must be non-empty. If the operator - is Exists or DoesNotExist, the values array - must be empty. If the operator is Gt or - Lt, the values array must have a single - element, which will be interpreted as an - integer. This array is replaced during a - strategic merge patch. + description: |- + An array of string values. If the operator is In or NotIn, + the values array must be non-empty. If the operator is Exists or DoesNotExist, + the values array must be empty. If the operator is Gt or Lt, the values + array must have a single element, which will be interpreted as an integer. + This array is replaced during a strategic merge patch. items: type: string type: array @@ -157,50 +153,46 @@ spec: type: object type: array requiredDuringSchedulingIgnoredDuringExecution: - description: If the affinity requirements specified by this - field are not met at scheduling time, the pod will not be - scheduled onto the node. If the affinity requirements specified - by this field cease to be met at some point during pod execution - (e.g. due to an update), the system may or may not try to - eventually evict the pod from its node. + description: |- + If the affinity requirements specified by this field are not met at + scheduling time, the pod will not be scheduled onto the node. + If the affinity requirements specified by this field cease to be met + at some point during pod execution (e.g. due to an update), the system + may or may not try to eventually evict the pod from its node. properties: nodeSelectorTerms: description: Required. A list of node selector terms. The terms are ORed. items: - description: A null or empty node selector term matches - no objects. The requirements of them are ANDed. The - TopologySelectorTerm type implements a subset of the - NodeSelectorTerm. + description: |- + A null or empty node selector term matches no objects. The requirements of + them are ANDed. + The TopologySelectorTerm type implements a subset of the NodeSelectorTerm. properties: matchExpressions: description: A list of node selector requirements by node's labels. items: - description: A node selector requirement is a - selector that contains values, a key, and an - operator that relates the key and values. + description: |- + A node selector requirement is a selector that contains values, a key, and an operator + that relates the key and values. properties: key: description: The label key that the selector applies to. type: string operator: - description: Represents a key's relationship - to a set of values. Valid operators are - In, NotIn, Exists, DoesNotExist. Gt, and - Lt. + description: |- + Represents a key's relationship to a set of values. + Valid operators are In, NotIn, Exists, DoesNotExist. Gt, and Lt. type: string values: - description: An array of string values. If - the operator is In or NotIn, the values - array must be non-empty. If the operator - is Exists or DoesNotExist, the values array - must be empty. If the operator is Gt or - Lt, the values array must have a single - element, which will be interpreted as an - integer. This array is replaced during a - strategic merge patch. + description: |- + An array of string values. If the operator is In or NotIn, + the values array must be non-empty. If the operator is Exists or DoesNotExist, + the values array must be empty. If the operator is Gt or Lt, the values + array must have a single element, which will be interpreted as an integer. + This array is replaced during a strategic merge patch. items: type: string type: array @@ -213,30 +205,26 @@ spec: description: A list of node selector requirements by node's fields. items: - description: A node selector requirement is a - selector that contains values, a key, and an - operator that relates the key and values. + description: |- + A node selector requirement is a selector that contains values, a key, and an operator + that relates the key and values. properties: key: description: The label key that the selector applies to. type: string operator: - description: Represents a key's relationship - to a set of values. Valid operators are - In, NotIn, Exists, DoesNotExist. Gt, and - Lt. + description: |- + Represents a key's relationship to a set of values. + Valid operators are In, NotIn, Exists, DoesNotExist. Gt, and Lt. type: string values: - description: An array of string values. If - the operator is In or NotIn, the values - array must be non-empty. If the operator - is Exists or DoesNotExist, the values array - must be empty. If the operator is Gt or - Lt, the values array must have a single - element, which will be interpreted as an - integer. This array is replaced during a - strategic merge patch. + description: |- + An array of string values. If the operator is In or NotIn, + the values array must be non-empty. If the operator is Exists or DoesNotExist, + the values array must be empty. If the operator is Gt or Lt, the values + array must have a single element, which will be interpreted as an integer. + This array is replaced during a strategic merge patch. items: type: string type: array @@ -258,16 +246,15 @@ spec: this pod in the same node, zone, etc. as some other pod(s)). properties: preferredDuringSchedulingIgnoredDuringExecution: - description: The scheduler will prefer to schedule pods to - nodes that satisfy the affinity expressions specified by - this field, but it may choose a node that violates one or - more of the expressions. The node that is most preferred - is the one with the greatest sum of weights, i.e. for each - node that meets all of the scheduling requirements (resource - request, requiredDuringScheduling affinity expressions, - etc.), compute a sum by iterating through the elements of - this field and adding "weight" to the sum if the node has - pods which matches the corresponding podAffinityTerm; the + description: |- + The scheduler will prefer to schedule pods to nodes that satisfy + the affinity expressions specified by this field, but it may choose + a node that violates one or more of the expressions. The node that is + most preferred is the one with the greatest sum of weights, i.e. + for each node that meets all of the scheduling requirements (resource + request, requiredDuringScheduling affinity expressions, etc.), + compute a sum by iterating through the elements of this field and adding + "weight" to the sum if the node has pods which matches the corresponding podAffinityTerm; the node(s) with the highest sum are the most preferred. items: description: The weights of all of the matched WeightedPodAffinityTerm @@ -278,37 +265,33 @@ spec: with the corresponding weight. properties: labelSelector: - description: A label query over a set of resources, - in this case pods. If it's null, this PodAffinityTerm - matches with no Pods. + description: |- + A label query over a set of resources, in this case pods. + If it's null, this PodAffinityTerm matches with no Pods. properties: matchExpressions: description: matchExpressions is a list of label selector requirements. The requirements are ANDed. items: - description: A label selector requirement - is a selector that contains values, a key, - and an operator that relates the key and - values. + description: |- + A label selector requirement is a selector that contains values, a key, and an operator that + relates the key and values. properties: key: description: key is the label key that the selector applies to. type: string operator: - description: operator represents a key's - relationship to a set of values. Valid - operators are In, NotIn, Exists and - DoesNotExist. + description: |- + operator represents a key's relationship to a set of values. + Valid operators are In, NotIn, Exists and DoesNotExist. type: string values: - description: values is an array of string - values. If the operator is In or NotIn, - the values array must be non-empty. - If the operator is Exists or DoesNotExist, - the values array must be empty. This - array is replaced during a strategic + description: |- + values is an array of string values. If the operator is In or NotIn, + the values array must be non-empty. If the operator is Exists or DoesNotExist, + the values array must be empty. This array is replaced during a strategic merge patch. items: type: string @@ -321,89 +304,74 @@ spec: matchLabels: additionalProperties: type: string - description: matchLabels is a map of {key,value} - pairs. A single {key,value} in the matchLabels - map is equivalent to an element of matchExpressions, - whose key field is "key", the operator is - "In", and the values array contains only "value". - The requirements are ANDed. + description: |- + matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels + map is equivalent to an element of matchExpressions, whose key field is "key", the + operator is "In", and the values array contains only "value". The requirements are ANDed. type: object type: object x-kubernetes-map-type: atomic matchLabelKeys: - description: MatchLabelKeys is a set of pod label - keys to select which pods will be taken into consideration. - The keys are used to lookup values from the incoming - pod labels, those key-value labels are merged - with `LabelSelector` as `key in (value)` to select - the group of existing pods which pods will be - taken into consideration for the incoming pod's - pod (anti) affinity. Keys that don't exist in - the incoming pod labels will be ignored. The default - value is empty. The same key is forbidden to exist - in both MatchLabelKeys and LabelSelector. Also, - MatchLabelKeys cannot be set when LabelSelector - isn't set. This is an alpha field and requires - enabling MatchLabelKeysInPodAffinity feature gate. + description: |- + MatchLabelKeys is a set of pod label keys to select which pods will + be taken into consideration. The keys are used to lookup values from the + incoming pod labels, those key-value labels are merged with `LabelSelector` as `key in (value)` + to select the group of existing pods which pods will be taken into consideration + for the incoming pod's pod (anti) affinity. Keys that don't exist in the incoming + pod labels will be ignored. The default value is empty. + The same key is forbidden to exist in both MatchLabelKeys and LabelSelector. + Also, MatchLabelKeys cannot be set when LabelSelector isn't set. + This is an alpha field and requires enabling MatchLabelKeysInPodAffinity feature gate. items: type: string type: array x-kubernetes-list-type: atomic mismatchLabelKeys: - description: MismatchLabelKeys is a set of pod label - keys to select which pods will be taken into consideration. - The keys are used to lookup values from the incoming - pod labels, those key-value labels are merged - with `LabelSelector` as `key notin (value)` to - select the group of existing pods which pods will - be taken into consideration for the incoming pod's - pod (anti) affinity. Keys that don't exist in - the incoming pod labels will be ignored. The default - value is empty. The same key is forbidden to exist - in both MismatchLabelKeys and LabelSelector. Also, - MismatchLabelKeys cannot be set when LabelSelector - isn't set. This is an alpha field and requires - enabling MatchLabelKeysInPodAffinity feature gate. + description: |- + MismatchLabelKeys is a set of pod label keys to select which pods will + be taken into consideration. The keys are used to lookup values from the + incoming pod labels, those key-value labels are merged with `LabelSelector` as `key notin (value)` + to select the group of existing pods which pods will be taken into consideration + for the incoming pod's pod (anti) affinity. Keys that don't exist in the incoming + pod labels will be ignored. The default value is empty. + The same key is forbidden to exist in both MismatchLabelKeys and LabelSelector. + Also, MismatchLabelKeys cannot be set when LabelSelector isn't set. + This is an alpha field and requires enabling MatchLabelKeysInPodAffinity feature gate. items: type: string type: array x-kubernetes-list-type: atomic namespaceSelector: - description: A label query over the set of namespaces - that the term applies to. The term is applied - to the union of the namespaces selected by this - field and the ones listed in the namespaces field. - null selector and null or empty namespaces list - means "this pod's namespace". An empty selector - ({}) matches all namespaces. + description: |- + A label query over the set of namespaces that the term applies to. + The term is applied to the union of the namespaces selected by this field + and the ones listed in the namespaces field. + null selector and null or empty namespaces list means "this pod's namespace". + An empty selector ({}) matches all namespaces. properties: matchExpressions: description: matchExpressions is a list of label selector requirements. The requirements are ANDed. items: - description: A label selector requirement - is a selector that contains values, a key, - and an operator that relates the key and - values. + description: |- + A label selector requirement is a selector that contains values, a key, and an operator that + relates the key and values. properties: key: description: key is the label key that the selector applies to. type: string operator: - description: operator represents a key's - relationship to a set of values. Valid - operators are In, NotIn, Exists and - DoesNotExist. + description: |- + operator represents a key's relationship to a set of values. + Valid operators are In, NotIn, Exists and DoesNotExist. type: string values: - description: values is an array of string - values. If the operator is In or NotIn, - the values array must be non-empty. - If the operator is Exists or DoesNotExist, - the values array must be empty. This - array is replaced during a strategic + description: |- + values is an array of string values. If the operator is In or NotIn, + the values array must be non-empty. If the operator is Exists or DoesNotExist, + the values array must be empty. This array is replaced during a strategic merge patch. items: type: string @@ -416,40 +384,37 @@ spec: matchLabels: additionalProperties: type: string - description: matchLabels is a map of {key,value} - pairs. A single {key,value} in the matchLabels - map is equivalent to an element of matchExpressions, - whose key field is "key", the operator is - "In", and the values array contains only "value". - The requirements are ANDed. + description: |- + matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels + map is equivalent to an element of matchExpressions, whose key field is "key", the + operator is "In", and the values array contains only "value". The requirements are ANDed. type: object type: object x-kubernetes-map-type: atomic namespaces: - description: namespaces specifies a static list - of namespace names that the term applies to. The - term is applied to the union of the namespaces - listed in this field and the ones selected by - namespaceSelector. null or empty namespaces list - and null namespaceSelector means "this pod's namespace". + description: |- + namespaces specifies a static list of namespace names that the term applies to. + The term is applied to the union of the namespaces listed in this field + and the ones selected by namespaceSelector. + null or empty namespaces list and null namespaceSelector means "this pod's namespace". items: type: string type: array topologyKey: - description: This pod should be co-located (affinity) - or not co-located (anti-affinity) with the pods - matching the labelSelector in the specified namespaces, - where co-located is defined as running on a node - whose value of the label with key topologyKey - matches that of any node on which any of the selected - pods is running. Empty topologyKey is not allowed. + description: |- + This pod should be co-located (affinity) or not co-located (anti-affinity) with the pods matching + the labelSelector in the specified namespaces, where co-located is defined as running on a node + whose value of the label with key topologyKey matches that of any node on which any of the + selected pods is running. + Empty topologyKey is not allowed. type: string required: - topologyKey type: object weight: - description: weight associated with matching the corresponding - podAffinityTerm, in the range 1-100. + description: |- + weight associated with matching the corresponding podAffinityTerm, + in the range 1-100. format: int32 type: integer required: @@ -458,53 +423,51 @@ spec: type: object type: array requiredDuringSchedulingIgnoredDuringExecution: - description: If the affinity requirements specified by this - field are not met at scheduling time, the pod will not be - scheduled onto the node. If the affinity requirements specified - by this field cease to be met at some point during pod execution - (e.g. due to a pod label update), the system may or may - not try to eventually evict the pod from its node. When - there are multiple elements, the lists of nodes corresponding - to each podAffinityTerm are intersected, i.e. all terms - must be satisfied. + description: |- + If the affinity requirements specified by this field are not met at + scheduling time, the pod will not be scheduled onto the node. + If the affinity requirements specified by this field cease to be met + at some point during pod execution (e.g. due to a pod label update), the + system may or may not try to eventually evict the pod from its node. + When there are multiple elements, the lists of nodes corresponding to each + podAffinityTerm are intersected, i.e. all terms must be satisfied. items: - description: Defines a set of pods (namely those matching - the labelSelector relative to the given namespace(s)) - that this pod should be co-located (affinity) or not co-located - (anti-affinity) with, where co-located is defined as running - on a node whose value of the label with key - matches that of any node on which a pod of the set of - pods is running + description: |- + Defines a set of pods (namely those matching the labelSelector + relative to the given namespace(s)) that this pod should be + co-located (affinity) or not co-located (anti-affinity) with, + where co-located is defined as running on a node whose value of + the label with key matches that of any node on which + a pod of the set of pods is running properties: labelSelector: - description: A label query over a set of resources, - in this case pods. If it's null, this PodAffinityTerm - matches with no Pods. + description: |- + A label query over a set of resources, in this case pods. + If it's null, this PodAffinityTerm matches with no Pods. properties: matchExpressions: description: matchExpressions is a list of label selector requirements. The requirements are ANDed. items: - description: A label selector requirement is a - selector that contains values, a key, and an - operator that relates the key and values. + description: |- + A label selector requirement is a selector that contains values, a key, and an operator that + relates the key and values. properties: key: description: key is the label key that the selector applies to. type: string operator: - description: operator represents a key's relationship - to a set of values. Valid operators are - In, NotIn, Exists and DoesNotExist. + description: |- + operator represents a key's relationship to a set of values. + Valid operators are In, NotIn, Exists and DoesNotExist. type: string values: - description: values is an array of string - values. If the operator is In or NotIn, - the values array must be non-empty. If the - operator is Exists or DoesNotExist, the - values array must be empty. This array is - replaced during a strategic merge patch. + description: |- + values is an array of string values. If the operator is In or NotIn, + the values array must be non-empty. If the operator is Exists or DoesNotExist, + the values array must be empty. This array is replaced during a strategic + merge patch. items: type: string type: array @@ -516,84 +479,74 @@ spec: matchLabels: additionalProperties: type: string - description: matchLabels is a map of {key,value} - pairs. A single {key,value} in the matchLabels - map is equivalent to an element of matchExpressions, - whose key field is "key", the operator is "In", - and the values array contains only "value". The - requirements are ANDed. + description: |- + matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels + map is equivalent to an element of matchExpressions, whose key field is "key", the + operator is "In", and the values array contains only "value". The requirements are ANDed. type: object type: object x-kubernetes-map-type: atomic matchLabelKeys: - description: MatchLabelKeys is a set of pod label keys - to select which pods will be taken into consideration. - The keys are used to lookup values from the incoming - pod labels, those key-value labels are merged with - `LabelSelector` as `key in (value)` to select the - group of existing pods which pods will be taken into - consideration for the incoming pod's pod (anti) affinity. - Keys that don't exist in the incoming pod labels will - be ignored. The default value is empty. The same key - is forbidden to exist in both MatchLabelKeys and LabelSelector. - Also, MatchLabelKeys cannot be set when LabelSelector - isn't set. This is an alpha field and requires enabling - MatchLabelKeysInPodAffinity feature gate. + description: |- + MatchLabelKeys is a set of pod label keys to select which pods will + be taken into consideration. The keys are used to lookup values from the + incoming pod labels, those key-value labels are merged with `LabelSelector` as `key in (value)` + to select the group of existing pods which pods will be taken into consideration + for the incoming pod's pod (anti) affinity. Keys that don't exist in the incoming + pod labels will be ignored. The default value is empty. + The same key is forbidden to exist in both MatchLabelKeys and LabelSelector. + Also, MatchLabelKeys cannot be set when LabelSelector isn't set. + This is an alpha field and requires enabling MatchLabelKeysInPodAffinity feature gate. items: type: string type: array x-kubernetes-list-type: atomic mismatchLabelKeys: - description: MismatchLabelKeys is a set of pod label - keys to select which pods will be taken into consideration. - The keys are used to lookup values from the incoming - pod labels, those key-value labels are merged with - `LabelSelector` as `key notin (value)` to select the - group of existing pods which pods will be taken into - consideration for the incoming pod's pod (anti) affinity. - Keys that don't exist in the incoming pod labels will - be ignored. The default value is empty. The same key - is forbidden to exist in both MismatchLabelKeys and - LabelSelector. Also, MismatchLabelKeys cannot be set - when LabelSelector isn't set. This is an alpha field - and requires enabling MatchLabelKeysInPodAffinity - feature gate. + description: |- + MismatchLabelKeys is a set of pod label keys to select which pods will + be taken into consideration. The keys are used to lookup values from the + incoming pod labels, those key-value labels are merged with `LabelSelector` as `key notin (value)` + to select the group of existing pods which pods will be taken into consideration + for the incoming pod's pod (anti) affinity. Keys that don't exist in the incoming + pod labels will be ignored. The default value is empty. + The same key is forbidden to exist in both MismatchLabelKeys and LabelSelector. + Also, MismatchLabelKeys cannot be set when LabelSelector isn't set. + This is an alpha field and requires enabling MatchLabelKeysInPodAffinity feature gate. items: type: string type: array x-kubernetes-list-type: atomic namespaceSelector: - description: A label query over the set of namespaces - that the term applies to. The term is applied to the - union of the namespaces selected by this field and - the ones listed in the namespaces field. null selector - and null or empty namespaces list means "this pod's - namespace". An empty selector ({}) matches all namespaces. + description: |- + A label query over the set of namespaces that the term applies to. + The term is applied to the union of the namespaces selected by this field + and the ones listed in the namespaces field. + null selector and null or empty namespaces list means "this pod's namespace". + An empty selector ({}) matches all namespaces. properties: matchExpressions: description: matchExpressions is a list of label selector requirements. The requirements are ANDed. items: - description: A label selector requirement is a - selector that contains values, a key, and an - operator that relates the key and values. + description: |- + A label selector requirement is a selector that contains values, a key, and an operator that + relates the key and values. properties: key: description: key is the label key that the selector applies to. type: string operator: - description: operator represents a key's relationship - to a set of values. Valid operators are - In, NotIn, Exists and DoesNotExist. + description: |- + operator represents a key's relationship to a set of values. + Valid operators are In, NotIn, Exists and DoesNotExist. type: string values: - description: values is an array of string - values. If the operator is In or NotIn, - the values array must be non-empty. If the - operator is Exists or DoesNotExist, the - values array must be empty. This array is - replaced during a strategic merge patch. + description: |- + values is an array of string values. If the operator is In or NotIn, + the values array must be non-empty. If the operator is Exists or DoesNotExist, + the values array must be empty. This array is replaced during a strategic + merge patch. items: type: string type: array @@ -605,32 +558,28 @@ spec: matchLabels: additionalProperties: type: string - description: matchLabels is a map of {key,value} - pairs. A single {key,value} in the matchLabels - map is equivalent to an element of matchExpressions, - whose key field is "key", the operator is "In", - and the values array contains only "value". The - requirements are ANDed. + description: |- + matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels + map is equivalent to an element of matchExpressions, whose key field is "key", the + operator is "In", and the values array contains only "value". The requirements are ANDed. type: object type: object x-kubernetes-map-type: atomic namespaces: - description: namespaces specifies a static list of namespace - names that the term applies to. The term is applied - to the union of the namespaces listed in this field - and the ones selected by namespaceSelector. null or - empty namespaces list and null namespaceSelector means - "this pod's namespace". + description: |- + namespaces specifies a static list of namespace names that the term applies to. + The term is applied to the union of the namespaces listed in this field + and the ones selected by namespaceSelector. + null or empty namespaces list and null namespaceSelector means "this pod's namespace". items: type: string type: array topologyKey: - description: This pod should be co-located (affinity) - or not co-located (anti-affinity) with the pods matching - the labelSelector in the specified namespaces, where - co-located is defined as running on a node whose value - of the label with key topologyKey matches that of - any node on which any of the selected pods is running. + description: |- + This pod should be co-located (affinity) or not co-located (anti-affinity) with the pods matching + the labelSelector in the specified namespaces, where co-located is defined as running on a node + whose value of the label with key topologyKey matches that of any node on which any of the + selected pods is running. Empty topologyKey is not allowed. type: string required: @@ -644,16 +593,15 @@ spec: other pod(s)). properties: preferredDuringSchedulingIgnoredDuringExecution: - description: The scheduler will prefer to schedule pods to - nodes that satisfy the anti-affinity expressions specified - by this field, but it may choose a node that violates one - or more of the expressions. The node that is most preferred - is the one with the greatest sum of weights, i.e. for each - node that meets all of the scheduling requirements (resource - request, requiredDuringScheduling anti-affinity expressions, - etc.), compute a sum by iterating through the elements of - this field and adding "weight" to the sum if the node has - pods which matches the corresponding podAffinityTerm; the + description: |- + The scheduler will prefer to schedule pods to nodes that satisfy + the anti-affinity expressions specified by this field, but it may choose + a node that violates one or more of the expressions. The node that is + most preferred is the one with the greatest sum of weights, i.e. + for each node that meets all of the scheduling requirements (resource + request, requiredDuringScheduling anti-affinity expressions, etc.), + compute a sum by iterating through the elements of this field and adding + "weight" to the sum if the node has pods which matches the corresponding podAffinityTerm; the node(s) with the highest sum are the most preferred. items: description: The weights of all of the matched WeightedPodAffinityTerm @@ -664,37 +612,33 @@ spec: with the corresponding weight. properties: labelSelector: - description: A label query over a set of resources, - in this case pods. If it's null, this PodAffinityTerm - matches with no Pods. + description: |- + A label query over a set of resources, in this case pods. + If it's null, this PodAffinityTerm matches with no Pods. properties: matchExpressions: description: matchExpressions is a list of label selector requirements. The requirements are ANDed. items: - description: A label selector requirement - is a selector that contains values, a key, - and an operator that relates the key and - values. + description: |- + A label selector requirement is a selector that contains values, a key, and an operator that + relates the key and values. properties: key: description: key is the label key that the selector applies to. type: string operator: - description: operator represents a key's - relationship to a set of values. Valid - operators are In, NotIn, Exists and - DoesNotExist. + description: |- + operator represents a key's relationship to a set of values. + Valid operators are In, NotIn, Exists and DoesNotExist. type: string values: - description: values is an array of string - values. If the operator is In or NotIn, - the values array must be non-empty. - If the operator is Exists or DoesNotExist, - the values array must be empty. This - array is replaced during a strategic + description: |- + values is an array of string values. If the operator is In or NotIn, + the values array must be non-empty. If the operator is Exists or DoesNotExist, + the values array must be empty. This array is replaced during a strategic merge patch. items: type: string @@ -707,89 +651,74 @@ spec: matchLabels: additionalProperties: type: string - description: matchLabels is a map of {key,value} - pairs. A single {key,value} in the matchLabels - map is equivalent to an element of matchExpressions, - whose key field is "key", the operator is - "In", and the values array contains only "value". - The requirements are ANDed. + description: |- + matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels + map is equivalent to an element of matchExpressions, whose key field is "key", the + operator is "In", and the values array contains only "value". The requirements are ANDed. type: object type: object x-kubernetes-map-type: atomic matchLabelKeys: - description: MatchLabelKeys is a set of pod label - keys to select which pods will be taken into consideration. - The keys are used to lookup values from the incoming - pod labels, those key-value labels are merged - with `LabelSelector` as `key in (value)` to select - the group of existing pods which pods will be - taken into consideration for the incoming pod's - pod (anti) affinity. Keys that don't exist in - the incoming pod labels will be ignored. The default - value is empty. The same key is forbidden to exist - in both MatchLabelKeys and LabelSelector. Also, - MatchLabelKeys cannot be set when LabelSelector - isn't set. This is an alpha field and requires - enabling MatchLabelKeysInPodAffinity feature gate. + description: |- + MatchLabelKeys is a set of pod label keys to select which pods will + be taken into consideration. The keys are used to lookup values from the + incoming pod labels, those key-value labels are merged with `LabelSelector` as `key in (value)` + to select the group of existing pods which pods will be taken into consideration + for the incoming pod's pod (anti) affinity. Keys that don't exist in the incoming + pod labels will be ignored. The default value is empty. + The same key is forbidden to exist in both MatchLabelKeys and LabelSelector. + Also, MatchLabelKeys cannot be set when LabelSelector isn't set. + This is an alpha field and requires enabling MatchLabelKeysInPodAffinity feature gate. items: type: string type: array x-kubernetes-list-type: atomic mismatchLabelKeys: - description: MismatchLabelKeys is a set of pod label - keys to select which pods will be taken into consideration. - The keys are used to lookup values from the incoming - pod labels, those key-value labels are merged - with `LabelSelector` as `key notin (value)` to - select the group of existing pods which pods will - be taken into consideration for the incoming pod's - pod (anti) affinity. Keys that don't exist in - the incoming pod labels will be ignored. The default - value is empty. The same key is forbidden to exist - in both MismatchLabelKeys and LabelSelector. Also, - MismatchLabelKeys cannot be set when LabelSelector - isn't set. This is an alpha field and requires - enabling MatchLabelKeysInPodAffinity feature gate. + description: |- + MismatchLabelKeys is a set of pod label keys to select which pods will + be taken into consideration. The keys are used to lookup values from the + incoming pod labels, those key-value labels are merged with `LabelSelector` as `key notin (value)` + to select the group of existing pods which pods will be taken into consideration + for the incoming pod's pod (anti) affinity. Keys that don't exist in the incoming + pod labels will be ignored. The default value is empty. + The same key is forbidden to exist in both MismatchLabelKeys and LabelSelector. + Also, MismatchLabelKeys cannot be set when LabelSelector isn't set. + This is an alpha field and requires enabling MatchLabelKeysInPodAffinity feature gate. items: type: string type: array x-kubernetes-list-type: atomic namespaceSelector: - description: A label query over the set of namespaces - that the term applies to. The term is applied - to the union of the namespaces selected by this - field and the ones listed in the namespaces field. - null selector and null or empty namespaces list - means "this pod's namespace". An empty selector - ({}) matches all namespaces. + description: |- + A label query over the set of namespaces that the term applies to. + The term is applied to the union of the namespaces selected by this field + and the ones listed in the namespaces field. + null selector and null or empty namespaces list means "this pod's namespace". + An empty selector ({}) matches all namespaces. properties: matchExpressions: description: matchExpressions is a list of label selector requirements. The requirements are ANDed. items: - description: A label selector requirement - is a selector that contains values, a key, - and an operator that relates the key and - values. + description: |- + A label selector requirement is a selector that contains values, a key, and an operator that + relates the key and values. properties: key: description: key is the label key that the selector applies to. type: string operator: - description: operator represents a key's - relationship to a set of values. Valid - operators are In, NotIn, Exists and - DoesNotExist. + description: |- + operator represents a key's relationship to a set of values. + Valid operators are In, NotIn, Exists and DoesNotExist. type: string values: - description: values is an array of string - values. If the operator is In or NotIn, - the values array must be non-empty. - If the operator is Exists or DoesNotExist, - the values array must be empty. This - array is replaced during a strategic + description: |- + values is an array of string values. If the operator is In or NotIn, + the values array must be non-empty. If the operator is Exists or DoesNotExist, + the values array must be empty. This array is replaced during a strategic merge patch. items: type: string @@ -802,40 +731,37 @@ spec: matchLabels: additionalProperties: type: string - description: matchLabels is a map of {key,value} - pairs. A single {key,value} in the matchLabels - map is equivalent to an element of matchExpressions, - whose key field is "key", the operator is - "In", and the values array contains only "value". - The requirements are ANDed. + description: |- + matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels + map is equivalent to an element of matchExpressions, whose key field is "key", the + operator is "In", and the values array contains only "value". The requirements are ANDed. type: object type: object x-kubernetes-map-type: atomic namespaces: - description: namespaces specifies a static list - of namespace names that the term applies to. The - term is applied to the union of the namespaces - listed in this field and the ones selected by - namespaceSelector. null or empty namespaces list - and null namespaceSelector means "this pod's namespace". + description: |- + namespaces specifies a static list of namespace names that the term applies to. + The term is applied to the union of the namespaces listed in this field + and the ones selected by namespaceSelector. + null or empty namespaces list and null namespaceSelector means "this pod's namespace". items: type: string type: array topologyKey: - description: This pod should be co-located (affinity) - or not co-located (anti-affinity) with the pods - matching the labelSelector in the specified namespaces, - where co-located is defined as running on a node - whose value of the label with key topologyKey - matches that of any node on which any of the selected - pods is running. Empty topologyKey is not allowed. + description: |- + This pod should be co-located (affinity) or not co-located (anti-affinity) with the pods matching + the labelSelector in the specified namespaces, where co-located is defined as running on a node + whose value of the label with key topologyKey matches that of any node on which any of the + selected pods is running. + Empty topologyKey is not allowed. type: string required: - topologyKey type: object weight: - description: weight associated with matching the corresponding - podAffinityTerm, in the range 1-100. + description: |- + weight associated with matching the corresponding podAffinityTerm, + in the range 1-100. format: int32 type: integer required: @@ -844,53 +770,51 @@ spec: type: object type: array requiredDuringSchedulingIgnoredDuringExecution: - description: If the anti-affinity requirements specified by - this field are not met at scheduling time, the pod will - not be scheduled onto the node. If the anti-affinity requirements - specified by this field cease to be met at some point during - pod execution (e.g. due to a pod label update), the system - may or may not try to eventually evict the pod from its - node. When there are multiple elements, the lists of nodes - corresponding to each podAffinityTerm are intersected, i.e. - all terms must be satisfied. + description: |- + If the anti-affinity requirements specified by this field are not met at + scheduling time, the pod will not be scheduled onto the node. + If the anti-affinity requirements specified by this field cease to be met + at some point during pod execution (e.g. due to a pod label update), the + system may or may not try to eventually evict the pod from its node. + When there are multiple elements, the lists of nodes corresponding to each + podAffinityTerm are intersected, i.e. all terms must be satisfied. items: - description: Defines a set of pods (namely those matching - the labelSelector relative to the given namespace(s)) - that this pod should be co-located (affinity) or not co-located - (anti-affinity) with, where co-located is defined as running - on a node whose value of the label with key - matches that of any node on which a pod of the set of - pods is running + description: |- + Defines a set of pods (namely those matching the labelSelector + relative to the given namespace(s)) that this pod should be + co-located (affinity) or not co-located (anti-affinity) with, + where co-located is defined as running on a node whose value of + the label with key matches that of any node on which + a pod of the set of pods is running properties: labelSelector: - description: A label query over a set of resources, - in this case pods. If it's null, this PodAffinityTerm - matches with no Pods. + description: |- + A label query over a set of resources, in this case pods. + If it's null, this PodAffinityTerm matches with no Pods. properties: matchExpressions: description: matchExpressions is a list of label selector requirements. The requirements are ANDed. items: - description: A label selector requirement is a - selector that contains values, a key, and an - operator that relates the key and values. + description: |- + A label selector requirement is a selector that contains values, a key, and an operator that + relates the key and values. properties: key: description: key is the label key that the selector applies to. type: string operator: - description: operator represents a key's relationship - to a set of values. Valid operators are - In, NotIn, Exists and DoesNotExist. + description: |- + operator represents a key's relationship to a set of values. + Valid operators are In, NotIn, Exists and DoesNotExist. type: string values: - description: values is an array of string - values. If the operator is In or NotIn, - the values array must be non-empty. If the - operator is Exists or DoesNotExist, the - values array must be empty. This array is - replaced during a strategic merge patch. + description: |- + values is an array of string values. If the operator is In or NotIn, + the values array must be non-empty. If the operator is Exists or DoesNotExist, + the values array must be empty. This array is replaced during a strategic + merge patch. items: type: string type: array @@ -902,84 +826,74 @@ spec: matchLabels: additionalProperties: type: string - description: matchLabels is a map of {key,value} - pairs. A single {key,value} in the matchLabels - map is equivalent to an element of matchExpressions, - whose key field is "key", the operator is "In", - and the values array contains only "value". The - requirements are ANDed. + description: |- + matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels + map is equivalent to an element of matchExpressions, whose key field is "key", the + operator is "In", and the values array contains only "value". The requirements are ANDed. type: object type: object x-kubernetes-map-type: atomic matchLabelKeys: - description: MatchLabelKeys is a set of pod label keys - to select which pods will be taken into consideration. - The keys are used to lookup values from the incoming - pod labels, those key-value labels are merged with - `LabelSelector` as `key in (value)` to select the - group of existing pods which pods will be taken into - consideration for the incoming pod's pod (anti) affinity. - Keys that don't exist in the incoming pod labels will - be ignored. The default value is empty. The same key - is forbidden to exist in both MatchLabelKeys and LabelSelector. - Also, MatchLabelKeys cannot be set when LabelSelector - isn't set. This is an alpha field and requires enabling - MatchLabelKeysInPodAffinity feature gate. + description: |- + MatchLabelKeys is a set of pod label keys to select which pods will + be taken into consideration. The keys are used to lookup values from the + incoming pod labels, those key-value labels are merged with `LabelSelector` as `key in (value)` + to select the group of existing pods which pods will be taken into consideration + for the incoming pod's pod (anti) affinity. Keys that don't exist in the incoming + pod labels will be ignored. The default value is empty. + The same key is forbidden to exist in both MatchLabelKeys and LabelSelector. + Also, MatchLabelKeys cannot be set when LabelSelector isn't set. + This is an alpha field and requires enabling MatchLabelKeysInPodAffinity feature gate. items: type: string type: array x-kubernetes-list-type: atomic mismatchLabelKeys: - description: MismatchLabelKeys is a set of pod label - keys to select which pods will be taken into consideration. - The keys are used to lookup values from the incoming - pod labels, those key-value labels are merged with - `LabelSelector` as `key notin (value)` to select the - group of existing pods which pods will be taken into - consideration for the incoming pod's pod (anti) affinity. - Keys that don't exist in the incoming pod labels will - be ignored. The default value is empty. The same key - is forbidden to exist in both MismatchLabelKeys and - LabelSelector. Also, MismatchLabelKeys cannot be set - when LabelSelector isn't set. This is an alpha field - and requires enabling MatchLabelKeysInPodAffinity - feature gate. + description: |- + MismatchLabelKeys is a set of pod label keys to select which pods will + be taken into consideration. The keys are used to lookup values from the + incoming pod labels, those key-value labels are merged with `LabelSelector` as `key notin (value)` + to select the group of existing pods which pods will be taken into consideration + for the incoming pod's pod (anti) affinity. Keys that don't exist in the incoming + pod labels will be ignored. The default value is empty. + The same key is forbidden to exist in both MismatchLabelKeys and LabelSelector. + Also, MismatchLabelKeys cannot be set when LabelSelector isn't set. + This is an alpha field and requires enabling MatchLabelKeysInPodAffinity feature gate. items: type: string type: array x-kubernetes-list-type: atomic namespaceSelector: - description: A label query over the set of namespaces - that the term applies to. The term is applied to the - union of the namespaces selected by this field and - the ones listed in the namespaces field. null selector - and null or empty namespaces list means "this pod's - namespace". An empty selector ({}) matches all namespaces. + description: |- + A label query over the set of namespaces that the term applies to. + The term is applied to the union of the namespaces selected by this field + and the ones listed in the namespaces field. + null selector and null or empty namespaces list means "this pod's namespace". + An empty selector ({}) matches all namespaces. properties: matchExpressions: description: matchExpressions is a list of label selector requirements. The requirements are ANDed. items: - description: A label selector requirement is a - selector that contains values, a key, and an - operator that relates the key and values. + description: |- + A label selector requirement is a selector that contains values, a key, and an operator that + relates the key and values. properties: key: description: key is the label key that the selector applies to. type: string operator: - description: operator represents a key's relationship - to a set of values. Valid operators are - In, NotIn, Exists and DoesNotExist. + description: |- + operator represents a key's relationship to a set of values. + Valid operators are In, NotIn, Exists and DoesNotExist. type: string values: - description: values is an array of string - values. If the operator is In or NotIn, - the values array must be non-empty. If the - operator is Exists or DoesNotExist, the - values array must be empty. This array is - replaced during a strategic merge patch. + description: |- + values is an array of string values. If the operator is In or NotIn, + the values array must be non-empty. If the operator is Exists or DoesNotExist, + the values array must be empty. This array is replaced during a strategic + merge patch. items: type: string type: array @@ -991,32 +905,28 @@ spec: matchLabels: additionalProperties: type: string - description: matchLabels is a map of {key,value} - pairs. A single {key,value} in the matchLabels - map is equivalent to an element of matchExpressions, - whose key field is "key", the operator is "In", - and the values array contains only "value". The - requirements are ANDed. + description: |- + matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels + map is equivalent to an element of matchExpressions, whose key field is "key", the + operator is "In", and the values array contains only "value". The requirements are ANDed. type: object type: object x-kubernetes-map-type: atomic namespaces: - description: namespaces specifies a static list of namespace - names that the term applies to. The term is applied - to the union of the namespaces listed in this field - and the ones selected by namespaceSelector. null or - empty namespaces list and null namespaceSelector means - "this pod's namespace". + description: |- + namespaces specifies a static list of namespace names that the term applies to. + The term is applied to the union of the namespaces listed in this field + and the ones selected by namespaceSelector. + null or empty namespaces list and null namespaceSelector means "this pod's namespace". items: type: string type: array topologyKey: - description: This pod should be co-located (affinity) - or not co-located (anti-affinity) with the pods matching - the labelSelector in the specified namespaces, where - co-located is defined as running on a node whose value - of the label with key topologyKey matches that of - any node on which any of the selected pods is running. + description: |- + This pod should be co-located (affinity) or not co-located (anti-affinity) with the pods matching + the labelSelector in the specified namespaces, where co-located is defined as running on a node + whose value of the label with key topologyKey matches that of any node on which any of the + selected pods is running. Empty topologyKey is not allowed. type: string required: @@ -1026,19 +936,23 @@ spec: type: object type: object clusterID: - description: Defines the local service cluster name where Envoy is - running. Defaults to the NodeID in the EnvoyConfig if unset + description: |- + Defines the local service cluster name where Envoy is running. Defaults + to the NodeID in the EnvoyConfig if unset type: string discoveryServiceRef: - description: DiscoveryServiceRef points to a DiscoveryService in the - same namespace + description: |- + DiscoveryServiceRef points to a DiscoveryService in the same + namespace type: string duration: - description: Defines the duration of the client certificate that is - used to authenticate with the DiscoveryService + description: |- + Defines the duration of the client certificate that is used to authenticate + with the DiscoveryService type: string envoyConfigRef: - description: EnvoyConfigRef points to an EnvoyConfig in the same namespace + description: |- + EnvoyConfigRef points to an EnvoyConfig in the same namespace that holds the envoy resources for this Deployment type: string extraArgs: @@ -1051,8 +965,9 @@ spec: description: Image is the envoy image and tag to use type: string initManager: - description: InitManager defines configuration for Envoy's init manager, - which handles initialization for Envoy pods + description: |- + InitManager defines configuration for Envoy's init + manager, which handles initialization for Envoy pods properties: image: description: Image is the init manager image and tag to use @@ -1098,21 +1013,21 @@ spec: anyOf: - type: integer - type: string - description: An eviction is allowed if at most "maxUnavailable" - pods selected by "selector" are unavailable after the eviction, - i.e. even in absence of the evicted pod. For example, one can - prevent all voluntary evictions by specifying 0. This is a mutually - exclusive setting with "minAvailable". + description: |- + An eviction is allowed if at most "maxUnavailable" pods selected by + "selector" are unavailable after the eviction, i.e. even in absence of + the evicted pod. For example, one can prevent all voluntary evictions + by specifying 0. This is a mutually exclusive setting with "minAvailable". x-kubernetes-int-or-string: true minAvailable: anyOf: - type: integer - type: string - description: An eviction is allowed if at least "minAvailable" - pods selected by "selector" will still be available after the - eviction, i.e. even in the absence of the evicted pod. So for - example you can prevent all voluntary evictions by specifying - "100%". + description: |- + An eviction is allowed if at least "minAvailable" pods selected by + "selector" will still be available after the eviction, i.e. even in the + absence of the evicted pod. So for example you can prevent all voluntary + evictions by specifying "100%". x-kubernetes-int-or-string: true type: object ports: @@ -1171,41 +1086,39 @@ spec: - timeoutSeconds type: object replicas: - description: Replicas configures the number of replicas in the Deployment. - One of 'static', 'dynamic' can be set. If both are set, static has - precedence. + description: |- + Replicas configures the number of replicas in the Deployment. One of + 'static', 'dynamic' can be set. If both are set, static has precedence. properties: dynamic: description: Configure a min and max value for the number of pods to autoscale dynamically. properties: behavior: - description: behavior configures the scaling behavior of the - target in both Up and Down directions (scaleUp and scaleDown - fields respectively). If not set, the default HPAScalingRules - for scale up and scale down are used. + description: |- + behavior configures the scaling behavior of the target + in both Up and Down directions (scaleUp and scaleDown fields respectively). + If not set, the default HPAScalingRules for scale up and scale down are used. properties: scaleDown: - description: scaleDown is scaling policy for scaling Down. - If not set, the default value is to allow to scale down - to minReplicas pods, with a 300 second stabilization - window (i.e., the highest recommendation for the last - 300sec is used). + description: |- + scaleDown is scaling policy for scaling Down. + If not set, the default value is to allow to scale down to minReplicas pods, with a + 300 second stabilization window (i.e., the highest recommendation for + the last 300sec is used). properties: policies: - description: policies is a list of potential scaling - polices which can be used during scaling. At least - one policy must be specified, otherwise the HPAScalingRules - will be discarded as invalid + description: |- + policies is a list of potential scaling polices which can be used during scaling. + At least one policy must be specified, otherwise the HPAScalingRules will be discarded as invalid items: description: HPAScalingPolicy is a single policy which must hold true for a specified past interval. properties: periodSeconds: - description: periodSeconds specifies the window - of time for which the policy should hold true. - PeriodSeconds must be greater than zero and - less than or equal to 1800 (30 min). + description: |- + periodSeconds specifies the window of time for which the policy should hold true. + PeriodSeconds must be greater than zero and less than or equal to 1800 (30 min). format: int32 type: integer type: @@ -1213,9 +1126,9 @@ spec: policy. type: string value: - description: value contains the amount of change - which is permitted by the policy. It must - be greater than zero + description: |- + value contains the amount of change which is permitted by the policy. + It must be greater than zero format: int32 type: integer required: @@ -1226,43 +1139,41 @@ spec: type: array x-kubernetes-list-type: atomic selectPolicy: - description: selectPolicy is used to specify which - policy should be used. If not set, the default value - Max is used. + description: |- + selectPolicy is used to specify which policy should be used. + If not set, the default value Max is used. type: string stabilizationWindowSeconds: - description: 'stabilizationWindowSeconds is the number - of seconds for which past recommendations should - be considered while scaling up or scaling down. - StabilizationWindowSeconds must be greater than - or equal to zero and less than or equal to 3600 - (one hour). If not set, use the default values: + description: |- + stabilizationWindowSeconds is the number of seconds for which past recommendations should be + considered while scaling up or scaling down. + StabilizationWindowSeconds must be greater than or equal to zero and less than or equal to 3600 (one hour). + If not set, use the default values: - For scale up: 0 (i.e. no stabilization is done). - - For scale down: 300 (i.e. the stabilization window - is 300 seconds long).' + - For scale down: 300 (i.e. the stabilization window is 300 seconds long). format: int32 type: integer type: object scaleUp: - description: 'scaleUp is scaling policy for scaling Up. - If not set, the default value is the higher of: * increase - no more than 4 pods per 60 seconds * double the number - of pods per 60 seconds No stabilization is used.' + description: |- + scaleUp is scaling policy for scaling Up. + If not set, the default value is the higher of: + * increase no more than 4 pods per 60 seconds + * double the number of pods per 60 seconds + No stabilization is used. properties: policies: - description: policies is a list of potential scaling - polices which can be used during scaling. At least - one policy must be specified, otherwise the HPAScalingRules - will be discarded as invalid + description: |- + policies is a list of potential scaling polices which can be used during scaling. + At least one policy must be specified, otherwise the HPAScalingRules will be discarded as invalid items: description: HPAScalingPolicy is a single policy which must hold true for a specified past interval. properties: periodSeconds: - description: periodSeconds specifies the window - of time for which the policy should hold true. - PeriodSeconds must be greater than zero and - less than or equal to 1800 (30 min). + description: |- + periodSeconds specifies the window of time for which the policy should hold true. + PeriodSeconds must be greater than zero and less than or equal to 1800 (30 min). format: int32 type: integer type: @@ -1270,9 +1181,9 @@ spec: policy. type: string value: - description: value contains the amount of change - which is permitted by the policy. It must - be greater than zero + description: |- + value contains the amount of change which is permitted by the policy. + It must be greater than zero format: int32 type: integer required: @@ -1283,56 +1194,51 @@ spec: type: array x-kubernetes-list-type: atomic selectPolicy: - description: selectPolicy is used to specify which - policy should be used. If not set, the default value - Max is used. + description: |- + selectPolicy is used to specify which policy should be used. + If not set, the default value Max is used. type: string stabilizationWindowSeconds: - description: 'stabilizationWindowSeconds is the number - of seconds for which past recommendations should - be considered while scaling up or scaling down. - StabilizationWindowSeconds must be greater than - or equal to zero and less than or equal to 3600 - (one hour). If not set, use the default values: + description: |- + stabilizationWindowSeconds is the number of seconds for which past recommendations should be + considered while scaling up or scaling down. + StabilizationWindowSeconds must be greater than or equal to zero and less than or equal to 3600 (one hour). + If not set, use the default values: - For scale up: 0 (i.e. no stabilization is done). - - For scale down: 300 (i.e. the stabilization window - is 300 seconds long).' + - For scale down: 300 (i.e. the stabilization window is 300 seconds long). format: int32 type: integer type: object type: object maxReplicas: - description: maxReplicas is the upper limit for the number - of replicas to which the autoscaler can scale up. It cannot - be less that minReplicas. + description: |- + maxReplicas is the upper limit for the number of replicas to which the autoscaler can scale up. + It cannot be less that minReplicas. format: int32 type: integer metrics: - description: metrics contains the specifications for which - to use to calculate the desired replica count (the maximum - replica count across all metrics will be used). The desired - replica count is calculated multiplying the ratio between - the target value and the current value by the current number - of pods. Ergo, metrics used must decrease as the pod count - is increased, and vice-versa. See the individual metric - source types for more information about how each type of - metric must respond. If not set, the default metric will - be set to 80% average CPU utilization. + description: |- + metrics contains the specifications for which to use to calculate the + desired replica count (the maximum replica count across all metrics will + be used). The desired replica count is calculated multiplying the + ratio between the target value and the current value by the current + number of pods. Ergo, metrics used must decrease as the pod count is + increased, and vice-versa. See the individual metric source types for + more information about how each type of metric must respond. + If not set, the default metric will be set to 80% average CPU utilization. items: - description: MetricSpec specifies how to scale based on - a single metric (only `type` and one other matching field - should be set at once). + description: |- + MetricSpec specifies how to scale based on a single metric + (only `type` and one other matching field should be set at once). properties: containerResource: - description: containerResource refers to a resource - metric (such as those specified in requests and limits) - known to Kubernetes describing a single container - in each pod of the current scale target (e.g. CPU - or memory). Such metrics are built in to Kubernetes, - and have special scaling options on top of those available - to normal per-pod metrics using the "pods" source. - This is an alpha feature and can be enabled by the - HPAContainerMetrics feature flag. + description: |- + containerResource refers to a resource metric (such as those specified in + requests and limits) known to Kubernetes describing a single container in + each pod of the current scale target (e.g. CPU or memory). Such metrics are + built in to Kubernetes, and have special scaling options on top of those + available to normal per-pod metrics using the "pods" source. + This is an alpha feature and can be enabled by the HPAContainerMetrics feature flag. properties: container: description: container is the name of the container @@ -1347,21 +1253,20 @@ spec: the given metric properties: averageUtilization: - description: averageUtilization is the target - value of the average of the resource metric - across all relevant pods, represented as a - percentage of the requested value of the resource - for the pods. Currently only valid for Resource - metric source type + description: |- + averageUtilization is the target value of the average of the + resource metric across all relevant pods, represented as a percentage of + the requested value of the resource for the pods. + Currently only valid for Resource metric source type format: int32 type: integer averageValue: anyOf: - type: integer - type: string - description: averageValue is the target value - of the average of the metric across all relevant - pods (as a quantity) + description: |- + averageValue is the target value of the average of the + metric across all relevant pods (as a quantity) pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$ x-kubernetes-int-or-string: true type: @@ -1385,12 +1290,12 @@ spec: - target type: object external: - description: external refers to a global metric that - is not associated with any Kubernetes object. It allows - autoscaling based on information coming from components - running outside of cluster (for example length of - queue in cloud messaging service, or QPS from loadbalancer - running outside of cluster). + description: |- + external refers to a global metric that is not associated + with any Kubernetes object. It allows autoscaling based on information + coming from components running outside of cluster + (for example length of queue in cloud messaging service, or + QPS from loadbalancer running outside of cluster). properties: metric: description: metric identifies the target metric @@ -1400,43 +1305,35 @@ spec: description: name is the name of the given metric type: string selector: - description: selector is the string-encoded - form of a standard kubernetes label selector - for the given metric When set, it is passed - as an additional parameter to the metrics - server for more specific metrics scoping. - When unset, just the metricName will be used - to gather metrics. + description: |- + selector is the string-encoded form of a standard kubernetes label selector for the given metric + When set, it is passed as an additional parameter to the metrics server for more specific metrics scoping. + When unset, just the metricName will be used to gather metrics. properties: matchExpressions: description: matchExpressions is a list of label selector requirements. The requirements are ANDed. items: - description: A label selector requirement - is a selector that contains values, - a key, and an operator that relates - the key and values. + description: |- + A label selector requirement is a selector that contains values, a key, and an operator that + relates the key and values. properties: key: description: key is the label key that the selector applies to. type: string operator: - description: operator represents a - key's relationship to a set of values. - Valid operators are In, NotIn, Exists - and DoesNotExist. + description: |- + operator represents a key's relationship to a set of values. + Valid operators are In, NotIn, Exists and DoesNotExist. type: string values: - description: values is an array of - string values. If the operator is - In or NotIn, the values array must - be non-empty. If the operator is - Exists or DoesNotExist, the values - array must be empty. This array - is replaced during a strategic merge - patch. + description: |- + values is an array of string values. If the operator is In or NotIn, + the values array must be non-empty. If the operator is Exists or DoesNotExist, + the values array must be empty. This array is replaced during a strategic + merge patch. items: type: string type: array @@ -1448,12 +1345,10 @@ spec: matchLabels: additionalProperties: type: string - description: matchLabels is a map of {key,value} - pairs. A single {key,value} in the matchLabels - map is equivalent to an element of matchExpressions, - whose key field is "key", the operator - is "In", and the values array contains - only "value". The requirements are ANDed. + description: |- + matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels + map is equivalent to an element of matchExpressions, whose key field is "key", the + operator is "In", and the values array contains only "value". The requirements are ANDed. type: object type: object x-kubernetes-map-type: atomic @@ -1465,21 +1360,20 @@ spec: the given metric properties: averageUtilization: - description: averageUtilization is the target - value of the average of the resource metric - across all relevant pods, represented as a - percentage of the requested value of the resource - for the pods. Currently only valid for Resource - metric source type + description: |- + averageUtilization is the target value of the average of the + resource metric across all relevant pods, represented as a percentage of + the requested value of the resource for the pods. + Currently only valid for Resource metric source type format: int32 type: integer averageValue: anyOf: - type: integer - type: string - description: averageValue is the target value - of the average of the metric across all relevant - pods (as a quantity) + description: |- + averageValue is the target value of the average of the + metric across all relevant pods (as a quantity) pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$ x-kubernetes-int-or-string: true type: @@ -1502,9 +1396,9 @@ spec: - target type: object object: - description: object refers to a metric describing a - single kubernetes object (for example, hits-per-second - on an Ingress object). + description: |- + object refers to a metric describing a single kubernetes object + (for example, hits-per-second on an Ingress object). properties: describedObject: description: describedObject specifies the descriptions @@ -1534,43 +1428,35 @@ spec: description: name is the name of the given metric type: string selector: - description: selector is the string-encoded - form of a standard kubernetes label selector - for the given metric When set, it is passed - as an additional parameter to the metrics - server for more specific metrics scoping. - When unset, just the metricName will be used - to gather metrics. + description: |- + selector is the string-encoded form of a standard kubernetes label selector for the given metric + When set, it is passed as an additional parameter to the metrics server for more specific metrics scoping. + When unset, just the metricName will be used to gather metrics. properties: matchExpressions: description: matchExpressions is a list of label selector requirements. The requirements are ANDed. items: - description: A label selector requirement - is a selector that contains values, - a key, and an operator that relates - the key and values. + description: |- + A label selector requirement is a selector that contains values, a key, and an operator that + relates the key and values. properties: key: description: key is the label key that the selector applies to. type: string operator: - description: operator represents a - key's relationship to a set of values. - Valid operators are In, NotIn, Exists - and DoesNotExist. + description: |- + operator represents a key's relationship to a set of values. + Valid operators are In, NotIn, Exists and DoesNotExist. type: string values: - description: values is an array of - string values. If the operator is - In or NotIn, the values array must - be non-empty. If the operator is - Exists or DoesNotExist, the values - array must be empty. This array - is replaced during a strategic merge - patch. + description: |- + values is an array of string values. If the operator is In or NotIn, + the values array must be non-empty. If the operator is Exists or DoesNotExist, + the values array must be empty. This array is replaced during a strategic + merge patch. items: type: string type: array @@ -1582,12 +1468,10 @@ spec: matchLabels: additionalProperties: type: string - description: matchLabels is a map of {key,value} - pairs. A single {key,value} in the matchLabels - map is equivalent to an element of matchExpressions, - whose key field is "key", the operator - is "In", and the values array contains - only "value". The requirements are ANDed. + description: |- + matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels + map is equivalent to an element of matchExpressions, whose key field is "key", the + operator is "In", and the values array contains only "value". The requirements are ANDed. type: object type: object x-kubernetes-map-type: atomic @@ -1599,21 +1483,20 @@ spec: the given metric properties: averageUtilization: - description: averageUtilization is the target - value of the average of the resource metric - across all relevant pods, represented as a - percentage of the requested value of the resource - for the pods. Currently only valid for Resource - metric source type + description: |- + averageUtilization is the target value of the average of the + resource metric across all relevant pods, represented as a percentage of + the requested value of the resource for the pods. + Currently only valid for Resource metric source type format: int32 type: integer averageValue: anyOf: - type: integer - type: string - description: averageValue is the target value - of the average of the metric across all relevant - pods (as a quantity) + description: |- + averageValue is the target value of the average of the + metric across all relevant pods (as a quantity) pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$ x-kubernetes-int-or-string: true type: @@ -1637,10 +1520,10 @@ spec: - target type: object pods: - description: pods refers to a metric describing each - pod in the current scale target (for example, transactions-processed-per-second). The - values will be averaged together before being compared - to the target value. + description: |- + pods refers to a metric describing each pod in the current scale target + (for example, transactions-processed-per-second). The values will be + averaged together before being compared to the target value. properties: metric: description: metric identifies the target metric @@ -1650,43 +1533,35 @@ spec: description: name is the name of the given metric type: string selector: - description: selector is the string-encoded - form of a standard kubernetes label selector - for the given metric When set, it is passed - as an additional parameter to the metrics - server for more specific metrics scoping. - When unset, just the metricName will be used - to gather metrics. + description: |- + selector is the string-encoded form of a standard kubernetes label selector for the given metric + When set, it is passed as an additional parameter to the metrics server for more specific metrics scoping. + When unset, just the metricName will be used to gather metrics. properties: matchExpressions: description: matchExpressions is a list of label selector requirements. The requirements are ANDed. items: - description: A label selector requirement - is a selector that contains values, - a key, and an operator that relates - the key and values. + description: |- + A label selector requirement is a selector that contains values, a key, and an operator that + relates the key and values. properties: key: description: key is the label key that the selector applies to. type: string operator: - description: operator represents a - key's relationship to a set of values. - Valid operators are In, NotIn, Exists - and DoesNotExist. + description: |- + operator represents a key's relationship to a set of values. + Valid operators are In, NotIn, Exists and DoesNotExist. type: string values: - description: values is an array of - string values. If the operator is - In or NotIn, the values array must - be non-empty. If the operator is - Exists or DoesNotExist, the values - array must be empty. This array - is replaced during a strategic merge - patch. + description: |- + values is an array of string values. If the operator is In or NotIn, + the values array must be non-empty. If the operator is Exists or DoesNotExist, + the values array must be empty. This array is replaced during a strategic + merge patch. items: type: string type: array @@ -1698,12 +1573,10 @@ spec: matchLabels: additionalProperties: type: string - description: matchLabels is a map of {key,value} - pairs. A single {key,value} in the matchLabels - map is equivalent to an element of matchExpressions, - whose key field is "key", the operator - is "In", and the values array contains - only "value". The requirements are ANDed. + description: |- + matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels + map is equivalent to an element of matchExpressions, whose key field is "key", the + operator is "In", and the values array contains only "value". The requirements are ANDed. type: object type: object x-kubernetes-map-type: atomic @@ -1715,21 +1588,20 @@ spec: the given metric properties: averageUtilization: - description: averageUtilization is the target - value of the average of the resource metric - across all relevant pods, represented as a - percentage of the requested value of the resource - for the pods. Currently only valid for Resource - metric source type + description: |- + averageUtilization is the target value of the average of the + resource metric across all relevant pods, represented as a percentage of + the requested value of the resource for the pods. + Currently only valid for Resource metric source type format: int32 type: integer averageValue: anyOf: - type: integer - type: string - description: averageValue is the target value - of the average of the metric across all relevant - pods (as a quantity) + description: |- + averageValue is the target value of the average of the + metric across all relevant pods (as a quantity) pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$ x-kubernetes-int-or-string: true type: @@ -1752,13 +1624,12 @@ spec: - target type: object resource: - description: resource refers to a resource metric (such - as those specified in requests and limits) known to - Kubernetes describing each pod in the current scale - target (e.g. CPU or memory). Such metrics are built - in to Kubernetes, and have special scaling options - on top of those available to normal per-pod metrics - using the "pods" source. + description: |- + resource refers to a resource metric (such as those specified in + requests and limits) known to Kubernetes describing each pod in the + current scale target (e.g. CPU or memory). Such metrics are built in to + Kubernetes, and have special scaling options on top of those available + to normal per-pod metrics using the "pods" source. properties: name: description: name is the name of the resource in @@ -1769,21 +1640,20 @@ spec: the given metric properties: averageUtilization: - description: averageUtilization is the target - value of the average of the resource metric - across all relevant pods, represented as a - percentage of the requested value of the resource - for the pods. Currently only valid for Resource - metric source type + description: |- + averageUtilization is the target value of the average of the + resource metric across all relevant pods, represented as a percentage of + the requested value of the resource for the pods. + Currently only valid for Resource metric source type format: int32 type: integer averageValue: anyOf: - type: integer - type: string - description: averageValue is the target value - of the average of the metric across all relevant - pods (as a quantity) + description: |- + averageValue is the target value of the average of the + metric across all relevant pods (as a quantity) pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$ x-kubernetes-int-or-string: true type: @@ -1806,24 +1676,23 @@ spec: - target type: object type: - description: 'type is the type of metric source. It - should be one of "ContainerResource", "External", - "Object", "Pods" or "Resource", each mapping to a - matching field in the object. Note: "ContainerResource" - type is available on when the feature-gate HPAContainerMetrics - is enabled' + description: |- + type is the type of metric source. It should be one of "ContainerResource", "External", + "Object", "Pods" or "Resource", each mapping to a matching field in the object. + Note: "ContainerResource" type is available on when the feature-gate + HPAContainerMetrics is enabled type: string required: - type type: object type: array minReplicas: - description: minReplicas is the lower limit for the number - of replicas to which the autoscaler can scale down. It - defaults to 1 pod. minReplicas is allowed to be 0 if the - alpha feature gate HPAScaleToZero is enabled and at least - one Object or External metric is configured. Scaling is - active as long as at least one metric value is available. + description: |- + minReplicas is the lower limit for the number of replicas to which the autoscaler + can scale down. It defaults to 1 pod. minReplicas is allowed to be 0 if the + alpha feature gate HPAScaleToZero is enabled and at least one Object or External + metric is configured. Scaling is active as long as at least one metric value is + available. format: int32 type: integer required: @@ -1836,22 +1705,29 @@ spec: type: integer type: object resources: - description: Resources holds the resource requirements to use for - the Envoy Deployment. Defaults to no resource requests nor limits. + description: |- + Resources holds the resource requirements to use for the Envoy + Deployment. Defaults to no resource requests nor limits. properties: claims: - description: "Claims lists the names of resources, defined in - spec.resourceClaims, that are used by this container. \n This - is an alpha field and requires enabling the DynamicResourceAllocation - feature gate. \n This field is immutable. It can only be set - for containers." + description: |- + Claims lists the names of resources, defined in spec.resourceClaims, + that are used by this container. + + + This is an alpha field and requires enabling the + DynamicResourceAllocation feature gate. + + + This field is immutable. It can only be set for containers. items: description: ResourceClaim references one entry in PodSpec.ResourceClaims. properties: name: - description: Name must match the name of one entry in pod.spec.resourceClaims - of the Pod where this field is used. It makes that resource - available inside a container. + description: |- + Name must match the name of one entry in pod.spec.resourceClaims of + the Pod where this field is used. It makes that resource available + inside a container. type: string required: - name @@ -1867,8 +1743,9 @@ spec: - type: string pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$ x-kubernetes-int-or-string: true - description: 'Limits describes the maximum amount of compute resources - allowed. More info: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/' + description: |- + Limits describes the maximum amount of compute resources allowed. + More info: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ type: object requests: additionalProperties: @@ -1877,29 +1754,30 @@ spec: - type: string pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$ x-kubernetes-int-or-string: true - description: 'Requests describes the minimum amount of compute - resources required. If Requests is omitted for a container, - it defaults to Limits if that is explicitly specified, otherwise - to an implementation-defined value. Requests cannot exceed Limits. - More info: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/' + description: |- + Requests describes the minimum amount of compute resources required. + If Requests is omitted for a container, it defaults to Limits if that is explicitly specified, + otherwise to an implementation-defined value. Requests cannot exceed Limits. + More info: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/ type: object type: object shutdownManager: - description: ShutdownManager defines configuration for Envoy's shutdown + description: |- + ShutdownManager defines configuration for Envoy's shutdown manager, which handles graceful termination of Envoy pods properties: drainStrategy: - description: The drain strategy for the graceful shutdown. It - also affects drain when listeners are modified or removed via - LDS. + description: |- + The drain strategy for the graceful shutdown. It also affects + drain when listeners are modified or removed via LDS. enum: - gradual - immediate type: string drainTime: - description: The time in seconds that Envoy will drain connections - during shutdown. It also affects drain behaviour when listeners - are modified or removed via LDS. + description: |- + The time in seconds that Envoy will drain connections during shutdown. + It also affects drain behaviour when listeners are modified or removed via LDS. format: int64 type: integer image: @@ -1930,9 +1808,10 @@ spec: format: int32 type: integer collisionCount: - description: Count of hash collisions for the Deployment. The - Deployment controller uses this field as a collision avoidance - mechanism when it needs to create the name for the newest ReplicaSet. + description: |- + Count of hash collisions for the Deployment. The Deployment controller uses this + field as a collision avoidance mechanism when it needs to create the name for the + newest ReplicaSet. format: int32 type: integer conditions: @@ -1985,11 +1864,10 @@ spec: format: int32 type: integer unavailableReplicas: - description: Total number of unavailable pods targeted by this - deployment. This is the total number of pods that are still - required for the deployment to have 100% available capacity. - They may either be pods that are running but not yet available - or pods that still have not been created. + description: |- + Total number of unavailable pods targeted by this deployment. This is the total number of + pods that are still required for the deployment to have 100% available capacity. They may + either be pods that are running but not yet available or pods that still have not been created. format: int32 type: integer updatedReplicas: diff --git a/catalog/marin3r/alpha-channel.yaml b/catalog/marin3r/alpha-channel.yaml index c80550a5..11f7e46a 100644 --- a/catalog/marin3r/alpha-channel.yaml +++ b/catalog/marin3r/alpha-channel.yaml @@ -31,6 +31,10 @@ entries: - name: marin3r.v0.13.1 replaces: marin3r.v0.13.0 skipRange: ">=0.13.0 <0.13.1" + - name: marin3r.v0.13.2-alpha.1 + replaces: marin3r.v0.13.1 + - name: marin3r.v0.13.2-alpha.2 + replaces: marin3r.v0.13.2-alpha.1 name: alpha package: marin3r schema: olm.channel diff --git a/catalog/marin3r/objects/marin3r.v0.13.2-alpha.1.clusterserviceversion.yaml b/catalog/marin3r/objects/marin3r.v0.13.2-alpha.1.clusterserviceversion.yaml new file mode 100644 index 00000000..3a45aaaa --- /dev/null +++ b/catalog/marin3r/objects/marin3r.v0.13.2-alpha.1.clusterserviceversion.yaml @@ -0,0 +1,70 @@ +--- +image: quay.io/3scale/marin3r-bundle:v0.13.2-alpha.1 +name: marin3r.v0.13.2-alpha.1 +package: marin3r +properties: +- type: olm.gvk + value: + group: marin3r.3scale.net + kind: EnvoyConfig + version: v1alpha1 +- type: olm.gvk + value: + group: marin3r.3scale.net + kind: EnvoyConfigRevision + version: v1alpha1 +- type: olm.gvk + value: + group: operator.marin3r.3scale.net + kind: DiscoveryService + version: v1alpha1 +- type: olm.gvk + value: + group: operator.marin3r.3scale.net + kind: DiscoveryServiceCertificate + version: v1alpha1 +- type: olm.gvk + value: + group: operator.marin3r.3scale.net + kind: EnvoyDeployment + version: v1alpha1 +- type: olm.package + value: + packageName: marin3r + version: 0.13.2-alpha.1 +- type: olm.bundle.object + value: + data: eyJhcGlWZXJzaW9uIjoidjEiLCJraW5kIjoiU2VydmljZSIsIm1ldGFkYXRhIjp7ImNyZWF0aW9uVGltZXN0YW1wIjpudWxsLCJsYWJlbHMiOnsiY29udHJvbC1wbGFuZSI6ImNvbnRyb2xsZXItbWFuYWdlciJ9LCJuYW1lIjoibWFyaW4zci1jb250cm9sbGVyLW1hbmFnZXItbWV0cmljcy1zZXJ2aWNlIn0sInNwZWMiOnsicG9ydHMiOlt7Im5hbWUiOiJtZXRyaWNzIiwicG9ydCI6ODA4MCwicHJvdG9jb2wiOiJUQ1AiLCJ0YXJnZXRQb3J0IjoibWV0cmljcyJ9XSwic2VsZWN0b3IiOnsiY29udHJvbC1wbGFuZSI6ImNvbnRyb2xsZXItbWFuYWdlciJ9fSwic3RhdHVzIjp7ImxvYWRCYWxhbmNlciI6e319fQ== +- type: olm.bundle.object + value: + data: eyJhcGlWZXJzaW9uIjoidjEiLCJkYXRhIjp7ImNvbnRyb2xsZXJfbWFuYWdlcl9jb25maWcueWFtbCI6ImFwaVZlcnNpb246IGNvbnRyb2xsZXItcnVudGltZS5zaWdzLms4cy5pby92MWFscGhhMVxua2luZDogQ29udHJvbGxlck1hbmFnZXJDb25maWdcbmhlYWx0aDpcbiAgaGVhbHRoUHJvYmVCaW5kQWRkcmVzczogOjgwODFcbm1ldHJpY3M6XG4gIGJpbmRBZGRyZXNzOiAxMjcuMC4wLjE6ODA4MFxud2ViaG9vazpcbiAgcG9ydDogOTQ0M1xubGVhZGVyRWxlY3Rpb246XG4gIGxlYWRlckVsZWN0OiB0cnVlXG4gIHJlc291cmNlTmFtZTogOTQ0NGYxZDcuM3NjYWxlLm5ldFxuIn0sImtpbmQiOiJDb25maWdNYXAiLCJtZXRhZGF0YSI6eyJuYW1lIjoibWFyaW4zci1tYW5hZ2VyLWNvbmZpZyJ9fQ== +- type: olm.bundle.object + value: + data: eyJhcGlWZXJzaW9uIjoicmJhYy5hdXRob3JpemF0aW9uLms4cy5pby92MSIsImtpbmQiOiJDbHVzdGVyUm9sZSIsIm1ldGFkYXRhIjp7ImNyZWF0aW9uVGltZXN0YW1wIjpudWxsLCJuYW1lIjoibWFyaW4zci1tZXRyaWNzLXJlYWRlciJ9LCJydWxlcyI6W3sibm9uUmVzb3VyY2VVUkxzIjpbIi9tZXRyaWNzIl0sInZlcmJzIjpbImdldCJdfV19 +- type: olm.bundle.object + value: + data: eyJhcGlWZXJzaW9uIjoidjEiLCJraW5kIjoiU2VydmljZSIsIm1ldGFkYXRhIjp7ImNyZWF0aW9uVGltZXN0YW1wIjpudWxsLCJuYW1lIjoibWFyaW4zci13ZWJob29rLXNlcnZpY2UifSwic3BlYyI6eyJwb3J0cyI6W3sicG9ydCI6NDQzLCJwcm90b2NvbCI6IlRDUCIsInRhcmdldFBvcnQiOjk0NDN9XSwic2VsZWN0b3IiOnsiY29udHJvbC1wbGFuZSI6ImNvbnRyb2xsZXItd2ViaG9vayJ9fSwic3RhdHVzIjp7ImxvYWRCYWxhbmNlciI6e319fQ== +- type: olm.bundle.object + value: + data: {"apiVersion":"apiextensions.k8s.io/v1","kind":"CustomResourceDefinition","metadata":{"annotations":{"controller-gen.kubebuilder.io/version":"v0.11.3"},"creationTimestamp":null,"name":"envoyconfigrevisions.marin3r.3scale.net"},"spec":{"group":"marin3r.3scale.net","names":{"kind":"EnvoyConfigRevision","listKind":"EnvoyConfigRevisionList","plural":"envoyconfigrevisions","shortNames":["ecr"],"singular":"envoyconfigrevision"},"scope":"Namespaced","versions":[{"additionalPrinterColumns":[{"jsonPath":".spec.nodeID","name":"Node ID","type":"string"},{"jsonPath":".spec.envoyAPI","name":"Envoy API","type":"string"},{"jsonPath":".spec.version","name":"Version","type":"string"},{"jsonPath":".status.published","name":"Published","type":"boolean"},{"format":"date-time","jsonPath":".metadata.creationTimestamp","name":"Created At","type":"string"},{"format":"date-time","jsonPath":".status.lastPublishedAt","name":"Last Published At","type":"string"},{"jsonPath":".status.tainted","name":"Tainted","type":"boolean"}],"name":"v1alpha1","schema":{"openAPIV3Schema":{"description":"EnvoyConfigRevision is an internal resource that stores a specific version of an EnvoyConfig resource. EnvoyConfigRevisions are automatically created and deleted by the EnvoyConfig controller and are not intended to be directly used. Use EnvoyConfig objects instead.","properties":{"apiVersion":{"description":"APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources","type":"string"},"kind":{"description":"Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds","type":"string"},"metadata":{"type":"object"},"spec":{"description":"EnvoyConfigRevisionSpec defines the desired state of EnvoyConfigRevision","properties":{"envoyAPI":{"description":"EnvoyAPI is the version of envoy's API to use. Defaults to v3.","enum":["v3"],"type":"string"},"envoyResources":{"description":"EnvoyResources holds the different types of resources suported by the envoy discovery service","properties":{"clusters":{"description":"Clusters is a list of the envoy Cluster resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/cluster/v3/cluster.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy resource","properties":{"name":{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"endpoints":{"description":"Endpoints is a list of the envoy ClusterLoadAssignment resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/endpoint/v3/endpoint.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy resource","properties":{"name":{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"extensionConfigs":{"description":"ExtensionConfigs is a list of the envoy ExtensionConfig resource type API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/core/v3/extension.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy resource","properties":{"name":{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"listeners":{"description":"Listeners is a list of the envoy Listener resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/listener/v3/listener.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy resource","properties":{"name":{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"routes":{"description":"Routes is a list of the envoy Route resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/route/v3/route.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy resource","properties":{"name":{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"runtimes":{"description":"Runtimes is a list of the envoy Runtime resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/service/runtime/v3/rtds.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy resource","properties":{"name":{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"scopedRoutes":{"description":"ScopedRoutes is a list of the envoy ScopeRoute resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/route/v3/scoped_route.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy resource","properties":{"name":{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"secrets":{"description":"Secrets is a list of references to Kubernetes Secret objects.","items":{"description":"EnvoySecretResource holds a reference to a k8s Secret from where to take a secret from. Only Secrets within the same namespace can be referred.","properties":{"name":{"description":"Name of the envoy tslCerticate secret resource. The certificate will be fetched from a Kubernetes Secrets of type 'kubernetes.io/tls' with this same name.","type":"string"},"ref":{"description":"DEPRECATED: this field is deprecated and it's value will be ignored. The 'name' of the Kubernetes Secret must match the 'name' field.","properties":{"name":{"description":"name is unique within a namespace to reference a secret resource.","type":"string"},"namespace":{"description":"namespace defines the space within which the secret name must be unique.","type":"string"}},"type":"object","x-kubernetes-map-type":"atomic"}},"required":["name"],"type":"object"},"type":"array"}},"type":"object"},"nodeID":{"description":"NodeID holds the envoy identifier for the discovery service to know which set of resources to send to each of the envoy clients that connect to it.","type":"string"},"resources":{"description":"Resources holds the different types of resources suported by the envoy discovery service","items":{"description":"Resource holds serialized representation of an envoy resource","properties":{"blueprint":{"description":"Blueprint specifies a template to generate a configuration proto. It is currently only supported to generate secret configuration resources from k8s Secrets","enum":["tlsCertificate","validationContext"],"type":"string"},"generateFromEndpointSlices":{"description":"Specifies a label selector to watch for EndpointSlices that will be used to generate the endpoint resource","properties":{"clusterName":{"type":"string"},"selector":{"description":"A label selector is a label query over a set of resources. The result of matchLabels and matchExpressions are ANDed. An empty label selector matches all objects. A null label selector matches no objects.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that relates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values. Valid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn, the values array must be non-empty. If the operator is Exists or DoesNotExist, the values array must be empty. This array is replaced during a strategic merge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"},"targetPort":{"type":"string"}},"required":["clusterName","selector","targetPort"],"type":"object"},"generateFromOpaqueSecret":{"description":"The name of a Kubernetes Secret of type \"Opaque\". It will generate an envoy \"generic secret\" proto.","properties":{"alias":{"description":"A unique name to refer to the name:key combination","type":"string"},"key":{"description":"The key of the secret to select from.  Must be a valid secret key.","type":"string"},"name":{"description":"The name of the secret in the pod's namespace to select from.","type":"string"}},"required":["alias","key","name"],"type":"object"},"generateFromTlsSecret":{"description":"The name of a Kubernetes Secret of type \"kubernetes.io/tls\"","type":"string"},"type":{"description":"Type is the type url for the protobuf message","enum":["listener","route","scopedRoute","cluster","endpoint","secret","runtime","extensionConfig"],"type":"string"},"value":{"description":"Value is the protobufer message that configures the resource. The proto must match the envoy configuration API v3 specification for the given resource type (https://www.envoyproxy.io/docs/envoy/latest/api-docs/xds_protocol#resource-types)","type":"object","x-kubernetes-preserve-unknown-fields":true}},"required":["type"],"type":"object"},"type":"array"},"serialization":{"description":"Serialization specicifies the serialization format used to describe the resources. \"json\" and \"yaml\" are supported. \"json\" is used if unset.","enum":["json","b64json","yaml"],"type":"string"},"version":{"description":"Version is a hash of the EnvoyResources field","type":"string"}},"required":["nodeID","version"],"type":"object"},"status":{"description":"EnvoyConfigRevisionStatus defines the observed state of EnvoyConfigRevision","properties":{"conditions":{"description":"Conditions represent the latest available observations of an object's state","items":{"description":"Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions.  For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }","properties":{"lastTransitionTime":{"description":"lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed.  If that is not known, then using the time when the API field changed is acceptable.","format":"date-time","type":"string"},"message":{"description":"message is a human readable message indicating details about the transition. This may be an empty string.","maxLength":32768,"type":"string"},"observedGeneration":{"description":"observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.","format":"int64","minimum":0,"type":"integer"},"reason":{"description":"reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.","maxLength":1024,"minLength":1,"pattern":"^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$","type":"string"},"status":{"description":"status of the condition, one of True, False, Unknown.","enum":["True","False","Unknown"],"type":"string"},"type":{"description":"type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)","maxLength":316,"pattern":"^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$","type":"string"}},"required":["lastTransitionTime","message","reason","status","type"],"type":"object"},"type":"array"},"lastPublishedAt":{"description":"LastPublishedAt indicates the last time this config review transitioned to published","format":"date-time","type":"string"},"providesVersions":{"description":"ProvidesVersions keeps track of the version that this revision publishes in the xDS server for each resource type","properties":{"clusters":{"type":"string"},"endpoints":{"type":"string"},"extensionConfigs":{"type":"string"},"listeners":{"type":"string"},"routes":{"type":"string"},"runtimes":{"type":"string"},"scopedRoutes":{"type":"string"},"secrets":{"type":"string"}},"type":"object"},"published":{"description":"Published signals if the EnvoyConfigRevision is the one currently published in the xds server cache","type":"boolean"},"tainted":{"description":"Tainted indicates whether the EnvoyConfigRevision is eligible for publishing or not","type":"boolean"}},"type":"object"}},"type":"object"}},"served":true,"storage":true,"subresources":{"status":{}}}]},"status":{"acceptedNames":{"kind":"","plural":""},"conditions":null,"storedVersions":null}} +- type: olm.bundle.object + value: + data: {"apiVersion":"apiextensions.k8s.io/v1","kind":"CustomResourceDefinition","metadata":{"annotations":{"controller-gen.kubebuilder.io/version":"v0.11.3"},"creationTimestamp":null,"name":"envoyconfigs.marin3r.3scale.net"},"spec":{"group":"marin3r.3scale.net","names":{"kind":"EnvoyConfig","listKind":"EnvoyConfigList","plural":"envoyconfigs","shortNames":["ec"],"singular":"envoyconfig"},"scope":"Namespaced","versions":[{"additionalPrinterColumns":[{"jsonPath":".spec.nodeID","name":"Node ID","type":"string"},{"jsonPath":".spec.envoyAPI","name":"Envoy API","type":"string"},{"jsonPath":".status.desiredVersion","name":"Desired Version","type":"string"},{"jsonPath":".status.publishedVersion","name":"Published Version","type":"string"},{"jsonPath":".status.cacheState","name":"Cache State","type":"string"}],"name":"v1alpha1","schema":{"openAPIV3Schema":{"description":"EnvoyConfig holds the configuration for a given envoy nodeID. The spec of an EnvoyConfig object holds the Envoy resources that conform the desired configuration for the given nodeID and that the discovery service will send to any envoy client that identifies itself with that nodeID.","properties":{"apiVersion":{"description":"APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources","type":"string"},"kind":{"description":"Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds","type":"string"},"metadata":{"type":"object"},"spec":{"description":"EnvoyConfigSpec defines the desired state of EnvoyConfig","properties":{"envoyAPI":{"description":"EnvoyAPI is the version of envoy's API to use. Defaults to v3.","enum":["v3"],"type":"string"},"envoyResources":{"description":"EnvoyResources holds the different types of resources suported by the envoy discovery service DEPRECATED. Use the `resources` field instead.","properties":{"clusters":{"description":"Clusters is a list of the envoy Cluster resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/cluster/v3/cluster.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy resource","properties":{"name":{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"endpoints":{"description":"Endpoints is a list of the envoy ClusterLoadAssignment resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/endpoint/v3/endpoint.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy resource","properties":{"name":{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"extensionConfigs":{"description":"ExtensionConfigs is a list of the envoy ExtensionConfig resource type API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/core/v3/extension.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy resource","properties":{"name":{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"listeners":{"description":"Listeners is a list of the envoy Listener resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/listener/v3/listener.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy resource","properties":{"name":{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"routes":{"description":"Routes is a list of the envoy Route resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/route/v3/route.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy resource","properties":{"name":{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"runtimes":{"description":"Runtimes is a list of the envoy Runtime resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/service/runtime/v3/rtds.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy resource","properties":{"name":{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"scopedRoutes":{"description":"ScopedRoutes is a list of the envoy ScopeRoute resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/route/v3/scoped_route.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy resource","properties":{"name":{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"secrets":{"description":"Secrets is a list of references to Kubernetes Secret objects.","items":{"description":"EnvoySecretResource holds a reference to a k8s Secret from where to take a secret from. Only Secrets within the same namespace can be referred.","properties":{"name":{"description":"Name of the envoy tslCerticate secret resource. The certificate will be fetched from a Kubernetes Secrets of type 'kubernetes.io/tls' with this same name.","type":"string"},"ref":{"description":"DEPRECATED: this field is deprecated and it's value will be ignored. The 'name' of the Kubernetes Secret must match the 'name' field.","properties":{"name":{"description":"name is unique within a namespace to reference a secret resource.","type":"string"},"namespace":{"description":"namespace defines the space within which the secret name must be unique.","type":"string"}},"type":"object","x-kubernetes-map-type":"atomic"}},"required":["name"],"type":"object"},"type":"array"}},"type":"object"},"nodeID":{"description":"NodeID holds the envoy identifier for the discovery service to know which set of resources to send to each of the envoy clients that connect to it.","type":"string"},"resources":{"description":"Resources holds the different types of resources suported by the envoy discovery service","items":{"description":"Resource holds serialized representation of an envoy resource","properties":{"blueprint":{"description":"Blueprint specifies a template to generate a configuration proto. It is currently only supported to generate secret configuration resources from k8s Secrets","enum":["tlsCertificate","validationContext"],"type":"string"},"generateFromEndpointSlices":{"description":"Specifies a label selector to watch for EndpointSlices that will be used to generate the endpoint resource","properties":{"clusterName":{"type":"string"},"selector":{"description":"A label selector is a label query over a set of resources. The result of matchLabels and matchExpressions are ANDed. An empty label selector matches all objects. A null label selector matches no objects.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that relates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values. Valid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn, the values array must be non-empty. If the operator is Exists or DoesNotExist, the values array must be empty. This array is replaced during a strategic merge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"},"targetPort":{"type":"string"}},"required":["clusterName","selector","targetPort"],"type":"object"},"generateFromOpaqueSecret":{"description":"The name of a Kubernetes Secret of type \"Opaque\". It will generate an envoy \"generic secret\" proto.","properties":{"alias":{"description":"A unique name to refer to the name:key combination","type":"string"},"key":{"description":"The key of the secret to select from.  Must be a valid secret key.","type":"string"},"name":{"description":"The name of the secret in the pod's namespace to select from.","type":"string"}},"required":["alias","key","name"],"type":"object"},"generateFromTlsSecret":{"description":"The name of a Kubernetes Secret of type \"kubernetes.io/tls\"","type":"string"},"type":{"description":"Type is the type url for the protobuf message","enum":["listener","route","scopedRoute","cluster","endpoint","secret","runtime","extensionConfig"],"type":"string"},"value":{"description":"Value is the protobufer message that configures the resource. The proto must match the envoy configuration API v3 specification for the given resource type (https://www.envoyproxy.io/docs/envoy/latest/api-docs/xds_protocol#resource-types)","type":"object","x-kubernetes-preserve-unknown-fields":true}},"required":["type"],"type":"object"},"type":"array"},"serialization":{"description":"Serialization specicifies the serialization format used to describe the resources. \"json\" and \"yaml\" are supported. \"json\" is used if unset.","enum":["json","yaml"],"type":"string"}},"required":["nodeID"],"type":"object"},"status":{"description":"EnvoyConfigStatus defines the observed state of EnvoyConfig","properties":{"cacheState":{"description":"CacheState summarizes all the observations about the EnvoyConfig to give the user a concrete idea on the general status of the discovery servie cache. It is intended only for human consumption. Other controllers should relly on conditions to determine the status of the discovery server cache.","type":"string"},"conditions":{"description":"Conditions represent the latest available observations of an object's state","items":{"description":"Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions.  For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }","properties":{"lastTransitionTime":{"description":"lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed.  If that is not known, then using the time when the API field changed is acceptable.","format":"date-time","type":"string"},"message":{"description":"message is a human readable message indicating details about the transition. This may be an empty string.","maxLength":32768,"type":"string"},"observedGeneration":{"description":"observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.","format":"int64","minimum":0,"type":"integer"},"reason":{"description":"reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.","maxLength":1024,"minLength":1,"pattern":"^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$","type":"string"},"status":{"description":"status of the condition, one of True, False, Unknown.","enum":["True","False","Unknown"],"type":"string"},"type":{"description":"type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)","maxLength":316,"pattern":"^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$","type":"string"}},"required":["lastTransitionTime","message","reason","status","type"],"type":"object"},"type":"array"},"desiredVersion":{"description":"DesiredVersion represents the resources version described in the spec of the EnvoyConfig object","type":"string"},"publishedVersion":{"description":"PublishedVersion is the config version currently served by the envoy discovery service for the give nodeID","type":"string"},"revisions":{"description":"ConfigRevisions is an ordered list of references to EnvoyConfigRevision objects","items":{"description":"ConfigRevisionRef holds a reference to EnvoyConfigRevision object","properties":{"ref":{"description":"Ref is a reference to the EnvoyConfigRevision object that holds the configuration matching the Version field.","properties":{"apiVersion":{"description":"API version of the referent.","type":"string"},"fieldPath":{"description":"If referring to a piece of an object instead of an entire object, this string should contain a valid JSON/Go field access statement, such as desiredState.manifest.containers[2]. For example, if the object reference is to a container within a pod, this would take on a value like: \"spec.containers{name}\" (where \"name\" refers to the name of the container that triggered the event) or if no container name is specified \"spec.containers[2]\" (container with index 2 in this pod). This syntax is chosen only to have some well-defined way of referencing a part of an object. TODO: this design is not final and this field is subject to change in the future.","type":"string"},"kind":{"description":"Kind of the referent. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds","type":"string"},"name":{"description":"Name of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names","type":"string"},"namespace":{"description":"Namespace of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/","type":"string"},"resourceVersion":{"description":"Specific resourceVersion to which this reference is made, if any. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#concurrency-control-and-consistency","type":"string"},"uid":{"description":"UID of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#uids","type":"string"}},"type":"object","x-kubernetes-map-type":"atomic"},"version":{"description":"Version is a hash of the EnvoyResources field","type":"string"}},"required":["ref","version"],"type":"object"},"type":"array"}},"type":"object"}},"type":"object"}},"served":true,"storage":true,"subresources":{"status":{}}}]},"status":{"acceptedNames":{"kind":"","plural":""},"conditions":null,"storedVersions":null}} +- type: olm.bundle.object + value: + data: {"apiVersion":"operators.coreos.com/v1alpha1","kind":"ClusterServiceVersion","metadata":{"annotations":{"alm-examples":"[\n  {\n    \"apiVersion\": \"marin3r.3scale.net/v1alpha1\",\n    \"kind\": \"EnvoyConfig\",\n    \"metadata\": {\n      \"name\": \"envoyconfig-example\",\n      \"namespace\": \"my-namespace\"\n    },\n    \"spec\": {\n      \"nodeID\": \"example\",\n      \"resources\": [\n        {\n          \"type\": \"cluster\",\n          \"value\": {\n            \"connect_timeout\": \"0.01s\",\n            \"dns_lookup_family\": \"V4_ONLY\",\n            \"lb_policy\": \"ROUND_ROBIN\",\n            \"load_assignment\": {\n              \"cluster_name\": \"example\",\n              \"endpoints\": [\n                {\n                  \"lb_endpoints\": [\n                    {\n                      \"endpoint\": {\n                        \"address\": {\n                          \"socket_address\": {\n                            \"address\": \"example\",\n                            \"port_value\": 8080\n                          }\n                        }\n                      }\n                    }\n                  ]\n                }\n              ]\n            },\n            \"name\": \"example\",\n            \"type\": \"STRICT_DNS\"\n          }\n        },\n        {\n          \"type\": \"route\",\n          \"value\": {\n            \"name\": \"local\",\n            \"virtual_hosts\": [\n              {\n                \"domains\": [\n                  \"*\"\n                ],\n                \"name\": \"all\",\n                \"routes\": [\n                  {\n                    \"match\": {\n                      \"prefix\": \"/\"\n                    },\n                    \"route\": {\n                      \"cluster\": \"example\"\n                    }\n                  }\n                ]\n              }\n            ]\n          }\n        },\n        {\n          \"type\": \"listener\",\n          \"value\": {\n            \"address\": {\n              \"socket_address\": {\n                \"address\": \"0.0.0.0\",\n                \"port_value\": 8443\n              }\n            },\n            \"filter_chains\": [\n              {\n                \"filters\": [\n                  {\n                    \"name\": \"envoy.filters.network.http_connection_manager\",\n                    \"typed_config\": {\n                      \"@type\": \"type.googleapis.com/envoy.extensions.filters.network.http_connection_manager.v3.HttpConnectionManager\",\n                      \"access_log\": [\n                        {\n                          \"name\": \"envoy.access_loggers.file\",\n                          \"typed_config\": {\n                            \"@type\": \"type.googleapis.com/envoy.extensions.access_loggers.file.v3.FileAccessLog\",\n                            \"path\": \"/dev/stdout\"\n                          }\n                        }\n                      ],\n                      \"http_filters\": [\n                        {\n                          \"name\": \"envoy.filters.http.router\",\n                          \"typed_config\": {\n                            \"@type\": \"type.googleapis.com/envoy.extensions.filters.http.router.v3.Router\"\n                          }\n                        }\n                      ],\n                      \"rds\": {\n                        \"config_source\": {\n                          \"ads\": {},\n                          \"resource_api_version\": \"V3\"\n                        },\n                        \"route_config_name\": \"local\"\n                      },\n                      \"stat_prefix\": \"https\"\n                    }\n                  }\n                ],\n                \"transport_socket\": {\n                  \"name\": \"envoy.transport_sockets.tls\",\n                  \"typed_config\": {\n                    \"@type\": \"type.googleapis.com/envoy.extensions.transport_sockets.tls.v3.DownstreamTlsContext\",\n                    \"common_tls_context\": {\n                      \"tls_certificate_sds_secret_configs\": [\n                        {\n                          \"name\": \"example.default.svc\",\n                          \"sds_config\": {\n                            \"ads\": {},\n                            \"resource_api_version\": \"V3\"\n                          }\n                        }\n                      ]\n                    }\n                  }\n                }\n              }\n            ],\n            \"name\": \"https\"\n          }\n        },\n        {\n          \"blueprint\": \"tlsCertificate\",\n          \"generateFromTlsSecret\": \"example.default.svc\",\n          \"type\": \"secret\"\n        }\n      ]\n    }\n  },\n  {\n    \"apiVersion\": \"operator.marin3r.3scale.net/v1alpha1\",\n    \"kind\": \"DiscoveryService\",\n    \"metadata\": {\n      \"name\": \"discoveryservice-example\",\n      \"namespace\": \"my-namespace\"\n    },\n    \"spec\": {}\n  },\n  {\n    \"apiVersion\": \"operator.marin3r.3scale.net/v1alpha1\",\n    \"kind\": \"EnvoyDeployment\",\n    \"metadata\": {\n      \"name\": \"envoydeployment-sample\",\n      \"namespace\": \"my-namespace\"\n    },\n    \"spec\": {\n      \"discoveryServiceRef\": \"discoveryservice-example\",\n      \"envoyConfigRef\": \"envoyconfig-example\",\n      \"ports\": [\n        {\n          \"name\": \"https\",\n          \"port\": 8443\n        }\n      ]\n    }\n  }\n]","capabilities":"Full Lifecycle","categories":"Networking","certified":"false","containerImage":"quay.io/3scale/marin3r","createdAt":"2024-11-04T10:39:27Z","description":"Lighweight, CRD based Envoy control plane for Kubernetes","operators.operatorframework.io/builder":"operator-sdk-v1.28.0","operators.operatorframework.io/internal-objects":"[\"envoyconfigrevisions.marin3r.3scale.net\",\"discoveryservicecertificates.operator.marin3r.3scale.net\"]","operators.operatorframework.io/project_layout":"go.kubebuilder.io/v3","repository":"https://github.com/3scale-ops/marin3r","support":"Red Hat, Inc."},"name":"marin3r.v0.13.2-alpha.1","namespace":"placeholder"},"spec":{"apiservicedefinitions":{},"customresourcedefinitions":{"owned":[{"description":"DiscoveryServiceCertificate is an internal resource used to create certificates. This resource is used by the DiscoveryService controller to create the required certificates for the different components. Direct use of DiscoveryServiceCertificate objects is discouraged.","displayName":"DiscoveryServiceCertificate","kind":"DiscoveryServiceCertificate","name":"discoveryservicecertificates.operator.marin3r.3scale.net","specDescriptors":[{"description":"CertificateRenewalConfig configures the certificate renewal process. If unset default behavior is to renew the certificate but not notify of renewals.","displayName":"Certificate Renewal Config","path":"certificateRenewal"},{"description":"Enabled is a flag to enable or disable renewal of the certificate","displayName":"Enabled","path":"certificateRenewal.enabled"},{"description":"CommonName is the CommonName of the certificate","displayName":"Common Name","path":"commonName"},{"description":"Hosts is the list of hosts the certificate is valid for. Only use when 'IsServerCertificate' is true. If unset, the CommonName field will be used to populate the valid hosts of the certificate.","displayName":"Hosts","path":"hosts"},{"description":"IsCA is a boolean specifying that the certificate is a CA","displayName":"Is CA","path":"isCA"},{"description":"SecretRef is a reference to the secret that will hold the certificate and the private key.","displayName":"Secret Ref","path":"secretRef"},{"description":"IsServerCertificate is a boolean specifying if the certificate should be issued with server auth usage enabled","displayName":"Is Server Certificate","path":"server"},{"description":"Signer specifies  the signer to use to create this certificate. Supported signers are CertManager and SelfSigned.","displayName":"Signer","path":"signer"},{"description":"CASigned holds specific configuration for the CASigned signer","displayName":"CASigned","path":"signer.caSigned"},{"description":"A reference to a Secret containing the CA","displayName":"Secret Ref","path":"signer.caSigned.caSecretRef"},{"description":"SelfSigned holds specific configuration for the SelfSigned signer","displayName":"Self Signed","path":"signer.selfSigned"},{"description":"ValidFor specifies the validity of the certificate in seconds","displayName":"Valid For","path":"validFor"}],"statusDescriptors":[{"description":"CertificateHash stores the current hash of the certificate. It is used for other controllers to validate if a certificate has been re-issued.","displayName":"Certificate Hash","path":"certificateHash"},{"description":"Conditions represent the latest available observations of an object's state","displayName":"Conditions","path":"conditions"},{"description":"NotAfter is the time at which the certificate expires","displayName":"Not After","path":"notAfter"},{"description":"NotBefore is the time at which the certificate starts being valid","displayName":"Not Before","path":"notBefore"},{"description":"Ready is a boolean that specifies if the certificate is ready to be used","displayName":"Ready","path":"ready"}],"version":"v1alpha1"},{"description":"DiscoveryService represents an envoy discovery service server. Only one instance per namespace is currently supported.","displayName":"DiscoveryService","kind":"DiscoveryService","name":"discoveryservices.operator.marin3r.3scale.net","specDescriptors":[{"description":"Debug enables debugging log level for the discovery service controllers. It is safe to use since secret data is never shown in the logs.","displayName":"Debug","path":"debug"},{"description":"Image holds the image to use for the discovery service Deployment","displayName":"Image","path":"image"},{"description":"MetricsPort is the port where metrics are served. Defaults to 8383.","displayName":"Metrics Port","path":"metricsPort"},{"description":"PKIConfig has configuration for the PKI that marin3r manages for the different certificates it requires","displayName":"PKIConfig","path":"pkiConfg"},{"displayName":"Root Certificate Authority","path":"pkiConfg.rootCertificateAuthority"},{"displayName":"Duration","path":"pkiConfg.rootCertificateAuthority.duration"},{"displayName":"Secret Name","path":"pkiConfg.rootCertificateAuthority.secretName"},{"displayName":"Server Certificate","path":"pkiConfg.serverCertificate"},{"displayName":"Duration","path":"pkiConfg.serverCertificate.duration"},{"displayName":"Secret Name","path":"pkiConfg.serverCertificate.secretName"},{"description":"PriorityClass to assign the discovery service Pod to","displayName":"Pod Priority Class","path":"podPriorityClass"},{"description":"ProbePort is the port where healthz endpoint is served. Defaults to 8384.","displayName":"Probe Port","path":"probePort"},{"description":"Resources holds the Resource Requirements to use for the discovery service Deployment. When not set it defaults to no resource requests nor limits. CPU and Memory resources are supported.","displayName":"Resources","path":"resources"},{"description":"ServiceConfig configures the way the DiscoveryService endpoints are exposed","displayName":"Service Config","path":"serviceConfig"},{"displayName":"Name","path":"serviceConfig.name"},{"displayName":"Type","path":"serviceConfig.type"},{"description":"XdsServerPort is the port where the xDS server listens. Defaults to 18000.","displayName":"Xds Server Port","path":"xdsServerPort"}],"version":"v1alpha1"},{"description":"EnvoyConfigRevision is an internal resource that stores a specific version of an EnvoyConfig resource. EnvoyConfigRevisions are automatically created and deleted by the EnvoyConfig controller and are not intended to be directly used. Use EnvoyConfig objects instead.","displayName":"EnvoyConfigRevision","kind":"EnvoyConfigRevision","name":"envoyconfigrevisions.marin3r.3scale.net","specDescriptors":[{"description":"EnvoyAPI is the version of envoy's API to use. Defaults to v3.","displayName":"Envoy API","path":"envoyAPI"},{"description":"EnvoyResources holds the different types of resources suported by the envoy discovery service","displayName":"Envoy Resources","path":"envoyResources"},{"description":"Clusters is a list of the envoy Cluster resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/cluster/v3/cluster.proto","displayName":"Clusters","path":"envoyResources.clusters"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.clusters[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.clusters[0].value"},{"description":"Endpoints is a list of the envoy ClusterLoadAssignment resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/endpoint/v3/endpoint.proto","displayName":"Endpoints","path":"envoyResources.endpoints"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.endpoints[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.endpoints[0].value"},{"description":"ExtensionConfigs is a list of the envoy ExtensionConfig resource type API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/core/v3/extension.proto","displayName":"Extension Configs","path":"envoyResources.extensionConfigs"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.extensionConfigs[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.extensionConfigs[0].value"},{"description":"Listeners is a list of the envoy Listener resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/listener/v3/listener.proto","displayName":"Listeners","path":"envoyResources.listeners"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.listeners[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.listeners[0].value"},{"description":"Routes is a list of the envoy Route resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/route/v3/route.proto","displayName":"Routes","path":"envoyResources.routes"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.routes[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.routes[0].value"},{"description":"Runtimes is a list of the envoy Runtime resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/service/runtime/v3/rtds.proto","displayName":"Runtimes","path":"envoyResources.runtimes"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.runtimes[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.runtimes[0].value"},{"description":"ScopedRoutes is a list of the envoy ScopeRoute resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/route/v3/scoped_route.proto","displayName":"Scoped Routes","path":"envoyResources.scopedRoutes"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.scopedRoutes[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.scopedRoutes[0].value"},{"description":"Secrets is a list of references to Kubernetes Secret objects.","displayName":"Secrets","path":"envoyResources.secrets"},{"description":"Name of the envoy tslCerticate secret resource. The certificate will be fetched from a Kubernetes Secrets of type 'kubernetes.io/tls' with this same name.","displayName":"Name","path":"envoyResources.secrets[0].name"},{"description":"DEPRECATED: this field is deprecated and it's value will be ignored. The 'name' of the Kubernetes Secret must match the 'name' field.","displayName":"Ref","path":"envoyResources.secrets[0].ref","x-descriptors":["urn:alm:descriptor:io.kubernetes:SecretReference"]},{"description":"NodeID holds the envoy identifier for the discovery service to know which set of resources to send to each of the envoy clients that connect to it.","displayName":"Node ID","path":"nodeID"},{"description":"Resources holds the different types of resources suported by the envoy discovery service","displayName":"Resources","path":"resources"},{"description":"Blueprint specifies a template to generate a configuration proto. It is currently only supported to generate secret configuration resources from k8s Secrets","displayName":"Blueprint","path":"resources[0].blueprint"},{"description":"Specifies a label selector to watch for EndpointSlices that will be used to generate the endpoint resource","displayName":"Generate From Endpoint Slices","path":"resources[0].generateFromEndpointSlices"},{"description":"The name of a Kubernetes Secret of type \"Opaque\". It will generate an envoy \"generic secret\" proto.","displayName":"Generate From Opaque Secret","path":"resources[0].generateFromOpaqueSecret"},{"description":"The name of a Kubernetes Secret of type \"kubernetes.io/tls\"","displayName":"Generate From Tls Secret","path":"resources[0].generateFromTlsSecret"},{"description":"Type is the type url for the protobuf message","displayName":"Type","path":"resources[0].type"},{"description":"Value is the protobufer message that configures the resource. The proto must match the envoy configuration API v3 specification for the given resource type (https://www.envoyproxy.io/docs/envoy/latest/api-docs/xds_protocol#resource-types)","displayName":"Value","path":"resources[0].value"},{"description":"Serialization specicifies the serialization format used to describe the resources. \"json\" and \"yaml\" are supported. \"json\" is used if unset.","displayName":"Serialization","path":"serialization"},{"description":"Version is a hash of the EnvoyResources field","displayName":"Version","path":"version"}],"statusDescriptors":[{"description":"Conditions represent the latest available observations of an object's state","displayName":"Conditions","path":"conditions"},{"description":"LastPublishedAt indicates the last time this config review transitioned to published","displayName":"Last Published At","path":"lastPublishedAt"},{"description":"ProvidesVersions keeps track of the version that this revision publishes in the xDS server for each resource type","displayName":"Provides Versions","path":"providesVersions"},{"description":"Published signals if the EnvoyConfigRevision is the one currently published in the xds server cache","displayName":"Published","path":"published"},{"description":"Tainted indicates whether the EnvoyConfigRevision is eligible for publishing or not","displayName":"Tainted","path":"tainted"}],"version":"v1alpha1"},{"description":"EnvoyConfig holds the configuration for a given envoy nodeID. The spec of an EnvoyConfig object holds the Envoy resources that conform the desired configuration for the given nodeID and that the discovery service will send to any envoy client that identifies itself with that nodeID.","displayName":"EnvoyConfig","kind":"EnvoyConfig","name":"envoyconfigs.marin3r.3scale.net","resources":[{"kind":"EnvoyConfigRevision","name":"","version":"v1alpha1"}],"specDescriptors":[{"description":"EnvoyAPI is the version of envoy's API to use. Defaults to v3.","displayName":"Envoy API","path":"envoyAPI"},{"description":"EnvoyResources holds the different types of resources suported by the envoy discovery service DEPRECATED. Use the `resources` field instead.","displayName":"Envoy Resources","path":"envoyResources"},{"description":"Clusters is a list of the envoy Cluster resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/cluster/v3/cluster.proto","displayName":"Clusters","path":"envoyResources.clusters"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.clusters[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.clusters[0].value"},{"description":"Endpoints is a list of the envoy ClusterLoadAssignment resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/endpoint/v3/endpoint.proto","displayName":"Endpoints","path":"envoyResources.endpoints"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.endpoints[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.endpoints[0].value"},{"description":"ExtensionConfigs is a list of the envoy ExtensionConfig resource type API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/core/v3/extension.proto","displayName":"Extension Configs","path":"envoyResources.extensionConfigs"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.extensionConfigs[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.extensionConfigs[0].value"},{"description":"Listeners is a list of the envoy Listener resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/listener/v3/listener.proto","displayName":"Listeners","path":"envoyResources.listeners"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.listeners[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.listeners[0].value"},{"description":"Routes is a list of the envoy Route resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/route/v3/route.proto","displayName":"Routes","path":"envoyResources.routes"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.routes[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.routes[0].value"},{"description":"Runtimes is a list of the envoy Runtime resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/service/runtime/v3/rtds.proto","displayName":"Runtimes","path":"envoyResources.runtimes"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.runtimes[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.runtimes[0].value"},{"description":"ScopedRoutes is a list of the envoy ScopeRoute resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/route/v3/scoped_route.proto","displayName":"Scoped Routes","path":"envoyResources.scopedRoutes"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.scopedRoutes[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.scopedRoutes[0].value"},{"description":"Secrets is a list of references to Kubernetes Secret objects.","displayName":"Secrets","path":"envoyResources.secrets"},{"description":"Name of the envoy tslCerticate secret resource. The certificate will be fetched from a Kubernetes Secrets of type 'kubernetes.io/tls' with this same name.","displayName":"Name","path":"envoyResources.secrets[0].name"},{"description":"DEPRECATED: this field is deprecated and it's value will be ignored. The 'name' of the Kubernetes Secret must match the 'name' field.","displayName":"Ref","path":"envoyResources.secrets[0].ref","x-descriptors":["urn:alm:descriptor:io.kubernetes:SecretReference"]},{"description":"NodeID holds the envoy identifier for the discovery service to know which set of resources to send to each of the envoy clients that connect to it.","displayName":"Node ID","path":"nodeID"},{"description":"Resources holds the different types of resources suported by the envoy discovery service","displayName":"Resources","path":"resources"},{"description":"Blueprint specifies a template to generate a configuration proto. It is currently only supported to generate secret configuration resources from k8s Secrets","displayName":"Blueprint","path":"resources[0].blueprint"},{"description":"Specifies a label selector to watch for EndpointSlices that will be used to generate the endpoint resource","displayName":"Generate From Endpoint Slices","path":"resources[0].generateFromEndpointSlices"},{"description":"The name of a Kubernetes Secret of type \"Opaque\". It will generate an envoy \"generic secret\" proto.","displayName":"Generate From Opaque Secret","path":"resources[0].generateFromOpaqueSecret"},{"description":"The name of a Kubernetes Secret of type \"kubernetes.io/tls\"","displayName":"Generate From Tls Secret","path":"resources[0].generateFromTlsSecret"},{"description":"Type is the type url for the protobuf message","displayName":"Type","path":"resources[0].type"},{"description":"Value is the protobufer message that configures the resource. The proto must match the envoy configuration API v3 specification for the given resource type (https://www.envoyproxy.io/docs/envoy/latest/api-docs/xds_protocol#resource-types)","displayName":"Value","path":"resources[0].value"},{"description":"Serialization specicifies the serialization format used to describe the resources. \"json\" and \"yaml\" are supported. \"json\" is used if unset.","displayName":"Serialization","path":"serialization"}],"statusDescriptors":[{"description":"CacheState summarizes all the observations about the EnvoyConfig to give the user a concrete idea on the general status of the discovery servie cache. It is intended only for human consumption. Other controllers should relly on conditions to determine the status of the discovery server cache.","displayName":"Cache State","path":"cacheState"},{"description":"Conditions represent the latest available observations of an object's state","displayName":"Conditions","path":"conditions"},{"description":"DesiredVersion represents the resources version described in the spec of the EnvoyConfig object","displayName":"Desired Version","path":"desiredVersion"},{"description":"PublishedVersion is the config version currently served by the envoy discovery service for the give nodeID","displayName":"Published Version","path":"publishedVersion"},{"description":"ConfigRevisions is an ordered list of references to EnvoyConfigRevision objects","displayName":"Config Revisions","path":"revisions"},{"description":"Ref is a reference to the EnvoyConfigRevision object that holds the configuration matching the Version field.","displayName":"Ref","path":"revisions[0].ref"},{"description":"Version is a hash of the EnvoyResources field","displayName":"Version","path":"revisions[0].version"}],"version":"v1alpha1"},{"description":"EnvoyDeployment is a resource to deploy and manage a Kubernetes Deployment of Envoy Pods.","displayName":"EnvoyDeployment","kind":"EnvoyDeployment","name":"envoydeployments.operator.marin3r.3scale.net","specDescriptors":[{"description":"Configures envoy's admin access log path. Defaults to /dev/null.","displayName":"Admin Access Log Path","path":"adminAccessLogPath"},{"description":"Configures envoy's admin port. Defaults to 9901.","displayName":"Admin Port","path":"adminPort"},{"description":"Affinity configuration for the envoy pods","displayName":"Affinity","path":"affinity"},{"description":"Defines the local service cluster name where Envoy is running. Defaults to the NodeID in the EnvoyConfig if unset","displayName":"Cluster ID","path":"clusterID"},{"description":"DiscoveryServiceRef points to a DiscoveryService in the same namespace","displayName":"Discovery Service Ref","path":"discoveryServiceRef"},{"description":"Defines the duration of the client certificate that is used to authenticate with the DiscoveryService","displayName":"Client Certificate Duration","path":"duration"},{"description":"EnvoyConfigRef points to an EnvoyConfig in the same namespace that holds the envoy resources for this Deployment","displayName":"Envoy Config Ref","path":"envoyConfigRef"},{"description":"Allows the user to define extra command line arguments for the Envoy process","displayName":"Extra Args","path":"extraArgs"},{"description":"Image is the envoy image and tag to use","displayName":"Image","path":"image"},{"description":"InitManager defines configuration for Envoy's init manager, which handles initialization for Envoy pods","displayName":"Init Manager","path":"initManager"},{"description":"Image is the init manager image and tag to use","displayName":"Image","path":"initManager.image"},{"description":"Liveness probe for the envoy pods","displayName":"Liveness Probe","path":"livenessProbe"},{"description":"Minimum consecutive failures for the probe to be considered failed after having succeeded","displayName":"Failure Threshold","path":"livenessProbe.failureThreshold"},{"description":"Number of seconds after the container has started before liveness probes are initiated","displayName":"Initial Delay Seconds","path":"livenessProbe.initialDelaySeconds"},{"description":"How often (in seconds) to perform the probe","displayName":"Period Seconds","path":"livenessProbe.periodSeconds"},{"description":"Minimum consecutive successes for the probe to be considered successful after having failed","displayName":"Success Threshold","path":"livenessProbe.successThreshold"},{"description":"Number of seconds after which the probe times out","displayName":"Timeout Seconds","path":"livenessProbe.timeoutSeconds"},{"description":"Configures PodDisruptionBudget for the envoy Pods","displayName":"Pod Disruption Budget","path":"podDisruptionBudget"},{"description":"An eviction is allowed if at most \"maxUnavailable\" pods selected by \"selector\" are unavailable after the eviction, i.e. even in absence of the evicted pod. For example, one can prevent all voluntary evictions by specifying 0. This is a mutually exclusive setting with \"minAvailable\".","displayName":"Max Unavailable","path":"podDisruptionBudget.maxUnavailable"},{"description":"An eviction is allowed if at least \"minAvailable\" pods selected by \"selector\" will still be available after the eviction, i.e. even in the absence of the evicted pod.  So for example you can prevent all voluntary evictions by specifying \"100%\".","displayName":"Min Available","path":"podDisruptionBudget.minAvailable"},{"description":"Ports exposed by the Envoy container","displayName":"Ports","path":"ports"},{"description":"Port name","displayName":"Name","path":"ports[0].name"},{"description":"Port value","displayName":"Port","path":"ports[0].port"},{"description":"Protocol. Defaults to TCP.","displayName":"Protocol","path":"ports[0].protocol"},{"description":"Readiness probe for the envoy pods","displayName":"Readiness Probe","path":"readinessProbe"},{"description":"Minimum consecutive failures for the probe to be considered failed after having succeeded","displayName":"Failure Threshold","path":"readinessProbe.failureThreshold"},{"description":"Number of seconds after the container has started before liveness probes are initiated","displayName":"Initial Delay Seconds","path":"readinessProbe.initialDelaySeconds"},{"description":"How often (in seconds) to perform the probe","displayName":"Period Seconds","path":"readinessProbe.periodSeconds"},{"description":"Minimum consecutive successes for the probe to be considered successful after having failed","displayName":"Success Threshold","path":"readinessProbe.successThreshold"},{"description":"Number of seconds after which the probe times out","displayName":"Timeout Seconds","path":"readinessProbe.timeoutSeconds"},{"description":"Replicas configures the number of replicas in the Deployment. One of 'static', 'dynamic' can be set. If both are set, static has precedence.","displayName":"Replicas","path":"replicas"},{"description":"Configure a min and max value for the number of pods to autoscale dynamically.","displayName":"Dynamic","path":"replicas.dynamic"},{"description":"behavior configures the scaling behavior of the target in both Up and Down directions (scaleUp and scaleDown fields respectively). If not set, the default HPAScalingRules for scale up and scale down are used.","displayName":"Behavior","path":"replicas.dynamic.behavior"},{"description":"metrics contains the specifications for which to use to calculate the desired replica count (the maximum replica count across all metrics will be used).  The desired replica count is calculated multiplying the ratio between the target value and the current value by the current number of pods.  Ergo, metrics used must decrease as the pod count is increased, and vice-versa.  See the individual metric source types for more information about how each type of metric must respond. If not set, the default metric will be set to 80% average CPU utilization.","displayName":"Metrics","path":"replicas.dynamic.metrics"},{"description":"minReplicas is the lower limit for the number of replicas to which the autoscaler can scale down.  It defaults to 1 pod.  minReplicas is allowed to be 0 if the alpha feature gate HPAScaleToZero is enabled and at least one Object or External metric is configured.  Scaling is active as long as at least one metric value is available.","displayName":"Min Replicas","path":"replicas.dynamic.minReplicas"},{"description":"Configure a static number of replicas. Defaults to 1.","displayName":"Static","path":"replicas.static"},{"description":"Resources holds the resource requirements to use for the Envoy Deployment. Defaults to no resource requests nor limits.","displayName":"Resources","path":"resources"},{"description":"ShutdownManager defines configuration for Envoy's shutdown manager, which handles graceful termination of Envoy pods","displayName":"Shutdown Manager","path":"shutdownManager"},{"description":"The drain strategy for the graceful shutdown. It also affects drain when listeners are modified or removed via LDS.","displayName":"Drain Strategy","path":"shutdownManager.drainStrategy"},{"description":"The time in seconds that Envoy will drain connections during shutdown. It also affects drain behaviour when listeners are modified or removed via LDS.","displayName":"Drain Time","path":"shutdownManager.drainTime"},{"description":"Image is the shutdown manager image and tag to use","displayName":"Image","path":"shutdownManager.image"},{"description":"Configures the sutdown manager's server port. Defaults to 8090.","displayName":"Server Port","path":"shutdownManager.serverPort"}],"version":"v1alpha1"}]},"description":"MARIN3R implements a control plane to deploy, configure and operate a fleet of envoy instances within a Kubernetes cluster.\nIt operates a group of gateways and Pod sidecar containers to provide general purpose functionality required to operate production systems.\n\nFeatures:\n\n* Deploy and manage an Envoy xDS server using the DiscoveryService custom resource.\n* Inject Envoy sidecar containers based on Pod annotations.\n* Deploy Envoy as a Kubernetes Deployment using the EnvoyDeployment custom resource.\n* Dynamic Envoy configuration and re-configuration using the EnvoyConfig custom resource.\n* Use Kubernetes Secrets as certificate sources.\n* Syntactic validation of Envoy configurations.\n* Lifecycle management of Envoy containers (graceful shutdown and connection draining).\n* Self-healing.\n\nCheck the [docs](https://github.com/3scale-ops/marin3r#readme) for more information.\n\n## License\nMARIN3R is licensed under the [Apache 2.0 license](https://github.com/3scale/prometheus-exporter-operator/blob/master/LICENSE)\n","displayName":"MARIN3R","icon":[{"base64data":"<?xml version="1.0" encoding="UTF-8"?>
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="375pt" height="374.999991pt" viewBox="0 0 375 374.999991" version="1.2">
<defs>
<g>
<symbol overflow="visible" id="glyph0-0">
<path style="stroke:none;" d=""/>
</symbol>
<symbol overflow="visible" id="glyph0-1">
<path style="stroke:none;" d="M 95.953125 0 L 85.890625 0 L 85.890625 -42.796875 L 54.984375 0 L 49.8125 0 L 18.90625 -42.796875 L 18.90625 0 L 8.828125 0 L 8.828125 -63.328125 L 16.421875 -63.328125 L 52.421875 -13.59375 L 88.359375 -63.328125 L 95.953125 -63.328125 Z M 95.953125 0 "/>
</symbol>
<symbol overflow="visible" id="glyph0-2">
<path style="stroke:none;" d="M 61.953125 0 L 6.625 0 L 6.625 -10.0625 L 61.953125 -10.0625 C 63.335938 -10.0625 64.519531 -10.554688 65.5 -11.546875 C 66.488281 -12.535156 66.984375 -13.722656 66.984375 -15.109375 L 66.984375 -21.59375 C 66.984375 -22.976562 66.507812 -24.148438 65.5625 -25.109375 C 64.625 -26.066406 63.46875 -26.570312 62.09375 -26.625 L 16.6875 -26.625 L 16.6875 -36.703125 L 62.09375 -36.703125 C 63.46875 -36.753906 64.625 -37.257812 65.5625 -38.21875 C 66.507812 -39.175781 66.984375 -40.347656 66.984375 -41.734375 L 66.984375 -48.265625 C 66.984375 -49.648438 66.488281 -50.828125 65.5 -51.796875 C 64.519531 -52.765625 63.335938 -53.25 61.953125 -53.25 L 6.625 -53.25 L 6.625 -63.328125 L 61.953125 -63.328125 C 66.109375 -63.328125 69.664062 -61.851562 72.625 -58.90625 C 75.582031 -55.957031 77.0625 -52.410156 77.0625 -48.265625 L 77.0625 -41.734375 C 77.0625 -37.878906 75.78125 -34.519531 73.21875 -31.65625 C 75.78125 -28.832031 77.0625 -25.476562 77.0625 -21.59375 L 77.0625 -15.109375 C 77.0625 -10.921875 75.582031 -7.351562 72.625 -4.40625 C 69.664062 -1.46875 66.109375 0 61.953125 0 Z M 61.953125 0 "/>
</symbol>
<symbol overflow="visible" id="glyph0-3">
<path style="stroke:none;" d="M 84.296875 0 L 74.234375 0 L 74.234375 -17.84375 C 74.234375 -19.226562 73.738281 -20.410156 72.75 -21.390625 C 71.757812 -22.378906 70.578125 -22.875 69.203125 -22.875 L 18.90625 -22.875 L 18.90625 0 L 8.828125 0 L 8.828125 -63.328125 L 69.203125 -63.328125 C 73.347656 -63.328125 76.898438 -61.851562 79.859375 -58.90625 C 82.816406 -55.957031 84.296875 -52.410156 84.296875 -48.265625 L 84.296875 -37.984375 C 84.296875 -34.085938 83 -30.726562 80.40625 -27.90625 C 83 -25.050781 84.296875 -21.695312 84.296875 -17.84375 Z M 69.203125 -32.9375 C 70.578125 -32.9375 71.757812 -33.429688 72.75 -34.421875 C 73.738281 -35.410156 74.234375 -36.597656 74.234375 -37.984375 L 74.234375 -48.265625 C 74.234375 -49.648438 73.738281 -50.832031 72.75 -51.8125 C 71.757812 -52.800781 70.578125 -53.296875 69.203125 -53.296875 L 18.90625 -53.296875 L 18.90625 -32.9375 Z M 69.203125 -32.9375 "/>
</symbol>
</g>
</defs>
<g id="surface1">
<rect x="0" y="0" width="375" height="374.999991" style="fill:rgb(100%,100%,100%);fill-opacity:1;stroke:none;"/>
<rect x="0" y="0" width="375" height="374.999991" style="fill:rgb(100%,100%,100%);fill-opacity:1;stroke:none;"/>
<rect x="0" y="0" width="375" height="374.999991" style="fill:rgb(100%,100%,100%);fill-opacity:1;stroke:none;"/>
<path style=" stroke:none;fill-rule:nonzero;fill:rgb(0%,0%,0%);fill-opacity:1;" d="M 187.5 19.328125 C 184.746094 19.328125 181.996094 19.398438 179.25 19.53125 C 176.5 19.667969 173.753906 19.871094 171.015625 20.140625 C 168.277344 20.410156 165.546875 20.746094 162.824219 21.148438 C 160.101562 21.554688 157.390625 22.023438 154.691406 22.5625 C 151.992188 23.097656 149.308594 23.699219 146.636719 24.371094 C 143.96875 25.039062 141.316406 25.773438 138.683594 26.570312 C 136.050781 27.371094 133.4375 28.234375 130.84375 29.160156 C 128.253906 30.085938 125.6875 31.078125 123.144531 32.132812 C 120.601562 33.183594 118.085938 34.300781 115.597656 35.476562 C 113.109375 36.652344 110.652344 37.890625 108.226562 39.1875 C 105.796875 40.484375 103.402344 41.839844 101.042969 43.253906 C 98.683594 44.671875 96.359375 46.144531 94.070312 47.671875 C 91.78125 49.199219 89.53125 50.785156 87.320312 52.425781 C 85.109375 54.0625 82.941406 55.757812 80.8125 57.503906 C 78.6875 59.25 76.601562 61.046875 74.5625 62.894531 C 72.523438 64.742188 70.53125 66.640625 68.585938 68.585938 C 66.640625 70.53125 64.742188 72.523438 62.894531 74.5625 C 61.046875 76.601562 59.25 78.6875 57.503906 80.8125 C 55.757812 82.941406 54.0625 85.109375 52.425781 87.320312 C 50.785156 89.53125 49.199219 91.78125 47.671875 94.070312 C 46.144531 96.359375 44.671875 98.683594 43.253906 101.042969 C 41.839844 103.402344 40.484375 105.796875 39.1875 108.226562 C 37.890625 110.652344 36.652344 113.109375 35.476562 115.597656 C 34.300781 118.085938 33.183594 120.601562 32.132812 123.144531 C 31.078125 125.6875 30.085938 128.253906 29.160156 130.84375 C 28.234375 133.4375 27.371094 136.050781 26.570312 138.683594 C 25.773438 141.316406 25.039062 143.96875 24.371094 146.636719 C 23.699219 149.308594 23.097656 151.992188 22.5625 154.691406 C 22.023438 157.390625 21.554688 160.101562 21.148438 162.824219 C 20.746094 165.546875 20.410156 168.277344 20.140625 171.015625 C 19.871094 173.753906 19.667969 176.5 19.53125 179.25 C 19.398438 181.996094 19.328125 184.746094 19.328125 187.5 C 19.328125 190.253906 19.398438 193.003906 19.53125 195.75 C 19.667969 198.5 19.871094 201.246094 20.140625 203.984375 C 20.410156 206.722656 20.746094 209.453125 21.148438 212.175781 C 21.554688 214.898438 22.023438 217.609375 22.5625 220.308594 C 23.097656 223.007812 23.699219 225.691406 24.371094 228.363281 C 25.039062 231.03125 25.773438 233.683594 26.570312 236.316406 C 27.371094 238.949219 28.234375 241.5625 29.160156 244.15625 C 30.085938 246.746094 31.078125 249.3125 32.132812 251.855469 C 33.183594 254.398438 34.300781 256.914062 35.476562 259.402344 C 36.652344 261.890625 37.890625 264.347656 39.1875 266.773438 C 40.484375 269.203125 41.839844 271.597656 43.253906 273.957031 C 44.671875 276.316406 46.144531 278.640625 47.671875 280.929688 C 49.199219 283.21875 50.785156 285.46875 52.425781 287.679688 C 54.0625 289.890625 55.757812 292.058594 57.503906 294.1875 C 59.25 296.3125 61.046875 298.398438 62.894531 300.4375 C 64.742188 302.476562 66.640625 304.46875 68.585938 306.414062 C 70.53125 308.359375 72.523438 310.257812 74.5625 312.105469 C 76.601562 313.953125 78.6875 315.75 80.8125 317.496094 C 82.941406 319.242188 85.109375 320.9375 87.320312 322.574219 C 89.53125 324.214844 91.78125 325.800781 94.070312 327.328125 C 96.359375 328.855469 98.683594 330.328125 101.042969 331.746094 C 103.402344 333.160156 105.796875 334.515625 108.226562 335.8125 C 110.652344 337.109375 113.109375 338.347656 115.597656 339.523438 C 118.085938 340.699219 120.601562 341.816406 123.144531 342.867188 C 125.6875 343.921875 128.253906 344.914062 130.84375 345.839844 C 133.4375 346.765625 136.050781 347.628906 138.683594 348.429688 C 141.316406 349.226562 143.96875 349.960938 146.636719 350.628906 C 149.308594 351.300781 151.992188 351.902344 154.691406 352.4375 C 157.390625 352.976562 160.101562 353.445312 162.824219 353.851562 C 165.546875 354.253906 168.277344 354.589844 171.015625 354.859375 C 173.753906 355.128906 176.5 355.332031 179.25 355.46875 C 181.996094 355.601562 184.746094 355.671875 187.5 355.671875 C 190.253906 355.671875 193.003906 355.601562 195.75 355.46875 C 198.5 355.332031 201.246094 355.128906 203.984375 354.859375 C 206.722656 354.589844 209.453125 354.253906 212.175781 353.851562 C 214.898438 353.445312 217.609375 352.976562 220.308594 352.4375 C 223.007812 351.902344 225.691406 351.300781 228.363281 350.628906 C 231.03125 349.960938 233.683594 349.226562 236.316406 348.429688 C 238.949219 347.628906 241.5625 346.765625 244.15625 345.839844 C 246.746094 344.914062 249.3125 343.921875 251.855469 342.867188 C 254.398438 341.816406 256.914062 340.699219 259.402344 339.523438 C 261.890625 338.347656 264.347656 337.109375 266.773438 335.8125 C 269.203125 334.515625 271.597656 333.160156 273.957031 331.746094 C 276.316406 330.328125 278.640625 328.855469 280.929688 327.328125 C 283.21875 325.800781 285.46875 324.214844 287.679688 322.574219 C 289.890625 320.9375 292.058594 319.242188 294.1875 317.496094 C 296.3125 315.75 298.398438 313.953125 300.4375 312.105469 C 302.476562 310.257812 304.46875 308.359375 306.414062 306.414062 C 308.359375 304.46875 310.257812 302.476562 312.105469 300.4375 C 313.953125 298.398438 315.75 296.3125 317.496094 294.1875 C 319.242188 292.058594 320.9375 289.890625 322.574219 287.679688 C 324.214844 285.46875 325.800781 283.21875 327.328125 280.929688 C 328.855469 278.640625 330.328125 276.316406 331.746094 273.957031 C 333.160156 271.597656 334.515625 269.203125 335.8125 266.773438 C 337.109375 264.347656 338.347656 261.890625 339.523438 259.402344 C 340.699219 256.914062 341.816406 254.398438 342.867188 251.855469 C 343.921875 249.3125 344.914062 246.746094 345.839844 244.15625 C 346.765625 241.5625 347.628906 238.949219 348.429688 236.316406 C 349.226562 233.683594 349.960938 231.03125 350.628906 228.363281 C 351.300781 225.691406 351.902344 223.007812 352.4375 220.308594 C 352.976562 217.609375 353.445312 214.898438 353.851562 212.175781 C 354.253906 209.453125 354.589844 206.722656 354.859375 203.984375 C 355.128906 201.246094 355.332031 198.5 355.46875 195.75 C 355.601562 193.003906 355.671875 190.253906 355.671875 187.5 C 355.671875 184.746094 355.601562 181.996094 355.46875 179.25 C 355.332031 176.5 355.128906 173.753906 354.859375 171.015625 C 354.589844 168.277344 354.253906 165.546875 353.851562 162.824219 C 353.445312 160.101562 352.976562 157.390625 352.4375 154.691406 C 351.902344 151.992188 351.300781 149.308594 350.628906 146.636719 C 349.960938 143.96875 349.226562 141.316406 348.429688 138.683594 C 347.628906 136.050781 346.765625 133.4375 345.839844 130.84375 C 344.914062 128.253906 343.921875 125.6875 342.867188 123.144531 C 341.816406 120.601562 340.699219 118.085938 339.523438 115.597656 C 338.347656 113.109375 337.109375 110.652344 335.8125 108.226562 C 334.515625 105.796875 333.160156 103.402344 331.746094 101.042969 C 330.328125 98.683594 328.855469 96.359375 327.328125 94.070312 C 325.800781 91.78125 324.214844 89.53125 322.574219 87.320312 C 320.9375 85.109375 319.242188 82.941406 317.496094 80.8125 C 315.75 78.6875 313.953125 76.601562 312.105469 74.5625 C 310.257812 72.523438 308.359375 70.53125 306.414062 68.585938 C 304.46875 66.640625 302.476562 64.742188 300.4375 62.894531 C 298.398438 61.046875 296.3125 59.25 294.1875 57.503906 C 292.058594 55.757812 289.890625 54.0625 287.679688 52.425781 C 285.46875 50.785156 283.21875 49.199219 280.929688 47.671875 C 278.640625 46.144531 276.316406 44.671875 273.957031 43.253906 C 271.597656 41.839844 269.203125 40.484375 266.773438 39.1875 C 264.347656 37.890625 261.890625 36.652344 259.402344 35.476562 C 256.914062 34.300781 254.398438 33.183594 251.855469 32.132812 C 249.3125 31.078125 246.746094 30.085938 244.15625 29.160156 C 241.5625 28.234375 238.949219 27.371094 236.316406 26.570312 C 233.683594 25.773438 231.03125 25.039062 228.363281 24.371094 C 225.691406 23.699219 223.007812 23.097656 220.308594 22.5625 C 217.609375 22.023438 214.898438 21.554688 212.175781 21.148438 C 209.453125 20.746094 206.722656 20.410156 203.984375 20.140625 C 201.246094 19.871094 198.5 19.667969 195.75 19.53125 C 193.003906 19.398438 190.253906 19.328125 187.5 19.328125 Z M 187.5 19.328125 "/>
<g style="fill:rgb(100%,100%,100%);fill-opacity:1;">
  <use xlink:href="#glyph0-1" x="47.846154" y="215.471728"/>
</g>
<g style="fill:rgb(100%,56.858826%,30.198669%);fill-opacity:1;">
  <use xlink:href="#glyph0-2" x="152.603607" y="215.471728"/>
</g>
<g style="fill:rgb(100%,100%,100%);fill-opacity:1;">
  <use xlink:href="#glyph0-3" x="236.245673" y="215.471728"/>
</g>
</g>
</svg>
","mediatype":"image/svg+xml"}],"install":{"spec":{"clusterPermissions":[{"rules":[{"apiGroups":["authentication.k8s.io"],"resources":["tokenreviews"],"verbs":["create"]},{"apiGroups":["authorization.k8s.io"],"resources":["subjectaccessreviews"],"verbs":["create"]}],"serviceAccountName":"marin3r-controller-manager"}],"deployments":[{"label":{"control-plane":"controller-manager"},"name":"marin3r-controller-manager","spec":{"replicas":1,"selector":{"matchLabels":{"control-plane":"controller-manager"}},"strategy":{},"template":{"metadata":{"labels":{"control-plane":"controller-manager"}},"spec":{"containers":[{"args":["operator","--leader-elect"],"command":["/manager"],"env":[{"name":"WATCH_NAMESPACE","valueFrom":{"fieldRef":{"fieldPath":"metadata.annotations['olm.targetNamespaces']"}}}],"image":"quay.io/3scale/marin3r:v0.13.2-alpha.1","livenessProbe":{"httpGet":{"path":"/healthz","port":8081},"initialDelaySeconds":15,"periodSeconds":20},"name":"manager","ports":[{"containerPort":8080,"name":"metrics","protocol":"TCP"}],"readinessProbe":{"httpGet":{"path":"/readyz","port":8081},"initialDelaySeconds":5,"periodSeconds":10},"resources":{"limits":{"cpu":"300m","memory":"300Mi"},"requests":{"cpu":"50m","memory":"100Mi"}},"securityContext":{"allowPrivilegeEscalation":false}}],"securityContext":{"runAsNonRoot":true},"serviceAccountName":"marin3r-controller-manager","terminationGracePeriodSeconds":10}}}},{"label":{"control-plane":"controller-webhook"},"name":"marin3r-controller-webhook","spec":{"replicas":2,"selector":{"matchLabels":{"control-plane":"controller-webhook"}},"strategy":{},"template":{"metadata":{"labels":{"control-plane":"controller-webhook"}},"spec":{"containers":[{"args":["webhook","--tls-dir=/apiserver.local.config/certificates","--tls-cert-name=apiserver.crt","--tls-key-name=apiserver.key"],"command":["/manager"],"env":[{"name":"WATCH_NAMESPACE","valueFrom":{"fieldRef":{"fieldPath":"metadata.annotations['olm.targetNamespaces']"}}}],"image":"quay.io/3scale/marin3r:v0.13.2-alpha.1","livenessProbe":{"httpGet":{"path":"/healthz","port":8081},"initialDelaySeconds":15,"periodSeconds":20},"name":"webhook","ports":[{"containerPort":9443,"name":"webhook-server","protocol":"TCP"}],"readinessProbe":{"httpGet":{"path":"/readyz","port":8081},"initialDelaySeconds":5,"periodSeconds":10},"resources":{"limits":{"cpu":"100m","memory":"100Mi"},"requests":{"cpu":"50m","memory":"30Mi"}},"securityContext":{"allowPrivilegeEscalation":false}}],"serviceAccountName":"marin3r-controller-manager"}}}}],"permissions":[{"rules":[{"apiGroups":[""],"resources":["configmaps"],"verbs":["get","list","watch","create","update","patch","delete"]},{"apiGroups":["coordination.k8s.io"],"resources":["leases"],"verbs":["get","list","watch","create","update","patch","delete"]},{"apiGroups":[""],"resources":["events"],"verbs":["create","patch"]},{"apiGroups":["apps"],"resources":["deployments"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["autoscaling"],"resources":["horizontalpodautoscalers"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":[""],"resources":["pods"],"verbs":["get","list","watch"]},{"apiGroups":[""],"resources":["secrets"],"verbs":["create","get","list","patch","update","watch"]},{"apiGroups":[""],"resources":["serviceaccounts"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":[""],"resources":["services"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["discovery.k8s.io"],"resources":["endpointslices"],"verbs":["get","list","watch"]},{"apiGroups":["marin3r.3scale.net"],"resources":["*"],"verbs":["*"]},{"apiGroups":["marin3r.3scale.net"],"resources":["envoyconfigrevisions"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["marin3r.3scale.net"],"resources":["envoyconfigrevisions/status"],"verbs":["get","patch","update"]},{"apiGroups":["marin3r.3scale.net"],"resources":["envoyconfigs"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["marin3r.3scale.net"],"resources":["envoyconfigs/status"],"verbs":["get","patch","update"]},{"apiGroups":["operator.marin3r.3scale.net"],"resources":["*"],"verbs":["*"]},{"apiGroups":["operator.marin3r.3scale.net"],"resources":["discoveryservicecertificates"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["operator.marin3r.3scale.net"],"resources":["discoveryservicecertificates/status"],"verbs":["get","patch","update"]},{"apiGroups":["operator.marin3r.3scale.net"],"resources":["discoveryservices"],"verbs":["get","list","watch"]},{"apiGroups":["operator.marin3r.3scale.net"],"resources":["envoydeployments"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["operator.marin3r.3scale.net"],"resources":["envoydeployments/finalizers"],"verbs":["update"]},{"apiGroups":["operator.marin3r.3scale.net"],"resources":["envoydeployments/status"],"verbs":["get","patch","update"]},{"apiGroups":["policy"],"resources":["poddisruptionbudgets"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["rbac.authorization.k8s.io"],"resources":["rolebindings"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["rbac.authorization.k8s.io"],"resources":["roles"],"verbs":["create","delete","get","list","patch","update","watch"]}],"serviceAccountName":"marin3r-controller-manager"}]},"strategy":"deployment"},"installModes":[{"supported":true,"type":"OwnNamespace"},{"supported":true,"type":"SingleNamespace"},{"supported":true,"type":"MultiNamespace"},{"supported":true,"type":"AllNamespaces"}],"keywords":["envoy","discovery","controlplane","proxy","sidecar","xds","network","gateway"],"links":[{"name":"GitHub","url":"https://github.com/3scale-ops/marin3r"}],"maintainers":[{"email":"3scale-operations+marin3r@redhat.com","name":"3scale Operations Team"}],"maturity":"alpha","provider":{"name":"Red Hat"},"version":"0.13.2-alpha.1","webhookdefinitions":[{"admissionReviewVersions":["v1"],"containerPort":443,"deploymentName":"marin3r-controller-webhook","failurePolicy":"Fail","generateName":"envoyconfig.marin3r.3scale.net-v1alpha1","rules":[{"apiGroups":["marin3r.3scale.net"],"apiVersions":["v1alpha1"],"operations":["CREATE","UPDATE"],"resources":["envoyconfigs"]}],"sideEffects":"None","targetPort":9443,"type":"ValidatingAdmissionWebhook","webhookPath":"/validate-marin3r-3scale-net-v1alpha1-envoyconfig"},{"admissionReviewVersions":["v1"],"containerPort":443,"deploymentName":"marin3r-controller-webhook","failurePolicy":"Fail","generateName":"envoydeployment.operator.marin3r.3scale.net","rules":[{"apiGroups":["operator.marin3r.3scale.net"],"apiVersions":["v1alpha1"],"operations":["CREATE","UPDATE"],"resources":["envoydeployments"]}],"sideEffects":"None","targetPort":9443,"type":"ValidatingAdmissionWebhook","webhookPath":"/validate-operator-marin3r-3scale-net-v1alpha1-envoydeployment"},{"admissionReviewVersions":["v1"],"containerPort":443,"deploymentName":"marin3r-controller-webhook","failurePolicy":"Fail","generateName":"sidecar-injector.marin3r.3scale.net","matchPolicy":"Equivalent","objectSelector":{"matchLabels":{"marin3r.3scale.net/status":"enabled"}},"reinvocationPolicy":"Never","rules":[{"apiGroups":[""],"apiVersions":["v1"],"operations":["CREATE"],"resources":["pods"]}],"sideEffects":"None","targetPort":9443,"type":"MutatingAdmissionWebhook","webhookPath":"/pod-v1-mutate"}]}} +- type: olm.bundle.object + value: + data: {"apiVersion":"apiextensions.k8s.io/v1","kind":"CustomResourceDefinition","metadata":{"annotations":{"controller-gen.kubebuilder.io/version":"v0.11.3"},"creationTimestamp":null,"name":"discoveryservicecertificates.operator.marin3r.3scale.net"},"spec":{"group":"operator.marin3r.3scale.net","names":{"kind":"DiscoveryServiceCertificate","listKind":"DiscoveryServiceCertificateList","plural":"discoveryservicecertificates","singular":"discoveryservicecertificate"},"scope":"Namespaced","versions":[{"additionalPrinterColumns":[{"jsonPath":".status.ready","name":"Ready","type":"boolean"},{"format":"date-time","jsonPath":".status.notBefore","name":"Not Before","type":"string"},{"format":"date-time","jsonPath":".status.notAfter","name":"Not After","type":"string"}],"name":"v1alpha1","schema":{"openAPIV3Schema":{"description":"DiscoveryServiceCertificate is an internal resource used to create certificates. This resource is used by the DiscoveryService controller to create the required certificates for the different components. Direct use of DiscoveryServiceCertificate objects is discouraged.","properties":{"apiVersion":{"description":"APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources","type":"string"},"kind":{"description":"Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds","type":"string"},"metadata":{"type":"object"},"spec":{"description":"DiscoveryServiceCertificateSpec defines the desired state of DiscoveryServiceCertificate","properties":{"certificateRenewal":{"description":"CertificateRenewalConfig configures the certificate renewal process. If unset default behavior is to renew the certificate but not notify of renewals.","properties":{"enabled":{"description":"Enabled is a flag to enable or disable renewal of the certificate","type":"boolean"}},"required":["enabled"],"type":"object"},"commonName":{"description":"CommonName is the CommonName of the certificate","type":"string"},"hosts":{"description":"Hosts is the list of hosts the certificate is valid for. Only use when 'IsServerCertificate' is true. If unset, the CommonName field will be used to populate the valid hosts of the certificate.","items":{"type":"string"},"type":"array"},"isCA":{"description":"IsCA is a boolean specifying that the certificate is a CA","type":"boolean"},"secretRef":{"description":"SecretRef is a reference to the secret that will hold the certificate and the private key.","properties":{"name":{"description":"name is unique within a namespace to reference a secret resource.","type":"string"},"namespace":{"description":"namespace defines the space within which the secret name must be unique.","type":"string"}},"type":"object","x-kubernetes-map-type":"atomic"},"server":{"description":"IsServerCertificate is a boolean specifying if the certificate should be issued with server auth usage enabled","type":"boolean"},"signer":{"description":"Signer specifies  the signer to use to create this certificate. Supported signers are CertManager and SelfSigned.","properties":{"caSigned":{"description":"CASigned holds specific configuration for the CASigned signer","properties":{"caSecretRef":{"description":"A reference to a Secret containing the CA","properties":{"name":{"description":"name is unique within a namespace to reference a secret resource.","type":"string"},"namespace":{"description":"namespace defines the space within which the secret name must be unique.","type":"string"}},"type":"object","x-kubernetes-map-type":"atomic"}},"required":["caSecretRef"],"type":"object"},"selfSigned":{"description":"SelfSigned holds specific configuration for the SelfSigned signer","type":"object"}},"type":"object"},"validFor":{"description":"ValidFor specifies the validity of the certificate in seconds","format":"int64","type":"integer"}},"required":["commonName","secretRef","signer","validFor"],"type":"object"},"status":{"description":"DiscoveryServiceCertificateStatus defines the observed state of DiscoveryServiceCertificate","properties":{"certificateHash":{"description":"CertificateHash stores the current hash of the certificate. It is used for other controllers to validate if a certificate has been re-issued.","type":"string"},"conditions":{"description":"Conditions represent the latest available observations of an object's state","items":{"description":"Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions.  For example, \n type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }","properties":{"lastTransitionTime":{"description":"lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed.  If that is not known, then using the time when the API field changed is acceptable.","format":"date-time","type":"string"},"message":{"description":"message is a human readable message indicating details about the transition. This may be an empty string.","maxLength":32768,"type":"string"},"observedGeneration":{"description":"observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.","format":"int64","minimum":0,"type":"integer"},"reason":{"description":"reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.","maxLength":1024,"minLength":1,"pattern":"^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$","type":"string"},"status":{"description":"status of the condition, one of True, False, Unknown.","enum":["True","False","Unknown"],"type":"string"},"type":{"description":"type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)","maxLength":316,"pattern":"^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$","type":"string"}},"required":["lastTransitionTime","message","reason","status","type"],"type":"object"},"type":"array"},"notAfter":{"description":"NotAfter is the time at which the certificate expires","format":"date-time","type":"string"},"notBefore":{"description":"NotBefore is the time at which the certificate starts being valid","format":"date-time","type":"string"},"ready":{"description":"Ready is a boolean that specifies if the certificate is ready to be used","type":"boolean"}},"type":"object"}},"type":"object"}},"served":true,"storage":true,"subresources":{"status":{}}}]},"status":{"acceptedNames":{"kind":"","plural":""},"conditions":null,"storedVersions":null}} +- type: olm.bundle.object + value: + data: {"apiVersion":"apiextensions.k8s.io/v1","kind":"CustomResourceDefinition","metadata":{"annotations":{"controller-gen.kubebuilder.io/version":"v0.11.3"},"creationTimestamp":null,"name":"discoveryservices.operator.marin3r.3scale.net"},"spec":{"group":"operator.marin3r.3scale.net","names":{"kind":"DiscoveryService","listKind":"DiscoveryServiceList","plural":"discoveryservices","singular":"discoveryservice"},"scope":"Namespaced","versions":[{"name":"v1alpha1","schema":{"openAPIV3Schema":{"description":"DiscoveryService represents an envoy discovery service server. Only one instance per namespace is currently supported.","properties":{"apiVersion":{"description":"APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources","type":"string"},"kind":{"description":"Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds","type":"string"},"metadata":{"type":"object"},"spec":{"description":"DiscoveryServiceSpec defines the desired state of DiscoveryService","properties":{"debug":{"description":"Debug enables debugging log level for the discovery service controllers. It is safe to use since secret data is never shown in the logs.","type":"boolean"},"image":{"description":"Image holds the image to use for the discovery service Deployment","type":"string"},"metricsPort":{"description":"MetricsPort is the port where metrics are served. Defaults to 8383.","format":"int32","type":"integer"},"pkiConfg":{"description":"PKIConfig has configuration for the PKI that marin3r manages for the different certificates it requires","properties":{"rootCertificateAuthority":{"description":"CertificateOptions specifies options to generate the server certificate used both for the xDS server and the mutating webhook server.","properties":{"duration":{"type":"string"},"secretName":{"type":"string"}},"required":["duration","secretName"],"type":"object"},"serverCertificate":{"description":"CertificateOptions specifies options to generate the server certificate used both for the xDS server and the mutating webhook server.","properties":{"duration":{"type":"string"},"secretName":{"type":"string"}},"required":["duration","secretName"],"type":"object"}},"required":["rootCertificateAuthority","serverCertificate"],"type":"object"},"podPriorityClass":{"description":"PriorityClass to assign the discovery service Pod to","type":"string"},"probePort":{"description":"ProbePort is the port where healthz endpoint is served. Defaults to 8384.","format":"int32","type":"integer"},"resources":{"description":"Resources holds the Resource Requirements to use for the discovery service Deployment. When not set it defaults to no resource requests nor limits. CPU and Memory resources are supported.","properties":{"claims":{"description":"Claims lists the names of resources, defined in spec.resourceClaims, that are used by this container. \n This is an alpha field and requires enabling the DynamicResourceAllocation feature gate. \n This field is immutable. It can only be set for containers.","items":{"description":"ResourceClaim references one entry in PodSpec.ResourceClaims.","properties":{"name":{"description":"Name must match the name of one entry in pod.spec.resourceClaims of the Pod where this field is used. It makes that resource available inside a container.","type":"string"}},"required":["name"],"type":"object"},"type":"array","x-kubernetes-list-map-keys":["name"],"x-kubernetes-list-type":"map"},"limits":{"additionalProperties":{"anyOf":[{"type":"integer"},{"type":"string"}],"pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"description":"Limits describes the maximum amount of compute resources allowed. More info: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/","type":"object"},"requests":{"additionalProperties":{"anyOf":[{"type":"integer"},{"type":"string"}],"pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"description":"Requests describes the minimum amount of compute resources required. If Requests is omitted for a container, it defaults to Limits if that is explicitly specified, otherwise to an implementation-defined value. Requests cannot exceed Limits. More info: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/","type":"object"}},"type":"object"},"serviceConfig":{"description":"ServiceConfig configures the way the DiscoveryService endpoints are exposed","properties":{"name":{"type":"string"},"type":{"description":"ServiceType is an enum with the available discovery service Service types","type":"string"}},"type":"object"},"xdsServerPort":{"description":"XdsServerPort is the port where the xDS server listens. Defaults to 18000.","format":"int32","type":"integer"}},"type":"object"},"status":{"description":"DiscoveryServiceStatus defines the observed state of DiscoveryService","properties":{"deploymentName":{"type":"string"},"deploymentStatus":{"description":"DeploymentStatus is the most recently observed status of the Deployment.","properties":{"availableReplicas":{"description":"Total number of available pods (ready for at least minReadySeconds) targeted by this deployment.","format":"int32","type":"integer"},"collisionCount":{"description":"Count of hash collisions for the Deployment. The Deployment controller uses this field as a collision avoidance mechanism when it needs to create the name for the newest ReplicaSet.","format":"int32","type":"integer"},"conditions":{"description":"Represents the latest available observations of a deployment's current state.","items":{"description":"DeploymentCondition describes the state of a deployment at a certain point.","properties":{"lastTransitionTime":{"description":"Last time the condition transitioned from one status to another.","format":"date-time","type":"string"},"lastUpdateTime":{"description":"The last time this condition was updated.","format":"date-time","type":"string"},"message":{"description":"A human readable message indicating details about the transition.","type":"string"},"reason":{"description":"The reason for the condition's last transition.","type":"string"},"status":{"description":"Status of the condition, one of True, False, Unknown.","type":"string"},"type":{"description":"Type of deployment condition.","type":"string"}},"required":["status","type"],"type":"object"},"type":"array"},"observedGeneration":{"description":"The generation observed by the deployment controller.","format":"int64","type":"integer"},"readyReplicas":{"description":"readyReplicas is the number of pods targeted by this Deployment with a Ready Condition.","format":"int32","type":"integer"},"replicas":{"description":"Total number of non-terminated pods targeted by this deployment (their labels match the selector).","format":"int32","type":"integer"},"unavailableReplicas":{"description":"Total number of unavailable pods targeted by this deployment. This is the total number of pods that are still required for the deployment to have 100% available capacity. They may either be pods that are running but not yet available or pods that still have not been created.","format":"int32","type":"integer"},"updatedReplicas":{"description":"Total number of non-terminated pods targeted by this deployment that have the desired template spec.","format":"int32","type":"integer"}},"type":"object"}},"type":"object"}},"type":"object"}},"served":true,"storage":true,"subresources":{"status":{}}}]},"status":{"acceptedNames":{"kind":"","plural":""},"conditions":null,"storedVersions":null}} +- type: olm.bundle.object + value: + data: {"apiVersion":"apiextensions.k8s.io/v1","kind":"CustomResourceDefinition","metadata":{"annotations":{"controller-gen.kubebuilder.io/version":"v0.11.3"},"creationTimestamp":null,"name":"envoydeployments.operator.marin3r.3scale.net"},"spec":{"group":"operator.marin3r.3scale.net","names":{"kind":"EnvoyDeployment","listKind":"EnvoyDeploymentList","plural":"envoydeployments","singular":"envoydeployment"},"scope":"Namespaced","versions":[{"name":"v1alpha1","schema":{"openAPIV3Schema":{"description":"EnvoyDeployment is a resource to deploy and manage a Kubernetes Deployment of Envoy Pods.","properties":{"apiVersion":{"description":"APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources","type":"string"},"kind":{"description":"Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds","type":"string"},"metadata":{"type":"object"},"spec":{"description":"EnvoyDeploymentSpec defines the desired state of EnvoyDeployment","properties":{"adminAccessLogPath":{"description":"Configures envoy's admin access log path. Defaults to /dev/null.","type":"string"},"adminPort":{"description":"Configures envoy's admin port. Defaults to 9901.","format":"int32","type":"integer"},"affinity":{"description":"Affinity configuration for the envoy pods","properties":{"nodeAffinity":{"description":"Describes node affinity scheduling rules for the pod.","properties":{"preferredDuringSchedulingIgnoredDuringExecution":{"description":"The scheduler will prefer to schedule pods to nodes that satisfy the affinity expressions specified by this field, but it may choose a node that violates one or more of the expressions. The node that is most preferred is the one with the greatest sum of weights, i.e. for each node that meets all of the scheduling requirements (resource request, requiredDuringScheduling affinity expressions, etc.), compute a sum by iterating through the elements of this field and adding \"weight\" to the sum if the node matches the corresponding matchExpressions; the node(s) with the highest sum are the most preferred.","items":{"description":"An empty preferred scheduling term matches all objects with implicit weight 0 (i.e. it's a no-op). A null preferred scheduling term matches no objects (i.e. is also a no-op).","properties":{"preference":{"description":"A node selector term, associated with the corresponding weight.","properties":{"matchExpressions":{"description":"A list of node selector requirements by node's labels.","items":{"description":"A node selector requirement is a selector that contains values, a key, and an operator that relates the key and values.","properties":{"key":{"description":"The label key that the selector applies to.","type":"string"},"operator":{"description":"Represents a key's relationship to a set of values. Valid operators are In, NotIn, Exists, DoesNotExist. Gt, and Lt.","type":"string"},"values":{"description":"An array of string values. If the operator is In or NotIn, the values array must be non-empty. If the operator is Exists or DoesNotExist, the values array must be empty. If the operator is Gt or Lt, the values array must have a single element, which will be interpreted as an integer. This array is replaced during a strategic merge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchFields":{"description":"A list of node selector requirements by node's fields.","items":{"description":"A node selector requirement is a selector that contains values, a key, and an operator that relates the key and values.","properties":{"key":{"description":"The label key that the selector applies to.","type":"string"},"operator":{"description":"Represents a key's relationship to a set of values. Valid operators are In, NotIn, Exists, DoesNotExist. Gt, and Lt.","type":"string"},"values":{"description":"An array of string values. If the operator is In or NotIn, the values array must be non-empty. If the operator is Exists or DoesNotExist, the values array must be empty. If the operator is Gt or Lt, the values array must have a single element, which will be interpreted as an integer. This array is replaced during a strategic merge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"}},"type":"object","x-kubernetes-map-type":"atomic"},"weight":{"description":"Weight associated with matching the corresponding nodeSelectorTerm, in the range 1-100.","format":"int32","type":"integer"}},"required":["preference","weight"],"type":"object"},"type":"array"},"requiredDuringSchedulingIgnoredDuringExecution":{"description":"If the affinity requirements specified by this field are not met at scheduling time, the pod will not be scheduled onto the node. If the affinity requirements specified by this field cease to be met at some point during pod execution (e.g. due to an update), the system may or may not try to eventually evict the pod from its node.","properties":{"nodeSelectorTerms":{"description":"Required. A list of node selector terms. The terms are ORed.","items":{"description":"A null or empty node selector term matches no objects. The requirements of them are ANDed. The TopologySelectorTerm type implements a subset of the NodeSelectorTerm.","properties":{"matchExpressions":{"description":"A list of node selector requirements by node's labels.","items":{"description":"A node selector requirement is a selector that contains values, a key, and an operator that relates the key and values.","properties":{"key":{"description":"The label key that the selector applies to.","type":"string"},"operator":{"description":"Represents a key's relationship to a set of values. Valid operators are In, NotIn, Exists, DoesNotExist. Gt, and Lt.","type":"string"},"values":{"description":"An array of string values. If the operator is In or NotIn, the values array must be non-empty. If the operator is Exists or DoesNotExist, the values array must be empty. If the operator is Gt or Lt, the values array must have a single element, which will be interpreted as an integer. This array is replaced during a strategic merge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchFields":{"description":"A list of node selector requirements by node's fields.","items":{"description":"A node selector requirement is a selector that contains values, a key, and an operator that relates the key and values.","properties":{"key":{"description":"The label key that the selector applies to.","type":"string"},"operator":{"description":"Represents a key's relationship to a set of values. Valid operators are In, NotIn, Exists, DoesNotExist. Gt, and Lt.","type":"string"},"values":{"description":"An array of string values. If the operator is In or NotIn, the values array must be non-empty. If the operator is Exists or DoesNotExist, the values array must be empty. If the operator is Gt or Lt, the values array must have a single element, which will be interpreted as an integer. This array is replaced during a strategic merge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"}},"type":"object","x-kubernetes-map-type":"atomic"},"type":"array"}},"required":["nodeSelectorTerms"],"type":"object","x-kubernetes-map-type":"atomic"}},"type":"object"},"podAffinity":{"description":"Describes pod affinity scheduling rules (e.g. co-locate this pod in the same node, zone, etc. as some other pod(s)).","properties":{"preferredDuringSchedulingIgnoredDuringExecution":{"description":"The scheduler will prefer to schedule pods to nodes that satisfy the affinity expressions specified by this field, but it may choose a node that violates one or more of the expressions. The node that is most preferred is the one with the greatest sum of weights, i.e. for each node that meets all of the scheduling requirements (resource request, requiredDuringScheduling affinity expressions, etc.), compute a sum by iterating through the elements of this field and adding \"weight\" to the sum if the node has pods which matches the corresponding podAffinityTerm; the node(s) with the highest sum are the most preferred.","items":{"description":"The weights of all of the matched WeightedPodAffinityTerm fields are added per-node to find the most preferred node(s)","properties":{"podAffinityTerm":{"description":"Required. A pod affinity term, associated with the corresponding weight.","properties":{"labelSelector":{"description":"A label query over a set of resources, in this case pods. If it's null, this PodAffinityTerm matches with no Pods.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that relates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values. Valid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn, the values array must be non-empty. If the operator is Exists or DoesNotExist, the values array must be empty. This array is replaced during a strategic merge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"},"matchLabelKeys":{"description":"MatchLabelKeys is a set of pod label keys to select which pods will be taken into consideration. The keys are used to lookup values from the incoming pod labels, those key-value labels are merged with `LabelSelector` as `key in (value)` to select the group of existing pods which pods will be taken into consideration for the incoming pod's pod (anti) affinity. Keys that don't exist in the incoming pod labels will be ignored. The default value is empty. The same key is forbidden to exist in both MatchLabelKeys and LabelSelector. Also, MatchLabelKeys cannot be set when LabelSelector isn't set. This is an alpha field and requires enabling MatchLabelKeysInPodAffinity feature gate.","items":{"type":"string"},"type":"array","x-kubernetes-list-type":"atomic"},"mismatchLabelKeys":{"description":"MismatchLabelKeys is a set of pod label keys to select which pods will be taken into consideration. The keys are used to lookup values from the incoming pod labels, those key-value labels are merged with `LabelSelector` as `key notin (value)` to select the group of existing pods which pods will be taken into consideration for the incoming pod's pod (anti) affinity. Keys that don't exist in the incoming pod labels will be ignored. The default value is empty. The same key is forbidden to exist in both MismatchLabelKeys and LabelSelector. Also, MismatchLabelKeys cannot be set when LabelSelector isn't set. This is an alpha field and requires enabling MatchLabelKeysInPodAffinity feature gate.","items":{"type":"string"},"type":"array","x-kubernetes-list-type":"atomic"},"namespaceSelector":{"description":"A label query over the set of namespaces that the term applies to. The term is applied to the union of the namespaces selected by this field and the ones listed in the namespaces field. null selector and null or empty namespaces list means \"this pod's namespace\". An empty selector ({}) matches all namespaces.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that relates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values. Valid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn, the values array must be non-empty. If the operator is Exists or DoesNotExist, the values array must be empty. This array is replaced during a strategic merge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"},"namespaces":{"description":"namespaces specifies a static list of namespace names that the term applies to. The term is applied to the union of the namespaces listed in this field and the ones selected by namespaceSelector. null or empty namespaces list and null namespaceSelector means \"this pod's namespace\".","items":{"type":"string"},"type":"array"},"topologyKey":{"description":"This pod should be co-located (affinity) or not co-located (anti-affinity) with the pods matching the labelSelector in the specified namespaces, where co-located is defined as running on a node whose value of the label with key topologyKey matches that of any node on which any of the selected pods is running. Empty topologyKey is not allowed.","type":"string"}},"required":["topologyKey"],"type":"object"},"weight":{"description":"weight associated with matching the corresponding podAffinityTerm, in the range 1-100.","format":"int32","type":"integer"}},"required":["podAffinityTerm","weight"],"type":"object"},"type":"array"},"requiredDuringSchedulingIgnoredDuringExecution":{"description":"If the affinity requirements specified by this field are not met at scheduling time, the pod will not be scheduled onto the node. If the affinity requirements specified by this field cease to be met at some point during pod execution (e.g. due to a pod label update), the system may or may not try to eventually evict the pod from its node. When there are multiple elements, the lists of nodes corresponding to each podAffinityTerm are intersected, i.e. all terms must be satisfied.","items":{"description":"Defines a set of pods (namely those matching the labelSelector relative to the given namespace(s)) that this pod should be co-located (affinity) or not co-located (anti-affinity) with, where co-located is defined as running on a node whose value of the label with key \u003ctopologyKey\u003e matches that of any node on which a pod of the set of pods is running","properties":{"labelSelector":{"description":"A label query over a set of resources, in this case pods. If it's null, this PodAffinityTerm matches with no Pods.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that relates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values. Valid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn, the values array must be non-empty. If the operator is Exists or DoesNotExist, the values array must be empty. This array is replaced during a strategic merge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"},"matchLabelKeys":{"description":"MatchLabelKeys is a set of pod label keys to select which pods will be taken into consideration. The keys are used to lookup values from the incoming pod labels, those key-value labels are merged with `LabelSelector` as `key in (value)` to select the group of existing pods which pods will be taken into consideration for the incoming pod's pod (anti) affinity. Keys that don't exist in the incoming pod labels will be ignored. The default value is empty. The same key is forbidden to exist in both MatchLabelKeys and LabelSelector. Also, MatchLabelKeys cannot be set when LabelSelector isn't set. This is an alpha field and requires enabling MatchLabelKeysInPodAffinity feature gate.","items":{"type":"string"},"type":"array","x-kubernetes-list-type":"atomic"},"mismatchLabelKeys":{"description":"MismatchLabelKeys is a set of pod label keys to select which pods will be taken into consideration. The keys are used to lookup values from the incoming pod labels, those key-value labels are merged with `LabelSelector` as `key notin (value)` to select the group of existing pods which pods will be taken into consideration for the incoming pod's pod (anti) affinity. Keys that don't exist in the incoming pod labels will be ignored. The default value is empty. The same key is forbidden to exist in both MismatchLabelKeys and LabelSelector. Also, MismatchLabelKeys cannot be set when LabelSelector isn't set. This is an alpha field and requires enabling MatchLabelKeysInPodAffinity feature gate.","items":{"type":"string"},"type":"array","x-kubernetes-list-type":"atomic"},"namespaceSelector":{"description":"A label query over the set of namespaces that the term applies to. The term is applied to the union of the namespaces selected by this field and the ones listed in the namespaces field. null selector and null or empty namespaces list means \"this pod's namespace\". An empty selector ({}) matches all namespaces.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that relates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values. Valid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn, the values array must be non-empty. If the operator is Exists or DoesNotExist, the values array must be empty. This array is replaced during a strategic merge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"},"namespaces":{"description":"namespaces specifies a static list of namespace names that the term applies to. The term is applied to the union of the namespaces listed in this field and the ones selected by namespaceSelector. null or empty namespaces list and null namespaceSelector means \"this pod's namespace\".","items":{"type":"string"},"type":"array"},"topologyKey":{"description":"This pod should be co-located (affinity) or not co-located (anti-affinity) with the pods matching the labelSelector in the specified namespaces, where co-located is defined as running on a node whose value of the label with key topologyKey matches that of any node on which any of the selected pods is running. Empty topologyKey is not allowed.","type":"string"}},"required":["topologyKey"],"type":"object"},"type":"array"}},"type":"object"},"podAntiAffinity":{"description":"Describes pod anti-affinity scheduling rules (e.g. avoid putting this pod in the same node, zone, etc. as some other pod(s)).","properties":{"preferredDuringSchedulingIgnoredDuringExecution":{"description":"The scheduler will prefer to schedule pods to nodes that satisfy the anti-affinity expressions specified by this field, but it may choose a node that violates one or more of the expressions. The node that is most preferred is the one with the greatest sum of weights, i.e. for each node that meets all of the scheduling requirements (resource request, requiredDuringScheduling anti-affinity expressions, etc.), compute a sum by iterating through the elements of this field and adding \"weight\" to the sum if the node has pods which matches the corresponding podAffinityTerm; the node(s) with the highest sum are the most preferred.","items":{"description":"The weights of all of the matched WeightedPodAffinityTerm fields are added per-node to find the most preferred node(s)","properties":{"podAffinityTerm":{"description":"Required. A pod affinity term, associated with the corresponding weight.","properties":{"labelSelector":{"description":"A label query over a set of resources, in this case pods. If it's null, this PodAffinityTerm matches with no Pods.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that relates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values. Valid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn, the values array must be non-empty. If the operator is Exists or DoesNotExist, the values array must be empty. This array is replaced during a strategic merge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"},"matchLabelKeys":{"description":"MatchLabelKeys is a set of pod label keys to select which pods will be taken into consideration. The keys are used to lookup values from the incoming pod labels, those key-value labels are merged with `LabelSelector` as `key in (value)` to select the group of existing pods which pods will be taken into consideration for the incoming pod's pod (anti) affinity. Keys that don't exist in the incoming pod labels will be ignored. The default value is empty. The same key is forbidden to exist in both MatchLabelKeys and LabelSelector. Also, MatchLabelKeys cannot be set when LabelSelector isn't set. This is an alpha field and requires enabling MatchLabelKeysInPodAffinity feature gate.","items":{"type":"string"},"type":"array","x-kubernetes-list-type":"atomic"},"mismatchLabelKeys":{"description":"MismatchLabelKeys is a set of pod label keys to select which pods will be taken into consideration. The keys are used to lookup values from the incoming pod labels, those key-value labels are merged with `LabelSelector` as `key notin (value)` to select the group of existing pods which pods will be taken into consideration for the incoming pod's pod (anti) affinity. Keys that don't exist in the incoming pod labels will be ignored. The default value is empty. The same key is forbidden to exist in both MismatchLabelKeys and LabelSelector. Also, MismatchLabelKeys cannot be set when LabelSelector isn't set. This is an alpha field and requires enabling MatchLabelKeysInPodAffinity feature gate.","items":{"type":"string"},"type":"array","x-kubernetes-list-type":"atomic"},"namespaceSelector":{"description":"A label query over the set of namespaces that the term applies to. The term is applied to the union of the namespaces selected by this field and the ones listed in the namespaces field. null selector and null or empty namespaces list means \"this pod's namespace\". An empty selector ({}) matches all namespaces.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that relates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values. Valid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn, the values array must be non-empty. If the operator is Exists or DoesNotExist, the values array must be empty. This array is replaced during a strategic merge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"},"namespaces":{"description":"namespaces specifies a static list of namespace names that the term applies to. The term is applied to the union of the namespaces listed in this field and the ones selected by namespaceSelector. null or empty namespaces list and null namespaceSelector means \"this pod's namespace\".","items":{"type":"string"},"type":"array"},"topologyKey":{"description":"This pod should be co-located (affinity) or not co-located (anti-affinity) with the pods matching the labelSelector in the specified namespaces, where co-located is defined as running on a node whose value of the label with key topologyKey matches that of any node on which any of the selected pods is running. Empty topologyKey is not allowed.","type":"string"}},"required":["topologyKey"],"type":"object"},"weight":{"description":"weight associated with matching the corresponding podAffinityTerm, in the range 1-100.","format":"int32","type":"integer"}},"required":["podAffinityTerm","weight"],"type":"object"},"type":"array"},"requiredDuringSchedulingIgnoredDuringExecution":{"description":"If the anti-affinity requirements specified by this field are not met at scheduling time, the pod will not be scheduled onto the node. If the anti-affinity requirements specified by this field cease to be met at some point during pod execution (e.g. due to a pod label update), the system may or may not try to eventually evict the pod from its node. When there are multiple elements, the lists of nodes corresponding to each podAffinityTerm are intersected, i.e. all terms must be satisfied.","items":{"description":"Defines a set of pods (namely those matching the labelSelector relative to the given namespace(s)) that this pod should be co-located (affinity) or not co-located (anti-affinity) with, where co-located is defined as running on a node whose value of the label with key \u003ctopologyKey\u003e matches that of any node on which a pod of the set of pods is running","properties":{"labelSelector":{"description":"A label query over a set of resources, in this case pods. If it's null, this PodAffinityTerm matches with no Pods.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that relates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values. Valid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn, the values array must be non-empty. If the operator is Exists or DoesNotExist, the values array must be empty. This array is replaced during a strategic merge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"},"matchLabelKeys":{"description":"MatchLabelKeys is a set of pod label keys to select which pods will be taken into consideration. The keys are used to lookup values from the incoming pod labels, those key-value labels are merged with `LabelSelector` as `key in (value)` to select the group of existing pods which pods will be taken into consideration for the incoming pod's pod (anti) affinity. Keys that don't exist in the incoming pod labels will be ignored. The default value is empty. The same key is forbidden to exist in both MatchLabelKeys and LabelSelector. Also, MatchLabelKeys cannot be set when LabelSelector isn't set. This is an alpha field and requires enabling MatchLabelKeysInPodAffinity feature gate.","items":{"type":"string"},"type":"array","x-kubernetes-list-type":"atomic"},"mismatchLabelKeys":{"description":"MismatchLabelKeys is a set of pod label keys to select which pods will be taken into consideration. The keys are used to lookup values from the incoming pod labels, those key-value labels are merged with `LabelSelector` as `key notin (value)` to select the group of existing pods which pods will be taken into consideration for the incoming pod's pod (anti) affinity. Keys that don't exist in the incoming pod labels will be ignored. The default value is empty. The same key is forbidden to exist in both MismatchLabelKeys and LabelSelector. Also, MismatchLabelKeys cannot be set when LabelSelector isn't set. This is an alpha field and requires enabling MatchLabelKeysInPodAffinity feature gate.","items":{"type":"string"},"type":"array","x-kubernetes-list-type":"atomic"},"namespaceSelector":{"description":"A label query over the set of namespaces that the term applies to. The term is applied to the union of the namespaces selected by this field and the ones listed in the namespaces field. null selector and null or empty namespaces list means \"this pod's namespace\". An empty selector ({}) matches all namespaces.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that relates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values. Valid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn, the values array must be non-empty. If the operator is Exists or DoesNotExist, the values array must be empty. This array is replaced during a strategic merge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"},"namespaces":{"description":"namespaces specifies a static list of namespace names that the term applies to. The term is applied to the union of the namespaces listed in this field and the ones selected by namespaceSelector. null or empty namespaces list and null namespaceSelector means \"this pod's namespace\".","items":{"type":"string"},"type":"array"},"topologyKey":{"description":"This pod should be co-located (affinity) or not co-located (anti-affinity) with the pods matching the labelSelector in the specified namespaces, where co-located is defined as running on a node whose value of the label with key topologyKey matches that of any node on which any of the selected pods is running. Empty topologyKey is not allowed.","type":"string"}},"required":["topologyKey"],"type":"object"},"type":"array"}},"type":"object"}},"type":"object"},"clusterID":{"description":"Defines the local service cluster name where Envoy is running. Defaults to the NodeID in the EnvoyConfig if unset","type":"string"},"discoveryServiceRef":{"description":"DiscoveryServiceRef points to a DiscoveryService in the same namespace","type":"string"},"duration":{"description":"Defines the duration of the client certificate that is used to authenticate with the DiscoveryService","type":"string"},"envoyConfigRef":{"description":"EnvoyConfigRef points to an EnvoyConfig in the same namespace that holds the envoy resources for this Deployment","type":"string"},"extraArgs":{"description":"Allows the user to define extra command line arguments for the Envoy process","items":{"type":"string"},"type":"array"},"image":{"description":"Image is the envoy image and tag to use","type":"string"},"initManager":{"description":"InitManager defines configuration for Envoy's init manager, which handles initialization for Envoy pods","properties":{"image":{"description":"Image is the init manager image and tag to use","type":"string"}},"type":"object"},"livenessProbe":{"description":"Liveness probe for the envoy pods","properties":{"failureThreshold":{"description":"Minimum consecutive failures for the probe to be considered failed after having succeeded","format":"int32","type":"integer"},"initialDelaySeconds":{"description":"Number of seconds after the container has started before liveness probes are initiated","format":"int32","type":"integer"},"periodSeconds":{"description":"How often (in seconds) to perform the probe","format":"int32","type":"integer"},"successThreshold":{"description":"Minimum consecutive successes for the probe to be considered successful after having failed","format":"int32","type":"integer"},"timeoutSeconds":{"description":"Number of seconds after which the probe times out","format":"int32","type":"integer"}},"required":["failureThreshold","initialDelaySeconds","periodSeconds","successThreshold","timeoutSeconds"],"type":"object"},"podDisruptionBudget":{"description":"Configures PodDisruptionBudget for the envoy Pods","properties":{"maxUnavailable":{"anyOf":[{"type":"integer"},{"type":"string"}],"description":"An eviction is allowed if at most \"maxUnavailable\" pods selected by \"selector\" are unavailable after the eviction, i.e. even in absence of the evicted pod. For example, one can prevent all voluntary evictions by specifying 0. This is a mutually exclusive setting with \"minAvailable\".","x-kubernetes-int-or-string":true},"minAvailable":{"anyOf":[{"type":"integer"},{"type":"string"}],"description":"An eviction is allowed if at least \"minAvailable\" pods selected by \"selector\" will still be available after the eviction, i.e. even in the absence of the evicted pod.  So for example you can prevent all voluntary evictions by specifying \"100%\".","x-kubernetes-int-or-string":true}},"type":"object"},"ports":{"description":"Ports exposed by the Envoy container","items":{"description":"ContainerPort defines port for the Marin3r sidecar container","properties":{"name":{"description":"Port name","type":"string"},"port":{"description":"Port value","format":"int32","type":"integer"},"protocol":{"default":"TCP","description":"Protocol. Defaults to TCP.","type":"string"}},"required":["name","port"],"type":"object"},"type":"array"},"readinessProbe":{"description":"Readiness probe for the envoy pods","properties":{"failureThreshold":{"description":"Minimum consecutive failures for the probe to be considered failed after having succeeded","format":"int32","type":"integer"},"initialDelaySeconds":{"description":"Number of seconds after the container has started before liveness probes are initiated","format":"int32","type":"integer"},"periodSeconds":{"description":"How often (in seconds) to perform the probe","format":"int32","type":"integer"},"successThreshold":{"description":"Minimum consecutive successes for the probe to be considered successful after having failed","format":"int32","type":"integer"},"timeoutSeconds":{"description":"Number of seconds after which the probe times out","format":"int32","type":"integer"}},"required":["failureThreshold","initialDelaySeconds","periodSeconds","successThreshold","timeoutSeconds"],"type":"object"},"replicas":{"description":"Replicas configures the number of replicas in the Deployment. One of 'static', 'dynamic' can be set. If both are set, static has precedence.","properties":{"dynamic":{"description":"Configure a min and max value for the number of pods to autoscale dynamically.","properties":{"behavior":{"description":"behavior configures the scaling behavior of the target in both Up and Down directions (scaleUp and scaleDown fields respectively). If not set, the default HPAScalingRules for scale up and scale down are used.","properties":{"scaleDown":{"description":"scaleDown is scaling policy for scaling Down. If not set, the default value is to allow to scale down to minReplicas pods, with a 300 second stabilization window (i.e., the highest recommendation for the last 300sec is used).","properties":{"policies":{"description":"policies is a list of potential scaling polices which can be used during scaling. At least one policy must be specified, otherwise the HPAScalingRules will be discarded as invalid","items":{"description":"HPAScalingPolicy is a single policy which must hold true for a specified past interval.","properties":{"periodSeconds":{"description":"periodSeconds specifies the window of time for which the policy should hold true. PeriodSeconds must be greater than zero and less than or equal to 1800 (30 min).","format":"int32","type":"integer"},"type":{"description":"type is used to specify the scaling policy.","type":"string"},"value":{"description":"value contains the amount of change which is permitted by the policy. It must be greater than zero","format":"int32","type":"integer"}},"required":["periodSeconds","type","value"],"type":"object"},"type":"array","x-kubernetes-list-type":"atomic"},"selectPolicy":{"description":"selectPolicy is used to specify which policy should be used. If not set, the default value Max is used.","type":"string"},"stabilizationWindowSeconds":{"description":"stabilizationWindowSeconds is the number of seconds for which past recommendations should be considered while scaling up or scaling down. StabilizationWindowSeconds must be greater than or equal to zero and less than or equal to 3600 (one hour). If not set, use the default values: - For scale up: 0 (i.e. no stabilization is done). - For scale down: 300 (i.e. the stabilization window is 300 seconds long).","format":"int32","type":"integer"}},"type":"object"},"scaleUp":{"description":"scaleUp is scaling policy for scaling Up. If not set, the default value is the higher of: * increase no more than 4 pods per 60 seconds * double the number of pods per 60 seconds No stabilization is used.","properties":{"policies":{"description":"policies is a list of potential scaling polices which can be used during scaling. At least one policy must be specified, otherwise the HPAScalingRules will be discarded as invalid","items":{"description":"HPAScalingPolicy is a single policy which must hold true for a specified past interval.","properties":{"periodSeconds":{"description":"periodSeconds specifies the window of time for which the policy should hold true. PeriodSeconds must be greater than zero and less than or equal to 1800 (30 min).","format":"int32","type":"integer"},"type":{"description":"type is used to specify the scaling policy.","type":"string"},"value":{"description":"value contains the amount of change which is permitted by the policy. It must be greater than zero","format":"int32","type":"integer"}},"required":["periodSeconds","type","value"],"type":"object"},"type":"array","x-kubernetes-list-type":"atomic"},"selectPolicy":{"description":"selectPolicy is used to specify which policy should be used. If not set, the default value Max is used.","type":"string"},"stabilizationWindowSeconds":{"description":"stabilizationWindowSeconds is the number of seconds for which past recommendations should be considered while scaling up or scaling down. StabilizationWindowSeconds must be greater than or equal to zero and less than or equal to 3600 (one hour). If not set, use the default values: - For scale up: 0 (i.e. no stabilization is done). - For scale down: 300 (i.e. the stabilization window is 300 seconds long).","format":"int32","type":"integer"}},"type":"object"}},"type":"object"},"maxReplicas":{"description":"maxReplicas is the upper limit for the number of replicas to which the autoscaler can scale up. It cannot be less that minReplicas.","format":"int32","type":"integer"},"metrics":{"description":"metrics contains the specifications for which to use to calculate the desired replica count (the maximum replica count across all metrics will be used).  The desired replica count is calculated multiplying the ratio between the target value and the current value by the current number of pods.  Ergo, metrics used must decrease as the pod count is increased, and vice-versa.  See the individual metric source types for more information about how each type of metric must respond. If not set, the default metric will be set to 80% average CPU utilization.","items":{"description":"MetricSpec specifies how to scale based on a single metric (only `type` and one other matching field should be set at once).","properties":{"containerResource":{"description":"containerResource refers to a resource metric (such as those specified in requests and limits) known to Kubernetes describing a single container in each pod of the current scale target (e.g. CPU or memory). Such metrics are built in to Kubernetes, and have special scaling options on top of those available to normal per-pod metrics using the \"pods\" source. This is an alpha feature and can be enabled by the HPAContainerMetrics feature flag.","properties":{"container":{"description":"container is the name of the container in the pods of the scaling target","type":"string"},"name":{"description":"name is the name of the resource in question.","type":"string"},"target":{"description":"target specifies the target value for the given metric","properties":{"averageUtilization":{"description":"averageUtilization is the target value of the average of the resource metric across all relevant pods, represented as a percentage of the requested value of the resource for the pods. Currently only valid for Resource metric source type","format":"int32","type":"integer"},"averageValue":{"anyOf":[{"type":"integer"},{"type":"string"}],"description":"averageValue is the target value of the average of the metric across all relevant pods (as a quantity)","pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"type":{"description":"type represents whether the metric type is Utilization, Value, or AverageValue","type":"string"},"value":{"anyOf":[{"type":"integer"},{"type":"string"}],"description":"value is the target value of the metric (as a quantity).","pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true}},"required":["type"],"type":"object"}},"required":["container","name","target"],"type":"object"},"external":{"description":"external refers to a global metric that is not associated with any Kubernetes object. It allows autoscaling based on information coming from components running outside of cluster (for example length of queue in cloud messaging service, or QPS from loadbalancer running outside of cluster).","properties":{"metric":{"description":"metric identifies the target metric by name and selector","properties":{"name":{"description":"name is the name of the given metric","type":"string"},"selector":{"description":"selector is the string-encoded form of a standard kubernetes label selector for the given metric When set, it is passed as an additional parameter to the metrics server for more specific metrics scoping. When unset, just the metricName will be used to gather metrics.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that relates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values. Valid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn, the values array must be non-empty. If the operator is Exists or DoesNotExist, the values array must be empty. This array is replaced during a strategic merge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"}},"required":["name"],"type":"object"},"target":{"description":"target specifies the target value for the given metric","properties":{"averageUtilization":{"description":"averageUtilization is the target value of the average of the resource metric across all relevant pods, represented as a percentage of the requested value of the resource for the pods. Currently only valid for Resource metric source type","format":"int32","type":"integer"},"averageValue":{"anyOf":[{"type":"integer"},{"type":"string"}],"description":"averageValue is the target value of the average of the metric across all relevant pods (as a quantity)","pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"type":{"description":"type represents whether the metric type is Utilization, Value, or AverageValue","type":"string"},"value":{"anyOf":[{"type":"integer"},{"type":"string"}],"description":"value is the target value of the metric (as a quantity).","pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true}},"required":["type"],"type":"object"}},"required":["metric","target"],"type":"object"},"object":{"description":"object refers to a metric describing a single kubernetes object (for example, hits-per-second on an Ingress object).","properties":{"describedObject":{"description":"describedObject specifies the descriptions of a object,such as kind,name apiVersion","properties":{"apiVersion":{"description":"apiVersion is the API version of the referent","type":"string"},"kind":{"description":"kind is the kind of the referent; More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds","type":"string"},"name":{"description":"name is the name of the referent; More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names","type":"string"}},"required":["kind","name"],"type":"object"},"metric":{"description":"metric identifies the target metric by name and selector","properties":{"name":{"description":"name is the name of the given metric","type":"string"},"selector":{"description":"selector is the string-encoded form of a standard kubernetes label selector for the given metric When set, it is passed as an additional parameter to the metrics server for more specific metrics scoping. When unset, just the metricName will be used to gather metrics.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that relates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values. Valid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn, the values array must be non-empty. If the operator is Exists or DoesNotExist, the values array must be empty. This array is replaced during a strategic merge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"}},"required":["name"],"type":"object"},"target":{"description":"target specifies the target value for the given metric","properties":{"averageUtilization":{"description":"averageUtilization is the target value of the average of the resource metric across all relevant pods, represented as a percentage of the requested value of the resource for the pods. Currently only valid for Resource metric source type","format":"int32","type":"integer"},"averageValue":{"anyOf":[{"type":"integer"},{"type":"string"}],"description":"averageValue is the target value of the average of the metric across all relevant pods (as a quantity)","pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"type":{"description":"type represents whether the metric type is Utilization, Value, or AverageValue","type":"string"},"value":{"anyOf":[{"type":"integer"},{"type":"string"}],"description":"value is the target value of the metric (as a quantity).","pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true}},"required":["type"],"type":"object"}},"required":["describedObject","metric","target"],"type":"object"},"pods":{"description":"pods refers to a metric describing each pod in the current scale target (for example, transactions-processed-per-second).  The values will be averaged together before being compared to the target value.","properties":{"metric":{"description":"metric identifies the target metric by name and selector","properties":{"name":{"description":"name is the name of the given metric","type":"string"},"selector":{"description":"selector is the string-encoded form of a standard kubernetes label selector for the given metric When set, it is passed as an additional parameter to the metrics server for more specific metrics scoping. When unset, just the metricName will be used to gather metrics.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that relates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values. Valid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn, the values array must be non-empty. If the operator is Exists or DoesNotExist, the values array must be empty. This array is replaced during a strategic merge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels map is equivalent to an element of matchExpressions, whose key field is \"key\", the operator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"}},"required":["name"],"type":"object"},"target":{"description":"target specifies the target value for the given metric","properties":{"averageUtilization":{"description":"averageUtilization is the target value of the average of the resource metric across all relevant pods, represented as a percentage of the requested value of the resource for the pods. Currently only valid for Resource metric source type","format":"int32","type":"integer"},"averageValue":{"anyOf":[{"type":"integer"},{"type":"string"}],"description":"averageValue is the target value of the average of the metric across all relevant pods (as a quantity)","pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"type":{"description":"type represents whether the metric type is Utilization, Value, or AverageValue","type":"string"},"value":{"anyOf":[{"type":"integer"},{"type":"string"}],"description":"value is the target value of the metric (as a quantity).","pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true}},"required":["type"],"type":"object"}},"required":["metric","target"],"type":"object"},"resource":{"description":"resource refers to a resource metric (such as those specified in requests and limits) known to Kubernetes describing each pod in the current scale target (e.g. CPU or memory). Such metrics are built in to Kubernetes, and have special scaling options on top of those available to normal per-pod metrics using the \"pods\" source.","properties":{"name":{"description":"name is the name of the resource in question.","type":"string"},"target":{"description":"target specifies the target value for the given metric","properties":{"averageUtilization":{"description":"averageUtilization is the target value of the average of the resource metric across all relevant pods, represented as a percentage of the requested value of the resource for the pods. Currently only valid for Resource metric source type","format":"int32","type":"integer"},"averageValue":{"anyOf":[{"type":"integer"},{"type":"string"}],"description":"averageValue is the target value of the average of the metric across all relevant pods (as a quantity)","pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"type":{"description":"type represents whether the metric type is Utilization, Value, or AverageValue","type":"string"},"value":{"anyOf":[{"type":"integer"},{"type":"string"}],"description":"value is the target value of the metric (as a quantity).","pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true}},"required":["type"],"type":"object"}},"required":["name","target"],"type":"object"},"type":{"description":"type is the type of metric source.  It should be one of \"ContainerResource\", \"External\", \"Object\", \"Pods\" or \"Resource\", each mapping to a matching field in the object. Note: \"ContainerResource\" type is available on when the feature-gate HPAContainerMetrics is enabled","type":"string"}},"required":["type"],"type":"object"},"type":"array"},"minReplicas":{"description":"minReplicas is the lower limit for the number of replicas to which the autoscaler can scale down.  It defaults to 1 pod.  minReplicas is allowed to be 0 if the alpha feature gate HPAScaleToZero is enabled and at least one Object or External metric is configured.  Scaling is active as long as at least one metric value is available.","format":"int32","type":"integer"}},"required":["maxReplicas"],"type":"object"},"static":{"description":"Configure a static number of replicas. Defaults to 1.","format":"int32","type":"integer"}},"type":"object"},"resources":{"description":"Resources holds the resource requirements to use for the Envoy Deployment. Defaults to no resource requests nor limits.","properties":{"claims":{"description":"Claims lists the names of resources, defined in spec.resourceClaims, that are used by this container. \n This is an alpha field and requires enabling the DynamicResourceAllocation feature gate. \n This field is immutable. It can only be set for containers.","items":{"description":"ResourceClaim references one entry in PodSpec.ResourceClaims.","properties":{"name":{"description":"Name must match the name of one entry in pod.spec.resourceClaims of the Pod where this field is used. It makes that resource available inside a container.","type":"string"}},"required":["name"],"type":"object"},"type":"array","x-kubernetes-list-map-keys":["name"],"x-kubernetes-list-type":"map"},"limits":{"additionalProperties":{"anyOf":[{"type":"integer"},{"type":"string"}],"pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"description":"Limits describes the maximum amount of compute resources allowed. More info: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/","type":"object"},"requests":{"additionalProperties":{"anyOf":[{"type":"integer"},{"type":"string"}],"pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"description":"Requests describes the minimum amount of compute resources required. If Requests is omitted for a container, it defaults to Limits if that is explicitly specified, otherwise to an implementation-defined value. Requests cannot exceed Limits. More info: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/","type":"object"}},"type":"object"},"shutdownManager":{"description":"ShutdownManager defines configuration for Envoy's shutdown manager, which handles graceful termination of Envoy pods","properties":{"drainStrategy":{"description":"The drain strategy for the graceful shutdown. It also affects drain when listeners are modified or removed via LDS.","enum":["gradual","immediate"],"type":"string"},"drainTime":{"description":"The time in seconds that Envoy will drain connections during shutdown. It also affects drain behaviour when listeners are modified or removed via LDS.","format":"int64","type":"integer"},"image":{"description":"Image is the shutdown manager image and tag to use","type":"string"},"serverPort":{"description":"Configures the sutdown manager's server port. Defaults to 8090.","format":"int32","type":"integer"}},"type":"object"}},"required":["discoveryServiceRef","envoyConfigRef"],"type":"object"},"status":{"description":"EnvoyDeploymentStatus defines the observed state of EnvoyDeployment","properties":{"deploymentName":{"type":"string"},"deploymentStatus":{"description":"DeploymentStatus is the most recently observed status of the Deployment.","properties":{"availableReplicas":{"description":"Total number of available pods (ready for at least minReadySeconds) targeted by this deployment.","format":"int32","type":"integer"},"collisionCount":{"description":"Count of hash collisions for the Deployment. The Deployment controller uses this field as a collision avoidance mechanism when it needs to create the name for the newest ReplicaSet.","format":"int32","type":"integer"},"conditions":{"description":"Represents the latest available observations of a deployment's current state.","items":{"description":"DeploymentCondition describes the state of a deployment at a certain point.","properties":{"lastTransitionTime":{"description":"Last time the condition transitioned from one status to another.","format":"date-time","type":"string"},"lastUpdateTime":{"description":"The last time this condition was updated.","format":"date-time","type":"string"},"message":{"description":"A human readable message indicating details about the transition.","type":"string"},"reason":{"description":"The reason for the condition's last transition.","type":"string"},"status":{"description":"Status of the condition, one of True, False, Unknown.","type":"string"},"type":{"description":"Type of deployment condition.","type":"string"}},"required":["status","type"],"type":"object"},"type":"array"},"observedGeneration":{"description":"The generation observed by the deployment controller.","format":"int64","type":"integer"},"readyReplicas":{"description":"readyReplicas is the number of pods targeted by this Deployment with a Ready Condition.","format":"int32","type":"integer"},"replicas":{"description":"Total number of non-terminated pods targeted by this deployment (their labels match the selector).","format":"int32","type":"integer"},"unavailableReplicas":{"description":"Total number of unavailable pods targeted by this deployment. This is the total number of pods that are still required for the deployment to have 100% available capacity. They may either be pods that are running but not yet available or pods that still have not been created.","format":"int32","type":"integer"},"updatedReplicas":{"description":"Total number of non-terminated pods targeted by this deployment that have the desired template spec.","format":"int32","type":"integer"}},"type":"object"}},"type":"object"}},"type":"object"}},"served":true,"storage":true,"subresources":{"status":{}}}]},"status":{"acceptedNames":{"kind":"","plural":""},"conditions":null,"storedVersions":null}} +relatedImages: +- image: quay.io/3scale/marin3r-bundle:v0.13.2-alpha.1 + name: "" +- image: quay.io/3scale/marin3r:v0.13.2-alpha.1 + name: "" +schema: olm.bundle diff --git a/catalog/marin3r/objects/marin3r.v0.13.2-alpha.2.clusterserviceversion.yaml b/catalog/marin3r/objects/marin3r.v0.13.2-alpha.2.clusterserviceversion.yaml new file mode 100644 index 00000000..a9b4bc43 --- /dev/null +++ b/catalog/marin3r/objects/marin3r.v0.13.2-alpha.2.clusterserviceversion.yaml @@ -0,0 +1,70 @@ +--- +image: quay.io/3scale/marin3r-bundle:v0.13.2-alpha.2 +name: marin3r.v0.13.2-alpha.2 +package: marin3r +properties: +- type: olm.gvk + value: + group: marin3r.3scale.net + kind: EnvoyConfig + version: v1alpha1 +- type: olm.gvk + value: + group: marin3r.3scale.net + kind: EnvoyConfigRevision + version: v1alpha1 +- type: olm.gvk + value: + group: operator.marin3r.3scale.net + kind: DiscoveryService + version: v1alpha1 +- type: olm.gvk + value: + group: operator.marin3r.3scale.net + kind: DiscoveryServiceCertificate + version: v1alpha1 +- type: olm.gvk + value: + group: operator.marin3r.3scale.net + kind: EnvoyDeployment + version: v1alpha1 +- type: olm.package + value: + packageName: marin3r + version: 0.13.2-alpha.2 +- type: olm.bundle.object + value: + data: eyJhcGlWZXJzaW9uIjoidjEiLCJraW5kIjoiU2VydmljZSIsIm1ldGFkYXRhIjp7ImNyZWF0aW9uVGltZXN0YW1wIjpudWxsLCJsYWJlbHMiOnsiY29udHJvbC1wbGFuZSI6ImNvbnRyb2xsZXItbWFuYWdlciJ9LCJuYW1lIjoibWFyaW4zci1jb250cm9sbGVyLW1hbmFnZXItbWV0cmljcy1zZXJ2aWNlIn0sInNwZWMiOnsicG9ydHMiOlt7Im5hbWUiOiJtZXRyaWNzIiwicG9ydCI6ODA4MCwicHJvdG9jb2wiOiJUQ1AiLCJ0YXJnZXRQb3J0IjoibWV0cmljcyJ9XSwic2VsZWN0b3IiOnsiY29udHJvbC1wbGFuZSI6ImNvbnRyb2xsZXItbWFuYWdlciJ9fSwic3RhdHVzIjp7ImxvYWRCYWxhbmNlciI6e319fQ== +- type: olm.bundle.object + value: + data: eyJhcGlWZXJzaW9uIjoidjEiLCJkYXRhIjp7ImNvbnRyb2xsZXJfbWFuYWdlcl9jb25maWcueWFtbCI6ImFwaVZlcnNpb246IGNvbnRyb2xsZXItcnVudGltZS5zaWdzLms4cy5pby92MWFscGhhMVxua2luZDogQ29udHJvbGxlck1hbmFnZXJDb25maWdcbmhlYWx0aDpcbiAgaGVhbHRoUHJvYmVCaW5kQWRkcmVzczogOjgwODFcbm1ldHJpY3M6XG4gIGJpbmRBZGRyZXNzOiAxMjcuMC4wLjE6ODA4MFxud2ViaG9vazpcbiAgcG9ydDogOTQ0M1xubGVhZGVyRWxlY3Rpb246XG4gIGxlYWRlckVsZWN0OiB0cnVlXG4gIHJlc291cmNlTmFtZTogOTQ0NGYxZDcuM3NjYWxlLm5ldFxuIn0sImtpbmQiOiJDb25maWdNYXAiLCJtZXRhZGF0YSI6eyJuYW1lIjoibWFyaW4zci1tYW5hZ2VyLWNvbmZpZyJ9fQ== +- type: olm.bundle.object + value: + data: eyJhcGlWZXJzaW9uIjoicmJhYy5hdXRob3JpemF0aW9uLms4cy5pby92MSIsImtpbmQiOiJDbHVzdGVyUm9sZSIsIm1ldGFkYXRhIjp7ImNyZWF0aW9uVGltZXN0YW1wIjpudWxsLCJuYW1lIjoibWFyaW4zci1tZXRyaWNzLXJlYWRlciJ9LCJydWxlcyI6W3sibm9uUmVzb3VyY2VVUkxzIjpbIi9tZXRyaWNzIl0sInZlcmJzIjpbImdldCJdfV19 +- type: olm.bundle.object + value: + data: eyJhcGlWZXJzaW9uIjoidjEiLCJraW5kIjoiU2VydmljZSIsIm1ldGFkYXRhIjp7ImNyZWF0aW9uVGltZXN0YW1wIjpudWxsLCJuYW1lIjoibWFyaW4zci13ZWJob29rLXNlcnZpY2UifSwic3BlYyI6eyJwb3J0cyI6W3sicG9ydCI6NDQzLCJwcm90b2NvbCI6IlRDUCIsInRhcmdldFBvcnQiOjk0NDN9XSwic2VsZWN0b3IiOnsiY29udHJvbC1wbGFuZSI6ImNvbnRyb2xsZXItd2ViaG9vayJ9fSwic3RhdHVzIjp7ImxvYWRCYWxhbmNlciI6e319fQ== +- type: olm.bundle.object + value: + data: {"apiVersion":"apiextensions.k8s.io/v1","kind":"CustomResourceDefinition","metadata":{"annotations":{"controller-gen.kubebuilder.io/version":"v0.14.0"},"creationTimestamp":null,"name":"envoyconfigrevisions.marin3r.3scale.net"},"spec":{"group":"marin3r.3scale.net","names":{"kind":"EnvoyConfigRevision","listKind":"EnvoyConfigRevisionList","plural":"envoyconfigrevisions","shortNames":["ecr"],"singular":"envoyconfigrevision"},"scope":"Namespaced","versions":[{"additionalPrinterColumns":[{"jsonPath":".spec.nodeID","name":"Node ID","type":"string"},{"jsonPath":".spec.envoyAPI","name":"Envoy API","type":"string"},{"jsonPath":".spec.version","name":"Version","type":"string"},{"jsonPath":".status.published","name":"Published","type":"boolean"},{"format":"date-time","jsonPath":".metadata.creationTimestamp","name":"Created At","type":"string"},{"format":"date-time","jsonPath":".status.lastPublishedAt","name":"Last Published At","type":"string"},{"jsonPath":".status.tainted","name":"Tainted","type":"boolean"}],"name":"v1alpha1","schema":{"openAPIV3Schema":{"description":"EnvoyConfigRevision is an internal resource that stores a specific version of an EnvoyConfig\nresource. EnvoyConfigRevisions are automatically created and deleted by the EnvoyConfig\ncontroller and are not intended to be directly used. Use EnvoyConfig objects instead.","properties":{"apiVersion":{"description":"APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources","type":"string"},"kind":{"description":"Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds","type":"string"},"metadata":{"type":"object"},"spec":{"description":"EnvoyConfigRevisionSpec defines the desired state of EnvoyConfigRevision","properties":{"envoyAPI":{"description":"EnvoyAPI is the version of envoy's API to use. Defaults to v3.","enum":["v3"],"type":"string"},"envoyResources":{"description":"EnvoyResources holds the different types of resources suported by the envoy discovery service","properties":{"clusters":{"description":"Clusters is a list of the envoy Cluster resource type.\nAPI V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/cluster/v3/cluster.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy\nresource","properties":{"name":{"description":"Name of the envoy resource.\nDEPRECATED: this field has no effect and will be removed in an\nupcoming release. The name of the resources for discovery purposes\nis included in the resource itself. Refer to the envoy API reference\nto check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"endpoints":{"description":"Endpoints is a list of the envoy ClusterLoadAssignment resource type.\nAPI V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/endpoint/v3/endpoint.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy\nresource","properties":{"name":{"description":"Name of the envoy resource.\nDEPRECATED: this field has no effect and will be removed in an\nupcoming release. The name of the resources for discovery purposes\nis included in the resource itself. Refer to the envoy API reference\nto check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"extensionConfigs":{"description":"ExtensionConfigs is a list of the envoy ExtensionConfig resource type\nAPI V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/core/v3/extension.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy\nresource","properties":{"name":{"description":"Name of the envoy resource.\nDEPRECATED: this field has no effect and will be removed in an\nupcoming release. The name of the resources for discovery purposes\nis included in the resource itself. Refer to the envoy API reference\nto check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"listeners":{"description":"Listeners is a list of the envoy Listener resource type.\nAPI V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/listener/v3/listener.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy\nresource","properties":{"name":{"description":"Name of the envoy resource.\nDEPRECATED: this field has no effect and will be removed in an\nupcoming release. The name of the resources for discovery purposes\nis included in the resource itself. Refer to the envoy API reference\nto check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"routes":{"description":"Routes is a list of the envoy Route resource type.\nAPI V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/route/v3/route.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy\nresource","properties":{"name":{"description":"Name of the envoy resource.\nDEPRECATED: this field has no effect and will be removed in an\nupcoming release. The name of the resources for discovery purposes\nis included in the resource itself. Refer to the envoy API reference\nto check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"runtimes":{"description":"Runtimes is a list of the envoy Runtime resource type.\nAPI V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/service/runtime/v3/rtds.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy\nresource","properties":{"name":{"description":"Name of the envoy resource.\nDEPRECATED: this field has no effect and will be removed in an\nupcoming release. The name of the resources for discovery purposes\nis included in the resource itself. Refer to the envoy API reference\nto check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"scopedRoutes":{"description":"ScopedRoutes is a list of the envoy ScopeRoute resource type.\nAPI V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/route/v3/scoped_route.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy\nresource","properties":{"name":{"description":"Name of the envoy resource.\nDEPRECATED: this field has no effect and will be removed in an\nupcoming release. The name of the resources for discovery purposes\nis included in the resource itself. Refer to the envoy API reference\nto check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"secrets":{"description":"Secrets is a list of references to Kubernetes Secret objects.","items":{"description":"EnvoySecretResource holds a reference to a k8s Secret from where\nto take a secret from. Only Secrets within the same namespace can\nbe referred.","properties":{"name":{"description":"Name of the envoy tslCerticate secret resource. The certificate will be fetched\nfrom a Kubernetes Secrets of type 'kubernetes.io/tls' with this same name.","type":"string"},"ref":{"description":"DEPRECATED: this field is deprecated and it's value will be ignored. The 'name' of the\nKubernetes Secret must match the 'name' field.","properties":{"name":{"description":"name is unique within a namespace to reference a secret resource.","type":"string"},"namespace":{"description":"namespace defines the space within which the secret name must be unique.","type":"string"}},"type":"object","x-kubernetes-map-type":"atomic"}},"required":["name"],"type":"object"},"type":"array"}},"type":"object"},"nodeID":{"description":"NodeID holds the envoy identifier for the discovery service to know which set\nof resources to send to each of the envoy clients that connect to it.","type":"string"},"resources":{"description":"Resources holds the different types of resources suported by the envoy discovery service","items":{"description":"Resource holds serialized representation of an envoy\nresource","properties":{"blueprint":{"description":"Blueprint specifies a template to generate a configuration proto. It is currently\nonly supported to generate secret configuration resources from k8s Secrets","enum":["tlsCertificate","validationContext"],"type":"string"},"generateFromEndpointSlices":{"description":"Specifies a label selector to watch for EndpointSlices that will\nbe used to generate the endpoint resource","properties":{"clusterName":{"type":"string"},"selector":{"description":"A label selector is a label query over a set of resources. The result of matchLabels and\nmatchExpressions are ANDed. An empty label selector matches all objects. A null\nlabel selector matches no objects.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that\nrelates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values.\nValid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn,\nthe values array must be non-empty. If the operator is Exists or DoesNotExist,\nthe values array must be empty. This array is replaced during a strategic\nmerge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"},"targetPort":{"type":"string"}},"required":["clusterName","selector","targetPort"],"type":"object"},"generateFromOpaqueSecret":{"description":"The name of a Kubernetes Secret of type \"Opaque\". It will generate an\nenvoy \"generic secret\" proto.","properties":{"alias":{"description":"A unique name to refer to the name:key combination","type":"string"},"key":{"description":"The key of the secret to select from.  Must be a valid secret key.","type":"string"},"name":{"description":"The name of the secret in the pod's namespace to select from.","type":"string"}},"required":["alias","key","name"],"type":"object"},"generateFromTlsSecret":{"description":"The name of a Kubernetes Secret of type \"kubernetes.io/tls\"","type":"string"},"type":{"description":"Type is the type url for the protobuf message","enum":["listener","route","scopedRoute","cluster","endpoint","secret","runtime","extensionConfig"],"type":"string"},"value":{"description":"Value is the protobufer message that configures the resource. The proto\nmust match the envoy configuration API v3 specification for the given resource\ntype (https://www.envoyproxy.io/docs/envoy/latest/api-docs/xds_protocol#resource-types)","type":"object","x-kubernetes-preserve-unknown-fields":true}},"required":["type"],"type":"object"},"type":"array"},"serialization":{"description":"Serialization specicifies the serialization format used to describe the resources. \"json\" and \"yaml\"\nare supported. \"json\" is used if unset.","enum":["json","b64json","yaml"],"type":"string"},"version":{"description":"Version is a hash of the EnvoyResources field","type":"string"}},"required":["nodeID","version"],"type":"object"},"status":{"description":"EnvoyConfigRevisionStatus defines the observed state of EnvoyConfigRevision","properties":{"conditions":{"description":"Conditions represent the latest available observations of an object's state","items":{"description":"Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions.  For example,\n\n\n\ttype FooStatus struct{\n\t    // Represents the observations of a foo's current state.\n\t    // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t    // +patchMergeKey=type\n\t    // +patchStrategy=merge\n\t    // +listType=map\n\t    // +listMapKey=type\n\t    Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t    // other fields\n\t}","properties":{"lastTransitionTime":{"description":"lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed.  If that is not known, then using the time when the API field changed is acceptable.","format":"date-time","type":"string"},"message":{"description":"message is a human readable message indicating details about the transition.\nThis may be an empty string.","maxLength":32768,"type":"string"},"observedGeneration":{"description":"observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.","format":"int64","minimum":0,"type":"integer"},"reason":{"description":"reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.","maxLength":1024,"minLength":1,"pattern":"^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$","type":"string"},"status":{"description":"status of the condition, one of True, False, Unknown.","enum":["True","False","Unknown"],"type":"string"},"type":{"description":"type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)","maxLength":316,"pattern":"^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$","type":"string"}},"required":["lastTransitionTime","message","reason","status","type"],"type":"object"},"type":"array"},"lastPublishedAt":{"description":"LastPublishedAt indicates the last time this config review transitioned to\npublished","format":"date-time","type":"string"},"providesVersions":{"description":"ProvidesVersions keeps track of the version that this revision\npublishes in the xDS server for each resource type","properties":{"clusters":{"type":"string"},"endpoints":{"type":"string"},"extensionConfigs":{"type":"string"},"listeners":{"type":"string"},"routes":{"type":"string"},"runtimes":{"type":"string"},"scopedRoutes":{"type":"string"},"secrets":{"type":"string"}},"type":"object"},"published":{"description":"Published signals if the EnvoyConfigRevision is the one currently published\nin the xds server cache","type":"boolean"},"tainted":{"description":"Tainted indicates whether the EnvoyConfigRevision is eligible for publishing\nor not","type":"boolean"}},"type":"object"}},"type":"object"}},"served":true,"storage":true,"subresources":{"status":{}}}]},"status":{"acceptedNames":{"kind":"","plural":""},"conditions":null,"storedVersions":null}} +- type: olm.bundle.object + value: + data: {"apiVersion":"apiextensions.k8s.io/v1","kind":"CustomResourceDefinition","metadata":{"annotations":{"controller-gen.kubebuilder.io/version":"v0.14.0"},"creationTimestamp":null,"name":"envoyconfigs.marin3r.3scale.net"},"spec":{"group":"marin3r.3scale.net","names":{"kind":"EnvoyConfig","listKind":"EnvoyConfigList","plural":"envoyconfigs","shortNames":["ec"],"singular":"envoyconfig"},"scope":"Namespaced","versions":[{"additionalPrinterColumns":[{"jsonPath":".spec.nodeID","name":"Node ID","type":"string"},{"jsonPath":".spec.envoyAPI","name":"Envoy API","type":"string"},{"jsonPath":".status.desiredVersion","name":"Desired Version","type":"string"},{"jsonPath":".status.publishedVersion","name":"Published Version","type":"string"},{"jsonPath":".status.cacheState","name":"Cache State","type":"string"}],"name":"v1alpha1","schema":{"openAPIV3Schema":{"description":"EnvoyConfig holds the configuration for a given envoy nodeID. The spec of an EnvoyConfig\nobject holds the Envoy resources that conform the desired configuration for the given nodeID\nand that the discovery service will send to any envoy client that identifies itself with that\nnodeID.","properties":{"apiVersion":{"description":"APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources","type":"string"},"kind":{"description":"Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds","type":"string"},"metadata":{"type":"object"},"spec":{"description":"EnvoyConfigSpec defines the desired state of EnvoyConfig","properties":{"envoyAPI":{"description":"EnvoyAPI is the version of envoy's API to use. Defaults to v3.","enum":["v3"],"type":"string"},"envoyResources":{"description":"EnvoyResources holds the different types of resources suported by the envoy discovery service\nDEPRECATED. Use the `resources` field instead.","properties":{"clusters":{"description":"Clusters is a list of the envoy Cluster resource type.\nAPI V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/cluster/v3/cluster.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy\nresource","properties":{"name":{"description":"Name of the envoy resource.\nDEPRECATED: this field has no effect and will be removed in an\nupcoming release. The name of the resources for discovery purposes\nis included in the resource itself. Refer to the envoy API reference\nto check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"endpoints":{"description":"Endpoints is a list of the envoy ClusterLoadAssignment resource type.\nAPI V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/endpoint/v3/endpoint.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy\nresource","properties":{"name":{"description":"Name of the envoy resource.\nDEPRECATED: this field has no effect and will be removed in an\nupcoming release. The name of the resources for discovery purposes\nis included in the resource itself. Refer to the envoy API reference\nto check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"extensionConfigs":{"description":"ExtensionConfigs is a list of the envoy ExtensionConfig resource type\nAPI V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/core/v3/extension.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy\nresource","properties":{"name":{"description":"Name of the envoy resource.\nDEPRECATED: this field has no effect and will be removed in an\nupcoming release. The name of the resources for discovery purposes\nis included in the resource itself. Refer to the envoy API reference\nto check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"listeners":{"description":"Listeners is a list of the envoy Listener resource type.\nAPI V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/listener/v3/listener.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy\nresource","properties":{"name":{"description":"Name of the envoy resource.\nDEPRECATED: this field has no effect and will be removed in an\nupcoming release. The name of the resources for discovery purposes\nis included in the resource itself. Refer to the envoy API reference\nto check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"routes":{"description":"Routes is a list of the envoy Route resource type.\nAPI V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/route/v3/route.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy\nresource","properties":{"name":{"description":"Name of the envoy resource.\nDEPRECATED: this field has no effect and will be removed in an\nupcoming release. The name of the resources for discovery purposes\nis included in the resource itself. Refer to the envoy API reference\nto check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"runtimes":{"description":"Runtimes is a list of the envoy Runtime resource type.\nAPI V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/service/runtime/v3/rtds.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy\nresource","properties":{"name":{"description":"Name of the envoy resource.\nDEPRECATED: this field has no effect and will be removed in an\nupcoming release. The name of the resources for discovery purposes\nis included in the resource itself. Refer to the envoy API reference\nto check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"scopedRoutes":{"description":"ScopedRoutes is a list of the envoy ScopeRoute resource type.\nAPI V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/route/v3/scoped_route.proto","items":{"description":"EnvoyResource holds serialized representation of an envoy\nresource","properties":{"name":{"description":"Name of the envoy resource.\nDEPRECATED: this field has no effect and will be removed in an\nupcoming release. The name of the resources for discovery purposes\nis included in the resource itself. Refer to the envoy API reference\nto check how the name is specified for each resource type.","type":"string"},"value":{"description":"Value is the serialized representation of the envoy resource","type":"string"}},"required":["value"],"type":"object"},"type":"array"},"secrets":{"description":"Secrets is a list of references to Kubernetes Secret objects.","items":{"description":"EnvoySecretResource holds a reference to a k8s Secret from where\nto take a secret from. Only Secrets within the same namespace can\nbe referred.","properties":{"name":{"description":"Name of the envoy tslCerticate secret resource. The certificate will be fetched\nfrom a Kubernetes Secrets of type 'kubernetes.io/tls' with this same name.","type":"string"},"ref":{"description":"DEPRECATED: this field is deprecated and it's value will be ignored. The 'name' of the\nKubernetes Secret must match the 'name' field.","properties":{"name":{"description":"name is unique within a namespace to reference a secret resource.","type":"string"},"namespace":{"description":"namespace defines the space within which the secret name must be unique.","type":"string"}},"type":"object","x-kubernetes-map-type":"atomic"}},"required":["name"],"type":"object"},"type":"array"}},"type":"object"},"nodeID":{"description":"NodeID holds the envoy identifier for the discovery service to know which set\nof resources to send to each of the envoy clients that connect to it.","type":"string"},"resources":{"description":"Resources holds the different types of resources suported by the envoy discovery service","items":{"description":"Resource holds serialized representation of an envoy\nresource","properties":{"blueprint":{"description":"Blueprint specifies a template to generate a configuration proto. It is currently\nonly supported to generate secret configuration resources from k8s Secrets","enum":["tlsCertificate","validationContext"],"type":"string"},"generateFromEndpointSlices":{"description":"Specifies a label selector to watch for EndpointSlices that will\nbe used to generate the endpoint resource","properties":{"clusterName":{"type":"string"},"selector":{"description":"A label selector is a label query over a set of resources. The result of matchLabels and\nmatchExpressions are ANDed. An empty label selector matches all objects. A null\nlabel selector matches no objects.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that\nrelates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values.\nValid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn,\nthe values array must be non-empty. If the operator is Exists or DoesNotExist,\nthe values array must be empty. This array is replaced during a strategic\nmerge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"},"targetPort":{"type":"string"}},"required":["clusterName","selector","targetPort"],"type":"object"},"generateFromOpaqueSecret":{"description":"The name of a Kubernetes Secret of type \"Opaque\". It will generate an\nenvoy \"generic secret\" proto.","properties":{"alias":{"description":"A unique name to refer to the name:key combination","type":"string"},"key":{"description":"The key of the secret to select from.  Must be a valid secret key.","type":"string"},"name":{"description":"The name of the secret in the pod's namespace to select from.","type":"string"}},"required":["alias","key","name"],"type":"object"},"generateFromTlsSecret":{"description":"The name of a Kubernetes Secret of type \"kubernetes.io/tls\"","type":"string"},"type":{"description":"Type is the type url for the protobuf message","enum":["listener","route","scopedRoute","cluster","endpoint","secret","runtime","extensionConfig"],"type":"string"},"value":{"description":"Value is the protobufer message that configures the resource. The proto\nmust match the envoy configuration API v3 specification for the given resource\ntype (https://www.envoyproxy.io/docs/envoy/latest/api-docs/xds_protocol#resource-types)","type":"object","x-kubernetes-preserve-unknown-fields":true}},"required":["type"],"type":"object"},"type":"array"},"serialization":{"description":"Serialization specicifies the serialization format used to describe the resources. \"json\" and \"yaml\"\nare supported. \"json\" is used if unset.","enum":["json","yaml"],"type":"string"}},"required":["nodeID"],"type":"object"},"status":{"description":"EnvoyConfigStatus defines the observed state of EnvoyConfig","properties":{"cacheState":{"description":"CacheState summarizes all the observations about the EnvoyConfig\nto give the user a concrete idea on the general status of the discovery servie cache.\nIt is intended only for human consumption. Other controllers should relly on conditions\nto determine the status of the discovery server cache.","type":"string"},"conditions":{"description":"Conditions represent the latest available observations of an object's state","items":{"description":"Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions.  For example,\n\n\n\ttype FooStatus struct{\n\t    // Represents the observations of a foo's current state.\n\t    // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t    // +patchMergeKey=type\n\t    // +patchStrategy=merge\n\t    // +listType=map\n\t    // +listMapKey=type\n\t    Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t    // other fields\n\t}","properties":{"lastTransitionTime":{"description":"lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed.  If that is not known, then using the time when the API field changed is acceptable.","format":"date-time","type":"string"},"message":{"description":"message is a human readable message indicating details about the transition.\nThis may be an empty string.","maxLength":32768,"type":"string"},"observedGeneration":{"description":"observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.","format":"int64","minimum":0,"type":"integer"},"reason":{"description":"reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.","maxLength":1024,"minLength":1,"pattern":"^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$","type":"string"},"status":{"description":"status of the condition, one of True, False, Unknown.","enum":["True","False","Unknown"],"type":"string"},"type":{"description":"type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)","maxLength":316,"pattern":"^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$","type":"string"}},"required":["lastTransitionTime","message","reason","status","type"],"type":"object"},"type":"array"},"desiredVersion":{"description":"DesiredVersion represents the resources version described in\nthe spec of the EnvoyConfig object","type":"string"},"publishedVersion":{"description":"PublishedVersion is the config version currently\nserved by the envoy discovery service for the give nodeID","type":"string"},"revisions":{"description":"ConfigRevisions is an ordered list of references to EnvoyConfigRevision\nobjects","items":{"description":"ConfigRevisionRef holds a reference to EnvoyConfigRevision object","properties":{"ref":{"description":"Ref is a reference to the EnvoyConfigRevision object that\nholds the configuration matching the Version field.","properties":{"apiVersion":{"description":"API version of the referent.","type":"string"},"fieldPath":{"description":"If referring to a piece of an object instead of an entire object, this string\nshould contain a valid JSON/Go field access statement, such as desiredState.manifest.containers[2].\nFor example, if the object reference is to a container within a pod, this would take on a value like:\n\"spec.containers{name}\" (where \"name\" refers to the name of the container that triggered\nthe event) or if no container name is specified \"spec.containers[2]\" (container with\nindex 2 in this pod). This syntax is chosen only to have some well-defined way of\nreferencing a part of an object.\nTODO: this design is not final and this field is subject to change in the future.","type":"string"},"kind":{"description":"Kind of the referent.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds","type":"string"},"name":{"description":"Name of the referent.\nMore info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names","type":"string"},"namespace":{"description":"Namespace of the referent.\nMore info: https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/","type":"string"},"resourceVersion":{"description":"Specific resourceVersion to which this reference is made, if any.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#concurrency-control-and-consistency","type":"string"},"uid":{"description":"UID of the referent.\nMore info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#uids","type":"string"}},"type":"object","x-kubernetes-map-type":"atomic"},"version":{"description":"Version is a hash of the EnvoyResources field","type":"string"}},"required":["ref","version"],"type":"object"},"type":"array"}},"type":"object"}},"type":"object"}},"served":true,"storage":true,"subresources":{"status":{}}}]},"status":{"acceptedNames":{"kind":"","plural":""},"conditions":null,"storedVersions":null}} +- type: olm.bundle.object + value: + data: {"apiVersion":"operators.coreos.com/v1alpha1","kind":"ClusterServiceVersion","metadata":{"annotations":{"alm-examples":"[\n  {\n    \"apiVersion\": \"marin3r.3scale.net/v1alpha1\",\n    \"kind\": \"EnvoyConfig\",\n    \"metadata\": {\n      \"name\": \"envoyconfig-example\",\n      \"namespace\": \"my-namespace\"\n    },\n    \"spec\": {\n      \"nodeID\": \"example\",\n      \"resources\": [\n        {\n          \"type\": \"cluster\",\n          \"value\": {\n            \"connect_timeout\": \"0.01s\",\n            \"dns_lookup_family\": \"V4_ONLY\",\n            \"lb_policy\": \"ROUND_ROBIN\",\n            \"load_assignment\": {\n              \"cluster_name\": \"example\",\n              \"endpoints\": [\n                {\n                  \"lb_endpoints\": [\n                    {\n                      \"endpoint\": {\n                        \"address\": {\n                          \"socket_address\": {\n                            \"address\": \"example\",\n                            \"port_value\": 8080\n                          }\n                        }\n                      }\n                    }\n                  ]\n                }\n              ]\n            },\n            \"name\": \"example\",\n            \"type\": \"STRICT_DNS\"\n          }\n        },\n        {\n          \"type\": \"route\",\n          \"value\": {\n            \"name\": \"local\",\n            \"virtual_hosts\": [\n              {\n                \"domains\": [\n                  \"*\"\n                ],\n                \"name\": \"all\",\n                \"routes\": [\n                  {\n                    \"match\": {\n                      \"prefix\": \"/\"\n                    },\n                    \"route\": {\n                      \"cluster\": \"example\"\n                    }\n                  }\n                ]\n              }\n            ]\n          }\n        },\n        {\n          \"type\": \"listener\",\n          \"value\": {\n            \"address\": {\n              \"socket_address\": {\n                \"address\": \"0.0.0.0\",\n                \"port_value\": 8443\n              }\n            },\n            \"filter_chains\": [\n              {\n                \"filters\": [\n                  {\n                    \"name\": \"envoy.filters.network.http_connection_manager\",\n                    \"typed_config\": {\n                      \"@type\": \"type.googleapis.com/envoy.extensions.filters.network.http_connection_manager.v3.HttpConnectionManager\",\n                      \"access_log\": [\n                        {\n                          \"name\": \"envoy.access_loggers.file\",\n                          \"typed_config\": {\n                            \"@type\": \"type.googleapis.com/envoy.extensions.access_loggers.file.v3.FileAccessLog\",\n                            \"path\": \"/dev/stdout\"\n                          }\n                        }\n                      ],\n                      \"http_filters\": [\n                        {\n                          \"name\": \"envoy.filters.http.router\",\n                          \"typed_config\": {\n                            \"@type\": \"type.googleapis.com/envoy.extensions.filters.http.router.v3.Router\"\n                          }\n                        }\n                      ],\n                      \"rds\": {\n                        \"config_source\": {\n                          \"ads\": {},\n                          \"resource_api_version\": \"V3\"\n                        },\n                        \"route_config_name\": \"local\"\n                      },\n                      \"stat_prefix\": \"https\"\n                    }\n                  }\n                ],\n                \"transport_socket\": {\n                  \"name\": \"envoy.transport_sockets.tls\",\n                  \"typed_config\": {\n                    \"@type\": \"type.googleapis.com/envoy.extensions.transport_sockets.tls.v3.DownstreamTlsContext\",\n                    \"common_tls_context\": {\n                      \"tls_certificate_sds_secret_configs\": [\n                        {\n                          \"name\": \"example.default.svc\",\n                          \"sds_config\": {\n                            \"ads\": {},\n                            \"resource_api_version\": \"V3\"\n                          }\n                        }\n                      ]\n                    }\n                  }\n                }\n              }\n            ],\n            \"name\": \"https\"\n          }\n        },\n        {\n          \"blueprint\": \"tlsCertificate\",\n          \"generateFromTlsSecret\": \"example.default.svc\",\n          \"type\": \"secret\"\n        }\n      ]\n    }\n  },\n  {\n    \"apiVersion\": \"operator.marin3r.3scale.net/v1alpha1\",\n    \"kind\": \"DiscoveryService\",\n    \"metadata\": {\n      \"name\": \"discoveryservice-example\",\n      \"namespace\": \"my-namespace\"\n    },\n    \"spec\": {}\n  },\n  {\n    \"apiVersion\": \"operator.marin3r.3scale.net/v1alpha1\",\n    \"kind\": \"EnvoyDeployment\",\n    \"metadata\": {\n      \"name\": \"envoydeployment-sample\",\n      \"namespace\": \"my-namespace\"\n    },\n    \"spec\": {\n      \"discoveryServiceRef\": \"discoveryservice-example\",\n      \"envoyConfigRef\": \"envoyconfig-example\",\n      \"ports\": [\n        {\n          \"name\": \"https\",\n          \"port\": 8443\n        }\n      ]\n    }\n  }\n]","capabilities":"Full Lifecycle","categories":"Networking","certified":"false","containerImage":"quay.io/3scale/marin3r","createdAt":"2024-11-08T12:30:05Z","description":"Lighweight, CRD based Envoy control plane for Kubernetes","operators.operatorframework.io/builder":"operator-sdk-v1.28.0","operators.operatorframework.io/internal-objects":"[\"envoyconfigrevisions.marin3r.3scale.net\",\"discoveryservicecertificates.operator.marin3r.3scale.net\"]","operators.operatorframework.io/project_layout":"go.kubebuilder.io/v3","repository":"https://github.com/3scale-ops/marin3r","support":"Red Hat, Inc."},"name":"marin3r.v0.13.2-alpha.2","namespace":"placeholder"},"spec":{"apiservicedefinitions":{},"customresourcedefinitions":{"owned":[{"description":"DiscoveryServiceCertificate is an internal resource used to create certificates. This resource is used by the DiscoveryService controller to create the required certificates for the different components. Direct use of DiscoveryServiceCertificate objects is discouraged.","displayName":"DiscoveryServiceCertificate","kind":"DiscoveryServiceCertificate","name":"discoveryservicecertificates.operator.marin3r.3scale.net","specDescriptors":[{"description":"CertificateRenewalConfig configures the certificate renewal process. If unset default behavior is to renew the certificate but not notify of renewals.","displayName":"Certificate Renewal Config","path":"certificateRenewal"},{"description":"Enabled is a flag to enable or disable renewal of the certificate","displayName":"Enabled","path":"certificateRenewal.enabled"},{"description":"CommonName is the CommonName of the certificate","displayName":"Common Name","path":"commonName"},{"description":"Hosts is the list of hosts the certificate is valid for. Only use when 'IsServerCertificate' is true. If unset, the CommonName field will be used to populate the valid hosts of the certificate.","displayName":"Hosts","path":"hosts"},{"description":"IsCA is a boolean specifying that the certificate is a CA","displayName":"Is CA","path":"isCA"},{"description":"SecretRef is a reference to the secret that will hold the certificate and the private key.","displayName":"Secret Ref","path":"secretRef"},{"description":"IsServerCertificate is a boolean specifying if the certificate should be issued with server auth usage enabled","displayName":"Is Server Certificate","path":"server"},{"description":"Signer specifies  the signer to use to create this certificate. Supported signers are CertManager and SelfSigned.","displayName":"Signer","path":"signer"},{"description":"CASigned holds specific configuration for the CASigned signer","displayName":"CASigned","path":"signer.caSigned"},{"description":"A reference to a Secret containing the CA","displayName":"Secret Ref","path":"signer.caSigned.caSecretRef"},{"description":"SelfSigned holds specific configuration for the SelfSigned signer","displayName":"Self Signed","path":"signer.selfSigned"},{"description":"ValidFor specifies the validity of the certificate in seconds","displayName":"Valid For","path":"validFor"}],"statusDescriptors":[{"description":"CertificateHash stores the current hash of the certificate. It is used for other controllers to validate if a certificate has been re-issued.","displayName":"Certificate Hash","path":"certificateHash"},{"description":"Conditions represent the latest available observations of an object's state","displayName":"Conditions","path":"conditions"},{"description":"NotAfter is the time at which the certificate expires","displayName":"Not After","path":"notAfter"},{"description":"NotBefore is the time at which the certificate starts being valid","displayName":"Not Before","path":"notBefore"},{"description":"Ready is a boolean that specifies if the certificate is ready to be used","displayName":"Ready","path":"ready"}],"version":"v1alpha1"},{"description":"DiscoveryService represents an envoy discovery service server. Only one instance per namespace is currently supported.","displayName":"DiscoveryService","kind":"DiscoveryService","name":"discoveryservices.operator.marin3r.3scale.net","specDescriptors":[{"description":"Debug enables debugging log level for the discovery service controllers. It is safe to use since secret data is never shown in the logs.","displayName":"Debug","path":"debug"},{"description":"Image holds the image to use for the discovery service Deployment","displayName":"Image","path":"image"},{"description":"MetricsPort is the port where metrics are served. Defaults to 8383.","displayName":"Metrics Port","path":"metricsPort"},{"description":"PKIConfig has configuration for the PKI that marin3r manages for the different certificates it requires","displayName":"PKIConfig","path":"pkiConfg"},{"displayName":"Root Certificate Authority","path":"pkiConfg.rootCertificateAuthority"},{"displayName":"Duration","path":"pkiConfg.rootCertificateAuthority.duration"},{"displayName":"Secret Name","path":"pkiConfg.rootCertificateAuthority.secretName"},{"displayName":"Server Certificate","path":"pkiConfg.serverCertificate"},{"displayName":"Duration","path":"pkiConfg.serverCertificate.duration"},{"displayName":"Secret Name","path":"pkiConfg.serverCertificate.secretName"},{"description":"PriorityClass to assign the discovery service Pod to","displayName":"Pod Priority Class","path":"podPriorityClass"},{"description":"ProbePort is the port where healthz endpoint is served. Defaults to 8384.","displayName":"Probe Port","path":"probePort"},{"description":"Resources holds the Resource Requirements to use for the discovery service Deployment. When not set it defaults to no resource requests nor limits. CPU and Memory resources are supported.","displayName":"Resources","path":"resources"},{"description":"ServiceConfig configures the way the DiscoveryService endpoints are exposed","displayName":"Service Config","path":"serviceConfig"},{"displayName":"Name","path":"serviceConfig.name"},{"displayName":"Type","path":"serviceConfig.type"},{"description":"XdsServerPort is the port where the xDS server listens. Defaults to 18000.","displayName":"Xds Server Port","path":"xdsServerPort"}],"version":"v1alpha1"},{"description":"EnvoyConfigRevision is an internal resource that stores a specific version of an EnvoyConfig resource. EnvoyConfigRevisions are automatically created and deleted by the EnvoyConfig controller and are not intended to be directly used. Use EnvoyConfig objects instead.","displayName":"EnvoyConfigRevision","kind":"EnvoyConfigRevision","name":"envoyconfigrevisions.marin3r.3scale.net","specDescriptors":[{"description":"EnvoyAPI is the version of envoy's API to use. Defaults to v3.","displayName":"Envoy API","path":"envoyAPI"},{"description":"EnvoyResources holds the different types of resources suported by the envoy discovery service","displayName":"Envoy Resources","path":"envoyResources"},{"description":"Clusters is a list of the envoy Cluster resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/cluster/v3/cluster.proto","displayName":"Clusters","path":"envoyResources.clusters"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.clusters[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.clusters[0].value"},{"description":"Endpoints is a list of the envoy ClusterLoadAssignment resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/endpoint/v3/endpoint.proto","displayName":"Endpoints","path":"envoyResources.endpoints"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.endpoints[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.endpoints[0].value"},{"description":"ExtensionConfigs is a list of the envoy ExtensionConfig resource type API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/core/v3/extension.proto","displayName":"Extension Configs","path":"envoyResources.extensionConfigs"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.extensionConfigs[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.extensionConfigs[0].value"},{"description":"Listeners is a list of the envoy Listener resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/listener/v3/listener.proto","displayName":"Listeners","path":"envoyResources.listeners"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.listeners[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.listeners[0].value"},{"description":"Routes is a list of the envoy Route resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/route/v3/route.proto","displayName":"Routes","path":"envoyResources.routes"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.routes[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.routes[0].value"},{"description":"Runtimes is a list of the envoy Runtime resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/service/runtime/v3/rtds.proto","displayName":"Runtimes","path":"envoyResources.runtimes"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.runtimes[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.runtimes[0].value"},{"description":"ScopedRoutes is a list of the envoy ScopeRoute resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/route/v3/scoped_route.proto","displayName":"Scoped Routes","path":"envoyResources.scopedRoutes"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.scopedRoutes[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.scopedRoutes[0].value"},{"description":"Secrets is a list of references to Kubernetes Secret objects.","displayName":"Secrets","path":"envoyResources.secrets"},{"description":"Name of the envoy tslCerticate secret resource. The certificate will be fetched from a Kubernetes Secrets of type 'kubernetes.io/tls' with this same name.","displayName":"Name","path":"envoyResources.secrets[0].name"},{"description":"DEPRECATED: this field is deprecated and it's value will be ignored. The 'name' of the Kubernetes Secret must match the 'name' field.","displayName":"Ref","path":"envoyResources.secrets[0].ref","x-descriptors":["urn:alm:descriptor:io.kubernetes:SecretReference"]},{"description":"NodeID holds the envoy identifier for the discovery service to know which set of resources to send to each of the envoy clients that connect to it.","displayName":"Node ID","path":"nodeID"},{"description":"Resources holds the different types of resources suported by the envoy discovery service","displayName":"Resources","path":"resources"},{"description":"Blueprint specifies a template to generate a configuration proto. It is currently only supported to generate secret configuration resources from k8s Secrets","displayName":"Blueprint","path":"resources[0].blueprint"},{"description":"Specifies a label selector to watch for EndpointSlices that will be used to generate the endpoint resource","displayName":"Generate From Endpoint Slices","path":"resources[0].generateFromEndpointSlices"},{"description":"The name of a Kubernetes Secret of type \"Opaque\". It will generate an envoy \"generic secret\" proto.","displayName":"Generate From Opaque Secret","path":"resources[0].generateFromOpaqueSecret"},{"description":"The name of a Kubernetes Secret of type \"kubernetes.io/tls\"","displayName":"Generate From Tls Secret","path":"resources[0].generateFromTlsSecret"},{"description":"Type is the type url for the protobuf message","displayName":"Type","path":"resources[0].type"},{"description":"Value is the protobufer message that configures the resource. The proto must match the envoy configuration API v3 specification for the given resource type (https://www.envoyproxy.io/docs/envoy/latest/api-docs/xds_protocol#resource-types)","displayName":"Value","path":"resources[0].value"},{"description":"Serialization specicifies the serialization format used to describe the resources. \"json\" and \"yaml\" are supported. \"json\" is used if unset.","displayName":"Serialization","path":"serialization"},{"description":"Version is a hash of the EnvoyResources field","displayName":"Version","path":"version"}],"statusDescriptors":[{"description":"Conditions represent the latest available observations of an object's state","displayName":"Conditions","path":"conditions"},{"description":"LastPublishedAt indicates the last time this config review transitioned to published","displayName":"Last Published At","path":"lastPublishedAt"},{"description":"ProvidesVersions keeps track of the version that this revision publishes in the xDS server for each resource type","displayName":"Provides Versions","path":"providesVersions"},{"description":"Published signals if the EnvoyConfigRevision is the one currently published in the xds server cache","displayName":"Published","path":"published"},{"description":"Tainted indicates whether the EnvoyConfigRevision is eligible for publishing or not","displayName":"Tainted","path":"tainted"}],"version":"v1alpha1"},{"description":"EnvoyConfig holds the configuration for a given envoy nodeID. The spec of an EnvoyConfig object holds the Envoy resources that conform the desired configuration for the given nodeID and that the discovery service will send to any envoy client that identifies itself with that nodeID.","displayName":"EnvoyConfig","kind":"EnvoyConfig","name":"envoyconfigs.marin3r.3scale.net","resources":[{"kind":"EnvoyConfigRevision","name":"","version":"v1alpha1"}],"specDescriptors":[{"description":"EnvoyAPI is the version of envoy's API to use. Defaults to v3.","displayName":"Envoy API","path":"envoyAPI"},{"description":"EnvoyResources holds the different types of resources suported by the envoy discovery service DEPRECATED. Use the `resources` field instead.","displayName":"Envoy Resources","path":"envoyResources"},{"description":"Clusters is a list of the envoy Cluster resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/cluster/v3/cluster.proto","displayName":"Clusters","path":"envoyResources.clusters"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.clusters[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.clusters[0].value"},{"description":"Endpoints is a list of the envoy ClusterLoadAssignment resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/endpoint/v3/endpoint.proto","displayName":"Endpoints","path":"envoyResources.endpoints"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.endpoints[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.endpoints[0].value"},{"description":"ExtensionConfigs is a list of the envoy ExtensionConfig resource type API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/core/v3/extension.proto","displayName":"Extension Configs","path":"envoyResources.extensionConfigs"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.extensionConfigs[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.extensionConfigs[0].value"},{"description":"Listeners is a list of the envoy Listener resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/listener/v3/listener.proto","displayName":"Listeners","path":"envoyResources.listeners"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.listeners[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.listeners[0].value"},{"description":"Routes is a list of the envoy Route resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/route/v3/route.proto","displayName":"Routes","path":"envoyResources.routes"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.routes[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.routes[0].value"},{"description":"Runtimes is a list of the envoy Runtime resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/service/runtime/v3/rtds.proto","displayName":"Runtimes","path":"envoyResources.runtimes"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.runtimes[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.runtimes[0].value"},{"description":"ScopedRoutes is a list of the envoy ScopeRoute resource type. API V3 reference: https://www.envoyproxy.io/docs/envoy/latest/api-v3/config/route/v3/scoped_route.proto","displayName":"Scoped Routes","path":"envoyResources.scopedRoutes"},{"description":"Name of the envoy resource. DEPRECATED: this field has no effect and will be removed in an upcoming release. The name of the resources for discovery purposes is included in the resource itself. Refer to the envoy API reference to check how the name is specified for each resource type.","displayName":"Name","path":"envoyResources.scopedRoutes[0].name"},{"description":"Value is the serialized representation of the envoy resource","displayName":"Value","path":"envoyResources.scopedRoutes[0].value"},{"description":"Secrets is a list of references to Kubernetes Secret objects.","displayName":"Secrets","path":"envoyResources.secrets"},{"description":"Name of the envoy tslCerticate secret resource. The certificate will be fetched from a Kubernetes Secrets of type 'kubernetes.io/tls' with this same name.","displayName":"Name","path":"envoyResources.secrets[0].name"},{"description":"DEPRECATED: this field is deprecated and it's value will be ignored. The 'name' of the Kubernetes Secret must match the 'name' field.","displayName":"Ref","path":"envoyResources.secrets[0].ref","x-descriptors":["urn:alm:descriptor:io.kubernetes:SecretReference"]},{"description":"NodeID holds the envoy identifier for the discovery service to know which set of resources to send to each of the envoy clients that connect to it.","displayName":"Node ID","path":"nodeID"},{"description":"Resources holds the different types of resources suported by the envoy discovery service","displayName":"Resources","path":"resources"},{"description":"Blueprint specifies a template to generate a configuration proto. It is currently only supported to generate secret configuration resources from k8s Secrets","displayName":"Blueprint","path":"resources[0].blueprint"},{"description":"Specifies a label selector to watch for EndpointSlices that will be used to generate the endpoint resource","displayName":"Generate From Endpoint Slices","path":"resources[0].generateFromEndpointSlices"},{"description":"The name of a Kubernetes Secret of type \"Opaque\". It will generate an envoy \"generic secret\" proto.","displayName":"Generate From Opaque Secret","path":"resources[0].generateFromOpaqueSecret"},{"description":"The name of a Kubernetes Secret of type \"kubernetes.io/tls\"","displayName":"Generate From Tls Secret","path":"resources[0].generateFromTlsSecret"},{"description":"Type is the type url for the protobuf message","displayName":"Type","path":"resources[0].type"},{"description":"Value is the protobufer message that configures the resource. The proto must match the envoy configuration API v3 specification for the given resource type (https://www.envoyproxy.io/docs/envoy/latest/api-docs/xds_protocol#resource-types)","displayName":"Value","path":"resources[0].value"},{"description":"Serialization specicifies the serialization format used to describe the resources. \"json\" and \"yaml\" are supported. \"json\" is used if unset.","displayName":"Serialization","path":"serialization"}],"statusDescriptors":[{"description":"CacheState summarizes all the observations about the EnvoyConfig to give the user a concrete idea on the general status of the discovery servie cache. It is intended only for human consumption. Other controllers should relly on conditions to determine the status of the discovery server cache.","displayName":"Cache State","path":"cacheState"},{"description":"Conditions represent the latest available observations of an object's state","displayName":"Conditions","path":"conditions"},{"description":"DesiredVersion represents the resources version described in the spec of the EnvoyConfig object","displayName":"Desired Version","path":"desiredVersion"},{"description":"PublishedVersion is the config version currently served by the envoy discovery service for the give nodeID","displayName":"Published Version","path":"publishedVersion"},{"description":"ConfigRevisions is an ordered list of references to EnvoyConfigRevision objects","displayName":"Config Revisions","path":"revisions"},{"description":"Ref is a reference to the EnvoyConfigRevision object that holds the configuration matching the Version field.","displayName":"Ref","path":"revisions[0].ref"},{"description":"Version is a hash of the EnvoyResources field","displayName":"Version","path":"revisions[0].version"}],"version":"v1alpha1"},{"description":"EnvoyDeployment is a resource to deploy and manage a Kubernetes Deployment of Envoy Pods.","displayName":"EnvoyDeployment","kind":"EnvoyDeployment","name":"envoydeployments.operator.marin3r.3scale.net","specDescriptors":[{"description":"Configures envoy's admin access log path. Defaults to /dev/null.","displayName":"Admin Access Log Path","path":"adminAccessLogPath"},{"description":"Configures envoy's admin port. Defaults to 9901.","displayName":"Admin Port","path":"adminPort"},{"description":"Affinity configuration for the envoy pods","displayName":"Affinity","path":"affinity"},{"description":"Defines the local service cluster name where Envoy is running. Defaults to the NodeID in the EnvoyConfig if unset","displayName":"Cluster ID","path":"clusterID"},{"description":"DiscoveryServiceRef points to a DiscoveryService in the same namespace","displayName":"Discovery Service Ref","path":"discoveryServiceRef"},{"description":"Defines the duration of the client certificate that is used to authenticate with the DiscoveryService","displayName":"Client Certificate Duration","path":"duration"},{"description":"EnvoyConfigRef points to an EnvoyConfig in the same namespace that holds the envoy resources for this Deployment","displayName":"Envoy Config Ref","path":"envoyConfigRef"},{"description":"Allows the user to define extra command line arguments for the Envoy process","displayName":"Extra Args","path":"extraArgs"},{"description":"Image is the envoy image and tag to use","displayName":"Image","path":"image"},{"description":"InitManager defines configuration for Envoy's init manager, which handles initialization for Envoy pods","displayName":"Init Manager","path":"initManager"},{"description":"Image is the init manager image and tag to use","displayName":"Image","path":"initManager.image"},{"description":"Liveness probe for the envoy pods","displayName":"Liveness Probe","path":"livenessProbe"},{"description":"Minimum consecutive failures for the probe to be considered failed after having succeeded","displayName":"Failure Threshold","path":"livenessProbe.failureThreshold"},{"description":"Number of seconds after the container has started before liveness probes are initiated","displayName":"Initial Delay Seconds","path":"livenessProbe.initialDelaySeconds"},{"description":"How often (in seconds) to perform the probe","displayName":"Period Seconds","path":"livenessProbe.periodSeconds"},{"description":"Minimum consecutive successes for the probe to be considered successful after having failed","displayName":"Success Threshold","path":"livenessProbe.successThreshold"},{"description":"Number of seconds after which the probe times out","displayName":"Timeout Seconds","path":"livenessProbe.timeoutSeconds"},{"description":"Configures PodDisruptionBudget for the envoy Pods","displayName":"Pod Disruption Budget","path":"podDisruptionBudget"},{"description":"An eviction is allowed if at most \"maxUnavailable\" pods selected by \"selector\" are unavailable after the eviction, i.e. even in absence of the evicted pod. For example, one can prevent all voluntary evictions by specifying 0. This is a mutually exclusive setting with \"minAvailable\".","displayName":"Max Unavailable","path":"podDisruptionBudget.maxUnavailable"},{"description":"An eviction is allowed if at least \"minAvailable\" pods selected by \"selector\" will still be available after the eviction, i.e. even in the absence of the evicted pod.  So for example you can prevent all voluntary evictions by specifying \"100%\".","displayName":"Min Available","path":"podDisruptionBudget.minAvailable"},{"description":"Ports exposed by the Envoy container","displayName":"Ports","path":"ports"},{"description":"Port name","displayName":"Name","path":"ports[0].name"},{"description":"Port value","displayName":"Port","path":"ports[0].port"},{"description":"Protocol. Defaults to TCP.","displayName":"Protocol","path":"ports[0].protocol"},{"description":"Readiness probe for the envoy pods","displayName":"Readiness Probe","path":"readinessProbe"},{"description":"Minimum consecutive failures for the probe to be considered failed after having succeeded","displayName":"Failure Threshold","path":"readinessProbe.failureThreshold"},{"description":"Number of seconds after the container has started before liveness probes are initiated","displayName":"Initial Delay Seconds","path":"readinessProbe.initialDelaySeconds"},{"description":"How often (in seconds) to perform the probe","displayName":"Period Seconds","path":"readinessProbe.periodSeconds"},{"description":"Minimum consecutive successes for the probe to be considered successful after having failed","displayName":"Success Threshold","path":"readinessProbe.successThreshold"},{"description":"Number of seconds after which the probe times out","displayName":"Timeout Seconds","path":"readinessProbe.timeoutSeconds"},{"description":"Replicas configures the number of replicas in the Deployment. One of 'static', 'dynamic' can be set. If both are set, static has precedence.","displayName":"Replicas","path":"replicas"},{"description":"Configure a min and max value for the number of pods to autoscale dynamically.","displayName":"Dynamic","path":"replicas.dynamic"},{"description":"behavior configures the scaling behavior of the target in both Up and Down directions (scaleUp and scaleDown fields respectively). If not set, the default HPAScalingRules for scale up and scale down are used.","displayName":"Behavior","path":"replicas.dynamic.behavior"},{"description":"metrics contains the specifications for which to use to calculate the desired replica count (the maximum replica count across all metrics will be used).  The desired replica count is calculated multiplying the ratio between the target value and the current value by the current number of pods.  Ergo, metrics used must decrease as the pod count is increased, and vice-versa.  See the individual metric source types for more information about how each type of metric must respond. If not set, the default metric will be set to 80% average CPU utilization.","displayName":"Metrics","path":"replicas.dynamic.metrics"},{"description":"minReplicas is the lower limit for the number of replicas to which the autoscaler can scale down.  It defaults to 1 pod.  minReplicas is allowed to be 0 if the alpha feature gate HPAScaleToZero is enabled and at least one Object or External metric is configured.  Scaling is active as long as at least one metric value is available.","displayName":"Min Replicas","path":"replicas.dynamic.minReplicas"},{"description":"Configure a static number of replicas. Defaults to 1.","displayName":"Static","path":"replicas.static"},{"description":"Resources holds the resource requirements to use for the Envoy Deployment. Defaults to no resource requests nor limits.","displayName":"Resources","path":"resources"},{"description":"ShutdownManager defines configuration for Envoy's shutdown manager, which handles graceful termination of Envoy pods","displayName":"Shutdown Manager","path":"shutdownManager"},{"description":"The drain strategy for the graceful shutdown. It also affects drain when listeners are modified or removed via LDS.","displayName":"Drain Strategy","path":"shutdownManager.drainStrategy"},{"description":"The time in seconds that Envoy will drain connections during shutdown. It also affects drain behaviour when listeners are modified or removed via LDS.","displayName":"Drain Time","path":"shutdownManager.drainTime"},{"description":"Image is the shutdown manager image and tag to use","displayName":"Image","path":"shutdownManager.image"},{"description":"Configures the sutdown manager's server port. Defaults to 8090.","displayName":"Server Port","path":"shutdownManager.serverPort"}],"version":"v1alpha1"}]},"description":"MARIN3R implements a control plane to deploy, configure and operate a fleet of envoy instances within a Kubernetes cluster.\nIt operates a group of gateways and Pod sidecar containers to provide general purpose functionality required to operate production systems.\n\nFeatures:\n\n* Deploy and manage an Envoy xDS server using the DiscoveryService custom resource.\n* Inject Envoy sidecar containers based on Pod annotations.\n* Deploy Envoy as a Kubernetes Deployment using the EnvoyDeployment custom resource.\n* Dynamic Envoy configuration and re-configuration using the EnvoyConfig custom resource.\n* Use Kubernetes Secrets as certificate sources.\n* Syntactic validation of Envoy configurations.\n* Lifecycle management of Envoy containers (graceful shutdown and connection draining).\n* Self-healing.\n\nCheck the [docs](https://github.com/3scale-ops/marin3r#readme) for more information.\n\n## License\nMARIN3R is licensed under the [Apache 2.0 license](https://github.com/3scale/prometheus-exporter-operator/blob/master/LICENSE)\n","displayName":"MARIN3R","icon":[{"base64data":"<?xml version="1.0" encoding="UTF-8"?>
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="375pt" height="374.999991pt" viewBox="0 0 375 374.999991" version="1.2">
<defs>
<g>
<symbol overflow="visible" id="glyph0-0">
<path style="stroke:none;" d=""/>
</symbol>
<symbol overflow="visible" id="glyph0-1">
<path style="stroke:none;" d="M 95.953125 0 L 85.890625 0 L 85.890625 -42.796875 L 54.984375 0 L 49.8125 0 L 18.90625 -42.796875 L 18.90625 0 L 8.828125 0 L 8.828125 -63.328125 L 16.421875 -63.328125 L 52.421875 -13.59375 L 88.359375 -63.328125 L 95.953125 -63.328125 Z M 95.953125 0 "/>
</symbol>
<symbol overflow="visible" id="glyph0-2">
<path style="stroke:none;" d="M 61.953125 0 L 6.625 0 L 6.625 -10.0625 L 61.953125 -10.0625 C 63.335938 -10.0625 64.519531 -10.554688 65.5 -11.546875 C 66.488281 -12.535156 66.984375 -13.722656 66.984375 -15.109375 L 66.984375 -21.59375 C 66.984375 -22.976562 66.507812 -24.148438 65.5625 -25.109375 C 64.625 -26.066406 63.46875 -26.570312 62.09375 -26.625 L 16.6875 -26.625 L 16.6875 -36.703125 L 62.09375 -36.703125 C 63.46875 -36.753906 64.625 -37.257812 65.5625 -38.21875 C 66.507812 -39.175781 66.984375 -40.347656 66.984375 -41.734375 L 66.984375 -48.265625 C 66.984375 -49.648438 66.488281 -50.828125 65.5 -51.796875 C 64.519531 -52.765625 63.335938 -53.25 61.953125 -53.25 L 6.625 -53.25 L 6.625 -63.328125 L 61.953125 -63.328125 C 66.109375 -63.328125 69.664062 -61.851562 72.625 -58.90625 C 75.582031 -55.957031 77.0625 -52.410156 77.0625 -48.265625 L 77.0625 -41.734375 C 77.0625 -37.878906 75.78125 -34.519531 73.21875 -31.65625 C 75.78125 -28.832031 77.0625 -25.476562 77.0625 -21.59375 L 77.0625 -15.109375 C 77.0625 -10.921875 75.582031 -7.351562 72.625 -4.40625 C 69.664062 -1.46875 66.109375 0 61.953125 0 Z M 61.953125 0 "/>
</symbol>
<symbol overflow="visible" id="glyph0-3">
<path style="stroke:none;" d="M 84.296875 0 L 74.234375 0 L 74.234375 -17.84375 C 74.234375 -19.226562 73.738281 -20.410156 72.75 -21.390625 C 71.757812 -22.378906 70.578125 -22.875 69.203125 -22.875 L 18.90625 -22.875 L 18.90625 0 L 8.828125 0 L 8.828125 -63.328125 L 69.203125 -63.328125 C 73.347656 -63.328125 76.898438 -61.851562 79.859375 -58.90625 C 82.816406 -55.957031 84.296875 -52.410156 84.296875 -48.265625 L 84.296875 -37.984375 C 84.296875 -34.085938 83 -30.726562 80.40625 -27.90625 C 83 -25.050781 84.296875 -21.695312 84.296875 -17.84375 Z M 69.203125 -32.9375 C 70.578125 -32.9375 71.757812 -33.429688 72.75 -34.421875 C 73.738281 -35.410156 74.234375 -36.597656 74.234375 -37.984375 L 74.234375 -48.265625 C 74.234375 -49.648438 73.738281 -50.832031 72.75 -51.8125 C 71.757812 -52.800781 70.578125 -53.296875 69.203125 -53.296875 L 18.90625 -53.296875 L 18.90625 -32.9375 Z M 69.203125 -32.9375 "/>
</symbol>
</g>
</defs>
<g id="surface1">
<rect x="0" y="0" width="375" height="374.999991" style="fill:rgb(100%,100%,100%);fill-opacity:1;stroke:none;"/>
<rect x="0" y="0" width="375" height="374.999991" style="fill:rgb(100%,100%,100%);fill-opacity:1;stroke:none;"/>
<rect x="0" y="0" width="375" height="374.999991" style="fill:rgb(100%,100%,100%);fill-opacity:1;stroke:none;"/>
<path style=" stroke:none;fill-rule:nonzero;fill:rgb(0%,0%,0%);fill-opacity:1;" d="M 187.5 19.328125 C 184.746094 19.328125 181.996094 19.398438 179.25 19.53125 C 176.5 19.667969 173.753906 19.871094 171.015625 20.140625 C 168.277344 20.410156 165.546875 20.746094 162.824219 21.148438 C 160.101562 21.554688 157.390625 22.023438 154.691406 22.5625 C 151.992188 23.097656 149.308594 23.699219 146.636719 24.371094 C 143.96875 25.039062 141.316406 25.773438 138.683594 26.570312 C 136.050781 27.371094 133.4375 28.234375 130.84375 29.160156 C 128.253906 30.085938 125.6875 31.078125 123.144531 32.132812 C 120.601562 33.183594 118.085938 34.300781 115.597656 35.476562 C 113.109375 36.652344 110.652344 37.890625 108.226562 39.1875 C 105.796875 40.484375 103.402344 41.839844 101.042969 43.253906 C 98.683594 44.671875 96.359375 46.144531 94.070312 47.671875 C 91.78125 49.199219 89.53125 50.785156 87.320312 52.425781 C 85.109375 54.0625 82.941406 55.757812 80.8125 57.503906 C 78.6875 59.25 76.601562 61.046875 74.5625 62.894531 C 72.523438 64.742188 70.53125 66.640625 68.585938 68.585938 C 66.640625 70.53125 64.742188 72.523438 62.894531 74.5625 C 61.046875 76.601562 59.25 78.6875 57.503906 80.8125 C 55.757812 82.941406 54.0625 85.109375 52.425781 87.320312 C 50.785156 89.53125 49.199219 91.78125 47.671875 94.070312 C 46.144531 96.359375 44.671875 98.683594 43.253906 101.042969 C 41.839844 103.402344 40.484375 105.796875 39.1875 108.226562 C 37.890625 110.652344 36.652344 113.109375 35.476562 115.597656 C 34.300781 118.085938 33.183594 120.601562 32.132812 123.144531 C 31.078125 125.6875 30.085938 128.253906 29.160156 130.84375 C 28.234375 133.4375 27.371094 136.050781 26.570312 138.683594 C 25.773438 141.316406 25.039062 143.96875 24.371094 146.636719 C 23.699219 149.308594 23.097656 151.992188 22.5625 154.691406 C 22.023438 157.390625 21.554688 160.101562 21.148438 162.824219 C 20.746094 165.546875 20.410156 168.277344 20.140625 171.015625 C 19.871094 173.753906 19.667969 176.5 19.53125 179.25 C 19.398438 181.996094 19.328125 184.746094 19.328125 187.5 C 19.328125 190.253906 19.398438 193.003906 19.53125 195.75 C 19.667969 198.5 19.871094 201.246094 20.140625 203.984375 C 20.410156 206.722656 20.746094 209.453125 21.148438 212.175781 C 21.554688 214.898438 22.023438 217.609375 22.5625 220.308594 C 23.097656 223.007812 23.699219 225.691406 24.371094 228.363281 C 25.039062 231.03125 25.773438 233.683594 26.570312 236.316406 C 27.371094 238.949219 28.234375 241.5625 29.160156 244.15625 C 30.085938 246.746094 31.078125 249.3125 32.132812 251.855469 C 33.183594 254.398438 34.300781 256.914062 35.476562 259.402344 C 36.652344 261.890625 37.890625 264.347656 39.1875 266.773438 C 40.484375 269.203125 41.839844 271.597656 43.253906 273.957031 C 44.671875 276.316406 46.144531 278.640625 47.671875 280.929688 C 49.199219 283.21875 50.785156 285.46875 52.425781 287.679688 C 54.0625 289.890625 55.757812 292.058594 57.503906 294.1875 C 59.25 296.3125 61.046875 298.398438 62.894531 300.4375 C 64.742188 302.476562 66.640625 304.46875 68.585938 306.414062 C 70.53125 308.359375 72.523438 310.257812 74.5625 312.105469 C 76.601562 313.953125 78.6875 315.75 80.8125 317.496094 C 82.941406 319.242188 85.109375 320.9375 87.320312 322.574219 C 89.53125 324.214844 91.78125 325.800781 94.070312 327.328125 C 96.359375 328.855469 98.683594 330.328125 101.042969 331.746094 C 103.402344 333.160156 105.796875 334.515625 108.226562 335.8125 C 110.652344 337.109375 113.109375 338.347656 115.597656 339.523438 C 118.085938 340.699219 120.601562 341.816406 123.144531 342.867188 C 125.6875 343.921875 128.253906 344.914062 130.84375 345.839844 C 133.4375 346.765625 136.050781 347.628906 138.683594 348.429688 C 141.316406 349.226562 143.96875 349.960938 146.636719 350.628906 C 149.308594 351.300781 151.992188 351.902344 154.691406 352.4375 C 157.390625 352.976562 160.101562 353.445312 162.824219 353.851562 C 165.546875 354.253906 168.277344 354.589844 171.015625 354.859375 C 173.753906 355.128906 176.5 355.332031 179.25 355.46875 C 181.996094 355.601562 184.746094 355.671875 187.5 355.671875 C 190.253906 355.671875 193.003906 355.601562 195.75 355.46875 C 198.5 355.332031 201.246094 355.128906 203.984375 354.859375 C 206.722656 354.589844 209.453125 354.253906 212.175781 353.851562 C 214.898438 353.445312 217.609375 352.976562 220.308594 352.4375 C 223.007812 351.902344 225.691406 351.300781 228.363281 350.628906 C 231.03125 349.960938 233.683594 349.226562 236.316406 348.429688 C 238.949219 347.628906 241.5625 346.765625 244.15625 345.839844 C 246.746094 344.914062 249.3125 343.921875 251.855469 342.867188 C 254.398438 341.816406 256.914062 340.699219 259.402344 339.523438 C 261.890625 338.347656 264.347656 337.109375 266.773438 335.8125 C 269.203125 334.515625 271.597656 333.160156 273.957031 331.746094 C 276.316406 330.328125 278.640625 328.855469 280.929688 327.328125 C 283.21875 325.800781 285.46875 324.214844 287.679688 322.574219 C 289.890625 320.9375 292.058594 319.242188 294.1875 317.496094 C 296.3125 315.75 298.398438 313.953125 300.4375 312.105469 C 302.476562 310.257812 304.46875 308.359375 306.414062 306.414062 C 308.359375 304.46875 310.257812 302.476562 312.105469 300.4375 C 313.953125 298.398438 315.75 296.3125 317.496094 294.1875 C 319.242188 292.058594 320.9375 289.890625 322.574219 287.679688 C 324.214844 285.46875 325.800781 283.21875 327.328125 280.929688 C 328.855469 278.640625 330.328125 276.316406 331.746094 273.957031 C 333.160156 271.597656 334.515625 269.203125 335.8125 266.773438 C 337.109375 264.347656 338.347656 261.890625 339.523438 259.402344 C 340.699219 256.914062 341.816406 254.398438 342.867188 251.855469 C 343.921875 249.3125 344.914062 246.746094 345.839844 244.15625 C 346.765625 241.5625 347.628906 238.949219 348.429688 236.316406 C 349.226562 233.683594 349.960938 231.03125 350.628906 228.363281 C 351.300781 225.691406 351.902344 223.007812 352.4375 220.308594 C 352.976562 217.609375 353.445312 214.898438 353.851562 212.175781 C 354.253906 209.453125 354.589844 206.722656 354.859375 203.984375 C 355.128906 201.246094 355.332031 198.5 355.46875 195.75 C 355.601562 193.003906 355.671875 190.253906 355.671875 187.5 C 355.671875 184.746094 355.601562 181.996094 355.46875 179.25 C 355.332031 176.5 355.128906 173.753906 354.859375 171.015625 C 354.589844 168.277344 354.253906 165.546875 353.851562 162.824219 C 353.445312 160.101562 352.976562 157.390625 352.4375 154.691406 C 351.902344 151.992188 351.300781 149.308594 350.628906 146.636719 C 349.960938 143.96875 349.226562 141.316406 348.429688 138.683594 C 347.628906 136.050781 346.765625 133.4375 345.839844 130.84375 C 344.914062 128.253906 343.921875 125.6875 342.867188 123.144531 C 341.816406 120.601562 340.699219 118.085938 339.523438 115.597656 C 338.347656 113.109375 337.109375 110.652344 335.8125 108.226562 C 334.515625 105.796875 333.160156 103.402344 331.746094 101.042969 C 330.328125 98.683594 328.855469 96.359375 327.328125 94.070312 C 325.800781 91.78125 324.214844 89.53125 322.574219 87.320312 C 320.9375 85.109375 319.242188 82.941406 317.496094 80.8125 C 315.75 78.6875 313.953125 76.601562 312.105469 74.5625 C 310.257812 72.523438 308.359375 70.53125 306.414062 68.585938 C 304.46875 66.640625 302.476562 64.742188 300.4375 62.894531 C 298.398438 61.046875 296.3125 59.25 294.1875 57.503906 C 292.058594 55.757812 289.890625 54.0625 287.679688 52.425781 C 285.46875 50.785156 283.21875 49.199219 280.929688 47.671875 C 278.640625 46.144531 276.316406 44.671875 273.957031 43.253906 C 271.597656 41.839844 269.203125 40.484375 266.773438 39.1875 C 264.347656 37.890625 261.890625 36.652344 259.402344 35.476562 C 256.914062 34.300781 254.398438 33.183594 251.855469 32.132812 C 249.3125 31.078125 246.746094 30.085938 244.15625 29.160156 C 241.5625 28.234375 238.949219 27.371094 236.316406 26.570312 C 233.683594 25.773438 231.03125 25.039062 228.363281 24.371094 C 225.691406 23.699219 223.007812 23.097656 220.308594 22.5625 C 217.609375 22.023438 214.898438 21.554688 212.175781 21.148438 C 209.453125 20.746094 206.722656 20.410156 203.984375 20.140625 C 201.246094 19.871094 198.5 19.667969 195.75 19.53125 C 193.003906 19.398438 190.253906 19.328125 187.5 19.328125 Z M 187.5 19.328125 "/>
<g style="fill:rgb(100%,100%,100%);fill-opacity:1;">
  <use xlink:href="#glyph0-1" x="47.846154" y="215.471728"/>
</g>
<g style="fill:rgb(100%,56.858826%,30.198669%);fill-opacity:1;">
  <use xlink:href="#glyph0-2" x="152.603607" y="215.471728"/>
</g>
<g style="fill:rgb(100%,100%,100%);fill-opacity:1;">
  <use xlink:href="#glyph0-3" x="236.245673" y="215.471728"/>
</g>
</g>
</svg>
","mediatype":"image/svg+xml"}],"install":{"spec":{"clusterPermissions":[{"rules":[{"apiGroups":["authentication.k8s.io"],"resources":["tokenreviews"],"verbs":["create"]},{"apiGroups":["authorization.k8s.io"],"resources":["subjectaccessreviews"],"verbs":["create"]}],"serviceAccountName":"marin3r-controller-manager"}],"deployments":[{"label":{"control-plane":"controller-manager"},"name":"marin3r-controller-manager","spec":{"replicas":1,"selector":{"matchLabels":{"control-plane":"controller-manager"}},"strategy":{},"template":{"metadata":{"labels":{"control-plane":"controller-manager"}},"spec":{"containers":[{"args":["operator","--leader-elect"],"command":["/manager"],"env":[{"name":"WATCH_NAMESPACE","valueFrom":{"fieldRef":{"fieldPath":"metadata.annotations['olm.targetNamespaces']"}}}],"image":"quay.io/3scale/marin3r:v0.13.2-alpha.2","livenessProbe":{"httpGet":{"path":"/healthz","port":8081},"initialDelaySeconds":15,"periodSeconds":20},"name":"manager","ports":[{"containerPort":8080,"name":"metrics","protocol":"TCP"}],"readinessProbe":{"httpGet":{"path":"/readyz","port":8081},"initialDelaySeconds":5,"periodSeconds":10},"resources":{"limits":{"cpu":"300m","memory":"300Mi"},"requests":{"cpu":"50m","memory":"100Mi"}},"securityContext":{"allowPrivilegeEscalation":false}}],"securityContext":{"runAsNonRoot":true},"serviceAccountName":"marin3r-controller-manager","terminationGracePeriodSeconds":10}}}},{"label":{"control-plane":"controller-webhook"},"name":"marin3r-controller-webhook","spec":{"replicas":2,"selector":{"matchLabels":{"control-plane":"controller-webhook"}},"strategy":{},"template":{"metadata":{"labels":{"control-plane":"controller-webhook"}},"spec":{"containers":[{"args":["webhook","--tls-dir=/apiserver.local.config/certificates","--tls-cert-name=apiserver.crt","--tls-key-name=apiserver.key"],"command":["/manager"],"env":[{"name":"WATCH_NAMESPACE","valueFrom":{"fieldRef":{"fieldPath":"metadata.annotations['olm.targetNamespaces']"}}}],"image":"quay.io/3scale/marin3r:v0.13.2-alpha.2","livenessProbe":{"httpGet":{"path":"/healthz","port":8081},"initialDelaySeconds":15,"periodSeconds":20},"name":"webhook","ports":[{"containerPort":9443,"name":"webhook-server","protocol":"TCP"}],"readinessProbe":{"httpGet":{"path":"/readyz","port":8081},"initialDelaySeconds":5,"periodSeconds":10},"resources":{"limits":{"cpu":"100m","memory":"100Mi"},"requests":{"cpu":"50m","memory":"30Mi"}},"securityContext":{"allowPrivilegeEscalation":false}}],"serviceAccountName":"marin3r-controller-manager"}}}}],"permissions":[{"rules":[{"apiGroups":[""],"resources":["configmaps"],"verbs":["get","list","watch","create","update","patch","delete"]},{"apiGroups":["coordination.k8s.io"],"resources":["leases"],"verbs":["get","list","watch","create","update","patch","delete"]},{"apiGroups":[""],"resources":["events"],"verbs":["create","patch"]},{"apiGroups":["apps"],"resources":["deployments"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["autoscaling"],"resources":["horizontalpodautoscalers"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":[""],"resources":["pods"],"verbs":["get","list","watch"]},{"apiGroups":[""],"resources":["secrets"],"verbs":["create","get","list","patch","update","watch"]},{"apiGroups":[""],"resources":["serviceaccounts"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":[""],"resources":["services"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["discovery.k8s.io"],"resources":["endpointslices"],"verbs":["get","list","watch"]},{"apiGroups":["marin3r.3scale.net"],"resources":["*"],"verbs":["*"]},{"apiGroups":["marin3r.3scale.net"],"resources":["envoyconfigrevisions"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["marin3r.3scale.net"],"resources":["envoyconfigrevisions/status"],"verbs":["get","patch","update"]},{"apiGroups":["marin3r.3scale.net"],"resources":["envoyconfigs"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["marin3r.3scale.net"],"resources":["envoyconfigs/status"],"verbs":["get","patch","update"]},{"apiGroups":["operator.marin3r.3scale.net"],"resources":["*"],"verbs":["*"]},{"apiGroups":["operator.marin3r.3scale.net"],"resources":["discoveryservicecertificates"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["operator.marin3r.3scale.net"],"resources":["discoveryservicecertificates/status"],"verbs":["get","patch","update"]},{"apiGroups":["operator.marin3r.3scale.net"],"resources":["discoveryservices"],"verbs":["get","list","watch"]},{"apiGroups":["operator.marin3r.3scale.net"],"resources":["envoydeployments"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["operator.marin3r.3scale.net"],"resources":["envoydeployments/finalizers"],"verbs":["update"]},{"apiGroups":["operator.marin3r.3scale.net"],"resources":["envoydeployments/status"],"verbs":["get","patch","update"]},{"apiGroups":["policy"],"resources":["poddisruptionbudgets"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["rbac.authorization.k8s.io"],"resources":["rolebindings"],"verbs":["create","delete","get","list","patch","update","watch"]},{"apiGroups":["rbac.authorization.k8s.io"],"resources":["roles"],"verbs":["create","delete","get","list","patch","update","watch"]}],"serviceAccountName":"marin3r-controller-manager"}]},"strategy":"deployment"},"installModes":[{"supported":true,"type":"OwnNamespace"},{"supported":true,"type":"SingleNamespace"},{"supported":true,"type":"MultiNamespace"},{"supported":true,"type":"AllNamespaces"}],"keywords":["envoy","discovery","controlplane","proxy","sidecar","xds","network","gateway"],"links":[{"name":"GitHub","url":"https://github.com/3scale-ops/marin3r"}],"maintainers":[{"email":"3scale-operations+marin3r@redhat.com","name":"3scale Operations Team"}],"maturity":"alpha","provider":{"name":"Red Hat"},"version":"0.13.2-alpha.2","webhookdefinitions":[{"admissionReviewVersions":["v1"],"containerPort":443,"deploymentName":"marin3r-controller-webhook","failurePolicy":"Fail","generateName":"envoyconfig.marin3r.3scale.net-v1alpha1","rules":[{"apiGroups":["marin3r.3scale.net"],"apiVersions":["v1alpha1"],"operations":["CREATE","UPDATE"],"resources":["envoyconfigs"]}],"sideEffects":"None","targetPort":9443,"type":"ValidatingAdmissionWebhook","webhookPath":"/validate-marin3r-3scale-net-v1alpha1-envoyconfig"},{"admissionReviewVersions":["v1"],"containerPort":443,"deploymentName":"marin3r-controller-webhook","failurePolicy":"Fail","generateName":"envoydeployment.operator.marin3r.3scale.net","rules":[{"apiGroups":["operator.marin3r.3scale.net"],"apiVersions":["v1alpha1"],"operations":["CREATE","UPDATE"],"resources":["envoydeployments"]}],"sideEffects":"None","targetPort":9443,"type":"ValidatingAdmissionWebhook","webhookPath":"/validate-operator-marin3r-3scale-net-v1alpha1-envoydeployment"},{"admissionReviewVersions":["v1"],"containerPort":443,"deploymentName":"marin3r-controller-webhook","failurePolicy":"Fail","generateName":"sidecar-injector.marin3r.3scale.net","matchPolicy":"Equivalent","objectSelector":{"matchLabels":{"marin3r.3scale.net/status":"enabled"}},"reinvocationPolicy":"Never","rules":[{"apiGroups":[""],"apiVersions":["v1"],"operations":["CREATE"],"resources":["pods"]}],"sideEffects":"None","targetPort":9443,"type":"MutatingAdmissionWebhook","webhookPath":"/pod-v1-mutate"}]}} +- type: olm.bundle.object + value: + data: {"apiVersion":"apiextensions.k8s.io/v1","kind":"CustomResourceDefinition","metadata":{"annotations":{"controller-gen.kubebuilder.io/version":"v0.14.0"},"creationTimestamp":null,"name":"discoveryservicecertificates.operator.marin3r.3scale.net"},"spec":{"group":"operator.marin3r.3scale.net","names":{"kind":"DiscoveryServiceCertificate","listKind":"DiscoveryServiceCertificateList","plural":"discoveryservicecertificates","singular":"discoveryservicecertificate"},"scope":"Namespaced","versions":[{"additionalPrinterColumns":[{"jsonPath":".status.ready","name":"Ready","type":"boolean"},{"format":"date-time","jsonPath":".status.notBefore","name":"Not Before","type":"string"},{"format":"date-time","jsonPath":".status.notAfter","name":"Not After","type":"string"}],"name":"v1alpha1","schema":{"openAPIV3Schema":{"description":"DiscoveryServiceCertificate is an internal resource used to create certificates. This resource\nis used by the DiscoveryService controller to create the required certificates for the different\ncomponents. Direct use of DiscoveryServiceCertificate objects is discouraged.","properties":{"apiVersion":{"description":"APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources","type":"string"},"kind":{"description":"Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds","type":"string"},"metadata":{"type":"object"},"spec":{"description":"DiscoveryServiceCertificateSpec defines the desired state of DiscoveryServiceCertificate","properties":{"certificateRenewal":{"description":"CertificateRenewalConfig configures the certificate renewal process. If unset default\nbehavior is to renew the certificate but not notify of renewals.","properties":{"enabled":{"description":"Enabled is a flag to enable or disable renewal of the certificate","type":"boolean"}},"required":["enabled"],"type":"object"},"commonName":{"description":"CommonName is the CommonName of the certificate","type":"string"},"hosts":{"description":"Hosts is the list of hosts the certificate is valid for. Only\nuse when 'IsServerCertificate' is true. If unset, the CommonName\nfield will be used to populate the valid hosts of the certificate.","items":{"type":"string"},"type":"array"},"isCA":{"description":"IsCA is a boolean specifying that the certificate is a CA","type":"boolean"},"secretRef":{"description":"SecretRef is a reference to the secret that will hold the certificate\nand the private key.","properties":{"name":{"description":"name is unique within a namespace to reference a secret resource.","type":"string"},"namespace":{"description":"namespace defines the space within which the secret name must be unique.","type":"string"}},"type":"object","x-kubernetes-map-type":"atomic"},"server":{"description":"IsServerCertificate is a boolean specifying if the certificate should be\nissued with server auth usage enabled","type":"boolean"},"signer":{"description":"Signer specifies  the signer to use to create this certificate. Supported\nsigners are CertManager and SelfSigned.","properties":{"caSigned":{"description":"CASigned holds specific configuration for the CASigned signer","properties":{"caSecretRef":{"description":"A reference to a Secret containing the CA","properties":{"name":{"description":"name is unique within a namespace to reference a secret resource.","type":"string"},"namespace":{"description":"namespace defines the space within which the secret name must be unique.","type":"string"}},"type":"object","x-kubernetes-map-type":"atomic"}},"required":["caSecretRef"],"type":"object"},"selfSigned":{"description":"SelfSigned holds specific configuration for the SelfSigned signer","type":"object"}},"type":"object"},"validFor":{"description":"ValidFor specifies the validity of the certificate in seconds","format":"int64","type":"integer"}},"required":["commonName","secretRef","signer","validFor"],"type":"object"},"status":{"description":"DiscoveryServiceCertificateStatus defines the observed state of DiscoveryServiceCertificate","properties":{"certificateHash":{"description":"CertificateHash stores the current hash of the certificate. It is used\nfor other controllers to validate if a certificate has been re-issued.","type":"string"},"conditions":{"description":"Conditions represent the latest available observations of an object's state","items":{"description":"Condition contains details for one aspect of the current state of this API Resource.\n---\nThis struct is intended for direct use as an array at the field path .status.conditions.  For example,\n\n\n\ttype FooStatus struct{\n\t    // Represents the observations of a foo's current state.\n\t    // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\"\n\t    // +patchMergeKey=type\n\t    // +patchStrategy=merge\n\t    // +listType=map\n\t    // +listMapKey=type\n\t    Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t    // other fields\n\t}","properties":{"lastTransitionTime":{"description":"lastTransitionTime is the last time the condition transitioned from one status to another.\nThis should be when the underlying condition changed.  If that is not known, then using the time when the API field changed is acceptable.","format":"date-time","type":"string"},"message":{"description":"message is a human readable message indicating details about the transition.\nThis may be an empty string.","maxLength":32768,"type":"string"},"observedGeneration":{"description":"observedGeneration represents the .metadata.generation that the condition was set based upon.\nFor instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.","format":"int64","minimum":0,"type":"integer"},"reason":{"description":"reason contains a programmatic identifier indicating the reason for the condition's last transition.\nProducers of specific condition types may define expected values and meanings for this field,\nand whether the values are considered a guaranteed API.\nThe value should be a CamelCase string.\nThis field may not be empty.","maxLength":1024,"minLength":1,"pattern":"^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$","type":"string"},"status":{"description":"status of the condition, one of True, False, Unknown.","enum":["True","False","Unknown"],"type":"string"},"type":{"description":"type of condition in CamelCase or in foo.example.com/CamelCase.\n---\nMany .condition.type values are consistent across resources like Available, but because arbitrary conditions can be\nuseful (see .node.status.conditions), the ability to deconflict is important.\nThe regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)","maxLength":316,"pattern":"^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$","type":"string"}},"required":["lastTransitionTime","message","reason","status","type"],"type":"object"},"type":"array"},"notAfter":{"description":"NotAfter is the time at which the certificate expires","format":"date-time","type":"string"},"notBefore":{"description":"NotBefore is the time at which the certificate starts\nbeing valid","format":"date-time","type":"string"},"ready":{"description":"Ready is a boolean that specifies if the certificate is ready to be used","type":"boolean"}},"type":"object"}},"type":"object"}},"served":true,"storage":true,"subresources":{"status":{}}}]},"status":{"acceptedNames":{"kind":"","plural":""},"conditions":null,"storedVersions":null}} +- type: olm.bundle.object + value: + data: {"apiVersion":"apiextensions.k8s.io/v1","kind":"CustomResourceDefinition","metadata":{"annotations":{"controller-gen.kubebuilder.io/version":"v0.14.0"},"creationTimestamp":null,"name":"discoveryservices.operator.marin3r.3scale.net"},"spec":{"group":"operator.marin3r.3scale.net","names":{"kind":"DiscoveryService","listKind":"DiscoveryServiceList","plural":"discoveryservices","singular":"discoveryservice"},"scope":"Namespaced","versions":[{"name":"v1alpha1","schema":{"openAPIV3Schema":{"description":"DiscoveryService represents an envoy discovery service server. Only one\ninstance per namespace is currently supported.","properties":{"apiVersion":{"description":"APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources","type":"string"},"kind":{"description":"Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds","type":"string"},"metadata":{"type":"object"},"spec":{"description":"DiscoveryServiceSpec defines the desired state of DiscoveryService","properties":{"debug":{"description":"Debug enables debugging log level for the discovery service controllers. It is safe to\nuse since secret data is never shown in the logs.","type":"boolean"},"image":{"description":"Image holds the image to use for the discovery service Deployment","type":"string"},"metricsPort":{"description":"MetricsPort is the port where metrics are served. Defaults to 8383.","format":"int32","type":"integer"},"pkiConfg":{"description":"PKIConfig has configuration for the PKI that marin3r manages for the\ndifferent certificates it requires","properties":{"rootCertificateAuthority":{"description":"CertificateOptions specifies options to generate the server certificate used both\nfor the xDS server and the mutating webhook server.","properties":{"duration":{"type":"string"},"secretName":{"type":"string"}},"required":["duration","secretName"],"type":"object"},"serverCertificate":{"description":"CertificateOptions specifies options to generate the server certificate used both\nfor the xDS server and the mutating webhook server.","properties":{"duration":{"type":"string"},"secretName":{"type":"string"}},"required":["duration","secretName"],"type":"object"}},"required":["rootCertificateAuthority","serverCertificate"],"type":"object"},"podPriorityClass":{"description":"PriorityClass to assign the discovery service Pod to","type":"string"},"probePort":{"description":"ProbePort is the port where healthz endpoint is served. Defaults to 8384.","format":"int32","type":"integer"},"resources":{"description":"Resources holds the Resource Requirements to use for the discovery service\nDeployment. When not set it defaults to no resource requests nor limits.\nCPU and Memory resources are supported.","properties":{"claims":{"description":"Claims lists the names of resources, defined in spec.resourceClaims,\nthat are used by this container.\n\n\nThis is an alpha field and requires enabling the\nDynamicResourceAllocation feature gate.\n\n\nThis field is immutable. It can only be set for containers.","items":{"description":"ResourceClaim references one entry in PodSpec.ResourceClaims.","properties":{"name":{"description":"Name must match the name of one entry in pod.spec.resourceClaims of\nthe Pod where this field is used. It makes that resource available\ninside a container.","type":"string"}},"required":["name"],"type":"object"},"type":"array","x-kubernetes-list-map-keys":["name"],"x-kubernetes-list-type":"map"},"limits":{"additionalProperties":{"anyOf":[{"type":"integer"},{"type":"string"}],"pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"description":"Limits describes the maximum amount of compute resources allowed.\nMore info: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/","type":"object"},"requests":{"additionalProperties":{"anyOf":[{"type":"integer"},{"type":"string"}],"pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"description":"Requests describes the minimum amount of compute resources required.\nIf Requests is omitted for a container, it defaults to Limits if that is explicitly specified,\notherwise to an implementation-defined value. Requests cannot exceed Limits.\nMore info: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/","type":"object"}},"type":"object"},"serviceConfig":{"description":"ServiceConfig configures the way the DiscoveryService endpoints are exposed","properties":{"name":{"type":"string"},"type":{"description":"ServiceType is an enum with the available discovery service Service types","type":"string"}},"type":"object"},"xdsServerPort":{"description":"XdsServerPort is the port where the xDS server listens. Defaults to 18000.","format":"int32","type":"integer"}},"type":"object"},"status":{"description":"DiscoveryServiceStatus defines the observed state of DiscoveryService","properties":{"deploymentName":{"type":"string"},"deploymentStatus":{"description":"DeploymentStatus is the most recently observed status of the Deployment.","properties":{"availableReplicas":{"description":"Total number of available pods (ready for at least minReadySeconds) targeted by this deployment.","format":"int32","type":"integer"},"collisionCount":{"description":"Count of hash collisions for the Deployment. The Deployment controller uses this\nfield as a collision avoidance mechanism when it needs to create the name for the\nnewest ReplicaSet.","format":"int32","type":"integer"},"conditions":{"description":"Represents the latest available observations of a deployment's current state.","items":{"description":"DeploymentCondition describes the state of a deployment at a certain point.","properties":{"lastTransitionTime":{"description":"Last time the condition transitioned from one status to another.","format":"date-time","type":"string"},"lastUpdateTime":{"description":"The last time this condition was updated.","format":"date-time","type":"string"},"message":{"description":"A human readable message indicating details about the transition.","type":"string"},"reason":{"description":"The reason for the condition's last transition.","type":"string"},"status":{"description":"Status of the condition, one of True, False, Unknown.","type":"string"},"type":{"description":"Type of deployment condition.","type":"string"}},"required":["status","type"],"type":"object"},"type":"array"},"observedGeneration":{"description":"The generation observed by the deployment controller.","format":"int64","type":"integer"},"readyReplicas":{"description":"readyReplicas is the number of pods targeted by this Deployment with a Ready Condition.","format":"int32","type":"integer"},"replicas":{"description":"Total number of non-terminated pods targeted by this deployment (their labels match the selector).","format":"int32","type":"integer"},"unavailableReplicas":{"description":"Total number of unavailable pods targeted by this deployment. This is the total number of\npods that are still required for the deployment to have 100% available capacity. They may\neither be pods that are running but not yet available or pods that still have not been created.","format":"int32","type":"integer"},"updatedReplicas":{"description":"Total number of non-terminated pods targeted by this deployment that have the desired template spec.","format":"int32","type":"integer"}},"type":"object"}},"type":"object"}},"type":"object"}},"served":true,"storage":true,"subresources":{"status":{}}}]},"status":{"acceptedNames":{"kind":"","plural":""},"conditions":null,"storedVersions":null}} +- type: olm.bundle.object + value: + data: {"apiVersion":"apiextensions.k8s.io/v1","kind":"CustomResourceDefinition","metadata":{"annotations":{"controller-gen.kubebuilder.io/version":"v0.14.0"},"creationTimestamp":null,"name":"envoydeployments.operator.marin3r.3scale.net"},"spec":{"group":"operator.marin3r.3scale.net","names":{"kind":"EnvoyDeployment","listKind":"EnvoyDeploymentList","plural":"envoydeployments","singular":"envoydeployment"},"scope":"Namespaced","versions":[{"name":"v1alpha1","schema":{"openAPIV3Schema":{"description":"EnvoyDeployment is a resource to deploy and manage a Kubernetes Deployment\nof Envoy Pods.","properties":{"apiVersion":{"description":"APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources","type":"string"},"kind":{"description":"Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds","type":"string"},"metadata":{"type":"object"},"spec":{"description":"EnvoyDeploymentSpec defines the desired state of EnvoyDeployment","properties":{"adminAccessLogPath":{"description":"Configures envoy's admin access log path. Defaults to /dev/null.","type":"string"},"adminPort":{"description":"Configures envoy's admin port. Defaults to 9901.","format":"int32","type":"integer"},"affinity":{"description":"Affinity configuration for the envoy pods","properties":{"nodeAffinity":{"description":"Describes node affinity scheduling rules for the pod.","properties":{"preferredDuringSchedulingIgnoredDuringExecution":{"description":"The scheduler will prefer to schedule pods to nodes that satisfy\nthe affinity expressions specified by this field, but it may choose\na node that violates one or more of the expressions. The node that is\nmost preferred is the one with the greatest sum of weights, i.e.\nfor each node that meets all of the scheduling requirements (resource\nrequest, requiredDuringScheduling affinity expressions, etc.),\ncompute a sum by iterating through the elements of this field and adding\n\"weight\" to the sum if the node matches the corresponding matchExpressions; the\nnode(s) with the highest sum are the most preferred.","items":{"description":"An empty preferred scheduling term matches all objects with implicit weight 0\n(i.e. it's a no-op). A null preferred scheduling term matches no objects (i.e. is also a no-op).","properties":{"preference":{"description":"A node selector term, associated with the corresponding weight.","properties":{"matchExpressions":{"description":"A list of node selector requirements by node's labels.","items":{"description":"A node selector requirement is a selector that contains values, a key, and an operator\nthat relates the key and values.","properties":{"key":{"description":"The label key that the selector applies to.","type":"string"},"operator":{"description":"Represents a key's relationship to a set of values.\nValid operators are In, NotIn, Exists, DoesNotExist. Gt, and Lt.","type":"string"},"values":{"description":"An array of string values. If the operator is In or NotIn,\nthe values array must be non-empty. If the operator is Exists or DoesNotExist,\nthe values array must be empty. If the operator is Gt or Lt, the values\narray must have a single element, which will be interpreted as an integer.\nThis array is replaced during a strategic merge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchFields":{"description":"A list of node selector requirements by node's fields.","items":{"description":"A node selector requirement is a selector that contains values, a key, and an operator\nthat relates the key and values.","properties":{"key":{"description":"The label key that the selector applies to.","type":"string"},"operator":{"description":"Represents a key's relationship to a set of values.\nValid operators are In, NotIn, Exists, DoesNotExist. Gt, and Lt.","type":"string"},"values":{"description":"An array of string values. If the operator is In or NotIn,\nthe values array must be non-empty. If the operator is Exists or DoesNotExist,\nthe values array must be empty. If the operator is Gt or Lt, the values\narray must have a single element, which will be interpreted as an integer.\nThis array is replaced during a strategic merge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"}},"type":"object","x-kubernetes-map-type":"atomic"},"weight":{"description":"Weight associated with matching the corresponding nodeSelectorTerm, in the range 1-100.","format":"int32","type":"integer"}},"required":["preference","weight"],"type":"object"},"type":"array"},"requiredDuringSchedulingIgnoredDuringExecution":{"description":"If the affinity requirements specified by this field are not met at\nscheduling time, the pod will not be scheduled onto the node.\nIf the affinity requirements specified by this field cease to be met\nat some point during pod execution (e.g. due to an update), the system\nmay or may not try to eventually evict the pod from its node.","properties":{"nodeSelectorTerms":{"description":"Required. A list of node selector terms. The terms are ORed.","items":{"description":"A null or empty node selector term matches no objects. The requirements of\nthem are ANDed.\nThe TopologySelectorTerm type implements a subset of the NodeSelectorTerm.","properties":{"matchExpressions":{"description":"A list of node selector requirements by node's labels.","items":{"description":"A node selector requirement is a selector that contains values, a key, and an operator\nthat relates the key and values.","properties":{"key":{"description":"The label key that the selector applies to.","type":"string"},"operator":{"description":"Represents a key's relationship to a set of values.\nValid operators are In, NotIn, Exists, DoesNotExist. Gt, and Lt.","type":"string"},"values":{"description":"An array of string values. If the operator is In or NotIn,\nthe values array must be non-empty. If the operator is Exists or DoesNotExist,\nthe values array must be empty. If the operator is Gt or Lt, the values\narray must have a single element, which will be interpreted as an integer.\nThis array is replaced during a strategic merge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchFields":{"description":"A list of node selector requirements by node's fields.","items":{"description":"A node selector requirement is a selector that contains values, a key, and an operator\nthat relates the key and values.","properties":{"key":{"description":"The label key that the selector applies to.","type":"string"},"operator":{"description":"Represents a key's relationship to a set of values.\nValid operators are In, NotIn, Exists, DoesNotExist. Gt, and Lt.","type":"string"},"values":{"description":"An array of string values. If the operator is In or NotIn,\nthe values array must be non-empty. If the operator is Exists or DoesNotExist,\nthe values array must be empty. If the operator is Gt or Lt, the values\narray must have a single element, which will be interpreted as an integer.\nThis array is replaced during a strategic merge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"}},"type":"object","x-kubernetes-map-type":"atomic"},"type":"array"}},"required":["nodeSelectorTerms"],"type":"object","x-kubernetes-map-type":"atomic"}},"type":"object"},"podAffinity":{"description":"Describes pod affinity scheduling rules (e.g. co-locate this pod in the same node, zone, etc. as some other pod(s)).","properties":{"preferredDuringSchedulingIgnoredDuringExecution":{"description":"The scheduler will prefer to schedule pods to nodes that satisfy\nthe affinity expressions specified by this field, but it may choose\na node that violates one or more of the expressions. The node that is\nmost preferred is the one with the greatest sum of weights, i.e.\nfor each node that meets all of the scheduling requirements (resource\nrequest, requiredDuringScheduling affinity expressions, etc.),\ncompute a sum by iterating through the elements of this field and adding\n\"weight\" to the sum if the node has pods which matches the corresponding podAffinityTerm; the\nnode(s) with the highest sum are the most preferred.","items":{"description":"The weights of all of the matched WeightedPodAffinityTerm fields are added per-node to find the most preferred node(s)","properties":{"podAffinityTerm":{"description":"Required. A pod affinity term, associated with the corresponding weight.","properties":{"labelSelector":{"description":"A label query over a set of resources, in this case pods.\nIf it's null, this PodAffinityTerm matches with no Pods.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that\nrelates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values.\nValid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn,\nthe values array must be non-empty. If the operator is Exists or DoesNotExist,\nthe values array must be empty. This array is replaced during a strategic\nmerge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"},"matchLabelKeys":{"description":"MatchLabelKeys is a set of pod label keys to select which pods will\nbe taken into consideration. The keys are used to lookup values from the\nincoming pod labels, those key-value labels are merged with `LabelSelector` as `key in (value)`\nto select the group of existing pods which pods will be taken into consideration\nfor the incoming pod's pod (anti) affinity. Keys that don't exist in the incoming\npod labels will be ignored. The default value is empty.\nThe same key is forbidden to exist in both MatchLabelKeys and LabelSelector.\nAlso, MatchLabelKeys cannot be set when LabelSelector isn't set.\nThis is an alpha field and requires enabling MatchLabelKeysInPodAffinity feature gate.","items":{"type":"string"},"type":"array","x-kubernetes-list-type":"atomic"},"mismatchLabelKeys":{"description":"MismatchLabelKeys is a set of pod label keys to select which pods will\nbe taken into consideration. The keys are used to lookup values from the\nincoming pod labels, those key-value labels are merged with `LabelSelector` as `key notin (value)`\nto select the group of existing pods which pods will be taken into consideration\nfor the incoming pod's pod (anti) affinity. Keys that don't exist in the incoming\npod labels will be ignored. The default value is empty.\nThe same key is forbidden to exist in both MismatchLabelKeys and LabelSelector.\nAlso, MismatchLabelKeys cannot be set when LabelSelector isn't set.\nThis is an alpha field and requires enabling MatchLabelKeysInPodAffinity feature gate.","items":{"type":"string"},"type":"array","x-kubernetes-list-type":"atomic"},"namespaceSelector":{"description":"A label query over the set of namespaces that the term applies to.\nThe term is applied to the union of the namespaces selected by this field\nand the ones listed in the namespaces field.\nnull selector and null or empty namespaces list means \"this pod's namespace\".\nAn empty selector ({}) matches all namespaces.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that\nrelates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values.\nValid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn,\nthe values array must be non-empty. If the operator is Exists or DoesNotExist,\nthe values array must be empty. This array is replaced during a strategic\nmerge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"},"namespaces":{"description":"namespaces specifies a static list of namespace names that the term applies to.\nThe term is applied to the union of the namespaces listed in this field\nand the ones selected by namespaceSelector.\nnull or empty namespaces list and null namespaceSelector means \"this pod's namespace\".","items":{"type":"string"},"type":"array"},"topologyKey":{"description":"This pod should be co-located (affinity) or not co-located (anti-affinity) with the pods matching\nthe labelSelector in the specified namespaces, where co-located is defined as running on a node\nwhose value of the label with key topologyKey matches that of any node on which any of the\nselected pods is running.\nEmpty topologyKey is not allowed.","type":"string"}},"required":["topologyKey"],"type":"object"},"weight":{"description":"weight associated with matching the corresponding podAffinityTerm,\nin the range 1-100.","format":"int32","type":"integer"}},"required":["podAffinityTerm","weight"],"type":"object"},"type":"array"},"requiredDuringSchedulingIgnoredDuringExecution":{"description":"If the affinity requirements specified by this field are not met at\nscheduling time, the pod will not be scheduled onto the node.\nIf the affinity requirements specified by this field cease to be met\nat some point during pod execution (e.g. due to a pod label update), the\nsystem may or may not try to eventually evict the pod from its node.\nWhen there are multiple elements, the lists of nodes corresponding to each\npodAffinityTerm are intersected, i.e. all terms must be satisfied.","items":{"description":"Defines a set of pods (namely those matching the labelSelector\nrelative to the given namespace(s)) that this pod should be\nco-located (affinity) or not co-located (anti-affinity) with,\nwhere co-located is defined as running on a node whose value of\nthe label with key \u003ctopologyKey\u003e matches that of any node on which\na pod of the set of pods is running","properties":{"labelSelector":{"description":"A label query over a set of resources, in this case pods.\nIf it's null, this PodAffinityTerm matches with no Pods.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that\nrelates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values.\nValid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn,\nthe values array must be non-empty. If the operator is Exists or DoesNotExist,\nthe values array must be empty. This array is replaced during a strategic\nmerge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"},"matchLabelKeys":{"description":"MatchLabelKeys is a set of pod label keys to select which pods will\nbe taken into consideration. The keys are used to lookup values from the\nincoming pod labels, those key-value labels are merged with `LabelSelector` as `key in (value)`\nto select the group of existing pods which pods will be taken into consideration\nfor the incoming pod's pod (anti) affinity. Keys that don't exist in the incoming\npod labels will be ignored. The default value is empty.\nThe same key is forbidden to exist in both MatchLabelKeys and LabelSelector.\nAlso, MatchLabelKeys cannot be set when LabelSelector isn't set.\nThis is an alpha field and requires enabling MatchLabelKeysInPodAffinity feature gate.","items":{"type":"string"},"type":"array","x-kubernetes-list-type":"atomic"},"mismatchLabelKeys":{"description":"MismatchLabelKeys is a set of pod label keys to select which pods will\nbe taken into consideration. The keys are used to lookup values from the\nincoming pod labels, those key-value labels are merged with `LabelSelector` as `key notin (value)`\nto select the group of existing pods which pods will be taken into consideration\nfor the incoming pod's pod (anti) affinity. Keys that don't exist in the incoming\npod labels will be ignored. The default value is empty.\nThe same key is forbidden to exist in both MismatchLabelKeys and LabelSelector.\nAlso, MismatchLabelKeys cannot be set when LabelSelector isn't set.\nThis is an alpha field and requires enabling MatchLabelKeysInPodAffinity feature gate.","items":{"type":"string"},"type":"array","x-kubernetes-list-type":"atomic"},"namespaceSelector":{"description":"A label query over the set of namespaces that the term applies to.\nThe term is applied to the union of the namespaces selected by this field\nand the ones listed in the namespaces field.\nnull selector and null or empty namespaces list means \"this pod's namespace\".\nAn empty selector ({}) matches all namespaces.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that\nrelates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values.\nValid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn,\nthe values array must be non-empty. If the operator is Exists or DoesNotExist,\nthe values array must be empty. This array is replaced during a strategic\nmerge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"},"namespaces":{"description":"namespaces specifies a static list of namespace names that the term applies to.\nThe term is applied to the union of the namespaces listed in this field\nand the ones selected by namespaceSelector.\nnull or empty namespaces list and null namespaceSelector means \"this pod's namespace\".","items":{"type":"string"},"type":"array"},"topologyKey":{"description":"This pod should be co-located (affinity) or not co-located (anti-affinity) with the pods matching\nthe labelSelector in the specified namespaces, where co-located is defined as running on a node\nwhose value of the label with key topologyKey matches that of any node on which any of the\nselected pods is running.\nEmpty topologyKey is not allowed.","type":"string"}},"required":["topologyKey"],"type":"object"},"type":"array"}},"type":"object"},"podAntiAffinity":{"description":"Describes pod anti-affinity scheduling rules (e.g. avoid putting this pod in the same node, zone, etc. as some other pod(s)).","properties":{"preferredDuringSchedulingIgnoredDuringExecution":{"description":"The scheduler will prefer to schedule pods to nodes that satisfy\nthe anti-affinity expressions specified by this field, but it may choose\na node that violates one or more of the expressions. The node that is\nmost preferred is the one with the greatest sum of weights, i.e.\nfor each node that meets all of the scheduling requirements (resource\nrequest, requiredDuringScheduling anti-affinity expressions, etc.),\ncompute a sum by iterating through the elements of this field and adding\n\"weight\" to the sum if the node has pods which matches the corresponding podAffinityTerm; the\nnode(s) with the highest sum are the most preferred.","items":{"description":"The weights of all of the matched WeightedPodAffinityTerm fields are added per-node to find the most preferred node(s)","properties":{"podAffinityTerm":{"description":"Required. A pod affinity term, associated with the corresponding weight.","properties":{"labelSelector":{"description":"A label query over a set of resources, in this case pods.\nIf it's null, this PodAffinityTerm matches with no Pods.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that\nrelates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values.\nValid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn,\nthe values array must be non-empty. If the operator is Exists or DoesNotExist,\nthe values array must be empty. This array is replaced during a strategic\nmerge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"},"matchLabelKeys":{"description":"MatchLabelKeys is a set of pod label keys to select which pods will\nbe taken into consideration. The keys are used to lookup values from the\nincoming pod labels, those key-value labels are merged with `LabelSelector` as `key in (value)`\nto select the group of existing pods which pods will be taken into consideration\nfor the incoming pod's pod (anti) affinity. Keys that don't exist in the incoming\npod labels will be ignored. The default value is empty.\nThe same key is forbidden to exist in both MatchLabelKeys and LabelSelector.\nAlso, MatchLabelKeys cannot be set when LabelSelector isn't set.\nThis is an alpha field and requires enabling MatchLabelKeysInPodAffinity feature gate.","items":{"type":"string"},"type":"array","x-kubernetes-list-type":"atomic"},"mismatchLabelKeys":{"description":"MismatchLabelKeys is a set of pod label keys to select which pods will\nbe taken into consideration. The keys are used to lookup values from the\nincoming pod labels, those key-value labels are merged with `LabelSelector` as `key notin (value)`\nto select the group of existing pods which pods will be taken into consideration\nfor the incoming pod's pod (anti) affinity. Keys that don't exist in the incoming\npod labels will be ignored. The default value is empty.\nThe same key is forbidden to exist in both MismatchLabelKeys and LabelSelector.\nAlso, MismatchLabelKeys cannot be set when LabelSelector isn't set.\nThis is an alpha field and requires enabling MatchLabelKeysInPodAffinity feature gate.","items":{"type":"string"},"type":"array","x-kubernetes-list-type":"atomic"},"namespaceSelector":{"description":"A label query over the set of namespaces that the term applies to.\nThe term is applied to the union of the namespaces selected by this field\nand the ones listed in the namespaces field.\nnull selector and null or empty namespaces list means \"this pod's namespace\".\nAn empty selector ({}) matches all namespaces.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that\nrelates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values.\nValid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn,\nthe values array must be non-empty. If the operator is Exists or DoesNotExist,\nthe values array must be empty. This array is replaced during a strategic\nmerge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"},"namespaces":{"description":"namespaces specifies a static list of namespace names that the term applies to.\nThe term is applied to the union of the namespaces listed in this field\nand the ones selected by namespaceSelector.\nnull or empty namespaces list and null namespaceSelector means \"this pod's namespace\".","items":{"type":"string"},"type":"array"},"topologyKey":{"description":"This pod should be co-located (affinity) or not co-located (anti-affinity) with the pods matching\nthe labelSelector in the specified namespaces, where co-located is defined as running on a node\nwhose value of the label with key topologyKey matches that of any node on which any of the\nselected pods is running.\nEmpty topologyKey is not allowed.","type":"string"}},"required":["topologyKey"],"type":"object"},"weight":{"description":"weight associated with matching the corresponding podAffinityTerm,\nin the range 1-100.","format":"int32","type":"integer"}},"required":["podAffinityTerm","weight"],"type":"object"},"type":"array"},"requiredDuringSchedulingIgnoredDuringExecution":{"description":"If the anti-affinity requirements specified by this field are not met at\nscheduling time, the pod will not be scheduled onto the node.\nIf the anti-affinity requirements specified by this field cease to be met\nat some point during pod execution (e.g. due to a pod label update), the\nsystem may or may not try to eventually evict the pod from its node.\nWhen there are multiple elements, the lists of nodes corresponding to each\npodAffinityTerm are intersected, i.e. all terms must be satisfied.","items":{"description":"Defines a set of pods (namely those matching the labelSelector\nrelative to the given namespace(s)) that this pod should be\nco-located (affinity) or not co-located (anti-affinity) with,\nwhere co-located is defined as running on a node whose value of\nthe label with key \u003ctopologyKey\u003e matches that of any node on which\na pod of the set of pods is running","properties":{"labelSelector":{"description":"A label query over a set of resources, in this case pods.\nIf it's null, this PodAffinityTerm matches with no Pods.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that\nrelates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values.\nValid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn,\nthe values array must be non-empty. If the operator is Exists or DoesNotExist,\nthe values array must be empty. This array is replaced during a strategic\nmerge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"},"matchLabelKeys":{"description":"MatchLabelKeys is a set of pod label keys to select which pods will\nbe taken into consideration. The keys are used to lookup values from the\nincoming pod labels, those key-value labels are merged with `LabelSelector` as `key in (value)`\nto select the group of existing pods which pods will be taken into consideration\nfor the incoming pod's pod (anti) affinity. Keys that don't exist in the incoming\npod labels will be ignored. The default value is empty.\nThe same key is forbidden to exist in both MatchLabelKeys and LabelSelector.\nAlso, MatchLabelKeys cannot be set when LabelSelector isn't set.\nThis is an alpha field and requires enabling MatchLabelKeysInPodAffinity feature gate.","items":{"type":"string"},"type":"array","x-kubernetes-list-type":"atomic"},"mismatchLabelKeys":{"description":"MismatchLabelKeys is a set of pod label keys to select which pods will\nbe taken into consideration. The keys are used to lookup values from the\nincoming pod labels, those key-value labels are merged with `LabelSelector` as `key notin (value)`\nto select the group of existing pods which pods will be taken into consideration\nfor the incoming pod's pod (anti) affinity. Keys that don't exist in the incoming\npod labels will be ignored. The default value is empty.\nThe same key is forbidden to exist in both MismatchLabelKeys and LabelSelector.\nAlso, MismatchLabelKeys cannot be set when LabelSelector isn't set.\nThis is an alpha field and requires enabling MatchLabelKeysInPodAffinity feature gate.","items":{"type":"string"},"type":"array","x-kubernetes-list-type":"atomic"},"namespaceSelector":{"description":"A label query over the set of namespaces that the term applies to.\nThe term is applied to the union of the namespaces selected by this field\nand the ones listed in the namespaces field.\nnull selector and null or empty namespaces list means \"this pod's namespace\".\nAn empty selector ({}) matches all namespaces.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that\nrelates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values.\nValid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn,\nthe values array must be non-empty. If the operator is Exists or DoesNotExist,\nthe values array must be empty. This array is replaced during a strategic\nmerge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"},"namespaces":{"description":"namespaces specifies a static list of namespace names that the term applies to.\nThe term is applied to the union of the namespaces listed in this field\nand the ones selected by namespaceSelector.\nnull or empty namespaces list and null namespaceSelector means \"this pod's namespace\".","items":{"type":"string"},"type":"array"},"topologyKey":{"description":"This pod should be co-located (affinity) or not co-located (anti-affinity) with the pods matching\nthe labelSelector in the specified namespaces, where co-located is defined as running on a node\nwhose value of the label with key topologyKey matches that of any node on which any of the\nselected pods is running.\nEmpty topologyKey is not allowed.","type":"string"}},"required":["topologyKey"],"type":"object"},"type":"array"}},"type":"object"}},"type":"object"},"clusterID":{"description":"Defines the local service cluster name where Envoy is running. Defaults\nto the NodeID in the EnvoyConfig if unset","type":"string"},"discoveryServiceRef":{"description":"DiscoveryServiceRef points to a DiscoveryService in the same\nnamespace","type":"string"},"duration":{"description":"Defines the duration of the client certificate that is used to authenticate\nwith the DiscoveryService","type":"string"},"envoyConfigRef":{"description":"EnvoyConfigRef points to an EnvoyConfig in the same namespace\nthat holds the envoy resources for this Deployment","type":"string"},"extraArgs":{"description":"Allows the user to define extra command line arguments for the Envoy process","items":{"type":"string"},"type":"array"},"image":{"description":"Image is the envoy image and tag to use","type":"string"},"initManager":{"description":"InitManager defines configuration for Envoy's init\nmanager, which handles initialization for Envoy pods","properties":{"image":{"description":"Image is the init manager image and tag to use","type":"string"}},"type":"object"},"livenessProbe":{"description":"Liveness probe for the envoy pods","properties":{"failureThreshold":{"description":"Minimum consecutive failures for the probe to be considered failed after having succeeded","format":"int32","type":"integer"},"initialDelaySeconds":{"description":"Number of seconds after the container has started before liveness probes are initiated","format":"int32","type":"integer"},"periodSeconds":{"description":"How often (in seconds) to perform the probe","format":"int32","type":"integer"},"successThreshold":{"description":"Minimum consecutive successes for the probe to be considered successful after having failed","format":"int32","type":"integer"},"timeoutSeconds":{"description":"Number of seconds after which the probe times out","format":"int32","type":"integer"}},"required":["failureThreshold","initialDelaySeconds","periodSeconds","successThreshold","timeoutSeconds"],"type":"object"},"podDisruptionBudget":{"description":"Configures PodDisruptionBudget for the envoy Pods","properties":{"maxUnavailable":{"anyOf":[{"type":"integer"},{"type":"string"}],"description":"An eviction is allowed if at most \"maxUnavailable\" pods selected by\n\"selector\" are unavailable after the eviction, i.e. even in absence of\nthe evicted pod. For example, one can prevent all voluntary evictions\nby specifying 0. This is a mutually exclusive setting with \"minAvailable\".","x-kubernetes-int-or-string":true},"minAvailable":{"anyOf":[{"type":"integer"},{"type":"string"}],"description":"An eviction is allowed if at least \"minAvailable\" pods selected by\n\"selector\" will still be available after the eviction, i.e. even in the\nabsence of the evicted pod.  So for example you can prevent all voluntary\nevictions by specifying \"100%\".","x-kubernetes-int-or-string":true}},"type":"object"},"ports":{"description":"Ports exposed by the Envoy container","items":{"description":"ContainerPort defines port for the Marin3r sidecar container","properties":{"name":{"description":"Port name","type":"string"},"port":{"description":"Port value","format":"int32","type":"integer"},"protocol":{"default":"TCP","description":"Protocol. Defaults to TCP.","type":"string"}},"required":["name","port"],"type":"object"},"type":"array"},"readinessProbe":{"description":"Readiness probe for the envoy pods","properties":{"failureThreshold":{"description":"Minimum consecutive failures for the probe to be considered failed after having succeeded","format":"int32","type":"integer"},"initialDelaySeconds":{"description":"Number of seconds after the container has started before liveness probes are initiated","format":"int32","type":"integer"},"periodSeconds":{"description":"How often (in seconds) to perform the probe","format":"int32","type":"integer"},"successThreshold":{"description":"Minimum consecutive successes for the probe to be considered successful after having failed","format":"int32","type":"integer"},"timeoutSeconds":{"description":"Number of seconds after which the probe times out","format":"int32","type":"integer"}},"required":["failureThreshold","initialDelaySeconds","periodSeconds","successThreshold","timeoutSeconds"],"type":"object"},"replicas":{"description":"Replicas configures the number of replicas in the Deployment. One of\n'static', 'dynamic' can be set. If both are set, static has precedence.","properties":{"dynamic":{"description":"Configure a min and max value for the number of pods to autoscale dynamically.","properties":{"behavior":{"description":"behavior configures the scaling behavior of the target\nin both Up and Down directions (scaleUp and scaleDown fields respectively).\nIf not set, the default HPAScalingRules for scale up and scale down are used.","properties":{"scaleDown":{"description":"scaleDown is scaling policy for scaling Down.\nIf not set, the default value is to allow to scale down to minReplicas pods, with a\n300 second stabilization window (i.e., the highest recommendation for\nthe last 300sec is used).","properties":{"policies":{"description":"policies is a list of potential scaling polices which can be used during scaling.\nAt least one policy must be specified, otherwise the HPAScalingRules will be discarded as invalid","items":{"description":"HPAScalingPolicy is a single policy which must hold true for a specified past interval.","properties":{"periodSeconds":{"description":"periodSeconds specifies the window of time for which the policy should hold true.\nPeriodSeconds must be greater than zero and less than or equal to 1800 (30 min).","format":"int32","type":"integer"},"type":{"description":"type is used to specify the scaling policy.","type":"string"},"value":{"description":"value contains the amount of change which is permitted by the policy.\nIt must be greater than zero","format":"int32","type":"integer"}},"required":["periodSeconds","type","value"],"type":"object"},"type":"array","x-kubernetes-list-type":"atomic"},"selectPolicy":{"description":"selectPolicy is used to specify which policy should be used.\nIf not set, the default value Max is used.","type":"string"},"stabilizationWindowSeconds":{"description":"stabilizationWindowSeconds is the number of seconds for which past recommendations should be\nconsidered while scaling up or scaling down.\nStabilizationWindowSeconds must be greater than or equal to zero and less than or equal to 3600 (one hour).\nIf not set, use the default values:\n- For scale up: 0 (i.e. no stabilization is done).\n- For scale down: 300 (i.e. the stabilization window is 300 seconds long).","format":"int32","type":"integer"}},"type":"object"},"scaleUp":{"description":"scaleUp is scaling policy for scaling Up.\nIf not set, the default value is the higher of:\n  * increase no more than 4 pods per 60 seconds\n  * double the number of pods per 60 seconds\nNo stabilization is used.","properties":{"policies":{"description":"policies is a list of potential scaling polices which can be used during scaling.\nAt least one policy must be specified, otherwise the HPAScalingRules will be discarded as invalid","items":{"description":"HPAScalingPolicy is a single policy which must hold true for a specified past interval.","properties":{"periodSeconds":{"description":"periodSeconds specifies the window of time for which the policy should hold true.\nPeriodSeconds must be greater than zero and less than or equal to 1800 (30 min).","format":"int32","type":"integer"},"type":{"description":"type is used to specify the scaling policy.","type":"string"},"value":{"description":"value contains the amount of change which is permitted by the policy.\nIt must be greater than zero","format":"int32","type":"integer"}},"required":["periodSeconds","type","value"],"type":"object"},"type":"array","x-kubernetes-list-type":"atomic"},"selectPolicy":{"description":"selectPolicy is used to specify which policy should be used.\nIf not set, the default value Max is used.","type":"string"},"stabilizationWindowSeconds":{"description":"stabilizationWindowSeconds is the number of seconds for which past recommendations should be\nconsidered while scaling up or scaling down.\nStabilizationWindowSeconds must be greater than or equal to zero and less than or equal to 3600 (one hour).\nIf not set, use the default values:\n- For scale up: 0 (i.e. no stabilization is done).\n- For scale down: 300 (i.e. the stabilization window is 300 seconds long).","format":"int32","type":"integer"}},"type":"object"}},"type":"object"},"maxReplicas":{"description":"maxReplicas is the upper limit for the number of replicas to which the autoscaler can scale up.\nIt cannot be less that minReplicas.","format":"int32","type":"integer"},"metrics":{"description":"metrics contains the specifications for which to use to calculate the\ndesired replica count (the maximum replica count across all metrics will\nbe used).  The desired replica count is calculated multiplying the\nratio between the target value and the current value by the current\nnumber of pods.  Ergo, metrics used must decrease as the pod count is\nincreased, and vice-versa.  See the individual metric source types for\nmore information about how each type of metric must respond.\nIf not set, the default metric will be set to 80% average CPU utilization.","items":{"description":"MetricSpec specifies how to scale based on a single metric\n(only `type` and one other matching field should be set at once).","properties":{"containerResource":{"description":"containerResource refers to a resource metric (such as those specified in\nrequests and limits) known to Kubernetes describing a single container in\neach pod of the current scale target (e.g. CPU or memory). Such metrics are\nbuilt in to Kubernetes, and have special scaling options on top of those\navailable to normal per-pod metrics using the \"pods\" source.\nThis is an alpha feature and can be enabled by the HPAContainerMetrics feature flag.","properties":{"container":{"description":"container is the name of the container in the pods of the scaling target","type":"string"},"name":{"description":"name is the name of the resource in question.","type":"string"},"target":{"description":"target specifies the target value for the given metric","properties":{"averageUtilization":{"description":"averageUtilization is the target value of the average of the\nresource metric across all relevant pods, represented as a percentage of\nthe requested value of the resource for the pods.\nCurrently only valid for Resource metric source type","format":"int32","type":"integer"},"averageValue":{"anyOf":[{"type":"integer"},{"type":"string"}],"description":"averageValue is the target value of the average of the\nmetric across all relevant pods (as a quantity)","pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"type":{"description":"type represents whether the metric type is Utilization, Value, or AverageValue","type":"string"},"value":{"anyOf":[{"type":"integer"},{"type":"string"}],"description":"value is the target value of the metric (as a quantity).","pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true}},"required":["type"],"type":"object"}},"required":["container","name","target"],"type":"object"},"external":{"description":"external refers to a global metric that is not associated\nwith any Kubernetes object. It allows autoscaling based on information\ncoming from components running outside of cluster\n(for example length of queue in cloud messaging service, or\nQPS from loadbalancer running outside of cluster).","properties":{"metric":{"description":"metric identifies the target metric by name and selector","properties":{"name":{"description":"name is the name of the given metric","type":"string"},"selector":{"description":"selector is the string-encoded form of a standard kubernetes label selector for the given metric\nWhen set, it is passed as an additional parameter to the metrics server for more specific metrics scoping.\nWhen unset, just the metricName will be used to gather metrics.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that\nrelates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values.\nValid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn,\nthe values array must be non-empty. If the operator is Exists or DoesNotExist,\nthe values array must be empty. This array is replaced during a strategic\nmerge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"}},"required":["name"],"type":"object"},"target":{"description":"target specifies the target value for the given metric","properties":{"averageUtilization":{"description":"averageUtilization is the target value of the average of the\nresource metric across all relevant pods, represented as a percentage of\nthe requested value of the resource for the pods.\nCurrently only valid for Resource metric source type","format":"int32","type":"integer"},"averageValue":{"anyOf":[{"type":"integer"},{"type":"string"}],"description":"averageValue is the target value of the average of the\nmetric across all relevant pods (as a quantity)","pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"type":{"description":"type represents whether the metric type is Utilization, Value, or AverageValue","type":"string"},"value":{"anyOf":[{"type":"integer"},{"type":"string"}],"description":"value is the target value of the metric (as a quantity).","pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true}},"required":["type"],"type":"object"}},"required":["metric","target"],"type":"object"},"object":{"description":"object refers to a metric describing a single kubernetes object\n(for example, hits-per-second on an Ingress object).","properties":{"describedObject":{"description":"describedObject specifies the descriptions of a object,such as kind,name apiVersion","properties":{"apiVersion":{"description":"apiVersion is the API version of the referent","type":"string"},"kind":{"description":"kind is the kind of the referent; More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds","type":"string"},"name":{"description":"name is the name of the referent; More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names","type":"string"}},"required":["kind","name"],"type":"object"},"metric":{"description":"metric identifies the target metric by name and selector","properties":{"name":{"description":"name is the name of the given metric","type":"string"},"selector":{"description":"selector is the string-encoded form of a standard kubernetes label selector for the given metric\nWhen set, it is passed as an additional parameter to the metrics server for more specific metrics scoping.\nWhen unset, just the metricName will be used to gather metrics.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that\nrelates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values.\nValid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn,\nthe values array must be non-empty. If the operator is Exists or DoesNotExist,\nthe values array must be empty. This array is replaced during a strategic\nmerge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"}},"required":["name"],"type":"object"},"target":{"description":"target specifies the target value for the given metric","properties":{"averageUtilization":{"description":"averageUtilization is the target value of the average of the\nresource metric across all relevant pods, represented as a percentage of\nthe requested value of the resource for the pods.\nCurrently only valid for Resource metric source type","format":"int32","type":"integer"},"averageValue":{"anyOf":[{"type":"integer"},{"type":"string"}],"description":"averageValue is the target value of the average of the\nmetric across all relevant pods (as a quantity)","pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"type":{"description":"type represents whether the metric type is Utilization, Value, or AverageValue","type":"string"},"value":{"anyOf":[{"type":"integer"},{"type":"string"}],"description":"value is the target value of the metric (as a quantity).","pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true}},"required":["type"],"type":"object"}},"required":["describedObject","metric","target"],"type":"object"},"pods":{"description":"pods refers to a metric describing each pod in the current scale target\n(for example, transactions-processed-per-second).  The values will be\naveraged together before being compared to the target value.","properties":{"metric":{"description":"metric identifies the target metric by name and selector","properties":{"name":{"description":"name is the name of the given metric","type":"string"},"selector":{"description":"selector is the string-encoded form of a standard kubernetes label selector for the given metric\nWhen set, it is passed as an additional parameter to the metrics server for more specific metrics scoping.\nWhen unset, just the metricName will be used to gather metrics.","properties":{"matchExpressions":{"description":"matchExpressions is a list of label selector requirements. The requirements are ANDed.","items":{"description":"A label selector requirement is a selector that contains values, a key, and an operator that\nrelates the key and values.","properties":{"key":{"description":"key is the label key that the selector applies to.","type":"string"},"operator":{"description":"operator represents a key's relationship to a set of values.\nValid operators are In, NotIn, Exists and DoesNotExist.","type":"string"},"values":{"description":"values is an array of string values. If the operator is In or NotIn,\nthe values array must be non-empty. If the operator is Exists or DoesNotExist,\nthe values array must be empty. This array is replaced during a strategic\nmerge patch.","items":{"type":"string"},"type":"array"}},"required":["key","operator"],"type":"object"},"type":"array"},"matchLabels":{"additionalProperties":{"type":"string"},"description":"matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.","type":"object"}},"type":"object","x-kubernetes-map-type":"atomic"}},"required":["name"],"type":"object"},"target":{"description":"target specifies the target value for the given metric","properties":{"averageUtilization":{"description":"averageUtilization is the target value of the average of the\nresource metric across all relevant pods, represented as a percentage of\nthe requested value of the resource for the pods.\nCurrently only valid for Resource metric source type","format":"int32","type":"integer"},"averageValue":{"anyOf":[{"type":"integer"},{"type":"string"}],"description":"averageValue is the target value of the average of the\nmetric across all relevant pods (as a quantity)","pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"type":{"description":"type represents whether the metric type is Utilization, Value, or AverageValue","type":"string"},"value":{"anyOf":[{"type":"integer"},{"type":"string"}],"description":"value is the target value of the metric (as a quantity).","pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true}},"required":["type"],"type":"object"}},"required":["metric","target"],"type":"object"},"resource":{"description":"resource refers to a resource metric (such as those specified in\nrequests and limits) known to Kubernetes describing each pod in the\ncurrent scale target (e.g. CPU or memory). Such metrics are built in to\nKubernetes, and have special scaling options on top of those available\nto normal per-pod metrics using the \"pods\" source.","properties":{"name":{"description":"name is the name of the resource in question.","type":"string"},"target":{"description":"target specifies the target value for the given metric","properties":{"averageUtilization":{"description":"averageUtilization is the target value of the average of the\nresource metric across all relevant pods, represented as a percentage of\nthe requested value of the resource for the pods.\nCurrently only valid for Resource metric source type","format":"int32","type":"integer"},"averageValue":{"anyOf":[{"type":"integer"},{"type":"string"}],"description":"averageValue is the target value of the average of the\nmetric across all relevant pods (as a quantity)","pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"type":{"description":"type represents whether the metric type is Utilization, Value, or AverageValue","type":"string"},"value":{"anyOf":[{"type":"integer"},{"type":"string"}],"description":"value is the target value of the metric (as a quantity).","pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true}},"required":["type"],"type":"object"}},"required":["name","target"],"type":"object"},"type":{"description":"type is the type of metric source.  It should be one of \"ContainerResource\", \"External\",\n\"Object\", \"Pods\" or \"Resource\", each mapping to a matching field in the object.\nNote: \"ContainerResource\" type is available on when the feature-gate\nHPAContainerMetrics is enabled","type":"string"}},"required":["type"],"type":"object"},"type":"array"},"minReplicas":{"description":"minReplicas is the lower limit for the number of replicas to which the autoscaler\ncan scale down.  It defaults to 1 pod.  minReplicas is allowed to be 0 if the\nalpha feature gate HPAScaleToZero is enabled and at least one Object or External\nmetric is configured.  Scaling is active as long as at least one metric value is\navailable.","format":"int32","type":"integer"}},"required":["maxReplicas"],"type":"object"},"static":{"description":"Configure a static number of replicas. Defaults to 1.","format":"int32","type":"integer"}},"type":"object"},"resources":{"description":"Resources holds the resource requirements to use for the Envoy\nDeployment. Defaults to no resource requests nor limits.","properties":{"claims":{"description":"Claims lists the names of resources, defined in spec.resourceClaims,\nthat are used by this container.\n\n\nThis is an alpha field and requires enabling the\nDynamicResourceAllocation feature gate.\n\n\nThis field is immutable. It can only be set for containers.","items":{"description":"ResourceClaim references one entry in PodSpec.ResourceClaims.","properties":{"name":{"description":"Name must match the name of one entry in pod.spec.resourceClaims of\nthe Pod where this field is used. It makes that resource available\ninside a container.","type":"string"}},"required":["name"],"type":"object"},"type":"array","x-kubernetes-list-map-keys":["name"],"x-kubernetes-list-type":"map"},"limits":{"additionalProperties":{"anyOf":[{"type":"integer"},{"type":"string"}],"pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"description":"Limits describes the maximum amount of compute resources allowed.\nMore info: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/","type":"object"},"requests":{"additionalProperties":{"anyOf":[{"type":"integer"},{"type":"string"}],"pattern":"^(\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\\+|-)?(([0-9]+(\\.[0-9]*)?)|(\\.[0-9]+))))?$","x-kubernetes-int-or-string":true},"description":"Requests describes the minimum amount of compute resources required.\nIf Requests is omitted for a container, it defaults to Limits if that is explicitly specified,\notherwise to an implementation-defined value. Requests cannot exceed Limits.\nMore info: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/","type":"object"}},"type":"object"},"shutdownManager":{"description":"ShutdownManager defines configuration for Envoy's shutdown\nmanager, which handles graceful termination of Envoy pods","properties":{"drainStrategy":{"description":"The drain strategy for the graceful shutdown. It also affects\ndrain when listeners are modified or removed via LDS.","enum":["gradual","immediate"],"type":"string"},"drainTime":{"description":"The time in seconds that Envoy will drain connections during shutdown.\nIt also affects drain behaviour when listeners are modified or removed via LDS.","format":"int64","type":"integer"},"image":{"description":"Image is the shutdown manager image and tag to use","type":"string"},"serverPort":{"description":"Configures the sutdown manager's server port. Defaults to 8090.","format":"int32","type":"integer"}},"type":"object"}},"required":["discoveryServiceRef","envoyConfigRef"],"type":"object"},"status":{"description":"EnvoyDeploymentStatus defines the observed state of EnvoyDeployment","properties":{"deploymentName":{"type":"string"},"deploymentStatus":{"description":"DeploymentStatus is the most recently observed status of the Deployment.","properties":{"availableReplicas":{"description":"Total number of available pods (ready for at least minReadySeconds) targeted by this deployment.","format":"int32","type":"integer"},"collisionCount":{"description":"Count of hash collisions for the Deployment. The Deployment controller uses this\nfield as a collision avoidance mechanism when it needs to create the name for the\nnewest ReplicaSet.","format":"int32","type":"integer"},"conditions":{"description":"Represents the latest available observations of a deployment's current state.","items":{"description":"DeploymentCondition describes the state of a deployment at a certain point.","properties":{"lastTransitionTime":{"description":"Last time the condition transitioned from one status to another.","format":"date-time","type":"string"},"lastUpdateTime":{"description":"The last time this condition was updated.","format":"date-time","type":"string"},"message":{"description":"A human readable message indicating details about the transition.","type":"string"},"reason":{"description":"The reason for the condition's last transition.","type":"string"},"status":{"description":"Status of the condition, one of True, False, Unknown.","type":"string"},"type":{"description":"Type of deployment condition.","type":"string"}},"required":["status","type"],"type":"object"},"type":"array"},"observedGeneration":{"description":"The generation observed by the deployment controller.","format":"int64","type":"integer"},"readyReplicas":{"description":"readyReplicas is the number of pods targeted by this Deployment with a Ready Condition.","format":"int32","type":"integer"},"replicas":{"description":"Total number of non-terminated pods targeted by this deployment (their labels match the selector).","format":"int32","type":"integer"},"unavailableReplicas":{"description":"Total number of unavailable pods targeted by this deployment. This is the total number of\npods that are still required for the deployment to have 100% available capacity. They may\neither be pods that are running but not yet available or pods that still have not been created.","format":"int32","type":"integer"},"updatedReplicas":{"description":"Total number of non-terminated pods targeted by this deployment that have the desired template spec.","format":"int32","type":"integer"}},"type":"object"}},"type":"object"}},"type":"object"}},"served":true,"storage":true,"subresources":{"status":{}}}]},"status":{"acceptedNames":{"kind":"","plural":""},"conditions":null,"storedVersions":null}} +relatedImages: +- image: quay.io/3scale/marin3r-bundle:v0.13.2-alpha.2 + name: "" +- image: quay.io/3scale/marin3r:v0.13.2-alpha.2 + name: "" +schema: olm.bundle diff --git a/config/manager/kustomization.yaml b/config/manager/kustomization.yaml index afa2da14..7bac200e 100644 --- a/config/manager/kustomization.yaml +++ b/config/manager/kustomization.yaml @@ -13,7 +13,7 @@ kind: Kustomization images: - name: controller newName: quay.io/3scale/marin3r - newTag: v0.13.2-alpha.1 + newTag: v0.13.2-alpha.2 patchesStrategicMerge: - custom/manager_patch.yaml diff --git a/config/webhook/kustomization.yaml b/config/webhook/kustomization.yaml index 5fc79bef..3253078e 100644 --- a/config/webhook/kustomization.yaml +++ b/config/webhook/kustomization.yaml @@ -10,7 +10,7 @@ kind: Kustomization images: - name: controller newName: quay.io/3scale/marin3r - newTag: v0.13.2-alpha.1 + newTag: v0.13.2-alpha.2 # [CUSTOM: pod mutating webhook config] This patch adds a label selector to the MutatingWebhookConfig patchesStrategicMerge: diff --git a/pkg/image/zz_generated.go b/pkg/image/zz_generated.go index 90726247..768fb6e1 100644 --- a/pkg/image/zz_generated.go +++ b/pkg/image/zz_generated.go @@ -1,5 +1,5 @@ package image const ( - image string = "quay.io/3scale/marin3r:v0.13.2-alpha.1" + image string = "quay.io/3scale/marin3r:v0.13.2-alpha.2" ) diff --git a/pkg/version/zz_generated.go b/pkg/version/zz_generated.go index bb6288d7..01b2949f 100644 --- a/pkg/version/zz_generated.go +++ b/pkg/version/zz_generated.go @@ -1,5 +1,5 @@ package version const ( - version string = "v0.13.2-alpha.1" + version string = "v0.13.2-alpha.2" )