-
Notifications
You must be signed in to change notification settings - Fork 249
/
configure.go
67 lines (57 loc) · 1.41 KB
/
configure.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
55
56
57
58
59
60
61
62
63
64
65
66
67
package logger
import (
"github.com/sirupsen/logrus"
"github.com/unionj-cloud/go-doudou/framework/internal/config"
"github.com/unionj-cloud/go-doudou/toolkit/stringutils"
"io"
)
type LoggerOption func(*logrus.Logger)
func WithWritter(writer io.Writer) LoggerOption {
return func(log *logrus.Logger) {
log.SetOutput(writer)
}
}
func WithFormatter(formatter logrus.Formatter) LoggerOption {
return func(log *logrus.Logger) {
log.SetFormatter(formatter)
}
}
func WithReportCaller(reportCaller bool) LoggerOption {
return func(log *logrus.Logger) {
log.SetReportCaller(reportCaller)
}
}
func defaultFormatter() logrus.Formatter {
format := config.DefaultGddLogFormat
if stringutils.IsNotEmpty(config.GddLogFormat.Load()) {
format = config.GddLogFormat.Load()
}
var formatter logrus.Formatter
switch format {
case "json":
jf := new(logrus.JSONFormatter)
jf.TimestampFormat = "2006-01-02 15:04:05"
jf.DisableHTMLEscape = true
formatter = jf
case "text":
tf := new(logrus.TextFormatter)
tf.TimestampFormat = "2006-01-02 15:04:05"
tf.FullTimestamp = true
formatter = tf
default:
}
return formatter
}
func Init(opts ...LoggerOption) {
var loglevel config.LogLevel
(&loglevel).Decode(config.GddLogLevel.Load())
logger := logrus.StandardLogger()
logger.SetFormatter(defaultFormatter())
logger.SetLevel(logrus.Level(loglevel))
for _, opt := range opts {
opt(logger)
}
}
func init() {
Init()
}