github.com/oam-dev/kubevela@v1.9.11/pkg/multicluster/testdata/managedclusters.yaml (about)

     1  apiVersion: apiextensions.k8s.io/v1
     2  kind: CustomResourceDefinition
     3  metadata:
     4    name: managedclusters.cluster.open-cluster-management.io
     5  spec:
     6    group: cluster.open-cluster-management.io
     7    names:
     8      kind: ManagedCluster
     9      listKind: ManagedClusterList
    10      plural: managedclusters
    11      shortNames:
    12        - mcl
    13        - mcls
    14      singular: managedcluster
    15    scope: Cluster
    16    preserveUnknownFields: false
    17    versions:
    18      - additionalPrinterColumns:
    19          - jsonPath: .spec.hubAcceptsClient
    20            name: Hub Accepted
    21            type: boolean
    22          - jsonPath: .spec.managedClusterClientConfigs[*].url
    23            name: Managed Cluster URLs
    24            type: string
    25          - jsonPath: .status.conditions[?(@.type=="ManagedClusterJoined")].status
    26            name: Joined
    27            type: string
    28          - jsonPath: .status.conditions[?(@.type=="ManagedClusterConditionAvailable")].status
    29            name: Available
    30            type: string
    31          - jsonPath: .metadata.creationTimestamp
    32            name: Age
    33            type: date
    34        name: v1
    35        schema:
    36          openAPIV3Schema:
    37            description: "ManagedCluster represents the desired state and current status of managed cluster. ManagedCluster is a cluster scoped resource. The name is the cluster UID. \n The cluster join process follows a double opt-in process: \n 1. Agent on managed cluster creates CSR on hub with cluster UID and agent name. 2. Agent on managed cluster creates ManagedCluster on hub. 3. Cluster admin on hub approves the CSR for UID and agent name of the ManagedCluster. 4. Cluster admin sets spec.acceptClient of ManagedCluster to true. 5. Cluster admin on managed cluster creates credential of kubeconfig to hub. \n Once the hub creates the cluster namespace, the Klusterlet agent on the ManagedCluster pushes the credential to the hub to use against the kube-apiserver of the ManagedCluster."
    38            type: object
    39            properties:
    40              apiVersion:
    41                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'
    42                type: string
    43              kind:
    44                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'
    45                type: string
    46              metadata:
    47                type: object
    48              spec:
    49                description: Spec represents a desired configuration for the agent on the managed cluster.
    50                type: object
    51                properties:
    52                  hubAcceptsClient:
    53                    description: hubAcceptsClient represents that hub accepts the joining of Klusterlet agent on the managed cluster with the hub. The default value is false, and can only be set true when the user on hub has an RBAC rule to UPDATE on the virtual subresource of managedclusters/accept. When the value is set true, a namespace whose name is the same as the name of ManagedCluster is created on the hub. This namespace represents the managed cluster, also role/rolebinding is created on the namespace to grant the permision of access from the agent on the managed cluster. When the value is set to false, the namespace representing the managed cluster is deleted.
    54                    type: boolean
    55                  leaseDurationSeconds:
    56                    description: LeaseDurationSeconds is used to coordinate the lease update time of Klusterlet agents on the managed cluster. If its value is zero, the Klusterlet agent will update its lease every 60 seconds by default
    57                    type: integer
    58                    format: int32
    59                    default: 60
    60                  managedClusterClientConfigs:
    61                    description: ManagedClusterClientConfigs represents a list of the apiserver address of the managed cluster. If it is empty, the managed cluster has no accessible address for the hub to connect with it.
    62                    type: array
    63                    items:
    64                      description: ClientConfig represents the apiserver address of the managed cluster. TODO include credential to connect to managed cluster kube-apiserver
    65                      type: object
    66                      properties:
    67                        caBundle:
    68                          description: CABundle is the ca bundle to connect to apiserver of the managed cluster. System certs are used if it is not set.
    69                          type: string
    70                          format: byte
    71                        url:
    72                          description: URL is the URL of apiserver endpoint of the managed cluster.
    73                          type: string
    74                  taints:
    75                    description: Taints is a property of managed cluster that allow the cluster to be repelled when scheduling. Taints, including 'ManagedClusterUnavailable' and 'ManagedClusterUnreachable', can not be added/removed by agent running on the managed cluster; while it's fine to add/remove other taints from either hub cluser or managed cluster.
    76                    type: array
    77                    items:
    78                      description: The managed cluster this Taint is attached to has the "effect" on any placement that does not tolerate the Taint.
    79                      type: object
    80                      required:
    81                        - effect
    82                        - key
    83                      properties:
    84                        effect:
    85                          description: Effect indicates the effect of the taint on placements that do not tolerate the taint. Valid effects are NoSelect, PreferNoSelect and NoSelectIfNew.
    86                          type: string
    87                          enum:
    88                            - NoSelect
    89                            - PreferNoSelect
    90                            - NoSelectIfNew
    91                        key:
    92                          description: Key is the taint key applied to a cluster. e.g. bar or foo.example.com/bar. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)
    93                          type: string
    94                          maxLength: 316
    95                          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])$
    96                        timeAdded:
    97                          description: TimeAdded represents the time at which the taint was added.
    98                          type: string
    99                          format: date-time
   100                          nullable: true
   101                        value:
   102                          description: Value is the taint value corresponding to the taint key.
   103                          type: string
   104                          maxLength: 1024
   105              status:
   106                description: Status represents the current status of joined managed cluster
   107                type: object
   108                properties:
   109                  allocatable:
   110                    description: Allocatable represents the total allocatable resources on the managed cluster.
   111                    type: object
   112                    additionalProperties:
   113                      pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
   114                      anyOf:
   115                        - type: integer
   116                        - type: string
   117                      x-kubernetes-int-or-string: true
   118                  capacity:
   119                    description: Capacity represents the total resource capacity from all nodeStatuses on the managed cluster.
   120                    type: object
   121                    additionalProperties:
   122                      pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
   123                      anyOf:
   124                        - type: integer
   125                        - type: string
   126                      x-kubernetes-int-or-string: true
   127                  clusterClaims:
   128                    description: ClusterClaims represents cluster information that a managed cluster claims, for example a unique cluster identifier (id.k8s.io) and kubernetes version (kubeversion.open-cluster-management.io). They are written from the managed cluster. The set of claims is not uniform across a fleet, some claims can be vendor or version specific and may not be included from all managed clusters.
   129                    type: array
   130                    items:
   131                      description: ManagedClusterClaim represents a ClusterClaim collected from a managed cluster.
   132                      type: object
   133                      properties:
   134                        name:
   135                          description: Name is the name of a ClusterClaim resource on managed cluster. It's a well known or customized name to identify the claim.
   136                          type: string
   137                          maxLength: 253
   138                          minLength: 1
   139                        value:
   140                          description: Value is a claim-dependent string
   141                          type: string
   142                          maxLength: 1024
   143                          minLength: 1
   144                  conditions:
   145                    description: Conditions contains the different condition statuses for this managed cluster.
   146                    type: array
   147                    items:
   148                      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, 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 }"
   149                      type: object
   150                      required:
   151                        - lastTransitionTime
   152                        - message
   153                        - reason
   154                        - status
   155                        - type
   156                      properties:
   157                        lastTransitionTime:
   158                          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.
   159                          type: string
   160                          format: date-time
   161                        message:
   162                          description: message is a human readable message indicating details about the transition. This may be an empty string.
   163                          type: string
   164                          maxLength: 32768
   165                        observedGeneration:
   166                          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.
   167                          type: integer
   168                          format: int64
   169                          minimum: 0
   170                        reason:
   171                          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.
   172                          type: string
   173                          maxLength: 1024
   174                          minLength: 1
   175                          pattern: ^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$
   176                        status:
   177                          description: status of the condition, one of True, False, Unknown.
   178                          type: string
   179                          enum:
   180                            - "True"
   181                            - "False"
   182                            - Unknown
   183                        type:
   184                          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)
   185                          type: string
   186                          maxLength: 316
   187                          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])$
   188                  version:
   189                    description: Version represents the kubernetes version of the managed cluster.
   190                    type: object
   191                    properties:
   192                      kubernetes:
   193                        description: Kubernetes is the kubernetes version of managed cluster.
   194                        type: string
   195        served: true
   196        storage: true
   197        subresources:
   198          status: {}
   199  status:
   200    acceptedNames:
   201      kind: ""
   202      plural: ""
   203    conditions: []
   204    storedVersions: []