2023-08-03 13:42:04 -05:00
|
|
|
// Copyright (c) HashiCorp, Inc.
|
2023-08-21 12:31:54 -05:00
|
|
|
// SPDX-License-Identifier: MPL-2.0
|
2023-08-03 13:42:04 -05:00
|
|
|
|
|
|
|
syntax = "proto3";
|
|
|
|
|
2023-09-22 10:51:15 -06:00
|
|
|
package hashicorp.consul.catalog.v2beta1;
|
2023-08-03 13:42:04 -05:00
|
|
|
|
2023-09-21 17:18:47 -04:00
|
|
|
import "pbresource/annotations.proto";
|
2023-08-03 13:42:04 -05:00
|
|
|
import "pbresource/resource.proto";
|
|
|
|
|
|
|
|
// This is a Resource type.
|
|
|
|
message FailoverPolicy {
|
2023-09-21 17:18:47 -04:00
|
|
|
option (hashicorp.consul.resource.spec) = {scope: SCOPE_NAMESPACE};
|
|
|
|
|
2023-08-03 13:42:04 -05:00
|
|
|
// Config defines failover for any named port not present in PortConfigs.
|
|
|
|
FailoverConfig config = 1;
|
|
|
|
|
2024-01-29 10:43:41 -08:00
|
|
|
// PortConfigs defines failover for a specific port on a service and takes
|
2023-08-03 13:42:04 -05:00
|
|
|
// precedence over Config.
|
2024-01-29 10:43:41 -08:00
|
|
|
//
|
|
|
|
// For more details on potential values of the service port identifier key,
|
|
|
|
// see documentation for Service.ServicePort.
|
2023-08-03 13:42:04 -05:00
|
|
|
map<string, FailoverConfig> port_configs = 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
message FailoverConfig {
|
|
|
|
// Destinations specifies a fixed list of failover destinations to try. We
|
|
|
|
// never try a destination multiple times, so those are subtracted from this
|
|
|
|
// list before proceeding.
|
|
|
|
repeated FailoverDestination destinations = 1;
|
|
|
|
|
|
|
|
// Mode specifies the type of failover that will be performed. Valid values are
|
|
|
|
// "sequential", "" (equivalent to "sequential") and "order-by-locality".
|
|
|
|
FailoverMode mode = 2;
|
|
|
|
repeated string regions = 3;
|
|
|
|
|
|
|
|
// SamenessGroup specifies the sameness group to failover to.
|
|
|
|
string sameness_group = 4;
|
|
|
|
}
|
|
|
|
|
|
|
|
message FailoverDestination {
|
|
|
|
// This must be a Service.
|
|
|
|
hashicorp.consul.resource.Reference ref = 1;
|
2024-01-29 10:43:41 -08:00
|
|
|
|
|
|
|
// Port is the port of the destination service.
|
|
|
|
//
|
|
|
|
// For more details on potential values of the service port identifier key,
|
|
|
|
// see documentation for Service.ServicePort.
|
2023-08-03 13:42:04 -05:00
|
|
|
// TODO: what should an empty port mean?
|
|
|
|
string port = 2;
|
|
|
|
string datacenter = 3;
|
|
|
|
}
|
|
|
|
|
2023-11-07 11:02:38 -05:00
|
|
|
// +kubebuilder:validation:Enum=FAILOVER_MODE_UNSPECIFIED;FAILOVER_MODE_SEQUENTIAL;FAILOVER_MODE_ORDER_BY_LOCALITY
|
|
|
|
// +kubebuilder:validation:Type=string
|
2023-08-03 13:42:04 -05:00
|
|
|
enum FailoverMode {
|
|
|
|
FAILOVER_MODE_UNSPECIFIED = 0;
|
|
|
|
FAILOVER_MODE_SEQUENTIAL = 1;
|
|
|
|
FAILOVER_MODE_ORDER_BY_LOCALITY = 2;
|
|
|
|
}
|