
---
apiVersion: apiextensions.k8s.io/v1
kind: CustomResourceDefinition
metadata:
  annotations:
    controller-gen.kubebuilder.io/version: v0.7.0
  creationTimestamp: null
  name: cloudcarbonfootprints.co2e.crane.io
spec:
  group: co2e.crane.io
  names:
    kind: CloudCarbonFootprint
    listKind: CloudCarbonFootprintList
    plural: cloudcarbonfootprints
    shortNames:
    - ccf
    singular: cloudcarbonfootprint
  scope: Cluster
  versions:
  - name: v1alpha1
    schema:
      openAPIV3Schema:
        description: CloudCarbonFootprint defines carbon footprint configuration of
          a datacenter
        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:
            properties:
              computeConfig:
                description: compute power infos when there are multiple node types
                  in the cluster, define multiple compute configs
                items:
                  properties:
                    cpuEnergyConsumptionRatio:
                      description: sometimes it's hard to measure memory, storage,
                        and networking energy consumption CPUEnergyConsumptionRatio
                        can be defined to specify the percentage of cpu energy consumption
                        vs all IT equipments consumption
                      type: string
                    maxWattsPerCPU:
                      description: power when cpu utilization is 100%
                      type: string
                    memoryWattsPerGB:
                      description: power of per BG memory
                      type: string
                    minWattsPerCPU:
                      description: power when cpu is idle
                      type: string
                    nodeSelector:
                      description: when there are various types of compute server,
                        node selector selects the targets
                      properties:
                        matchExpressions:
                          description: matchExpressions is a list of label selector
                            requirements. The requirements are ANDed.
                          items:
                            description: A label selector requirement is a selector
                              that contains values, a key, and an operator that relates
                              the key and values.
                            properties:
                              key:
                                description: key is the label key that the selector
                                  applies to.
                                type: string
                              operator:
                                description: operator represents a key's relationship
                                  to a set of values. Valid operators are In, NotIn,
                                  Exists and DoesNotExist.
                                type: string
                              values:
                                description: values is an array of string values.
                                  If the operator is In or NotIn, the values array
                                  must be non-empty. If the operator is Exists or
                                  DoesNotExist, the values array must be empty. This
                                  array is replaced during a strategic merge patch.
                                items:
                                  type: string
                                type: array
                            required:
                            - key
                            - operator
                            type: object
                          type: array
                        matchLabels:
                          additionalProperties:
                            type: string
                          description: matchLabels is a map of {key,value} pairs.
                            A single {key,value} in the matchLabels map is equivalent
                            to an element of matchExpressions, whose key field is
                            "key", the operator is "In", and the values array contains
                            only "value". The requirements are ANDed.
                          type: object
                      type: object
                  type: object
                type: array
              emissionFactor:
                description: emission factor of the data center, unit is tCO2/MWh,
                  the average emission factor of China is 0.5810
                type: string
              locality:
                description: locality holds more information of location, e.g. ap/china/shanghai/az01/floor3
                type: string
              networkingConfig:
                description: networking power info
                items:
                  properties:
                    storageClass:
                      description: networking class, e.g. golden, server, bronze,
                        which define different redundancies of networking links, and
                        has different energy consumption
                      type: string
                    wattsPerGB:
                      description: power per GB for the class
                      type: string
                  type: object
                type: array
              provider:
                description: Provider is the provider of the ccf, when provider is
                  manual, all the properties of ccf would be configured manually when
                  a cloud provider exposes query API, a cloud provider controller
                  can query cloud api and fill the properties automatically
                type: string
              pue:
                description: power usage effectiveness = IT equipment energy usage
                  / total facility energy usage
                type: string
              region:
                description: region of the datacenter, e.g. shanghai
                type: string
              storageConfig:
                description: storage power info
                items:
                  properties:
                    storageClass:
                      description: storage class, e.g. cephfs
                      type: string
                    wattsPerTB:
                      description: power per TB for the class
                      type: string
                  type: object
                type: array
              zone:
                description: availability zone of the datacenter, e.g. shanghai-az01
                type: string
            type: object
          status:
            properties:
              condition:
                items:
                  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 }"
                  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
            type: object
        type: object
    served: true
    storage: true
status:
  acceptedNames:
    kind: ""
    plural: ""
  conditions: []
  storedVersions: []
