--- apiVersion: apiextensions.k8s.io/v1 kind: CustomResourceDefinition metadata: annotations: controller-gen.kubebuilder.io/version: (unknown) name: clusters.edge.ncr.com spec: group: edge.ncr.com names: kind: Cluster listKind: ClusterList plural: clusters singular: cluster scope: Cluster versions: - additionalPrinterColumns: - jsonPath: .spec.name name: ClusterName type: string - jsonPath: .spec.projectId name: ProjectID type: string - jsonPath: .spec.banner name: Banner type: string - jsonPath: .spec.fleet name: Fleet type: string - jsonPath: .spec.organization name: Organization type: string - jsonPath: .status.conditions[?(@.type=="Ready")].status name: Ready type: string - jsonPath: .status.conditions[?(@.type=="Ready")].message name: Status type: string name: v1alpha1 schema: openAPIV3Schema: description: Cluster is the Schema for the clusters 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: ClusterSpec defines the desired state of Cluster properties: autoscale: type: boolean banner: type: string banner_edge_id: type: string cluster_artifacts: description: |- Deprecated: Adding this was a mistake. Remove during migration to v1alpha2 Tracking: https://github.com/ncr-swt-retail/edge-roadmap/issues/7862 items: description: |- ArtifactVersion is a reference to an OCI artifact. E.g., store:latest. Name is provided without a registry context. Version may either be a tag or a digest properties: name: type: string version: type: string required: - name - version type: object type: array cluster_id: description: |- Deprecated: Remove during migration to v1alpha2 Tracking: https://github.com/ncr-swt-retail/edge-roadmap/issues/7862 type: string edge_id_syncing: description: |- Deprecated: Remove during migration to v1alpha2 Tracking: https://github.com/ncr-swt-retail/edge-roadmap/issues/7862 type: boolean fleet: description: Type is the enum type representing Edge Fleets type: string interval: default: 120s description: |- Interval is how often the object will be reconciled, in order to prevent drift. type: string location: description: Fields required for GKE only type: string machine_type: type: string max_nodes: type: integer min_nodes: type: integer name: type: string node_version: description: node version is optional. if not provided it will default to be on the stable type: string num_node: type: integer organization: type: string projectId: type: string type: description: Type is the enum type representing Edge Cluster Types type: string required: - banner - fleet - name - organization - projectId - type type: object status: default: observedGeneration: -1 description: ClusterStatus defines the observed state of Cluster properties: conditions: 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. 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 external_inventory: description: ExternalResourceInventory contains a list of resources not in kubernetes properties: okta_client: description: OktaClient contains the ID and name of an okta app properties: id: type: string name: type: string type: object secret_manager_secrets: description: SecretManagerSecrets list of secret ids in gcp secret manager items: type: string type: array required: - secret_manager_secrets type: object inventory: description: |- ResourceInventory contains a list of Kubernetes resource object references that have been applied. properties: entries: description: Entries of Kubernetes resource object references. items: description: ResourceRef contains the information necessary to locate a resource within a cluster. properties: id: description: |- ID is the string representation of the Kubernetes resource object's metadata, in the format '___'. type: string v: description: Version is the API version of the Kubernetes resource object's kind. type: string required: - id - v type: object type: array type: object observedGeneration: format: int64 type: integer type: object type: object served: true storage: true subresources: status: {}