mirror of https://github.com/hashicorp/consul
agent: Fix decoding of checks. Fixes #60
parent
6bbe8fd493
commit
00bedd4020
|
@ -55,7 +55,11 @@ func (s *HTTPServer) AgentForceLeave(resp http.ResponseWriter, req *http.Request
|
||||||
|
|
||||||
func (s *HTTPServer) AgentRegisterCheck(resp http.ResponseWriter, req *http.Request) (interface{}, error) {
|
func (s *HTTPServer) AgentRegisterCheck(resp http.ResponseWriter, req *http.Request) (interface{}, error) {
|
||||||
var args CheckDefinition
|
var args CheckDefinition
|
||||||
if err := decodeBody(req, &args); err != nil {
|
// Fixup the type decode of TTL or Interval
|
||||||
|
decodeCB := func(raw interface{}) error {
|
||||||
|
return FixupCheckType(raw)
|
||||||
|
}
|
||||||
|
if err := decodeBody(req, &args, decodeCB); err != nil {
|
||||||
resp.WriteHeader(400)
|
resp.WriteHeader(400)
|
||||||
resp.Write([]byte(fmt.Sprintf("Request decode failed: %v", err)))
|
resp.Write([]byte(fmt.Sprintf("Request decode failed: %v", err)))
|
||||||
return nil, nil
|
return nil, nil
|
||||||
|
@ -108,7 +112,19 @@ func (s *HTTPServer) AgentCheckFail(resp http.ResponseWriter, req *http.Request)
|
||||||
|
|
||||||
func (s *HTTPServer) AgentRegisterService(resp http.ResponseWriter, req *http.Request) (interface{}, error) {
|
func (s *HTTPServer) AgentRegisterService(resp http.ResponseWriter, req *http.Request) (interface{}, error) {
|
||||||
var args ServiceDefinition
|
var args ServiceDefinition
|
||||||
if err := decodeBody(req, &args); err != nil {
|
// Fixup the type decode of TTL or Interval if a check if provided
|
||||||
|
decodeCB := func(raw interface{}) error {
|
||||||
|
rawMap, ok := raw.(map[string]interface{})
|
||||||
|
if !ok {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
check, ok := rawMap["check"]
|
||||||
|
if !ok {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
return FixupCheckType(check)
|
||||||
|
}
|
||||||
|
if err := decodeBody(req, &args, decodeCB); err != nil {
|
||||||
resp.WriteHeader(400)
|
resp.WriteHeader(400)
|
||||||
resp.Write([]byte(fmt.Sprintf("Request decode failed: %v", err)))
|
resp.Write([]byte(fmt.Sprintf("Request decode failed: %v", err)))
|
||||||
return nil, nil
|
return nil, nil
|
||||||
|
|
|
@ -9,7 +9,7 @@ import (
|
||||||
|
|
||||||
func (s *HTTPServer) CatalogRegister(resp http.ResponseWriter, req *http.Request) (interface{}, error) {
|
func (s *HTTPServer) CatalogRegister(resp http.ResponseWriter, req *http.Request) (interface{}, error) {
|
||||||
var args structs.RegisterRequest
|
var args structs.RegisterRequest
|
||||||
if err := decodeBody(req, &args); err != nil {
|
if err := decodeBody(req, &args, nil); err != nil {
|
||||||
resp.WriteHeader(400)
|
resp.WriteHeader(400)
|
||||||
resp.Write([]byte(fmt.Sprintf("Request decode failed: %v", err)))
|
resp.Write([]byte(fmt.Sprintf("Request decode failed: %v", err)))
|
||||||
return nil, nil
|
return nil, nil
|
||||||
|
@ -30,7 +30,7 @@ func (s *HTTPServer) CatalogRegister(resp http.ResponseWriter, req *http.Request
|
||||||
|
|
||||||
func (s *HTTPServer) CatalogDeregister(resp http.ResponseWriter, req *http.Request) (interface{}, error) {
|
func (s *HTTPServer) CatalogDeregister(resp http.ResponseWriter, req *http.Request) (interface{}, error) {
|
||||||
var args structs.DeregisterRequest
|
var args structs.DeregisterRequest
|
||||||
if err := decodeBody(req, &args); err != nil {
|
if err := decodeBody(req, &args, nil); err != nil {
|
||||||
resp.WriteHeader(400)
|
resp.WriteHeader(400)
|
||||||
resp.Write([]byte(fmt.Sprintf("Request decode failed: %v", err)))
|
resp.Write([]byte(fmt.Sprintf("Request decode failed: %v", err)))
|
||||||
return nil, nil
|
return nil, nil
|
||||||
|
|
|
@ -4,6 +4,7 @@ import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"github.com/hashicorp/consul/consul/structs"
|
"github.com/hashicorp/consul/consul/structs"
|
||||||
|
"github.com/mitchellh/mapstructure"
|
||||||
"io"
|
"io"
|
||||||
"log"
|
"log"
|
||||||
"net"
|
"net"
|
||||||
|
@ -151,9 +152,20 @@ func (s *HTTPServer) Index(resp http.ResponseWriter, req *http.Request) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// decodeBody is used to decode a JSON request body
|
// decodeBody is used to decode a JSON request body
|
||||||
func decodeBody(req *http.Request, out interface{}) error {
|
func decodeBody(req *http.Request, out interface{}, cb func(interface{}) error) error {
|
||||||
|
var raw interface{}
|
||||||
dec := json.NewDecoder(req.Body)
|
dec := json.NewDecoder(req.Body)
|
||||||
return dec.Decode(out)
|
if err := dec.Decode(&raw); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
// Invoke the callback prior to decode
|
||||||
|
if cb != nil {
|
||||||
|
if err := cb(raw); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return mapstructure.Decode(raw, out)
|
||||||
}
|
}
|
||||||
|
|
||||||
// setIndex is used to set the index response header
|
// setIndex is used to set the index response header
|
||||||
|
|
Loading…
Reference in New Issue