-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathlogger.go
More file actions
75 lines (63 loc) · 1.82 KB
/
logger.go
File metadata and controls
75 lines (63 loc) · 1.82 KB
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
package temporal
import (
"github.com/rs/zerolog"
temporallog "go.temporal.io/sdk/log"
)
type ZerologAdapter struct {
logger zerolog.Logger
}
// NewZerologAdapter creates a new ZerologAdapter
func NewZerologAdapter(logger zerolog.Logger) *ZerologAdapter {
return &ZerologAdapter{
logger: logger,
}
}
func (z *ZerologAdapter) Debug(msg string, keyvals ...interface{}) {
z.log(z.logger.Debug(), msg, keyvals...)
}
func (z *ZerologAdapter) Info(msg string, keyvals ...interface{}) {
z.log(z.logger.Info(), msg, keyvals...)
}
func (z *ZerologAdapter) Warn(msg string, keyvals ...interface{}) {
z.log(z.logger.Warn(), msg, keyvals...)
}
func (z *ZerologAdapter) Error(msg string, keyvals ...interface{}) {
z.log(z.logger.Error(), msg, keyvals...)
}
func (z *ZerologAdapter) log(event *zerolog.Event, msg string, keyvals ...interface{}) {
// Process key-value pairs
for i := 0; i < len(keyvals); i += 2 {
if i+1 < len(keyvals) {
key, ok := keyvals[i].(string)
if !ok {
key = "unknown"
}
event = event.Interface(key, keyvals[i+1])
} else {
// Handle odd number of keyvals
event = event.Interface("unknown", keyvals[i])
}
}
event.Msg(msg)
}
func (z *ZerologAdapter) WithCallerSkip(skip int) temporallog.Logger {
// +2 accounts for: this adapter method frame + zerolog internal frame
newLogger := z.logger.With().CallerWithSkipFrameCount(skip + 2).Logger()
return NewZerologAdapter(newLogger)
}
func (z *ZerologAdapter) With(keyvals ...interface{}) temporallog.Logger {
ctx := z.logger.With()
for i := 0; i < len(keyvals); i += 2 {
if i+1 < len(keyvals) {
key, ok := keyvals[i].(string)
if !ok {
key = "unknown"
}
ctx = ctx.Interface(key, keyvals[i+1])
} else {
// Handle odd number of keyvals
ctx = ctx.Interface("unknown", keyvals[i])
}
}
return NewZerologAdapter(ctx.Logger())
}