-
Notifications
You must be signed in to change notification settings - Fork 64
/
sentry.go
97 lines (80 loc) · 2.36 KB
/
sentry.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
package main
import (
"os"
"strings"
"github.com/getsentry/sentry-go"
globalLogger "github.com/rs/zerolog/log"
"k8s.io/client-go/rest"
)
func beforeSend(event *sentry.Event, hint *sentry.EventHint) *sentry.Event {
// Update SDK info
event.Sdk.Name = "getsentry.sentry-kubernetes"
event.Sdk.Version = version
// Clear modules/packages
event.Modules = map[string]string{}
// We don't need these for now
event.Release = ""
event.ServerName = ""
return event
}
func initSentrySDK() {
globalLogger.Debug().Msg("Initializing Sentry SDK...")
err := sentry.Init(sentry.ClientOptions{
Debug: true,
EnableTracing: false,
BeforeSend: beforeSend,
// Clear integration list
Integrations: func([]sentry.Integration) []sentry.Integration { return []sentry.Integration{} },
})
if err != nil {
globalLogger.Fatal().Msgf("sentry.Init: %s", err)
}
if sentry.CurrentHub().Client().Options().Dsn == "" {
globalLogger.Warn().Msg("No Sentry DSN specified, events will not be sent.")
}
globalLogger.Debug().Msg("Sentry SDK initialized")
}
func setKubernetesSentryContext(config *rest.Config) {
kubernetesContext := map[string]interface{}{
"API endpoint": config.Host,
}
// Get cluster version via API
clusterVersion, err := getClusterVersion(config)
if err == nil {
kubernetesContext["Server version"] = clusterVersion.String()
} else {
globalLogger.Error().Msgf("Error while getting cluster version: %s", err)
}
sentry.CurrentHub().Scope().SetContext(
"Kubernetes",
kubernetesContext,
)
}
func setGlobalSentryTags() {
scope := sentry.CurrentHub().Scope()
if hostname, err := os.Hostname(); err == nil {
setTagIfNotEmpty(scope, "agent_hostname", hostname)
}
// Read from environment
for _, e := range os.Environ() {
pair := strings.SplitN(e, "=", 2)
if len(pair) != 2 {
continue
}
key, value := strings.TrimSpace(pair[0]), strings.TrimSpace(pair[1])
tagPrefix := "SENTRY_K8S_GLOBAL_TAG_"
if strings.HasPrefix(key, tagPrefix) {
tagKey := strings.TrimPrefix(key, tagPrefix)
globalLogger.Info().Msgf("Global tag detected: %s=%s", tagKey, value)
setTagIfNotEmpty(scope, tagKey, value)
}
}
}
func setTagIfNotEmpty(scope *sentry.Scope, key string, value string) {
if key != "" && value != "" {
scope.SetTag(key, value)
}
}
func setWatcherTag(scope *sentry.Scope, watcherName string) {
scope.SetTag("watcher_name", watcherName)
}