From efab19faa02b047724b79a3d4b95068d313b078e Mon Sep 17 00:00:00 2001 From: Tamal Saha Date: Thu, 21 Dec 2023 03:45:30 -0800 Subject: [PATCH] Publish resync audit events every hour Signed-off-by: Tamal Saha --- lib/publisher.go | 32 +++++++++++++------------------- 1 file changed, 13 insertions(+), 19 deletions(-) diff --git a/lib/publisher.go b/lib/publisher.go index 5cdd6b09..6df514d0 100644 --- a/lib/publisher.go +++ b/lib/publisher.go @@ -51,6 +51,14 @@ import ( "sigs.k8s.io/controller-runtime/pkg/manager" ) +// Informer - informer allows you interact with the underlying informer. +type Informer interface { + // AddEventHandlerWithResyncPeriod adds an event handler to the shared informer using the + // specified resync period. Events to a single handler are delivered sequentially, but there is + // no coordination between different handlers. + AddEventHandlerWithResyncPeriod(handler cache.ResourceEventHandler, resyncPeriod time.Duration) +} + type EventCreator func(obj client.Object) (*api.Event, error) type EventPublisher struct { @@ -157,12 +165,12 @@ func (p *EventPublisher) Publish(ev *api.Event, et api.EventType) error { } } -func (p *EventPublisher) ForGVK(gvk schema.GroupVersionKind) cache.ResourceEventHandler { +func (p *EventPublisher) ForGVK(informer Informer, gvk schema.GroupVersionKind) { if gvk.Version == "" || gvk.Kind == "" { panic(fmt.Sprintf("incomplete GVK; %+v", gvk)) } - return &ResourceEventPublisher{ + h := &ResourceEventPublisher{ p: p, createEvent: func(obj client.Object) (*api.Event, error) { r := obj.DeepCopyObject().(client.Object) @@ -183,6 +191,7 @@ func (p *EventPublisher) ForGVK(gvk schema.GroupVersionKind) cache.ResourceEvent return ev, nil }, } + informer.AddEventHandlerWithResyncPeriod(h, 1*time.Hour) } type funcNodeLister func() ([]*core.Node, error) @@ -278,7 +287,7 @@ func (p *EventPublisher) SetupWithManagerForKind(ctx context.Context, mgr manage if err != nil { return err } - i.AddEventHandler(p.ForGVK(gvk)) + p.ForGVK(i, gvk) return nil } @@ -314,27 +323,12 @@ func (p *ResourceEventPublisher) OnAdd(o interface{}) { } } -func (p *ResourceEventPublisher) OnUpdate(oldObj, newObj interface{}) { - uOld, ok := oldObj.(client.Object) - if !ok { - return - } +func (p *ResourceEventPublisher) OnUpdate(_, newObj interface{}) { uNew, ok := newObj.(client.Object) if !ok { return } - if uOld.GetUID() == uNew.GetUID() && uOld.GetGeneration() == uNew.GetGeneration() { - if klog.V(8).Enabled() { - klog.V(8).InfoS("skipping update event", - "gvk", uNew.GetObjectKind().GroupVersionKind(), - "namespace", uNew.GetNamespace(), - "name", uNew.GetName(), - ) - } - return - } - ev, err := p.createEvent(uNew) if err != nil { klog.V(5).InfoS("failed to create event data", "error", err)