mirror of
https://github.com/mainflux/mainflux.git
synced 2025-04-29 13:49:28 +08:00

* MF-1348 - Add go-kit transport level logging Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Fix reviews Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Fix reviews Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Fix merge Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Fix remark Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Fix go test flags Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Use httputil errors in things and http service Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Fix SDK tests Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Use httputil errors in certs and provision service Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Use httputil errors in consumers service Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * General renaming and add ErrMissingToken Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Rename httputil -> apiutil and use errors in users servive Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Use apiutil errors in auth, bootstrap, readers, things and twins Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Replace errors.Contain by comparison Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Fix remarks Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Simplify validateID Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Simplify validateID Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Simplify and rename ExtractAuthToken -> ExtractBearerToken Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Fix readers Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Fix auth key test and remarks Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Improve comment Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Simplify validateUUID check Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Fix typo Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> Co-authored-by: Dušan Borovčanin <dusan.borovcanin@mainflux.com>
149 lines
3.3 KiB
Go
149 lines
3.3 KiB
Go
// Copyright (c) Mainflux
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package apiutil
|
|
|
|
import (
|
|
"context"
|
|
"encoding/json"
|
|
"net/http"
|
|
"strconv"
|
|
|
|
kithttp "github.com/go-kit/kit/transport/http"
|
|
"github.com/go-zoo/bone"
|
|
"github.com/mainflux/mainflux/logger"
|
|
"github.com/mainflux/mainflux/pkg/errors"
|
|
)
|
|
|
|
// LoggingErrorEncoder is a go-kit error encoder logging decorator.
|
|
func LoggingErrorEncoder(logger logger.Logger, enc kithttp.ErrorEncoder) kithttp.ErrorEncoder {
|
|
return func(ctx context.Context, err error, w http.ResponseWriter) {
|
|
switch err {
|
|
case ErrBearerToken,
|
|
ErrMissingID,
|
|
ErrBearerKey,
|
|
ErrInvalidAuthKey,
|
|
ErrInvalidIDFormat,
|
|
ErrNameSize,
|
|
ErrLimitSize,
|
|
ErrOffsetSize,
|
|
ErrInvalidOrder,
|
|
ErrInvalidDirection,
|
|
ErrEmptyList,
|
|
ErrMalformedPolicy,
|
|
ErrMissingPolicySub,
|
|
ErrMissingPolicyObj,
|
|
ErrMissingPolicyAct,
|
|
ErrMissingCertData,
|
|
ErrInvalidTopic,
|
|
ErrInvalidContact,
|
|
ErrMissingEmail,
|
|
ErrMissingHost,
|
|
ErrMissingPass,
|
|
ErrMissingConfPass,
|
|
ErrInvalidResetPass,
|
|
ErrInvalidComparator,
|
|
ErrMissingMemberType,
|
|
ErrInvalidAPIKey,
|
|
ErrMaxLevelExceeded,
|
|
ErrBootstrapState:
|
|
logger.Error(err.Error())
|
|
}
|
|
|
|
enc(ctx, err, w)
|
|
}
|
|
}
|
|
|
|
// ReadUintQuery reads the value of uint64 http query parameters for a given key
|
|
func ReadUintQuery(r *http.Request, key string, def uint64) (uint64, error) {
|
|
vals := bone.GetQuery(r, key)
|
|
if len(vals) > 1 {
|
|
return 0, errors.ErrInvalidQueryParams
|
|
}
|
|
|
|
if len(vals) == 0 {
|
|
return def, nil
|
|
}
|
|
|
|
strval := vals[0]
|
|
val, err := strconv.ParseUint(strval, 10, 64)
|
|
if err != nil {
|
|
return 0, errors.ErrInvalidQueryParams
|
|
}
|
|
|
|
return val, nil
|
|
}
|
|
|
|
// ReadStringQuery reads the value of string http query parameters for a given key
|
|
func ReadStringQuery(r *http.Request, key string, def string) (string, error) {
|
|
vals := bone.GetQuery(r, key)
|
|
if len(vals) > 1 {
|
|
return "", errors.ErrInvalidQueryParams
|
|
}
|
|
|
|
if len(vals) == 0 {
|
|
return def, nil
|
|
}
|
|
|
|
return vals[0], nil
|
|
}
|
|
|
|
// ReadMetadataQuery reads the value of json http query parameters for a given key
|
|
func ReadMetadataQuery(r *http.Request, key string, def map[string]interface{}) (map[string]interface{}, error) {
|
|
vals := bone.GetQuery(r, key)
|
|
if len(vals) > 1 {
|
|
return nil, errors.ErrInvalidQueryParams
|
|
}
|
|
|
|
if len(vals) == 0 {
|
|
return def, nil
|
|
}
|
|
|
|
m := make(map[string]interface{})
|
|
err := json.Unmarshal([]byte(vals[0]), &m)
|
|
if err != nil {
|
|
return nil, errors.Wrap(errors.ErrInvalidQueryParams, err)
|
|
}
|
|
|
|
return m, nil
|
|
}
|
|
|
|
// ReadBoolQuery reads boolean query parameters in a given http request
|
|
func ReadBoolQuery(r *http.Request, key string, def bool) (bool, error) {
|
|
vals := bone.GetQuery(r, key)
|
|
if len(vals) > 1 {
|
|
return false, errors.ErrInvalidQueryParams
|
|
}
|
|
|
|
if len(vals) == 0 {
|
|
return def, nil
|
|
}
|
|
|
|
b, err := strconv.ParseBool(vals[0])
|
|
if err != nil {
|
|
return false, errors.ErrInvalidQueryParams
|
|
}
|
|
|
|
return b, nil
|
|
}
|
|
|
|
// ReadFloatQuery reads the value of float64 http query parameters for a given key
|
|
func ReadFloatQuery(r *http.Request, key string, def float64) (float64, error) {
|
|
vals := bone.GetQuery(r, key)
|
|
if len(vals) > 1 {
|
|
return 0, errors.ErrInvalidQueryParams
|
|
}
|
|
|
|
if len(vals) == 0 {
|
|
return def, nil
|
|
}
|
|
|
|
fval := vals[0]
|
|
val, err := strconv.ParseFloat(fval, 64)
|
|
if err != nil {
|
|
return 0, errors.ErrInvalidQueryParams
|
|
}
|
|
|
|
return val, nil
|
|
}
|