2023-03-28 21:12:41 +01:00
|
|
|
// Copyright (c) HashiCorp, Inc.
|
|
|
|
// SPDX-License-Identifier: MPL-2.0
|
|
|
|
|
2015-10-15 21:42:09 -07:00
|
|
|
package api
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/hashicorp/serf/coordinate"
|
|
|
|
)
|
|
|
|
|
|
|
|
// CoordinateEntry represents a node and its associated network coordinate.
|
|
|
|
type CoordinateEntry struct {
|
2021-07-22 14:33:22 -05:00
|
|
|
Node string
|
|
|
|
Segment string
|
|
|
|
Partition string `json:",omitempty"`
|
|
|
|
Coord *coordinate.Coordinate
|
2015-10-15 21:42:09 -07:00
|
|
|
}
|
|
|
|
|
2017-03-13 18:54:34 -07:00
|
|
|
// CoordinateDatacenterMap has the coordinates for servers in a given datacenter
|
|
|
|
// and area. Network coordinates are only compatible within the same area.
|
2015-10-15 21:42:09 -07:00
|
|
|
type CoordinateDatacenterMap struct {
|
|
|
|
Datacenter string
|
2017-03-13 18:54:34 -07:00
|
|
|
AreaID string
|
2015-10-15 21:42:09 -07:00
|
|
|
Coordinates []CoordinateEntry
|
|
|
|
}
|
|
|
|
|
|
|
|
// Coordinate can be used to query the coordinate endpoints
|
|
|
|
type Coordinate struct {
|
|
|
|
c *Client
|
|
|
|
}
|
|
|
|
|
|
|
|
// Coordinate returns a handle to the coordinate endpoints
|
|
|
|
func (c *Client) Coordinate() *Coordinate {
|
|
|
|
return &Coordinate{c}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Datacenters is used to return the coordinates of all the servers in the WAN
|
|
|
|
// pool.
|
|
|
|
func (c *Coordinate) Datacenters() ([]*CoordinateDatacenterMap, error) {
|
|
|
|
r := c.c.newRequest("GET", "/v1/coordinate/datacenters")
|
2021-10-28 21:54:23 +05:30
|
|
|
_, resp, err := c.c.doRequest(r)
|
2015-10-15 21:42:09 -07:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2021-06-14 18:49:32 -04:00
|
|
|
defer closeResponseBody(resp)
|
2021-10-28 21:54:23 +05:30
|
|
|
if err := requireOK(resp); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2015-10-15 21:42:09 -07:00
|
|
|
|
|
|
|
var out []*CoordinateDatacenterMap
|
|
|
|
if err := decodeBody(resp, &out); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return out, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Nodes is used to return the coordinates of all the nodes in the LAN pool.
|
|
|
|
func (c *Coordinate) Nodes(q *QueryOptions) ([]*CoordinateEntry, *QueryMeta, error) {
|
|
|
|
r := c.c.newRequest("GET", "/v1/coordinate/nodes")
|
|
|
|
r.setQueryOptions(q)
|
2021-10-28 21:54:23 +05:30
|
|
|
rtt, resp, err := c.c.doRequest(r)
|
2015-10-15 21:42:09 -07:00
|
|
|
if err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
2021-06-14 18:49:32 -04:00
|
|
|
defer closeResponseBody(resp)
|
2021-10-28 21:54:23 +05:30
|
|
|
if err := requireOK(resp); err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
2015-10-15 21:42:09 -07:00
|
|
|
|
|
|
|
qm := &QueryMeta{}
|
|
|
|
parseQueryMeta(resp, qm)
|
|
|
|
qm.RequestTime = rtt
|
|
|
|
|
|
|
|
var out []*CoordinateEntry
|
|
|
|
if err := decodeBody(resp, &out); err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
|
|
|
return out, qm, nil
|
|
|
|
}
|
2017-10-23 17:44:50 -07:00
|
|
|
|
|
|
|
// Update inserts or updates the LAN coordinate of a node.
|
|
|
|
func (c *Coordinate) Update(coord *CoordinateEntry, q *WriteOptions) (*WriteMeta, error) {
|
|
|
|
r := c.c.newRequest("PUT", "/v1/coordinate/update")
|
|
|
|
r.setWriteOptions(q)
|
|
|
|
r.obj = coord
|
2021-10-28 21:54:23 +05:30
|
|
|
rtt, resp, err := c.c.doRequest(r)
|
2017-10-23 17:44:50 -07:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2021-06-14 18:49:32 -04:00
|
|
|
defer closeResponseBody(resp)
|
2021-10-28 21:54:23 +05:30
|
|
|
if err := requireOK(resp); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2017-10-23 17:44:50 -07:00
|
|
|
|
|
|
|
wm := &WriteMeta{}
|
|
|
|
wm.RequestTime = rtt
|
|
|
|
|
|
|
|
return wm, nil
|
|
|
|
}
|
2017-10-26 19:20:24 -07:00
|
|
|
|
2019-11-05 20:34:46 -08:00
|
|
|
// Node is used to return the coordinates of a single node in the LAN pool.
|
2017-10-26 19:16:40 -07:00
|
|
|
func (c *Coordinate) Node(node string, q *QueryOptions) ([]*CoordinateEntry, *QueryMeta, error) {
|
2022-01-25 12:15:06 -05:00
|
|
|
r := c.c.newRequest("GET", "/v1/coordinate/node/"+node)
|
2017-10-26 19:16:40 -07:00
|
|
|
r.setQueryOptions(q)
|
2021-10-28 21:54:23 +05:30
|
|
|
rtt, resp, err := c.c.doRequest(r)
|
2017-10-26 19:16:40 -07:00
|
|
|
if err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
2021-06-14 18:49:32 -04:00
|
|
|
defer closeResponseBody(resp)
|
2021-10-28 21:54:23 +05:30
|
|
|
if err := requireOK(resp); err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
2017-10-26 19:16:40 -07:00
|
|
|
|
|
|
|
qm := &QueryMeta{}
|
|
|
|
parseQueryMeta(resp, qm)
|
|
|
|
qm.RequestTime = rtt
|
|
|
|
|
|
|
|
var out []*CoordinateEntry
|
|
|
|
if err := decodeBody(resp, &out); err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
|
|
|
return out, qm, nil
|
|
|
|
}
|