mirror of
https://github.com/status-im/consul.git
synced 2025-01-25 05:00:32 +00:00
Moves coordinate disabled logic down into endpoints.
Similar rationale to the previous change for ACLs.
This commit is contained in:
parent
29367cd5ae
commit
679775418f
@ -9,12 +9,16 @@ import (
|
|||||||
"github.com/hashicorp/consul/agent/structs"
|
"github.com/hashicorp/consul/agent/structs"
|
||||||
)
|
)
|
||||||
|
|
||||||
// coordinateDisabled handles all the endpoints when coordinates are not enabled,
|
// checkCoordinateDisabled will return a standard response if coordinates are
|
||||||
// returning an error message.
|
// disabled. This returns true if they are disabled and we should not continue.
|
||||||
func coordinateDisabled(resp http.ResponseWriter, req *http.Request) (interface{}, error) {
|
func (s *HTTPServer) checkCoordinateDisabled(resp http.ResponseWriter, req *http.Request) bool {
|
||||||
|
if !s.agent.config.DisableCoordinates {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
resp.WriteHeader(http.StatusUnauthorized)
|
resp.WriteHeader(http.StatusUnauthorized)
|
||||||
fmt.Fprint(resp, "Coordinate support disabled")
|
fmt.Fprint(resp, "Coordinate support disabled")
|
||||||
return nil, nil
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
// sorter wraps a coordinate list and implements the sort.Interface to sort by
|
// sorter wraps a coordinate list and implements the sort.Interface to sort by
|
||||||
@ -41,6 +45,9 @@ func (s *sorter) Less(i, j int) bool {
|
|||||||
// CoordinateDatacenters returns the WAN nodes in each datacenter, along with
|
// CoordinateDatacenters returns the WAN nodes in each datacenter, along with
|
||||||
// raw network coordinates.
|
// raw network coordinates.
|
||||||
func (s *HTTPServer) CoordinateDatacenters(resp http.ResponseWriter, req *http.Request) (interface{}, error) {
|
func (s *HTTPServer) CoordinateDatacenters(resp http.ResponseWriter, req *http.Request) (interface{}, error) {
|
||||||
|
if s.checkCoordinateDisabled(resp, req) {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
if req.Method != "GET" {
|
if req.Method != "GET" {
|
||||||
return nil, MethodNotAllowedError{req.Method, []string{"GET"}}
|
return nil, MethodNotAllowedError{req.Method, []string{"GET"}}
|
||||||
}
|
}
|
||||||
@ -70,6 +77,9 @@ func (s *HTTPServer) CoordinateDatacenters(resp http.ResponseWriter, req *http.R
|
|||||||
// CoordinateNodes returns the LAN nodes in the given datacenter, along with
|
// CoordinateNodes returns the LAN nodes in the given datacenter, along with
|
||||||
// raw network coordinates.
|
// raw network coordinates.
|
||||||
func (s *HTTPServer) CoordinateNodes(resp http.ResponseWriter, req *http.Request) (interface{}, error) {
|
func (s *HTTPServer) CoordinateNodes(resp http.ResponseWriter, req *http.Request) (interface{}, error) {
|
||||||
|
if s.checkCoordinateDisabled(resp, req) {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
if req.Method != "GET" {
|
if req.Method != "GET" {
|
||||||
return nil, MethodNotAllowedError{req.Method, []string{"GET"}}
|
return nil, MethodNotAllowedError{req.Method, []string{"GET"}}
|
||||||
}
|
}
|
||||||
@ -92,6 +102,9 @@ func (s *HTTPServer) CoordinateNodes(resp http.ResponseWriter, req *http.Request
|
|||||||
// CoordinateNode returns the LAN node in the given datacenter, along with
|
// CoordinateNode returns the LAN node in the given datacenter, along with
|
||||||
// raw network coordinates.
|
// raw network coordinates.
|
||||||
func (s *HTTPServer) CoordinateNode(resp http.ResponseWriter, req *http.Request) (interface{}, error) {
|
func (s *HTTPServer) CoordinateNode(resp http.ResponseWriter, req *http.Request) (interface{}, error) {
|
||||||
|
if s.checkCoordinateDisabled(resp, req) {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
if req.Method != "GET" {
|
if req.Method != "GET" {
|
||||||
return nil, MethodNotAllowedError{req.Method, []string{"GET"}}
|
return nil, MethodNotAllowedError{req.Method, []string{"GET"}}
|
||||||
}
|
}
|
||||||
@ -141,6 +154,9 @@ func filterCoordinates(req *http.Request, in structs.Coordinates) structs.Coordi
|
|||||||
|
|
||||||
// CoordinateUpdate inserts or updates the LAN coordinate of a node.
|
// CoordinateUpdate inserts or updates the LAN coordinate of a node.
|
||||||
func (s *HTTPServer) CoordinateUpdate(resp http.ResponseWriter, req *http.Request) (interface{}, error) {
|
func (s *HTTPServer) CoordinateUpdate(resp http.ResponseWriter, req *http.Request) (interface{}, error) {
|
||||||
|
if s.checkCoordinateDisabled(resp, req) {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
if req.Method != "PUT" {
|
if req.Method != "PUT" {
|
||||||
return nil, MethodNotAllowedError{req.Method, []string{"PUT"}}
|
return nil, MethodNotAllowedError{req.Method, []string{"PUT"}}
|
||||||
}
|
}
|
||||||
|
@ -1,8 +1,10 @@
|
|||||||
package agent
|
package agent
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/http/httptest"
|
"net/http/httptest"
|
||||||
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
@ -10,6 +12,40 @@ import (
|
|||||||
"github.com/hashicorp/serf/coordinate"
|
"github.com/hashicorp/serf/coordinate"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func TestCoordinate_Disabled_Response(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
a := NewTestAgent(t.Name(), `
|
||||||
|
disable_coordinates = true
|
||||||
|
`)
|
||||||
|
defer a.Shutdown()
|
||||||
|
|
||||||
|
tests := []func(resp http.ResponseWriter, req *http.Request) (interface{}, error){
|
||||||
|
a.srv.CoordinateDatacenters,
|
||||||
|
a.srv.CoordinateNodes,
|
||||||
|
a.srv.CoordinateNode,
|
||||||
|
a.srv.CoordinateUpdate,
|
||||||
|
}
|
||||||
|
for i, tt := range tests {
|
||||||
|
t.Run(fmt.Sprintf("%d", i), func(t *testing.T) {
|
||||||
|
req, _ := http.NewRequest("PUT", "/should/not/care", nil)
|
||||||
|
resp := httptest.NewRecorder()
|
||||||
|
obj, err := tt(resp, req)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("err: %v", err)
|
||||||
|
}
|
||||||
|
if obj != nil {
|
||||||
|
t.Fatalf("bad: %#v", obj)
|
||||||
|
}
|
||||||
|
if got, want := resp.Code, http.StatusUnauthorized; got != want {
|
||||||
|
t.Fatalf("got %d want %d", got, want)
|
||||||
|
}
|
||||||
|
if !strings.Contains(resp.Body.String(), "Coordinate support disabled") {
|
||||||
|
t.Fatalf("bad: %#v", resp)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func TestCoordinate_Datacenters(t *testing.T) {
|
func TestCoordinate_Datacenters(t *testing.T) {
|
||||||
t.Parallel()
|
t.Parallel()
|
||||||
a := NewTestAgent(t.Name(), "")
|
a := NewTestAgent(t.Name(), "")
|
||||||
|
@ -113,17 +113,10 @@ func (s *HTTPServer) handler(enableDebug bool) http.Handler {
|
|||||||
handleFuncMetrics("/v1/catalog/services", s.wrap(s.CatalogServices))
|
handleFuncMetrics("/v1/catalog/services", s.wrap(s.CatalogServices))
|
||||||
handleFuncMetrics("/v1/catalog/service/", s.wrap(s.CatalogServiceNodes))
|
handleFuncMetrics("/v1/catalog/service/", s.wrap(s.CatalogServiceNodes))
|
||||||
handleFuncMetrics("/v1/catalog/node/", s.wrap(s.CatalogNodeServices))
|
handleFuncMetrics("/v1/catalog/node/", s.wrap(s.CatalogNodeServices))
|
||||||
if !s.agent.config.DisableCoordinates {
|
handleFuncMetrics("/v1/coordinate/datacenters", s.wrap(s.CoordinateDatacenters))
|
||||||
handleFuncMetrics("/v1/coordinate/datacenters", s.wrap(s.CoordinateDatacenters))
|
handleFuncMetrics("/v1/coordinate/nodes", s.wrap(s.CoordinateNodes))
|
||||||
handleFuncMetrics("/v1/coordinate/nodes", s.wrap(s.CoordinateNodes))
|
handleFuncMetrics("/v1/coordinate/node/", s.wrap(s.CoordinateNode))
|
||||||
handleFuncMetrics("/v1/coordinate/node/", s.wrap(s.CoordinateNode))
|
handleFuncMetrics("/v1/coordinate/update", s.wrap(s.CoordinateUpdate))
|
||||||
handleFuncMetrics("/v1/coordinate/update", s.wrap(s.CoordinateUpdate))
|
|
||||||
} else {
|
|
||||||
handleFuncMetrics("/v1/coordinate/datacenters", s.wrap(coordinateDisabled))
|
|
||||||
handleFuncMetrics("/v1/coordinate/nodes", s.wrap(coordinateDisabled))
|
|
||||||
handleFuncMetrics("/v1/coordinate/node/", s.wrap(coordinateDisabled))
|
|
||||||
handleFuncMetrics("/v1/coordinate/update", s.wrap(coordinateDisabled))
|
|
||||||
}
|
|
||||||
handleFuncMetrics("/v1/event/fire/", s.wrap(s.EventFire))
|
handleFuncMetrics("/v1/event/fire/", s.wrap(s.EventFire))
|
||||||
handleFuncMetrics("/v1/event/list", s.wrap(s.EventList))
|
handleFuncMetrics("/v1/event/list", s.wrap(s.EventList))
|
||||||
handleFuncMetrics("/v1/health/node/", s.wrap(s.HealthNodeChecks))
|
handleFuncMetrics("/v1/health/node/", s.wrap(s.HealthNodeChecks))
|
||||||
|
Loading…
x
Reference in New Issue
Block a user