-
Notifications
You must be signed in to change notification settings - Fork 21
/
Copy pathlogger.go
114 lines (99 loc) · 2.71 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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
//go:build !windows
// +build !windows
package logging
import (
"context"
"io"
"log"
"log/syslog"
"os"
"github.com/gatewayd-io/gatewayd/config"
"github.com/rs/zerolog"
"go.opentelemetry.io/otel"
"gopkg.in/natefinch/lumberjack.v2"
)
type LoggerConfig struct {
Output []config.LogOutput
TimeFormat string
Level zerolog.Level
NoColor bool
ConsoleTimeFormat string
// (R)Syslog configuration.
RSyslogNetwork string
RSyslogAddress string
SyslogPriority syslog.Priority
// File output configuration.
FileName string
MaxSize int
MaxBackups int
MaxAge int
Compress bool
LocalTime bool
// the output of config.Console log will be written to this writer, if it is nil os.Stdout will be used.
ConsoleOut io.Writer
// group name
Name string
}
// NewLogger creates a new logger with the given configuration.
func NewLogger(ctx context.Context, cfg LoggerConfig) zerolog.Logger {
_, span := otel.Tracer(config.TracerName).Start(ctx, "Create new logger")
// Create a new logger.
var consoleOut io.Writer = os.Stdout
if cfg.ConsoleOut != nil {
consoleOut = cfg.ConsoleOut
}
consoleWriter := zerolog.ConsoleWriter{
Out: consoleOut,
TimeFormat: cfg.ConsoleTimeFormat,
NoColor: cfg.NoColor,
}
var outputs []io.Writer
for _, out := range cfg.Output {
switch out {
case config.Console:
outputs = append(outputs, consoleWriter)
case config.Stdout:
outputs = append(outputs, os.Stdout)
case config.Stderr:
outputs = append(outputs, os.Stderr)
case config.File:
outputs = append(
outputs, &lumberjack.Logger{
Filename: cfg.FileName,
MaxSize: cfg.MaxSize,
MaxBackups: cfg.MaxBackups,
MaxAge: cfg.MaxAge,
Compress: cfg.Compress,
LocalTime: cfg.LocalTime,
},
)
case config.Syslog:
syslogWriter, err := syslog.New(cfg.SyslogPriority, config.DefaultSyslogTag)
if err != nil {
span.RecordError(err)
span.End()
log.Fatal(err)
}
outputs = append(outputs, syslogWriter)
case config.RSyslog:
// TODO: Add support for TLS.
// See: https://github.com/RackSec/srslog (deprecated)
rsyslogWriter, err := syslog.Dial(
cfg.RSyslogNetwork, cfg.RSyslogAddress, cfg.SyslogPriority, config.DefaultSyslogTag)
if err != nil {
log.Fatal(err)
}
outputs = append(outputs, zerolog.SyslogLevelWriter(rsyslogWriter))
default:
outputs = append(outputs, consoleWriter)
}
}
zerolog.SetGlobalLevel(cfg.Level)
zerolog.TimeFieldFormat = cfg.TimeFormat
multiWriter := zerolog.MultiLevelWriter(outputs...)
logger := zerolog.New(multiWriter)
logger = logger.With().Timestamp().Logger()
logger = logger.With().Str("group", cfg.Name).Logger()
span.End()
return logger
}