-
Notifications
You must be signed in to change notification settings - Fork 0
/
logger.go
51 lines (43 loc) · 1.17 KB
/
logger.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
package rice
import (
"io"
"strings"
"github.com/rs/zerolog"
"github.com/rs/zerolog/pkgerrors"
)
const consoleDefaultTimeFormat = "2006/01/02 15:04:05.000000"
var Logger zerolog.Logger
var levelMap = map[string]zerolog.Level{
"debug": zerolog.DebugLevel,
"info": zerolog.InfoLevel,
"warn": zerolog.WarnLevel,
"error": zerolog.ErrorLevel,
"fatal": zerolog.FatalLevel,
"panic": zerolog.PanicLevel,
"no": zerolog.NoLevel,
"disabled": zerolog.Disabled,
"trace": zerolog.TraceLevel,
"": zerolog.InfoLevel,
}
func InitZerolog(level string, w ...io.Writer) {
zerolog.SetGlobalLevel(levelMap[strings.ToLower(level)])
zerolog.TimeFieldFormat = consoleDefaultTimeFormat
zerolog.TimestampFieldName = "timestamp"
zerolog.ErrorStackMarshaler = pkgerrors.MarshalStack
InitLogger(w...)
}
func InitLogger(w ...io.Writer) {
if len(w) == 0 {
w = make([]io.Writer, 0)
w = append(w, NewConsoleWriter())
}
multi := zerolog.MultiLevelWriter(w...)
gitRevision, goVersion := VersionInfo()
Logger = zerolog.New(multi).With().
Timestamp().
Str("git_revision", gitRevision).
Str("go_version", goVersion).
Caller().
Stack().
Logger()
}