2fas-server/internal/common/logging/logger.go

100 lines
2.0 KiB
Go

package logging
import (
"encoding/json"
"github.com/sirupsen/logrus"
"reflect"
"sync"
)
type Fields map[string]interface{}
var (
customLogger = New()
defaultFields = logrus.Fields{}
defaultFieldsMutex = sync.RWMutex{}
)
func New() *logrus.Logger {
logger := logrus.New()
logger.SetFormatter(&logrus.JSONFormatter{
FieldMap: logrus.FieldMap{
logrus.FieldKeyTime: "timestamp",
logrus.FieldKeyLevel: "level",
logrus.FieldKeyMsg: "message",
},
})
logger.SetLevel(logrus.InfoLevel)
return logger
}
func WithDefaultField(key, value string) *logrus.Logger {
defaultFieldsMutex.Lock()
defer defaultFieldsMutex.Unlock()
defaultFields[key] = value
return customLogger
}
func Info(args ...interface{}) {
customLogger.WithFields(defaultFields).Info(args)
}
func Error(args ...interface{}) {
customLogger.WithFields(defaultFields).Error(args)
}
func Warning(args ...interface{}) {
customLogger.WithFields(defaultFields).Warning(args)
}
func Debug(args ...interface{}) {
customLogger.WithFields(defaultFields).Debug(args)
}
func Fatal(args ...interface{}) {
customLogger.WithFields(defaultFields).Fatal(args)
}
func WithField(key string, value interface{}) *logrus.Entry {
return customLogger.
WithField(key, value).
WithFields(defaultFields)
}
func WithFields(fields Fields) *logrus.Entry {
return customLogger.
WithFields(logrus.Fields(fields)).
WithFields(defaultFields)
}
func LogCommand(command interface{}) {
context, _ := json.Marshal(command)
commandName := reflect.TypeOf(command).Elem().Name()
var commandAsFields logrus.Fields
json.Unmarshal(context, &commandAsFields)
customLogger.
WithFields(defaultFields).
WithFields(logrus.Fields{
"command_name": commandName,
"command": commandAsFields,
}).Info("Start command " + commandName)
}
func LogCommandFailed(command interface{}, err error) {
commandName := reflect.TypeOf(command).Elem().Name()
customLogger.
WithFields(defaultFields).
WithFields(logrus.Fields{
"reason": err.Error(),
}).Info("Command failed" + commandName)
}