mirror of https://github.com/hashicorp/consul
65 lines
2.5 KiB
Protocol Buffer
65 lines
2.5 KiB
Protocol Buffer
// Copyright (c) HashiCorp, Inc.
|
||
// SPDX-License-Identifier: MPL-2.0
|
||
|
||
syntax = "proto3";
|
||
|
||
package hashicorp.consul.mesh.v1alpha1;
|
||
|
||
import "pbresource/resource.proto";
|
||
|
||
// NOTE: roughly equivalent to structs.ResourceReference
|
||
message ParentReference {
|
||
// For east/west configuration, this should point to a pbcatalog.Service.
|
||
// For north/south it should point to a gateway (TBD)
|
||
hashicorp.consul.resource.Reference ref = 1;
|
||
|
||
// Port is the network port this Route targets. It can be interpreted
|
||
// differently based on the type of parent resource.
|
||
//
|
||
// When the parent resource is a Gateway, this targets all listeners
|
||
// listening on the specified port that also support this kind of Route(and
|
||
// select this Route). It’s not recommended to set Port unless the networking
|
||
// behaviors specified in a Route must apply to a specific port as opposed to
|
||
// a listener(s) whose port(s) may be changed. When both Port and SectionName
|
||
// are specified, the name and port of the selected listener must match both
|
||
// specified values.
|
||
//
|
||
// Implementations MAY choose to support other parent resources.
|
||
// Implementations supporting other types of parent resources MUST clearly
|
||
// document how/if Port is interpreted.
|
||
//
|
||
// For the purpose of status, an attachment is considered successful as long
|
||
// as the parent resource accepts it partially. For example, Gateway
|
||
// listeners can restrict which Routes can attach to them by Route kind,
|
||
// namespace, or hostname. If 1 of 2 Gateway listeners accept attachment from
|
||
// the referencing Route, the Route MUST be considered successfully attached.
|
||
// If no Gateway listeners accept attachment from this Route, the Route MUST
|
||
// be considered detached from the Gateway.
|
||
//
|
||
// For east/west this is the name of the consul port.
|
||
// For north/south this is the stringified integer port expected by GAMMA.
|
||
//
|
||
// https://gateway-api.sigs.k8s.io/geps/gep-957/
|
||
string port = 2;
|
||
}
|
||
|
||
message BackendReference {
|
||
// For east/west configuration, this should point to either a
|
||
// pbcatalog.Service or ServiceSubset.
|
||
//
|
||
// For Partition/PeerName fields likely we could map them to ServiceImports
|
||
// (MCS+GAMMA) when translating
|
||
hashicorp.consul.resource.Reference ref = 1;
|
||
|
||
// For east/west this is the name of the consul port.
|
||
string port = 2;
|
||
|
||
// NOT IN GAMMA; multi-cluster + GWapi is still unknown
|
||
//
|
||
// Likely we could map this to ServiceImports (MCS+GAMMA) when translating
|
||
// to/from k8s.
|
||
//
|
||
// https://gateway-api.sigs.k8s.io/geps/gep-1748/
|
||
string datacenter = 3;
|
||
}
|