mirror of
https://github.com/mainflux/mainflux.git
synced 2025-04-26 13:48:53 +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>
68 lines
1.5 KiB
Go
68 lines
1.5 KiB
Go
// Copyright (c) Mainflux
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package logger
|
|
|
|
import (
|
|
"fmt"
|
|
"io"
|
|
"time"
|
|
|
|
"github.com/go-kit/kit/log"
|
|
)
|
|
|
|
// Logger specifies logging API.
|
|
type Logger interface {
|
|
// Debug logs any object in JSON format on debug level.
|
|
Debug(string)
|
|
// Info logs any object in JSON format on info level.
|
|
Info(string)
|
|
// Warn logs any object in JSON format on warning level.
|
|
Warn(string)
|
|
// Error logs any object in JSON format on error level.
|
|
Error(string)
|
|
}
|
|
|
|
var _ Logger = (*logger)(nil)
|
|
|
|
type logger struct {
|
|
kitLogger log.Logger
|
|
level Level
|
|
}
|
|
|
|
// New returns wrapped go kit logger.
|
|
func New(out io.Writer, levelText string) (Logger, error) {
|
|
var level Level
|
|
err := level.UnmarshalText(levelText)
|
|
if err != nil {
|
|
return nil, fmt.Errorf(`{"level":"error","message":"%s: %s","ts":"%s"}`, err, levelText, time.RFC3339Nano)
|
|
}
|
|
l := log.NewJSONLogger(log.NewSyncWriter(out))
|
|
l = log.With(l, "ts", log.DefaultTimestampUTC)
|
|
return &logger{l, level}, err
|
|
}
|
|
|
|
func (l logger) Debug(msg string) {
|
|
if Debug.isAllowed(l.level) {
|
|
l.kitLogger.Log("level", Debug.String(), "message", msg)
|
|
}
|
|
}
|
|
|
|
func (l logger) Info(msg string) {
|
|
if Info.isAllowed(l.level) {
|
|
l.kitLogger.Log("level", Info.String(), "message", msg)
|
|
}
|
|
}
|
|
|
|
func (l logger) Warn(msg string) {
|
|
if Warn.isAllowed(l.level) {
|
|
l.kitLogger.Log("level", Warn.String(), "message", msg)
|
|
}
|
|
}
|
|
|
|
func (l logger) Error(msg string) {
|
|
if Error.isAllowed(l.level) {
|
|
l.kitLogger.Log("level", Error.String(), "message", msg)
|
|
}
|
|
}
|