Core

/app/lib/telemetry/logger.go (909 B)

 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
package telemetry

import (
"strings"

"{{{ .Package }}}/app/util"
)

func LoggerFor(logger util.Logger, span *Span) util.Logger {
if logger == nil {
return nil
}
if span == nil {
return logger
}
return logger.With("trace", span.TraceID(), "span", span.SpanID())
}

type ErrHandler struct {
logger util.Logger
hasPrinted bool
}

func (e *ErrHandler) Handle(err error) {
if err == nil {
return
}
msg := err.Error()
if strings.HasPrefix(msg, "Post \"") || strings.HasPrefix(msg, "traces export") {
if e.hasPrinted {
return
}
if idx := strings.Index(msg, "\":"); idx > -1 {
msg = strings.TrimSpace(msg[idx+2:])
}
if strings.Contains(msg, "connectex") {
msg = "connection failure"
}
e.logger.Warn("telemetry seems to be unavailable: [" + msg + "] (this message will appear only once)")
e.hasPrinted = true
return
}
e.logger.Warnf("telemetry error: %+v", err)
}