-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathlog.go
More file actions
113 lines (99 loc) · 2.42 KB
/
log.go
File metadata and controls
113 lines (99 loc) · 2.42 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
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
package toolbox
import (
"context"
"github.com/getsentry/sentry-go"
"github.com/go-kit/log"
"github.com/pkg/errors"
)
// LoggerWithStack wraps next and adds stacktrace to log entries when available.
func LoggerWithStack(next log.Logger) log.Logger {
return &stackLogger{
next: next,
}
}
type stackLogger struct {
next log.Logger
}
func (l *stackLogger) Log(keyvals ...interface{}) error {
for i := 0; i < len(keyvals); i += 2 {
if keyvals[i] == "err" {
if err, ok := keyvals[i+1].(error); ok {
if location, ok := HasStack(err); ok {
keyvals = append(keyvals, "location", location)
}
}
}
}
return l.next.Log(keyvals...)
}
// LoggerWithRequestContext wraps next and adds key values to log entries when available.
func LoggerWithRequestContext(ctx context.Context, next log.Logger) log.Logger {
return &reqContextLogger{
ctx: ctx,
next: next,
}
}
type reqContextLogger struct {
ctx context.Context
next log.Logger
}
func (l *reqContextLogger) Log(keyvals ...interface{}) error {
if method, path, err := GetRequestContext(l.ctx); err == nil {
keyvals = append([]interface{}{"method", method, "path", path}, keyvals...)
}
return l.next.Log(keyvals...)
}
// LoggerWithKeyValues wraps next and adds key values to log entries when available.
func LoggerWithKeyValues(next log.Logger) log.Logger {
return &keyvalsLogger{
next: next,
}
}
type keyvalsLogger struct {
next log.Logger
}
func (l *keyvalsLogger) Log(keyvals ...interface{}) error {
for i := 0; i < len(keyvals); i += 2 {
if keyvals[i] == "err" {
if err, ok := keyvals[i+1].(error); ok {
if newKeyvals, ok := HasKeyValues(err); ok {
keyvals = append(keyvals, newKeyvals...)
}
}
}
}
return l.next.Log(keyvals...)
}
// LoggerWithSentry exports errors to sentry.
func LoggerWithSentry(ctx context.Context, next log.Logger) log.Logger {
return &sentryLogger{
ctx: ctx,
next: next,
}
}
type sentryLogger struct {
ctx context.Context
next log.Logger
}
func (l *sentryLogger) Log(keyvals ...interface{}) error {
for i := 0; i < len(keyvals); i += 2 {
switch keyvals[i] {
case "err", "error":
var e error
switch err := keyvals[i+1].(type) {
case error:
e = err
case string:
e = errors.New(err)
}
if e != nil {
if hub := sentry.GetHubFromContext(l.ctx); hub != nil {
hub.CaptureException(e)
} else {
sentry.CaptureException(e)
}
}
}
}
return l.next.Log(keyvals...)
}