2023-03-28 18:39:22 +00:00
|
|
|
// Copyright (c) HashiCorp, Inc.
|
|
|
|
// SPDX-License-Identifier: MPL-2.0
|
|
|
|
|
2016-08-30 02:09:57 +00:00
|
|
|
package structs
|
|
|
|
|
|
|
|
import (
|
2017-09-25 18:40:42 +00:00
|
|
|
"net"
|
2017-03-01 22:04:40 +00:00
|
|
|
|
2016-08-30 02:09:57 +00:00
|
|
|
"github.com/hashicorp/raft"
|
|
|
|
)
|
|
|
|
|
2016-08-30 18:30:56 +00:00
|
|
|
// RaftServer has information about a server in the Raft configuration.
|
|
|
|
type RaftServer struct {
|
|
|
|
// ID is the unique ID for the server. These are currently the same
|
|
|
|
// as the address, but they will be changed to a real GUID in a future
|
|
|
|
// release of Consul.
|
|
|
|
ID raft.ServerID
|
|
|
|
|
|
|
|
// Node is the node name of the server, as known by Consul, or this
|
|
|
|
// will be set to "(unknown)" otherwise.
|
|
|
|
Node string
|
|
|
|
|
|
|
|
// Address is the IP:port of the server, used for Raft communications.
|
|
|
|
Address raft.ServerAddress
|
|
|
|
|
|
|
|
// Leader is true if this server is the current cluster leader.
|
|
|
|
Leader bool
|
|
|
|
|
2017-09-26 14:34:12 +00:00
|
|
|
// Protocol version is the raft protocol version used by the server
|
|
|
|
ProtocolVersion string
|
|
|
|
|
2016-08-30 18:30:56 +00:00
|
|
|
// Voter is true if this server has a vote in the cluster. This might
|
|
|
|
// be false if the server is staging and still coming online, or if
|
|
|
|
// it's a non-voting server, which will be added in a future release of
|
|
|
|
// Consul.
|
|
|
|
Voter bool
|
|
|
|
}
|
|
|
|
|
2017-09-26 14:34:12 +00:00
|
|
|
// RaftConfigurationResponse is returned when querying for the current Raft
|
2016-08-30 18:30:56 +00:00
|
|
|
// configuration.
|
2016-08-30 02:09:57 +00:00
|
|
|
type RaftConfigurationResponse struct {
|
2016-08-30 18:30:56 +00:00
|
|
|
// Servers has the list of servers in the Raft configuration.
|
|
|
|
Servers []*RaftServer
|
|
|
|
|
|
|
|
// Index has the Raft index of this configuration.
|
|
|
|
Index uint64
|
2016-08-30 02:09:57 +00:00
|
|
|
}
|
|
|
|
|
2017-03-30 01:09:41 +00:00
|
|
|
// RaftRemovePeerRequest is used by the Operator endpoint to apply a Raft
|
2016-08-30 02:09:57 +00:00
|
|
|
// operation on a specific Raft peer by address in the form of "IP:port".
|
2017-03-30 01:09:41 +00:00
|
|
|
type RaftRemovePeerRequest struct {
|
2016-08-30 02:09:57 +00:00
|
|
|
// Datacenter is the target this request is intended for.
|
|
|
|
Datacenter string
|
|
|
|
|
|
|
|
// Address is the peer to remove, in the form "IP:port".
|
|
|
|
Address raft.ServerAddress
|
|
|
|
|
2017-03-30 01:09:41 +00:00
|
|
|
// ID is the peer ID to remove.
|
|
|
|
ID raft.ServerID
|
|
|
|
|
2016-08-30 02:09:57 +00:00
|
|
|
// WriteRequest holds the ACL token to go along with this request.
|
|
|
|
WriteRequest
|
|
|
|
}
|
|
|
|
|
|
|
|
// RequestDatacenter returns the datacenter for a given request.
|
2017-03-30 01:09:41 +00:00
|
|
|
func (op *RaftRemovePeerRequest) RequestDatacenter() string {
|
2016-08-30 02:09:57 +00:00
|
|
|
return op.Datacenter
|
|
|
|
}
|
2017-02-24 04:32:13 +00:00
|
|
|
|
|
|
|
// AutopilotSetConfigRequest is used by the Operator endpoint to update the
|
|
|
|
// current Autopilot configuration of the cluster.
|
|
|
|
type AutopilotSetConfigRequest struct {
|
|
|
|
// Datacenter is the target this request is intended for.
|
|
|
|
Datacenter string
|
|
|
|
|
|
|
|
// Config is the new Autopilot configuration to use.
|
2020-09-25 17:46:38 +00:00
|
|
|
Config AutopilotConfig
|
2017-02-24 04:32:13 +00:00
|
|
|
|
2017-02-24 21:08:49 +00:00
|
|
|
// CAS controls whether to use check-and-set semantics for this request.
|
|
|
|
CAS bool
|
|
|
|
|
2017-02-24 04:32:13 +00:00
|
|
|
// WriteRequest holds the ACL token to go along with this request.
|
|
|
|
WriteRequest
|
|
|
|
}
|
|
|
|
|
|
|
|
// RequestDatacenter returns the datacenter for a given request.
|
|
|
|
func (op *AutopilotSetConfigRequest) RequestDatacenter() string {
|
|
|
|
return op.Datacenter
|
|
|
|
}
|
2017-03-01 22:04:40 +00:00
|
|
|
|
2017-09-25 18:40:42 +00:00
|
|
|
// (Enterprise-only) NetworkSegment is the configuration for a network segment, which is an
|
|
|
|
// isolated serf group on the LAN.
|
|
|
|
type NetworkSegment struct {
|
|
|
|
// Name is the name of the segment.
|
|
|
|
Name string
|
|
|
|
|
|
|
|
// Bind is the bind address for this segment.
|
|
|
|
Bind *net.TCPAddr
|
|
|
|
|
|
|
|
// Advertise is the advertise address of this segment.
|
|
|
|
Advertise *net.TCPAddr
|
|
|
|
|
|
|
|
// RPCListener is whether to bind a separate RPC listener on the bind address
|
|
|
|
// for this segment.
|
|
|
|
RPCListener bool
|
|
|
|
}
|