When mangaling JSON to parse durations do a case insensitive key lookup

pull/78/head
Tarrant 2014-04-24 19:44:27 -07:00
parent 513dfa8947
commit 32da5b2de0
2 changed files with 28 additions and 6 deletions

View File

@ -118,10 +118,17 @@ func (s *HTTPServer) AgentRegisterService(resp http.ResponseWriter, req *http.Re
if !ok { if !ok {
return nil return nil
} }
check, ok := rawMap["check"]
if !ok { var check interface{}
for k, v := range rawMap {
if strings.ToLower(k) == "check" {
check = v
}
}
if check == nil {
return nil return nil
} }
return FixupCheckType(check) return FixupCheckType(check)
} }
if err := decodeBody(req, &args, decodeCB); err != nil { if err := decodeBody(req, &args, decodeCB); err != nil {

View File

@ -265,23 +265,38 @@ func FixupCheckType(raw interface{}) error {
if !ok { if !ok {
return nil return nil
} }
if ttl, ok := rawMap["ttl"]; ok {
var ttlKey string
for k, _ := range rawMap {
if strings.ToLower(k) == "ttl" {
ttlKey = k
}
}
var intervalKey string
for k, _ := range rawMap {
if strings.ToLower(k) == "interval" {
intervalKey = k
}
}
if ttl, ok := rawMap[ttlKey]; ok {
ttlS, ok := ttl.(string) ttlS, ok := ttl.(string)
if ok { if ok {
if dur, err := time.ParseDuration(ttlS); err != nil { if dur, err := time.ParseDuration(ttlS); err != nil {
return err return err
} else { } else {
rawMap["ttl"] = dur rawMap[ttlKey] = dur
} }
} }
} }
if interval, ok := rawMap["interval"]; ok {
if interval, ok := rawMap[intervalKey]; ok {
intervalS, ok := interval.(string) intervalS, ok := interval.(string)
if ok { if ok {
if dur, err := time.ParseDuration(intervalS); err != nil { if dur, err := time.ParseDuration(intervalS); err != nil {
return err return err
} else { } else {
rawMap["interval"] = dur rawMap[intervalKey] = dur
} }
} }
} }