rancher-partner-charts/charts/confluent/confluent-for-kubernetes/crds/platform.confluent.io_schem...

503 lines
25 KiB
YAML

---
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
annotations:
controller-gen.kubebuilder.io/version: v0.9.2
creationTimestamp: null
name: schemaexporters.platform.confluent.io
spec:
group: platform.confluent.io
names:
categories:
- all
- confluent-platform
- confluent
kind: SchemaExporter
listKind: SchemaExporterList
plural: schemaexporters
shortNames:
- se
- schemaexporter
singular: schemaexporter
scope: Namespaced
versions:
- additionalPrinterColumns:
- jsonPath: .status.contextName
name: ContextName
type: string
- jsonPath: .status.exporterStatus
name: ExporterStatus
type: string
- jsonPath: .status.state
name: Status
type: string
- jsonPath: .metadata.creationTimestamp
name: Age
type: date
- jsonPath: .status.sourceSchemaRegistry.endpoint
name: SourceSchemaRegistryEndpoint
priority: 1
type: string
- jsonPath: .status.destinationSchemaRegistry.endpoint
name: DestinationSchemaRegistryEndpoint
priority: 1
type: string
name: v1beta1
schema:
openAPIV3Schema:
description: SchemaExporter is the schema for the SchemaExporter API.
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: spec defines the desired state of the schema exporter.
properties:
configs:
additionalProperties:
type: string
description: 'configs is a map of string key and value pairs. It specifies
additional configurations for the schema exporter. More info: https://docs.confluent.io/platform/current/schema-registry/schema-linking-cp.html#create-a-configuration-file-for-the-exporter'
type: object
x-kubernetes-map-type: granular
contextName:
description: contextName specifies the custom context name in the
destination Schema Registry cluster where the schemas will be exported.
If this is defined, contextType will be ignored. If this is not
defined, schemas will be exported to context in destination based
on contextType.
type: string
contextType:
description: contextType specifies the type of context created in
the destination Schema Registry cluster of the schema exporter.
Valid options are `AUTO` and `NONE`. The default value is `AUTO`.
enum:
- AUTO
- NONE
type: string
destinationCluster:
description: destinationCluster specifies the destination Schema Registry
cluster. If this is not defined, sourceCluster is chosen as the
destination and the schema exporter will be exporting schemas across
contexts within the sourceCluster. Schema exporter should be enabled
in Schema Registry cluster CR with `spec.enableSchemaExporter`.
properties:
schemaRegistryClusterRef:
description: schemaRegistryClusterRef references the CFK-managed
Schema Registry cluster.
properties:
name:
description: name specifies the name of the Confluent Platform
component cluster.
type: string
namespace:
description: namespace specifies the namespace where the Confluent
Platform component cluster is running.
type: string
required:
- name
type: object
schemaRegistryRest:
description: schemaRegistryRest specifies the Schema Registry
REST API configuration.
properties:
authentication:
description: authentication specifies the REST API authentication
mechanism.
properties:
basic:
description: basic specifies the basic authentication
settings for the REST API client.
properties:
debug:
description: debug enables the basic authentication
debug logs for JaaS configuration.
type: boolean
directoryPathInContainer:
description: 'directoryPathInContainer allows to pass
the basic credential through a directory path in
the container. More info: https://docs.confluent.io/operator/current/co-authenticate.html#basic-authentication'
minLength: 1
type: string
restrictedRoles:
description: restrictedRoles specify the restricted
roles on the server side only. Changes will be only
reflected in Control Center. This configuration
is ignored on the client side configuration.
items:
type: string
minItems: 1
type: array
roles:
description: roles specify the roles on the server
side only. This configuration is ignored on the
client side configuration.
items:
type: string
type: array
secretRef:
description: 'secretRef defines secret reference to
pass the required credentials. More info: https://docs.confluent.io/operator/current/co-authenticate.html#basic-authentication'
maxLength: 30
minLength: 1
pattern: ^[a-z0-9]([-a-z0-9]*[a-z0-9])?$
type: string
type: object
bearer:
description: bearer specifies the bearer authentication
settings for the REST API client.
properties:
directoryPathInContainer:
description: directoryPathInContainer specifies the
directory path in the container where the credential
is mounted.
minLength: 1
type: string
secretRef:
description: 'secretRef specifies the name of the
secret that contains the credential. More info:
https://docs.confluent.io/operator/current/co-authenticate.html#bearer-authentication'
maxLength: 30
minLength: 1
pattern: ^[a-z0-9]([-a-z0-9]*[a-z0-9])?$
type: string
type: object
type:
description: type specifies the REST API authentication
type. Valid options are `basic`, `bearer`, and `mtls`.
enum:
- basic
- bearer
- mtls
type: string
required:
- type
type: object
endpoint:
description: endpoint specifies where Confluent REST API is
running.
minLength: 1
pattern: ^https?://.*
type: string
kafkaClusterID:
description: kafkaClusterID specifies the id of Kafka cluster.
It takes precedence over using the Kafka REST API to get
the cluster id.
minLength: 1
type: string
tls:
description: tls specifies the custom TLS structure for the
application resources, e.g. connector, topic, schema, of
the Confluent Platform components.
properties:
directoryPathInContainer:
description: directoryPathInContainer contains the directory
path in the container where `keystore.jks`, `truststore.jks`,
`jksPassword.txt` keys are mounted.
minLength: 1
type: string
jksPassword:
description: jksPassword specifies the secret name that
contains the JKS password.
properties:
secretRef:
description: 'secretRef references the name of the
secret containing the JKS password. More info: https://docs.confluent.io/operator/current/co-network-encryption.html#configure-user-provided-tls-certificates'
maxLength: 30
minLength: 1
pattern: ^[a-z0-9]([-a-z0-9]*[a-z0-9])?$
type: string
required:
- secretRef
type: object
secretRef:
description: 'secretRef specifies the secret name that
contains the certificates. More info about certificates
key/value format: https://docs.confluent.io/operator/current/co-network-encryption.html#configure-user-provided-tls-certificates'
maxLength: 63
minLength: 1
pattern: ^[a-z0-9]([-a-z0-9]*[a-z0-9])?$
type: string
type: object
type: object
type: object
sourceCluster:
description: sourceCluster specifies the source Schema Registry cluster.
Schema exporter will be set up in the source cluster. If this is
not defined, controller will try to auto discover Schema Registry
in the namespace of the schema exporter. If it cannot discover a
Schema Registry cluster or more than one Schema Registry clusters
are found, controller will return error. Schema exporter should
be enabled in Schema Registry cluster CR with `spec.enableSchemaExporter`.
properties:
schemaRegistryClusterRef:
description: schemaRegistryClusterRef references the CFK-managed
Schema Registry cluster.
properties:
name:
description: name specifies the name of the Confluent Platform
component cluster.
type: string
namespace:
description: namespace specifies the namespace where the Confluent
Platform component cluster is running.
type: string
required:
- name
type: object
schemaRegistryRest:
description: schemaRegistryRest specifies the Schema Registry
REST API configuration.
properties:
authentication:
description: authentication specifies the REST API authentication
mechanism.
properties:
basic:
description: basic specifies the basic authentication
settings for the REST API client.
properties:
debug:
description: debug enables the basic authentication
debug logs for JaaS configuration.
type: boolean
directoryPathInContainer:
description: 'directoryPathInContainer allows to pass
the basic credential through a directory path in
the container. More info: https://docs.confluent.io/operator/current/co-authenticate.html#basic-authentication'
minLength: 1
type: string
restrictedRoles:
description: restrictedRoles specify the restricted
roles on the server side only. Changes will be only
reflected in Control Center. This configuration
is ignored on the client side configuration.
items:
type: string
minItems: 1
type: array
roles:
description: roles specify the roles on the server
side only. This configuration is ignored on the
client side configuration.
items:
type: string
type: array
secretRef:
description: 'secretRef defines secret reference to
pass the required credentials. More info: https://docs.confluent.io/operator/current/co-authenticate.html#basic-authentication'
maxLength: 30
minLength: 1
pattern: ^[a-z0-9]([-a-z0-9]*[a-z0-9])?$
type: string
type: object
bearer:
description: bearer specifies the bearer authentication
settings for the REST API client.
properties:
directoryPathInContainer:
description: directoryPathInContainer specifies the
directory path in the container where the credential
is mounted.
minLength: 1
type: string
secretRef:
description: 'secretRef specifies the name of the
secret that contains the credential. More info:
https://docs.confluent.io/operator/current/co-authenticate.html#bearer-authentication'
maxLength: 30
minLength: 1
pattern: ^[a-z0-9]([-a-z0-9]*[a-z0-9])?$
type: string
type: object
type:
description: type specifies the REST API authentication
type. Valid options are `basic`, `bearer`, and `mtls`.
enum:
- basic
- bearer
- mtls
type: string
required:
- type
type: object
endpoint:
description: endpoint specifies where Confluent REST API is
running.
minLength: 1
pattern: ^https?://.*
type: string
kafkaClusterID:
description: kafkaClusterID specifies the id of Kafka cluster.
It takes precedence over using the Kafka REST API to get
the cluster id.
minLength: 1
type: string
tls:
description: tls specifies the custom TLS structure for the
application resources, e.g. connector, topic, schema, of
the Confluent Platform components.
properties:
directoryPathInContainer:
description: directoryPathInContainer contains the directory
path in the container where `keystore.jks`, `truststore.jks`,
`jksPassword.txt` keys are mounted.
minLength: 1
type: string
jksPassword:
description: jksPassword specifies the secret name that
contains the JKS password.
properties:
secretRef:
description: 'secretRef references the name of the
secret containing the JKS password. More info: https://docs.confluent.io/operator/current/co-network-encryption.html#configure-user-provided-tls-certificates'
maxLength: 30
minLength: 1
pattern: ^[a-z0-9]([-a-z0-9]*[a-z0-9])?$
type: string
required:
- secretRef
type: object
secretRef:
description: 'secretRef specifies the secret name that
contains the certificates. More info about certificates
key/value format: https://docs.confluent.io/operator/current/co-network-encryption.html#configure-user-provided-tls-certificates'
maxLength: 63
minLength: 1
pattern: ^[a-z0-9]([-a-z0-9]*[a-z0-9])?$
type: string
type: object
type: object
type: object
subjectRenameFormat:
description: subjectRenameFormat specifies the rename format for the
subjects exported to the destination. For example, if the value
is `my-${subject}`, subjects at destination will become `my-firstSubject`
where `firstSubject` is the original subject name.
type: string
subjects:
description: subjects specifies the list of subjects to be exported
by schema exporter. The default value is `["*"]`. This indicates
all subjects in the default context.
items:
type: string
type: array
type: object
status:
description: status defines the observed state of the schema exporter.
properties:
appState:
default: Unknown
description: appState is the current state of the schema exporter
application.
enum:
- Unknown
- Created
- Failed
- Deleted
type: string
conditions:
description: conditions are the latest available observations of the
schema exporter's state.
items:
description: Condition represent the latest available observations
of the current state.
properties:
lastProbeTime:
description: lastProbeTime shows the last time the condition
was evaluated.
format: date-time
type: string
lastTransitionTime:
description: lastTransitionTime shows the last time the condition
was transitioned from one status to another.
format: date-time
type: string
message:
description: message shows a human-readable message with details
about the transition.
type: string
reason:
description: reason shows the reason for the last transition
of the condition.
type: string
status:
description: status shows the status of the condition, one of
`True`, `False`, or `Unknown`.
type: string
type:
description: type shows the condition type.
type: string
type: object
type: array
contextName:
description: contextName shows the name of the context in the destination
Schema Registry cluster where the schemas will be exported.
type: string
contextType:
description: contextType is the contextType of the schema exporter.
type: string
destinationSchemaRegistry:
description: destinationSchemaRegistry shows the destination Schema
Registry endpoint, authentication type and if it is using TLS.
properties:
authenticationType:
description: authenticationType is the authentication method used
for Schema Registry.
type: string
endpoint:
description: endpoint is the Schema Registry REST endpoint.
type: string
tls:
description: tls shows whether the Schema Registry is using TLS.
type: boolean
type: object
exporterStatus:
description: exporterStatus is the status of the schema exporter.
type: string
observedGeneration:
description: observedGeneration is the most recent generation observed
for this Confluent component.
format: int64
type: integer
sourceSchemaRegistry:
description: sourceSchemaRegistry shows the source Schema Registry
endpoint, authentication type and if it is using TLS.
properties:
authenticationType:
description: authenticationType is the authentication method used
for Schema Registry.
type: string
endpoint:
description: endpoint is the Schema Registry REST endpoint.
type: string
tls:
description: tls shows whether the Schema Registry is using TLS.
type: boolean
type: object
state:
description: state is the current state of the schema exporter.
type: string
subjects:
description: subjects is the list of subjects exported by the schema
exporter.
items:
type: string
type: array
type: object
type: object
served: true
storage: true
subresources:
status: {}