diff --git a/pages/deployments/operator/agent-api.md b/pages/deployments/operator/agent-api.md index 57089f9e..7e9025ac 100644 --- a/pages/deployments/operator/agent-api.md +++ b/pages/deployments/operator/agent-api.md @@ -10,6 +10,9 @@ Package v1alpha1 contains API Schema definitions for the deployments v1alpha1 AP ### Resource Types - [CustomHealth](#customhealth) +- [IngressReplica](#ingressreplica) +- [KubecostExtractor](#kubecostextractor) +- [MetricsAggregate](#metricsaggregate) - [PipelineGate](#pipelinegate) - [UpgradeInsights](#upgradeinsights) - [VirtualCluster](#virtualcluster) @@ -29,9 +32,9 @@ _Appears in:_ | Field | Description | Default | Validation | | --- | --- | --- | --- | -| `region` _string_ | Region is the name of the AWS region cluster lives in. | | Required: {}
| -| `accessKeyID` _string_ | AccessKeyID is your access key ID used to authenticate against AWS API. | | Required: {}
| -| `secretAccessKeyRef` _[SecretReference](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#secretreference-v1-core)_ | SecretAccessKeyRef is a reference to the secret that contains secret access key.
Since UpgradeInsights is a cluster-scoped resource we can't use local reference.
SecretAccessKey must be stored in a key named "secretAccessKey".
An example secret can look like this:
apiVersion: v1
kind: Secret
metadata:
name: eks-credentials
namespace: upgrade-insights-test
stringData:
secretAccessKey: "changeme"
Then it can be referenced like this:
...
secretAccessKeyRef:
name: eks-credentials
namespace: upgrade-insights-test | | Required: {}
| +| `region` _string_ | Region is the name of the AWS region cluster lives in. | | Required: \{\}
| +| `accessKeyID` _string_ | AccessKeyID is your access key ID used to authenticate against AWS API. | | Optional: \{\}
| +| `secretAccessKeyRef` _[SecretReference](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#secretreference-v1-core)_ | SecretAccessKeyRef is a reference to the secret that contains secret access key.
Since UpgradeInsights is a cluster-scoped resource we can't use local reference.
SecretAccessKey must be stored in a key named "secretAccessKey".
An example secret can look like this:
apiVersion: v1
kind: Secret
metadata:
name: eks-credentials
namespace: upgrade-insights-test
stringData:
secretAccessKey: "changeme"
Then it can be referenced like this:
...
secretAccessKeyRef:
name: eks-credentials
namespace: upgrade-insights-test | | Optional: \{\}
| #### AgentHelmConfiguration @@ -48,10 +51,10 @@ _Appears in:_ | Field | Description | Default | Validation | | --- | --- | --- | --- | | `chartName` _string_ | ChartName is a helm chart name. | | | -| `repoUrl` _string_ | RepoUrl is a url that points to this helm chart. | | Optional: {}
Type: string
| -| `values` _[RawExtension](https://pkg.go.dev/k8s.io/apimachinery/pkg/runtime#RawExtension)_ | Values allows defining arbitrary YAML values to pass to the helm as values.yaml file.
Use only one of:
- Values
- ValuesSecretRef
- ValuesConfigMapRef | | Optional: {}
| -| `valuesSecretRef` _[SecretKeySelector](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#secretkeyselector-v1-core)_ | ValuesSecretRef fetches helm values from a secret in this cluster.
Use only one of:
- Values
- ValuesSecretRef
- ValuesConfigMapRef | | Optional: {}
| -| `valuesConfigMapRef` _[ConfigMapKeySelector](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#configmapkeyselector-v1-core)_ | ValuesConfigMapRef fetches helm values from a config map in this cluster.
Use only one of:
- Values
- ValuesSecretRef
- ValuesConfigMapRef | | Optional: {}
| +| `repoUrl` _string_ | RepoUrl is a url that points to this helm chart. | | Optional: \{\}
Type: string
| +| `values` _[RawExtension](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#rawextension-runtime-pkg)_ | Values allows defining arbitrary YAML values to pass to the helm as values.yaml file.
Use only one of:
- Values
- ValuesSecretRef
- ValuesConfigMapRef | | Optional: \{\}
| +| `valuesSecretRef` _[SecretKeySelector](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#secretkeyselector-v1-core)_ | ValuesSecretRef fetches helm values from a secret in this cluster.
Use only one of:
- Values
- ValuesSecretRef
- ValuesConfigMapRef | | Optional: \{\}
| +| `valuesConfigMapRef` _[ConfigMapKeySelector](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#configmapkeyselector-v1-core)_ | ValuesConfigMapRef fetches helm values from a config map in this cluster.
Use only one of:
- Values
- ValuesSecretRef
- ValuesConfigMapRef | | Optional: \{\}
| #### Binding @@ -67,11 +70,11 @@ _Appears in:_ | Field | Description | Default | Validation | | --- | --- | --- | --- | -| `id` _string_ | | | Optional: {}
| -| `UserID` _string_ | | | Optional: {}
| -| `userEmail` _string_ | | | Optional: {}
| -| `groupID` _string_ | | | Optional: {}
| -| `groupName` _string_ | | | Optional: {}
| +| `id` _string_ | | | Optional: \{\}
| +| `UserID` _string_ | | | Optional: \{\}
| +| `userEmail` _string_ | | | Optional: \{\}
| +| `groupID` _string_ | | | Optional: \{\}
| +| `groupName` _string_ | | | Optional: \{\}
| #### Bindings @@ -89,8 +92,8 @@ _Appears in:_ | Field | Description | Default | Validation | | --- | --- | --- | --- | -| `read` _[Binding](#binding) array_ | Read bindings. | | Optional: {}
| -| `write` _[Binding](#binding) array_ | Write bindings. | | Optional: {}
| +| `read` _[Binding](#binding) array_ | Read bindings. | | Optional: \{\}
| +| `write` _[Binding](#binding) array_ | Write bindings. | | Optional: \{\}
| #### ClusterSpec @@ -106,10 +109,10 @@ _Appears in:_ | Field | Description | Default | Validation | | --- | --- | --- | --- | -| `handle` _string_ | Handle is a short, unique human-readable name used to identify this cluster.
Does not necessarily map to the cloud resource name. | | Optional: {}
| -| `tags` _object (keys:string, values:string)_ | Tags used to filter clusters. | | Optional: {}
| -| `metadata` _[RawExtension](https://pkg.go.dev/k8s.io/apimachinery/pkg/runtime#RawExtension)_ | Refer to Kubernetes API documentation for fields of `metadata`. | | Optional: {}
| -| `bindings` _[Bindings](#bindings)_ | Bindings contain read and write policies of this cluster | | Optional: {}
| +| `handle` _string_ | Handle is a short, unique human-readable name used to identify this cluster.
Does not necessarily map to the cloud resource name. | | Optional: \{\}
| +| `tags` _object (keys:string, values:string)_ | Tags used to filter clusters. | | Optional: \{\}
| +| `metadata` _[RawExtension](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#rawextension-runtime-pkg)_ | Refer to Kubernetes API documentation for fields of `metadata`. | | Optional: \{\}
| +| `bindings` _[Bindings](#bindings)_ | Bindings contain read and write policies of this cluster | | Optional: \{\}
| @@ -215,10 +218,10 @@ _Appears in:_ | Field | Description | Default | Validation | | --- | --- | --- | --- | | `chartName` _string_ | ChartName is a helm chart name. | | | -| `repoUrl` _string_ | RepoUrl is a url that points to this helm chart. | | Optional: {}
Type: string
| -| `values` _[RawExtension](https://pkg.go.dev/k8s.io/apimachinery/pkg/runtime#RawExtension)_ | Values allows defining arbitrary YAML values to pass to the helm as values.yaml file.
Use only one of:
- Values
- ValuesSecretRef
- ValuesConfigMapRef | | Optional: {}
| -| `valuesSecretRef` _[SecretKeySelector](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#secretkeyselector-v1-core)_ | ValuesSecretRef fetches helm values from a secret in this cluster.
Use only one of:
- Values
- ValuesSecretRef
- ValuesConfigMapRef | | Optional: {}
| -| `valuesConfigMapRef` _[ConfigMapKeySelector](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#configmapkeyselector-v1-core)_ | ValuesConfigMapRef fetches helm values from a config map in this cluster.
Use only one of:
- Values
- ValuesSecretRef
- ValuesConfigMapRef | | Optional: {}
| +| `repoUrl` _string_ | RepoUrl is a url that points to this helm chart. | | Optional: \{\}
Type: string
| +| `values` _[RawExtension](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#rawextension-runtime-pkg)_ | Values allows defining arbitrary YAML values to pass to the helm as values.yaml file.
Use only one of:
- Values
- ValuesSecretRef
- ValuesConfigMapRef | | Optional: \{\}
| +| `valuesSecretRef` _[SecretKeySelector](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#secretkeyselector-v1-core)_ | ValuesSecretRef fetches helm values from a secret in this cluster.
Use only one of:
- Values
- ValuesSecretRef
- ValuesConfigMapRef | | Optional: \{\}
| +| `valuesConfigMapRef` _[ConfigMapKeySelector](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#configmapkeyselector-v1-core)_ | ValuesConfigMapRef fetches helm values from a config map in this cluster.
Use only one of:
- Values
- ValuesSecretRef
- ValuesConfigMapRef | | Optional: \{\}
| #### HelmSpec @@ -234,8 +237,101 @@ _Appears in:_ | Field | Description | Default | Validation | | --- | --- | --- | --- | -| `agent` _[AgentHelmConfiguration](#agenthelmconfiguration)_ | Agent allows configuring agent specific helm chart options. | | Optional: {}
| -| `vcluster` _[VClusterHelmConfiguration](#vclusterhelmconfiguration)_ | VCluster allows configuring vcluster specific helm chart options. | | Optional: {}
| +| `agent` _[AgentHelmConfiguration](#agenthelmconfiguration)_ | Agent allows configuring agent specific helm chart options. | | Optional: \{\}
| +| `vcluster` _[VClusterHelmConfiguration](#vclusterhelmconfiguration)_ | VCluster allows configuring vcluster specific helm chart options. | | Optional: \{\}
| + + +#### IngressReplica + + + +IngressReplica is the Schema for the console ingress replica + + + + + +| Field | Description | Default | Validation | +| --- | --- | --- | --- | +| `apiVersion` _string_ | `deployments.plural.sh/v1alpha1` | | | +| `kind` _string_ | `IngressReplica` | | | +| `metadata` _[ObjectMeta](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#objectmeta-v1-meta)_ | Refer to Kubernetes API documentation for fields of `metadata`. | | | +| `spec` _[IngressReplicaSpec](#ingressreplicaspec)_ | Spec of the IngressReplica | | Required: \{\}
| + + +#### IngressReplicaSpec + + + + + + + +_Appears in:_ +- [IngressReplica](#ingressreplica) + +| Field | Description | Default | Validation | +| --- | --- | --- | --- | +| `ingressRef` _[ObjectReference](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#objectreference-v1-core)_ | | | Required: \{\}
| +| `ingressClassName` _string_ | | | Optional: \{\}
| +| `tls` _[IngressTLS](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#ingresstls-v1-networking) array_ | | | Optional: \{\}
| +| `hostMappings` _object (keys:string, values:string)_ | | | Required: \{\}
| + + +#### KubecostExtractor + + + +KubecostExtractor + + + + + +| Field | Description | Default | Validation | +| --- | --- | --- | --- | +| `apiVersion` _string_ | `deployments.plural.sh/v1alpha1` | | | +| `kind` _string_ | `KubecostExtractor` | | | +| `metadata` _[ObjectMeta](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#objectmeta-v1-meta)_ | Refer to Kubernetes API documentation for fields of `metadata`. | | | +| `spec` _[KubecostExtractorSpec](#kubecostextractorspec)_ | | | | + + +#### KubecostExtractorSpec + + + + + + + +_Appears in:_ +- [KubecostExtractor](#kubecostextractor) + +| Field | Description | Default | Validation | +| --- | --- | --- | --- | +| `interval` _string_ | | 1h | Optional: \{\}
| +| `kubecostServiceRef` _[ObjectReference](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#objectreference-v1-core)_ | | | | +| `kubecostPort` _integer_ | | | Optional: \{\}
| +| `recommendationThreshold` _string_ | RecommendationThreshold float value for example: `1.2 or 0.001` | | | + + +#### MetricsAggregate + + + +MetricsAggregate + + + + + +| Field | Description | Default | Validation | +| --- | --- | --- | --- | +| `apiVersion` _string_ | `deployments.plural.sh/v1alpha1` | | | +| `kind` _string_ | `MetricsAggregate` | | | +| `metadata` _[ObjectMeta](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#objectmeta-v1-meta)_ | Refer to Kubernetes API documentation for fields of `metadata`. | | | + + #### PipelineGate @@ -290,7 +386,7 @@ _Appears in:_ | Field | Description | Default | Validation | | --- | --- | --- | --- | -| `aws` _[AWSProviderCredentials](#awsprovidercredentials)_ | AWS defines attributes required to auth with AWS API. | | Optional: {}
| +| `aws` _[AWSProviderCredentials](#awsprovidercredentials)_ | AWS defines attributes required to auth with AWS API. | | Optional: \{\}
| #### Status @@ -306,8 +402,8 @@ _Appears in:_ | Field | Description | Default | Validation | | --- | --- | --- | --- | -| `id` _string_ | ID of the resource in the Console API. | | Optional: {}
Type: string
| -| `sha` _string_ | SHA of last applied configuration. | | Optional: {}
Type: string
| +| `id` _string_ | ID of the resource in the Console API. | | Optional: \{\}
Type: string
| +| `sha` _string_ | SHA of last applied configuration. | | Optional: \{\}
Type: string
| | `conditions` _[Condition](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#condition-v1-meta) array_ | Represents the observations of a PrAutomation's current state. | | | @@ -344,10 +440,10 @@ _Appears in:_ | Field | Description | Default | Validation | | --- | --- | --- | --- | -| `distro` _[ClusterDistro](#clusterdistro)_ | Distro defines which provider API should be used to fetch latest upgrade insights.
If not provided, we get the distro from the Plural API cluster tied to this operator deploy token. | | Enum: [EKS]
Optional: {}
| -| `clusterName` _string_ | ClusterName is your cloud provider cluster identifier (usually name) that is used
to fetch latest upgrade insights information from the cloud provider API.
If not provided, we get the cluster name from the Plural API cluster tied to this
operator deploy token and assume that it is the same as the cluster name in your cloud provider. | | Optional: {}
| -| `interval` _string_ | Interval defines how often should the upgrade insights information be fetched. | 10m | Optional: {}
| -| `credentials` _[ProviderCredentials](#providercredentials)_ | Credentials allow overriding default provider credentials bound to the operator. | | Optional: {}
| +| `distro` _[ClusterDistro](#clusterdistro)_ | Distro defines which provider API should be used to fetch latest upgrade insights.
If not provided, we get the distro from the Plural API cluster tied to this operator deploy token. | | Enum: [EKS]
Optional: \{\}
| +| `clusterName` _string_ | ClusterName is your cloud provider cluster identifier (usually name) that is used
to fetch latest upgrade insights information from the cloud provider API.
If not provided, we get the cluster name from the Plural API cluster tied to this
operator deploy token and assume that it is the same as the cluster name in your cloud provider. | | Optional: \{\}
| +| `interval` _string_ | Interval defines how often should the upgrade insights information be fetched. | 10m | Optional: \{\}
| +| `credentials` _[ProviderCredentials](#providercredentials)_ | Credentials allow overriding default provider credentials bound to the operator. | | Optional: \{\}
| #### VClusterHelmConfiguration @@ -364,10 +460,10 @@ _Appears in:_ | Field | Description | Default | Validation | | --- | --- | --- | --- | | `chartName` _string_ | ChartName is a helm chart name. | | | -| `repoUrl` _string_ | RepoUrl is a url that points to this helm chart. | | Optional: {}
Type: string
| -| `values` _[RawExtension](https://pkg.go.dev/k8s.io/apimachinery/pkg/runtime#RawExtension)_ | Values allows defining arbitrary YAML values to pass to the helm as values.yaml file.
Use only one of:
- Values
- ValuesSecretRef
- ValuesConfigMapRef | | Optional: {}
| -| `valuesSecretRef` _[SecretKeySelector](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#secretkeyselector-v1-core)_ | ValuesSecretRef fetches helm values from a secret in this cluster.
Use only one of:
- Values
- ValuesSecretRef
- ValuesConfigMapRef | | Optional: {}
| -| `valuesConfigMapRef` _[ConfigMapKeySelector](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#configmapkeyselector-v1-core)_ | ValuesConfigMapRef fetches helm values from a config map in this cluster.
Use only one of:
- Values
- ValuesSecretRef
- ValuesConfigMapRef | | Optional: {}
| +| `repoUrl` _string_ | RepoUrl is a url that points to this helm chart. | | Optional: \{\}
Type: string
| +| `values` _[RawExtension](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#rawextension-runtime-pkg)_ | Values allows defining arbitrary YAML values to pass to the helm as values.yaml file.
Use only one of:
- Values
- ValuesSecretRef
- ValuesConfigMapRef | | Optional: \{\}
| +| `valuesSecretRef` _[SecretKeySelector](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#secretkeyselector-v1-core)_ | ValuesSecretRef fetches helm values from a secret in this cluster.
Use only one of:
- Values
- ValuesSecretRef
- ValuesConfigMapRef | | Optional: \{\}
| +| `valuesConfigMapRef` _[ConfigMapKeySelector](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#configmapkeyselector-v1-core)_ | ValuesConfigMapRef fetches helm values from a config map in this cluster.
Use only one of:
- Values
- ValuesSecretRef
- ValuesConfigMapRef | | Optional: \{\}
| #### VirtualCluster @@ -385,7 +481,7 @@ VirtualCluster is the Schema for the virtual cluster API | `apiVersion` _string_ | `deployments.plural.sh/v1alpha1` | | | | `kind` _string_ | `VirtualCluster` | | | | `metadata` _[ObjectMeta](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#objectmeta-v1-meta)_ | Refer to Kubernetes API documentation for fields of `metadata`. | | | -| `spec` _[VirtualClusterSpec](#virtualclusterspec)_ | Spec ... | | Required: {}
| +| `spec` _[VirtualClusterSpec](#virtualclusterspec)_ | Spec ... | | Required: \{\}
| #### VirtualClusterSpec @@ -401,11 +497,11 @@ _Appears in:_ | Field | Description | Default | Validation | | --- | --- | --- | --- | -| `kubeconfigRef` _[LocalObjectReference](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#localobjectreference-v1-core)_ | KubeconfigRef is a reference to the secret created by the
vcluster helm chart. It contains kubeconfig with information
on how to access created virtual cluster. | | Required: {}
| -| `credentialsRef` _[SecretKeySelector](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#secretkeyselector-v1-core)_ | CredentialsRef is a reference to the secret pointing to the
key that holds Console API access token. It allows to communicate
with the standard Console API. | | Required: {}
| -| `cluster` _[ClusterSpec](#clusterspec)_ | Cluster is a simplified representation of the Console API cluster
object. See [ClusterSpec] for more information. | | Optional: {}
| -| `external` _boolean_ | External marks this virtual cluster as external one, meaning
that the vcluster deployment will not be automatically created.
User has to pre-provision vcluster and provide a valid KubeconfigRef
pointing to an existing vcluster installation. | | Optional: {}
| -| `helm` _[HelmSpec](#helmspec)_ | Helm allows configuring helm chart options of both agent and vcluster.
It is then deployed by the [VirtualCluster] CRD controller. | | Optional: {}
| +| `kubeconfigRef` _[LocalObjectReference](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#localobjectreference-v1-core)_ | KubeconfigRef is a reference to the secret created by the
vcluster helm chart. It contains kubeconfig with information
on how to access created virtual cluster. | | Required: \{\}
| +| `credentialsRef` _[SecretKeySelector](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.29/#secretkeyselector-v1-core)_ | CredentialsRef is a reference to the secret pointing to the
key that holds Console API access token. It allows to communicate
with the standard Console API. | | Required: \{\}
| +| `cluster` _[ClusterSpec](#clusterspec)_ | Cluster is a simplified representation of the Console API cluster
object. See [ClusterSpec] for more information. | | Optional: \{\}
| +| `external` _boolean_ | External marks this virtual cluster as external one, meaning
that the vcluster deployment will not be automatically created.
User has to pre-provision vcluster and provide a valid KubeconfigRef
pointing to an existing vcluster installation. | | Optional: \{\}
| +| `helm` _[HelmSpec](#helmspec)_ | Helm allows configuring helm chart options of both agent and vcluster.
It is then deployed by the [VirtualCluster] CRD controller. | | Optional: \{\}
|