forked from birkirb/loggers-mapper-logrus
-
Notifications
You must be signed in to change notification settings - Fork 0
/
logrus.go
54 lines (45 loc) · 1.42 KB
/
logrus.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
package logrus
import (
"fmt"
"github.com/Vivino/go-loggers"
"github.com/sirupsen/logrus"
)
// Logger is an Contextual logger wrapper over Logrus's logger.
type Logger struct {
*logrus.Logger
}
// NewLogger returns a Contextual Logger for Logrus's logger.
// Note that any initialization must be done on the input logrus.
func NewLogger(logrus *logrus.Logger) loggers.Contextual {
var l Logger
l.Logger = logrus
l.Info("Now using Logrus logger package (via loggers/mappers/logrus).")
return &l
}
// NewDefaultLogger returns a Contextual Logger for Logrus's logger.
// The logger will contain whatever defaults Logrus uses.
func NewDefaultLogger() loggers.Contextual {
var l Logger
l.Logger = logrus.New()
l.Info("Now using Logrus logger package (via loggers/mappers/logrus).")
return &l
}
// WithField returns an advanced logger with a pre-set field.
func (l *Logger) WithField(key string, value interface{}) loggers.Advanced {
return l.Logger.WithField(key, value)
}
// WithFields returns an advanced logger with pre-set fields.
func (l *Logger) WithFields(fields ...interface{}) loggers.Advanced {
f := make(map[string]interface{}, len(fields)/2)
var key, value interface{}
for i := 0; i+1 < len(fields); i = i + 2 {
key = fields[i]
value = fields[i+1]
if s, ok := key.(string); ok {
f[s] = value
} else if s, ok := key.(fmt.Stringer); ok {
f[s.String()] = value
}
}
return l.Logger.WithFields(logrus.Fields(f))
}