apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
  annotations:
    controller-gen.kubebuilder.io/version: v0.18.0
  creationTimestamp: "2026-04-04T02:17:00Z"
  generation: 1
  name: galeras.mariadb.openstack.org
  resourceVersion: "38662"
  uid: fa985197-aa05-4de5-99ef-7fd01c80f4f6
spec:
  conversion:
    strategy: None
  group: mariadb.openstack.org
  names:
    kind: Galera
    listKind: GaleraList
    plural: galeras
    singular: galera
  scope: Namespaced
  versions:
  - additionalPrinterColumns:
    - description: Ready
      jsonPath: .status.conditions[0].status
      name: Ready
      type: string
    - description: Message
      jsonPath: .status.conditions[0].message
      name: Message
      type: string
    name: v1beta1
    schema:
      openAPIV3Schema:
        description: Galera is the Schema for the galeras 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: GaleraSpec defines the desired state of Galera
            properties:
              containerImage:
                description: Name of the galera container image to run (will be set
                  to environmental default if empty)
                type: string
              customServiceConfig:
                description: |-
                  Customize config using this parameter to change service defaults,
                  or overwrite rendered information using raw MariaDB config format.
                  The content gets added to /etc/my.cnf.d/galera_custom.cnf
                type: string
              disableNonTLSListeners:
                description: When TLS is configured, only allow connections to the
                  DB over TLS
                type: boolean
              logToDisk:
                description: Log Galera pod's output to disk
                type: boolean
              nodeSelector:
                additionalProperties:
                  type: string
                description: NodeSelector to target subset of worker nodes running
                  this service
                type: object
              replicas:
                default: 1
                description: Size of the galera cluster deployment
                format: int32
                maximum: 3
                minimum: 0
                type: integer
              resources:
                description: Resources QoS configuration for pods
                properties:
                  claims:
                    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.
                          type: string
                        request:
                          description: |-
                            Request is the name chosen for a request in the referenced claim.
                            If empty, everything from the claim is made available, otherwise
                            only the result of this request.
                          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
              rootDatabaseAccount:
                description: |-
                  RootDatabaseAccount - name of MariaDBAccount which will be used to
                  generate root account / password.
                  this account is generated if not exists, and a name is chosen based
                  on a naming convention if not present
                type: string
              secret:
                description: |-
                  Name of the legacy secret to locate the initial galera root
                  password
                  this field will be removed once scripts can adjust to using root_auth.sh
                type: string
              storageClass:
                description: Storage class to host the mariadb databases
                type: string
              storageRequest:
                description: Storage size allocated for the mariadb databases
                type: string
              tls:
                description: TLS settings for MySQL service and internal Galera replication
                properties:
                  caBundleSecretName:
                    description: CaBundleSecretName - holding the CA certs in a pre-created
                      bundle file
                    type: string
                  secretName:
                    description: SecretName - holding the cert, key for the service
                    type: string
                type: object
              topologyRef:
                description: |-
                  TopologyRef to apply the Topology defined by the associated CR referenced
                  by name
                properties:
                  name:
                    description: Name - The Topology CR name that the Service references
                    type: string
                  namespace:
                    description: |-
                      Namespace - The Namespace to fetch the Topology CR referenced
                      NOTE: Namespace currently points by default to the same namespace where
                      the Service is deployed. Customizing the namespace is not supported and
                      webhooks prevent editing this field to a value different from the
                      current project
                    type: string
                type: object
            required:
            - containerImage
            - replicas
            - storageClass
            - storageRequest
            type: object
          status:
            description: GaleraStatus defines the observed state of Galera
            properties:
              attributes:
                additionalProperties:
                  description: GaleraAttributes holds startup information for a Galera
                    host
                  properties:
                    containerID:
                      description: Identifier of the container at the time the gcomm
                        URI was injected
                      type: string
                    gcomm:
                      description: Gcomm URI used to connect to the galera cluster
                      type: string
                    no_grastate:
                      description: This galera node has its state recovered from the
                        DB
                      type: boolean
                    safe_to_bootstrap:
                      description: This galera node can bootstrap a galera cluster
                      type: boolean
                    seqno:
                      description: Last recorded replication sequence number in the
                        DB
                      type: string
                    uuid:
                      description: UUID of the partition that is seen by the galera
                        node
                      type: string
                  required:
                  - seqno
                  type: object
                description: A map of database node attributes for each pod
                type: object
              bootstrapped:
                default: false
                description: Is the galera cluster currently running
                type: boolean
              clusterProperties:
                additionalProperties:
                  type: string
                description: Map of properties that require full cluster restart if
                  changed
                type: object
              conditions:
                description: Deployment Conditions
                items:
                  description: Condition defines an observation of a API resource
                    operational state.
                  properties:
                    lastTransitionTime:
                      description: |-
                        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: A human readable message indicating details about
                        the transition.
                      type: string
                    reason:
                      description: The reason for the condition's last transition
                        in CamelCase.
                      type: string
                    severity:
                      description: |-
                        Severity provides a classification of Reason code, so the current situation is immediately
                        understandable and could act accordingly.
                        It is meant for situations where Status=False and it should be indicated if it is just
                        informational, warning (next reconciliation might fix it) or an error (e.g. DB create issue
                        and no actions to automatically resolve the issue can/should be done).
                        For conditions where Status=Unknown or Status=True the Severity should be SeverityNone.
                      type: string
                    status:
                      description: Status of the condition, one of True, False, Unknown.
                      type: string
                    type:
                      description: Type of condition in CamelCase.
                      type: string
                  required:
                  - lastTransitionTime
                  - status
                  - type
                  type: object
                type: array
              hash:
                additionalProperties:
                  type: string
                description: Map of hashes to track input changes
                type: object
              lastAppliedTopology:
                description: LastAppliedTopology - the last applied Topology
                properties:
                  name:
                    description: Name - The Topology CR name that the Service references
                    type: string
                  namespace:
                    description: |-
                      Namespace - The Namespace to fetch the Topology CR referenced
                      NOTE: Namespace currently points by default to the same namespace where
                      the Service is deployed. Customizing the namespace is not supported and
                      webhooks prevent editing this field to a value different from the
                      current project
                    type: string
                type: object
              observedGeneration:
                description: |-
                  ObservedGeneration - the most recent generation observed for this
                  service. If the observed generation is less than the spec generation,
                  then the controller has not processed the latest changes injected by
                  the opentack-operator in the top-level CR (e.g. the ContainerImage)
                format: int64
                type: integer
              rootDatabaseSecret:
                description: name of the Secret that is being used for the root password
                type: string
              safeToBootstrap:
                description: Name of the node that can safely bootstrap a cluster
                type: string
              stopRequired:
                default: false
                description: Does the galera cluster requires to be stopped globally
                type: boolean
            required:
            - bootstrapped
            - stopRequired
            type: object
        type: object
    served: true
    storage: true
    subresources:
      status: {}
status:
  acceptedNames:
    kind: Galera
    listKind: GaleraList
    plural: galeras
    singular: galera
  conditions:
  - lastTransitionTime: "2026-04-04T02:17:00Z"
    message: no conflicts found
    reason: NoConflicts
    status: "True"
    type: NamesAccepted
  - lastTransitionTime: "2026-04-04T02:17:00Z"
    message: the initial names have been accepted
    reason: InitialNamesAccepted
    status: "True"
    type: Established
  storedVersions:
  - v1beta1
