{
  "description": "TargetGroupBinding is the Schema for the TargetGroupBinding API",
  "properties": {
    "apiVersion": {
      "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore 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.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds",
      "type": "string"
    },
    "metadata": {
      "type": "object"
    },
    "spec": {
      "description": "TargetGroupBindingSpec defines the desired state of TargetGroupBinding",
      "properties": {
        "networking": {
          "description": "networking defines the networking rules to allow ELBv2 LoadBalancer to access targets in TargetGroup.",
          "properties": {
            "ingress": {
              "description": "List of ingress rules to allow ELBv2 LoadBalancer to access targets in TargetGroup.",
              "items": {
                "description": "NetworkingIngressRule defines a particular set of traffic that is allowed to access TargetGroup's targets.",
                "properties": {
                  "from": {
                    "description": "List of peers which should be able to access the targets in TargetGroup.\nAt least one NetworkingPeer should be specified.",
                    "items": {
                      "description": "NetworkingPeer defines the source/destination peer for networking rules.",
                      "properties": {
                        "securityGroup": {
                          "description": "SecurityGroup defines a SecurityGroup peer.\nIf specified, none of the other fields can be set.",
                          "properties": {
                            "groupID": {
                              "description": "GroupID is the EC2 SecurityGroupID.",
                              "minLength": 1,
                              "type": "string"
                            }
                          },
                          "required": [
                            "groupID"
                          ],
                          "type": "object",
                          "additionalProperties": false
                        }
                      },
                      "type": "object",
                      "additionalProperties": false
                    },
                    "minItems": 1,
                    "type": "array"
                  },
                  "ports": {
                    "description": "List of ports which should be made accessible on the targets in TargetGroup.\nIf ports is empty or unspecified, it defaults to all ports with TCP.",
                    "items": {
                      "description": "NetworkingPort defines the port and protocol for networking rules.",
                      "properties": {
                        "port": {
                          "anyOf": [
                            {
                              "type": "integer"
                            },
                            {
                              "type": "string"
                            }
                          ],
                          "description": "The port which traffic must match.\nWhen NodePort endpoints(instance TargetType) is used, this must be a numerical port.\nWhen Port endpoints(ip TargetType) is used, this can be either numerical or named port on pods.\nif port is unspecified, it defaults to all ports.",
                          "x-kubernetes-int-or-string": true
                        },
                        "protocol": {
                          "description": "The protocol which traffic must match.\nIf protocol is unspecified, it defaults to TCP.",
                          "enum": [
                            "TCP",
                            "UDP"
                          ],
                          "type": "string"
                        }
                      },
                      "type": "object",
                      "additionalProperties": false
                    },
                    "type": "array"
                  }
                },
                "required": [
                  "from"
                ],
                "type": "object",
                "additionalProperties": false
              },
              "minItems": 1,
              "type": "array"
            }
          },
          "required": [
            "ingress"
          ],
          "type": "object",
          "additionalProperties": false
        },
        "nodeSelector": {
          "description": "node selector for instance type target groups to only register certain nodes",
          "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\nrelates 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.\nValid 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,\nthe values array must be non-empty. If the operator is Exists or DoesNotExist,\nthe values array must be empty. This array is replaced during a strategic\nmerge patch.",
                    "items": {
                      "type": "string"
                    },
                    "type": "array",
                    "x-kubernetes-list-type": "atomic"
                  }
                },
                "required": [
                  "key",
                  "operator"
                ],
                "type": "object",
                "additionalProperties": false
              },
              "type": "array",
              "x-kubernetes-list-type": "atomic"
            },
            "matchLabels": {
              "additionalProperties": {
                "type": "string"
              },
              "description": "matchLabels is a map of {key,value} pairs. A single {key,value} in the matchLabels\nmap is equivalent to an element of matchExpressions, whose key field is \"key\", the\noperator is \"In\", and the values array contains only \"value\". The requirements are ANDed.",
              "type": "object"
            }
          },
          "type": "object",
          "x-kubernetes-map-type": "atomic",
          "additionalProperties": false
        },
        "serviceRef": {
          "description": "serviceRef is a reference to a Kubernetes Service and ServicePort.",
          "properties": {
            "name": {
              "description": "Name is the name of the Service.",
              "minLength": 1,
              "type": "string"
            },
            "port": {
              "anyOf": [
                {
                  "type": "integer"
                },
                {
                  "type": "string"
                }
              ],
              "description": "Port is the port of the ServicePort.",
              "x-kubernetes-int-or-string": true
            }
          },
          "required": [
            "name",
            "port"
          ],
          "type": "object",
          "additionalProperties": false
        },
        "targetGroupARN": {
          "description": "targetGroupARN is the Amazon Resource Name (ARN) for the TargetGroup.",
          "minLength": 1,
          "type": "string"
        },
        "targetType": {
          "description": "targetType defines how to bind targets into targetGroup.",
          "enum": [
            "instance",
            "ip"
          ],
          "type": "string"
        }
      },
      "required": [
        "serviceRef",
        "targetGroupARN",
        "targetType"
      ],
      "type": "object",
      "additionalProperties": false
    },
    "status": {
      "description": "TargetGroupBindingStatus defines the observed state of TargetGroupBinding",
      "properties": {
        "observedGeneration": {
          "description": "The generation observed by the TargetGroupBinding controller.",
          "format": "int64",
          "type": "integer"
        }
      },
      "type": "object",
      "additionalProperties": false
    }
  },
  "type": "object"
}
