From c34f48ad407691493a4a1cfdfd3b78c155e26cb4 Mon Sep 17 00:00:00 2001 From: Hidde Beydals Date: Wed, 24 May 2023 15:48:38 +0200 Subject: [PATCH] Prefix event key attributes with identifier This to prevent collisions between different event attributes. For example when first an event with revision `foo` is received without a token, after which a token `foo` is received without a `revision`. Signed-off-by: Hidde Beydals --- internal/server/event_server.go | 23 +++++++++++++++-------- 1 file changed, 15 insertions(+), 8 deletions(-) diff --git a/internal/server/event_server.go b/internal/server/event_server.go index e7fb8e06b..8f762732f 100644 --- a/internal/server/event_server.go +++ b/internal/server/event_server.go @@ -190,28 +190,35 @@ func (s *EventServer) logRateLimitMiddleware(h http.Handler) http.Handler { }) } +// eventKeyFunc generates a unique key for an event based on the provided HTTP +// request, which can be used to deduplicate events. The key is calculated by +// concatenating specific event attributes and hashing them using SHA-256. +// The key is then returned as a hex-encoded string. +// +// The event attributes are prefixed with an identifier to avoid collisions +// between different event attributes. func eventKeyFunc(r *http.Request) (string, error) { event := r.Context().Value(eventContextKey{}).(*eventv1.Event) comps := []string{ "event", - event.InvolvedObject.Name, - event.InvolvedObject.Namespace, - event.InvolvedObject.Kind, - event.Message, + "name=" + event.InvolvedObject.Name, + "namespace=" + event.InvolvedObject.Namespace, + "kind=" + event.InvolvedObject.Kind, + "message=" + event.Message, } revision, ok := event.Metadata[eventv1.MetaRevisionKey] if ok { - comps = append(comps, revision) + comps = append(comps, "revision="+revision) } token, ok := event.Metadata[eventv1.MetaTokenKey] if ok { - comps = append(comps, token) + comps = append(comps, "token="+token) } - val := strings.Join(comps, "/") - digest := sha256.Sum256([]byte(val)) + key := strings.Join(comps, "/") + digest := sha256.Sum256([]byte(key)) return fmt.Sprintf("%x", digest), nil }