mirror of https://github.com/hashicorp/consul
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
320 lines
9.2 KiB
320 lines
9.2 KiB
syntax = "proto3"; |
|
|
|
package hashicorp.consul.internal.peering; |
|
|
|
import "google/protobuf/timestamp.proto"; |
|
|
|
// PeeringService handles operations for establishing peering relationships |
|
// between disparate Consul clusters. |
|
service PeeringService { |
|
rpc GenerateToken(GenerateTokenRequest) returns (GenerateTokenResponse); |
|
rpc Establish(EstablishRequest) returns (EstablishResponse); |
|
rpc PeeringRead(PeeringReadRequest) returns (PeeringReadResponse); |
|
rpc PeeringList(PeeringListRequest) returns (PeeringListResponse); |
|
rpc PeeringDelete(PeeringDeleteRequest) returns (PeeringDeleteResponse); |
|
|
|
// TODO(peering): As of writing, this method is only used in tests to set up Peerings in the state store. |
|
// Consider removing if we can find another way to populate state store in peering_endpoint_test.go |
|
rpc PeeringWrite(PeeringWriteRequest) returns (PeeringWriteResponse); |
|
|
|
// TODO(peering): Rename this to PeeredServiceRoots? or something like that? |
|
rpc TrustBundleListByService(TrustBundleListByServiceRequest) returns (TrustBundleListByServiceResponse); |
|
|
|
rpc TrustBundleRead(TrustBundleReadRequest) returns (TrustBundleReadResponse); |
|
} |
|
|
|
// PeeringState enumerates all the states a peering can be in |
|
enum PeeringState { |
|
// Undefined represents an unset value for PeeringState during |
|
// writes. |
|
UNDEFINED = 0; |
|
|
|
// Pending means the peering was created by generating a peering token. |
|
// Peerings stay in a pending state until the peer uses the token to dial |
|
// the local cluster. |
|
PENDING = 1; |
|
|
|
// Establishing means the peering is being established from a peering token. |
|
// This is the initial state for dialing peers. |
|
ESTABLISHING = 2; |
|
|
|
// Active means that the peering connection is active and healthy. |
|
ACTIVE = 3; |
|
|
|
// Failing means the peering connection has been interrupted but has not yet |
|
// been terminated. |
|
FAILING = 4; |
|
|
|
// Deleting means a peering was marked for deletion and is in the process |
|
// of being deleted. |
|
DELETING = 5; |
|
|
|
// Terminated means the peering relationship has been removed. |
|
TERMINATED = 6; |
|
} |
|
|
|
// Peering defines a peering relationship between two disparate Consul clusters |
|
// |
|
// mog annotation: |
|
// |
|
// target=github.com/hashicorp/consul/api.Peering |
|
// output=peering.gen.go |
|
// name=API |
|
message Peering { |
|
// ID is a datacenter-scoped UUID for the peering. |
|
// The ID is generated when a peering is first written to the state store. |
|
string ID = 1; |
|
|
|
// Name is the local alias for the peering relationship. |
|
string Name = 2; |
|
|
|
// Partition is the local partition connecting to the peer. |
|
string Partition = 3; |
|
|
|
// DeletedAt is the time when the Peering was marked for deletion |
|
// This is nullable so that we can omit if empty when encoding in JSON |
|
// mog: func-to=TimePtrFromProto func-from=TimePtrToProto |
|
google.protobuf.Timestamp DeletedAt = 4; |
|
|
|
// Meta is a mapping of some string value to any other string value |
|
map<string, string> Meta = 5; |
|
|
|
// State is one of the valid PeeringState values to represent the status of |
|
// peering relationship. |
|
// |
|
// mog: func-to=PeeringStateToAPI func-from=PeeringStateFromAPI |
|
PeeringState State = 6; |
|
|
|
// PeerID is the ID that our peer assigned to this peering. |
|
// This ID is to be used when dialing the peer, so that it can know who dialed it. |
|
string PeerID = 7; |
|
|
|
// PeerCAPems contains all the CA certificates for the remote peer. |
|
repeated string PeerCAPems = 8; |
|
|
|
// PeerServerName is the name of the remote server as it relates to TLS. |
|
string PeerServerName = 9; |
|
|
|
// PeerServerAddresses contains all the the connection addresses for the remote peer. |
|
repeated string PeerServerAddresses = 10; |
|
|
|
// ImportedServiceCount is the count of how many services are imported from this peering. |
|
uint64 ImportedServiceCount = 13; |
|
|
|
// ExportedServiceCount is the count of how many services are exported to this peering. |
|
uint64 ExportedServiceCount = 14; |
|
|
|
// CreateIndex is the Raft index at which the Peering was created. |
|
uint64 CreateIndex = 11; |
|
|
|
// ModifyIndex is the latest Raft index at which the Peering. was modified. |
|
uint64 ModifyIndex = 12; |
|
} |
|
|
|
// PeeringTrustBundle holds the trust information for validating requests from a peer. |
|
message PeeringTrustBundle { |
|
// TrustDomain is the domain for the bundle, example.com, foo.bar.gov for example. Note that this must not have a prefix such as "spiffe://". |
|
string TrustDomain = 1; |
|
|
|
// PeerName associates the trust bundle with a peer. |
|
string PeerName = 2; |
|
|
|
// Partition isolates the bundle from other trust bundles in separate local partitions. |
|
string Partition = 3; |
|
|
|
// RootPEMs holds ASN.1 DER encoded X.509 certificate data for the trust bundle. |
|
repeated string RootPEMs = 4; |
|
|
|
// ExportedPartition references the remote partition of the peer |
|
// which sent this trust bundle. Used for generating SpiffeIDs. |
|
string ExportedPartition = 5; |
|
|
|
// CreateIndex is the Raft index at which the trust domain was created. |
|
uint64 CreateIndex = 6; |
|
|
|
// ModifyIndex is the latest Raft index at which the trust bundle was modified. |
|
uint64 ModifyIndex = 7; |
|
} |
|
|
|
// @consul-rpc-glue: Datacenter,LeaderReadTODO |
|
message PeeringReadRequest { |
|
string Name = 1; |
|
string Partition = 2; |
|
|
|
string Datacenter = 3; |
|
|
|
//TODO(peering) query metadata |
|
} |
|
|
|
message PeeringReadResponse { |
|
Peering Peering = 1; |
|
|
|
//TODO(peering) query metadata |
|
} |
|
|
|
// @consul-rpc-glue: Datacenter,LeaderReadTODO |
|
message PeeringListRequest { |
|
string Partition = 1; |
|
|
|
string Datacenter = 2; |
|
|
|
//TODO(peering) query metadata |
|
} |
|
|
|
message PeeringListResponse { |
|
repeated Peering Peerings = 1; |
|
|
|
//TODO(peering) query metadata |
|
} |
|
|
|
// @consul-rpc-glue: Datacenter,WriteTODO |
|
message PeeringWriteRequest { |
|
Peering Peering = 1; |
|
|
|
//TODO(peering): what to do with embedded write request? |
|
string Datacenter = 2; |
|
|
|
// Meta is a mapping of some string value to any other string value |
|
map<string, string> Meta = 3; |
|
} |
|
|
|
// TODO(peering): Consider returning Peering if we keep this endpoint around |
|
message PeeringWriteResponse {} |
|
|
|
// @consul-rpc-glue: Datacenter,WriteTODO |
|
message PeeringDeleteRequest { |
|
string Name = 1; |
|
|
|
string Partition = 2; |
|
|
|
//TODO(peering): what to do with embedded write request? |
|
string Datacenter = 3; |
|
} |
|
|
|
message PeeringDeleteResponse {} |
|
|
|
// @consul-rpc-glue: Datacenter,ReadTODO |
|
message TrustBundleListByServiceRequest { |
|
string ServiceName = 1; |
|
string Namespace = 2; |
|
string Partition = 3; |
|
string Kind = 4; |
|
|
|
// these are common fields required for implementing structs.RPCInfo methods |
|
// that are used to forward requests |
|
string Datacenter = 5; |
|
} |
|
|
|
message TrustBundleListByServiceResponse { |
|
uint64 Index = 1; |
|
repeated PeeringTrustBundle Bundles = 2; |
|
} |
|
|
|
// @consul-rpc-glue: Datacenter,ReadTODO |
|
message TrustBundleReadRequest { |
|
string Name = 1; |
|
string Partition = 2; |
|
|
|
// these are common fields required for implementing structs.RPCInfo methods |
|
// that are used to forward requests |
|
string Datacenter = 3; |
|
} |
|
|
|
message TrustBundleReadResponse { |
|
uint64 Index = 1; |
|
PeeringTrustBundle Bundle = 2; |
|
} |
|
|
|
message PeeringTerminateByIDRequest { |
|
string ID = 1; |
|
} |
|
|
|
message PeeringTerminateByIDResponse {} |
|
|
|
// @consul-rpc-glue: Datacenter |
|
message PeeringTrustBundleWriteRequest { |
|
PeeringTrustBundle PeeringTrustBundle = 1; |
|
|
|
//TODO(peering): what to do with embedded write request? |
|
string Datacenter = 2; |
|
} |
|
|
|
message PeeringTrustBundleWriteResponse {} |
|
|
|
// @consul-rpc-glue: Datacenter |
|
message PeeringTrustBundleDeleteRequest { |
|
string Name = 1; |
|
|
|
string Partition = 2; |
|
|
|
//TODO(peering): what to do with embedded write request? |
|
string Datacenter = 3; |
|
} |
|
|
|
message PeeringTrustBundleDeleteResponse {} |
|
|
|
// mog annotation: |
|
// |
|
// target=github.com/hashicorp/consul/api.PeeringGenerateTokenRequest |
|
// output=peering.gen.go |
|
// name=API |
|
message GenerateTokenRequest { |
|
// Name of the remote peer. |
|
string PeerName = 1; |
|
|
|
// Partition is the local partition being peered. |
|
string Partition = 2; |
|
|
|
// these are common fields required for implementing structs.RPCInfo methods |
|
// that are used to forward requests |
|
string Datacenter = 3; |
|
string Token = 4; |
|
|
|
// Meta is a mapping of some string value to any other string value |
|
map<string, string> Meta = 5; |
|
} |
|
|
|
// mog annotation: |
|
// |
|
// target=github.com/hashicorp/consul/api.PeeringGenerateTokenResponse |
|
// output=peering.gen.go |
|
// name=API |
|
message GenerateTokenResponse { |
|
// PeeringToken is an opaque string provided to the remote peer for it to complete |
|
// the peering initialization handshake. |
|
string PeeringToken = 1; |
|
} |
|
|
|
// @consul-rpc-glue: Datacenter |
|
// |
|
// mog annotation: |
|
// |
|
// target=github.com/hashicorp/consul/api.PeeringEstablishRequest |
|
// output=peering.gen.go |
|
// name=API |
|
message EstablishRequest { |
|
// Name of the remote peer. |
|
string PeerName = 1; |
|
|
|
// The peering token returned from the peer's GenerateToken endpoint. |
|
string PeeringToken = 2; |
|
|
|
// Partition is the local partition being peered. |
|
string Partition = 3; |
|
|
|
// these are common fields required for implementing structs.RPCInfo methods |
|
// that are used to forward requests |
|
string Datacenter = 4; |
|
string Token = 5; |
|
|
|
// Meta is a mapping of some string value to any other string value |
|
map<string, string> Meta = 6; |
|
} |
|
|
|
// |
|
// mog annotation: |
|
// |
|
// target=github.com/hashicorp/consul/api.PeeringEstablishResponse |
|
// output=peering.gen.go |
|
// name=API |
|
message EstablishResponse {}
|
|
|