mirror of
				https://gitea.com/Lydanne/buildx.git
				synced 2025-10-26 21:53:51 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			198 lines
		
	
	
		
			8.0 KiB
		
	
	
	
		
			Protocol Buffer
		
	
	
	
	
	
			
		
		
	
	
			198 lines
		
	
	
		
			8.0 KiB
		
	
	
	
		
			Protocol Buffer
		
	
	
	
	
	
| /*
 | |
| 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.v1beta1;
 | |
| 
 | |
| 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/v1beta1";
 | |
| 
 | |
| // Endpoint represents a single logical "backend" implementing a service.
 | |
| message Endpoint {
 | |
|   // addresses of this endpoint. The contents of this field are interpreted
 | |
|   // according to the corresponding EndpointSlice addressType field. Consumers
 | |
|   // must handle different types of addresses in the context of their own
 | |
|   // capabilities. This must contain at least one address but no more than
 | |
|   // 100. These are all assumed to be fungible and clients may choose to only
 | |
|   // use the first element. Refer to: https://issue.k8s.io/106267
 | |
|   // +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;
 | |
| 
 | |
|   // topology contains arbitrary topology information associated with the
 | |
|   // endpoint. These key/value pairs must conform with the label format.
 | |
|   // https://kubernetes.io/docs/concepts/overview/working-with-objects/labels
 | |
|   // Topology may include a maximum of 16 key/value pairs. This includes, but
 | |
|   // is not limited to the following well known keys:
 | |
|   // * kubernetes.io/hostname: the value indicates the hostname of the node
 | |
|   //   where the endpoint is located. This should match the corresponding
 | |
|   //   node label.
 | |
|   // * topology.kubernetes.io/zone: the value indicates the zone where the
 | |
|   //   endpoint is located. This should match the corresponding node label.
 | |
|   // * topology.kubernetes.io/region: the value indicates the region where the
 | |
|   //   endpoint is located. This should match the corresponding node label.
 | |
|   // This field is deprecated and will be removed in future api versions.
 | |
|   // +optional
 | |
|   map<string, string> topology = 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;
 | |
| 
 | |
|   // hints contains information associated with how an endpoint should be
 | |
|   // consumed.
 | |
|   // +featureGate=TopologyAwareHints
 | |
|   // +optional
 | |
|   optional EndpointHints hints = 7;
 | |
| }
 | |
| 
 | |
| // EndpointConditions represents the current condition of an endpoint.
 | |
| message EndpointConditions {
 | |
|   // ready indicates that this endpoint is prepared to receive traffic,
 | |
|   // according to whatever system is managing the endpoint. A nil value
 | |
|   // indicates an unknown state. In most cases consumers should interpret this
 | |
|   // unknown state as ready. For compatibility reasons, ready should never be
 | |
|   // "true" for terminating endpoints.
 | |
|   // +optional
 | |
|   optional bool ready = 1;
 | |
| 
 | |
|   // serving is identical to ready except that it is set regardless of the
 | |
|   // terminating state of endpoints. This condition should be set to true for
 | |
|   // a ready endpoint that is terminating. If nil, consumers should defer to
 | |
|   // the ready condition.
 | |
|   // +optional
 | |
|   optional bool serving = 2;
 | |
| 
 | |
|   // terminating indicates that this endpoint is terminating. A nil value
 | |
|   // indicates an unknown state. Consumers should interpret this unknown state
 | |
|   // to mean that the endpoint is not terminating.
 | |
|   // +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 to
 | |
|   // enable topology aware routing. May contain a maximum of 8 entries.
 | |
|   // +listType=atomic
 | |
|   repeated ForZone forZones = 1;
 | |
| }
 | |
| 
 | |
| // EndpointPort represents a Port used by an EndpointSlice
 | |
| 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 this is not specified, ports are not restricted and must be
 | |
|   // interpreted in the context of the specific consumer.
 | |
|   optional int32 port = 3;
 | |
| 
 | |
|   // appProtocol represents the application protocol for this port.
 | |
|   // This field follows standard Kubernetes label syntax.
 | |
|   // Un-prefixed names are reserved for IANA standard service names (as per
 | |
|   // RFC-6335 and https://www.iana.org/assignments/service-names).
 | |
|   // Non-standard protocols should use prefixed names such as
 | |
|   // mycompany.com/my-custom-protocol.
 | |
|   // +optional
 | |
|   optional string appProtocol = 4;
 | |
| }
 | |
| 
 | |
| // EndpointSlice represents a subset of the endpoints that implement a service.
 | |
| // For a given service there may be multiple EndpointSlice objects, selected by
 | |
| // labels, which must be joined to produce the full set of endpoints.
 | |
| 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.
 | |
|   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. When ports is empty, it
 | |
|   // indicates that there are no defined ports. When a port is defined with a
 | |
|   // nil port value, it indicates "all ports". Each slice may include a
 | |
|   // maximum of 100 ports.
 | |
|   // +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;
 | |
| }
 | |
| 
 | |
| // ForZone provides information about which zones should consume this endpoint.
 | |
| message ForZone {
 | |
|   // name represents the name of the zone.
 | |
|   optional string name = 1;
 | |
| }
 | |
| 
 | 
