forked from wichert/k8s-sentry
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhandler_default.go
66 lines (56 loc) · 1.84 KB
/
handler_default.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
/*
Copyright 2019 Wichert Akkerman
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package main
import (
v1 "k8s.io/api/core/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
)
// DefaultEventHandler is the default handler for events.
type DefaultEventHandler struct {
Event *v1.Event
}
// Fingerprint returns the fingerprint entries that are specific for an event typeX
func (h DefaultEventHandler) Fingerprint() []string {
return []string{
h.Event.InvolvedObject.APIVersion,
h.Event.InvolvedObject.Kind,
h.Event.InvolvedObject.Namespace,
h.Event.InvolvedObject.Name,
h.Event.InvolvedObject.FieldPath,
}
}
// Tags returns a set of tags that should be added to the event
func (h DefaultEventHandler) Tags() map[string]string {
return h.Event.GetLabels()
}
// NewDefaultEventHandler creates a new DefaultEventHandler instance
func NewDefaultEventHandler(app *application, evt *v1.Event) EventHandler {
return &DefaultEventHandler{Event: evt}
}
func fingerprintFromMeta(resource *metav1.ObjectMeta) []string {
// If the object has a controller owner, use that for grouping purposes.
for _, owner := range resource.OwnerReferences {
if owner.Controller != nil && *owner.Controller {
return []string{
owner.APIVersion,
owner.Kind,
owner.Name,
}
}
}
// Otherwise we group based onthe object itself
return []string{
resource.Namespace,
string(resource.UID),
}
}