| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223 |
- /*
- Copyright The Kubernetes Authors.
- Licensed under the Apache License, Version 2.0 (the "License");
- you may not use this file except in compliance with the License.
- You may obtain a copy of the License at
- http://www.apache.org/licenses/LICENSE-2.0
- Unless required by applicable law or agreed to in writing, software
- distributed under the License is distributed on an "AS IS" BASIS,
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- See the License for the specific language governing permissions and
- limitations under the License.
- */
- // This file was autogenerated by go-to-protobuf. Do not edit it manually!
- syntax = "proto2";
- package k8s.io.api.discovery.v1;
- import "k8s.io/api/core/v1/generated.proto";
- import "k8s.io/apimachinery/pkg/apis/meta/v1/generated.proto";
- import "k8s.io/apimachinery/pkg/runtime/generated.proto";
- import "k8s.io/apimachinery/pkg/runtime/schema/generated.proto";
- // Package-wide variables from generator "generated".
- option go_package = "k8s.io/api/discovery/v1";
- // Endpoint represents a single logical "backend" implementing a service.
- message Endpoint {
- // addresses of this endpoint. For EndpointSlices of addressType "IPv4" or "IPv6",
- // the values are IP addresses in canonical form. The syntax and semantics of
- // other addressType values are not defined. This must contain at least one
- // address but no more than 100. EndpointSlices generated by the EndpointSlice
- // controller will always have exactly 1 address. No semantics are defined for
- // additional addresses beyond the first, and kube-proxy does not look at them.
- // +listType=set
- repeated string addresses = 1;
- // conditions contains information about the current status of the endpoint.
- optional EndpointConditions conditions = 2;
- // hostname of this endpoint. This field may be used by consumers of
- // endpoints to distinguish endpoints from each other (e.g. in DNS names).
- // Multiple endpoints which use the same hostname should be considered
- // fungible (e.g. multiple A values in DNS). Must be lowercase and pass DNS
- // Label (RFC 1123) validation.
- // +optional
- optional string hostname = 3;
- // targetRef is a reference to a Kubernetes object that represents this
- // endpoint.
- // +optional
- optional .k8s.io.api.core.v1.ObjectReference targetRef = 4;
- // deprecatedTopology contains topology information part of the v1beta1
- // API. This field is deprecated, and will be removed when the v1beta1
- // API is removed (no sooner than kubernetes v1.24). While this field can
- // hold values, it is not writable through the v1 API, and any attempts to
- // write to it will be silently ignored. Topology information can be found
- // in the zone and nodeName fields instead.
- // +optional
- map<string, string> deprecatedTopology = 5;
- // nodeName represents the name of the Node hosting this endpoint. This can
- // be used to determine endpoints local to a Node.
- // +optional
- optional string nodeName = 6;
- // zone is the name of the Zone this endpoint exists in.
- // +optional
- optional string zone = 7;
- // hints contains information associated with how an endpoint should be
- // consumed.
- // +optional
- optional EndpointHints hints = 8;
- }
- // EndpointConditions represents the current condition of an endpoint.
- message EndpointConditions {
- // ready indicates that this endpoint is ready to receive traffic,
- // according to whatever system is managing the endpoint. A nil value
- // should be interpreted as "true". In general, an endpoint should be
- // marked ready if it is serving and not terminating, though this can
- // be overridden in some cases, such as when the associated Service has
- // set the publishNotReadyAddresses flag.
- // +optional
- optional bool ready = 1;
- // serving indicates that this endpoint is able to receive traffic,
- // according to whatever system is managing the endpoint. For endpoints
- // backed by pods, the EndpointSlice controller will mark the endpoint
- // as serving if the pod's Ready condition is True. A nil value should be
- // interpreted as "true".
- // +optional
- optional bool serving = 2;
- // terminating indicates that this endpoint is terminating. A nil value
- // should be interpreted as "false".
- // +optional
- optional bool terminating = 3;
- }
- // EndpointHints provides hints describing how an endpoint should be consumed.
- message EndpointHints {
- // forZones indicates the zone(s) this endpoint should be consumed by when
- // using topology aware routing. May contain a maximum of 8 entries.
- // +listType=atomic
- repeated ForZone forZones = 1;
- // forNodes indicates the node(s) this endpoint should be consumed by when
- // using topology aware routing. May contain a maximum of 8 entries.
- // +listType=atomic
- repeated ForNode forNodes = 2;
- }
- // EndpointPort represents a Port used by an EndpointSlice
- // +structType=atomic
- message EndpointPort {
- // name represents the name of this port. All ports in an EndpointSlice must have a unique name.
- // If the EndpointSlice is derived from a Kubernetes service, this corresponds to the Service.ports[].name.
- // Name must either be an empty string or pass DNS_LABEL validation:
- // * must be no more than 63 characters long.
- // * must consist of lower case alphanumeric characters or '-'.
- // * must start and end with an alphanumeric character.
- // Default is empty string.
- optional string name = 1;
- // protocol represents the IP protocol for this port.
- // Must be UDP, TCP, or SCTP.
- // Default is TCP.
- optional string protocol = 2;
- // port represents the port number of the endpoint.
- // If the EndpointSlice is derived from a Kubernetes service, this must be set
- // to the service's target port. EndpointSlices used for other purposes may have
- // a nil port.
- optional int32 port = 3;
- // The application protocol for this port.
- // This is used as a hint for implementations to offer richer behavior for protocols that they understand.
- // This field follows standard Kubernetes label syntax.
- // Valid values are either:
- //
- // * Un-prefixed protocol names - reserved for IANA standard service names (as per
- // RFC-6335 and https://www.iana.org/assignments/service-names).
- //
- // * Kubernetes-defined prefixed names:
- // * 'kubernetes.io/h2c' - HTTP/2 prior knowledge over cleartext as described in https://www.rfc-editor.org/rfc/rfc9113.html#name-starting-http-2-with-prior-
- // * 'kubernetes.io/ws' - WebSocket over cleartext as described in https://www.rfc-editor.org/rfc/rfc6455
- // * 'kubernetes.io/wss' - WebSocket over TLS as described in https://www.rfc-editor.org/rfc/rfc6455
- //
- // * Other protocols should use implementation-defined prefixed names such as
- // mycompany.com/my-custom-protocol.
- // +optional
- optional string appProtocol = 4;
- }
- // EndpointSlice represents a set of service endpoints. Most EndpointSlices are created by
- // the EndpointSlice controller to represent the Pods selected by Service objects. For a
- // given service there may be multiple EndpointSlice objects which must be joined to
- // produce the full set of endpoints; you can find all of the slices for a given service
- // by listing EndpointSlices in the service's namespace whose `kubernetes.io/service-name`
- // label contains the service's name.
- message EndpointSlice {
- // Standard object's metadata.
- // +optional
- optional .k8s.io.apimachinery.pkg.apis.meta.v1.ObjectMeta metadata = 1;
- // addressType specifies the type of address carried by this EndpointSlice.
- // All addresses in this slice must be the same type. This field is
- // immutable after creation. The following address types are currently
- // supported:
- // * IPv4: Represents an IPv4 Address.
- // * IPv6: Represents an IPv6 Address.
- // * FQDN: Represents a Fully Qualified Domain Name. (Deprecated)
- // The EndpointSlice controller only generates, and kube-proxy only processes,
- // slices of addressType "IPv4" and "IPv6". No semantics are defined for
- // the "FQDN" type.
- optional string addressType = 4;
- // endpoints is a list of unique endpoints in this slice. Each slice may
- // include a maximum of 1000 endpoints.
- // +listType=atomic
- repeated Endpoint endpoints = 2;
- // ports specifies the list of network ports exposed by each endpoint in
- // this slice. Each port must have a unique name. Each slice may include a
- // maximum of 100 ports.
- // Services always have at least 1 port, so EndpointSlices generated by the
- // EndpointSlice controller will likewise always have at least 1 port.
- // EndpointSlices used for other purposes may have an empty ports list.
- // +optional
- // +listType=atomic
- repeated EndpointPort ports = 3;
- }
- // EndpointSliceList represents a list of endpoint slices
- message EndpointSliceList {
- // Standard list metadata.
- // +optional
- optional .k8s.io.apimachinery.pkg.apis.meta.v1.ListMeta metadata = 1;
- // items is the list of endpoint slices
- repeated EndpointSlice items = 2;
- }
- // ForNode provides information about which nodes should consume this endpoint.
- message ForNode {
- // name represents the name of the node.
- optional string name = 1;
- }
- // ForZone provides information about which zones should consume this endpoint.
- message ForZone {
- // name represents the name of the zone.
- optional string name = 1;
- }
|