forked from rexray/rexray
/
handlers_query_params.go
65 lines (56 loc) · 1.36 KB
/
handlers_query_params.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
package handlers
import (
"net/http"
"strconv"
log "github.com/sirupsen/logrus"
"github.com/rexray/rexray/libstorage/api/types"
)
// queryParamsHandler is an HTTP filter for injecting the store with query
// parameters
type queryParamsHandler struct {
handler types.APIFunc
}
func (h *queryParamsHandler) Name() string {
return "query-params-handler"
}
// NewQueryParamsHandler returns a new filter for injecting the store with query
// parameters
func NewQueryParamsHandler() types.Middleware {
return &queryParamsHandler{}
}
func (h *queryParamsHandler) Handler(m types.APIFunc) types.APIFunc {
return (&queryParamsHandler{m}).Handle
}
// Handle is the type's Handler function.
func (h *queryParamsHandler) Handle(
ctx types.Context,
w http.ResponseWriter,
req *http.Request,
store types.Store) error {
for k, v := range req.URL.Query() {
ctx.WithFields(log.Fields{
"key": k,
"value": v,
"len(value)": len(v),
}).Debug("query param")
switch len(v) {
case 0:
store.Set(k, true)
case 1:
if len(v[0]) == 0 {
store.Set(k, true)
} else {
if i, err := strconv.ParseInt(v[0], 10, 64); err == nil {
store.Set(k, i)
} else if b, err := strconv.ParseBool(v[0]); err == nil {
store.Set(k, b)
} else {
store.Set(k, v[0])
}
}
default:
store.Set(k, v)
}
}
return h.handler(ctx, w, req, store)
}