From 18399ab37ad0ca1566a30e6edb624bc422c96b08 Mon Sep 17 00:00:00 2001 From: chlins Date: Mon, 3 Apr 2023 10:20:34 +0800 Subject: [PATCH] fix: correct the retention webhook payload Fix the incorrect number of total and retained in the retention webhook payload, and completes the deleted_artifacts field. Fixes: #18428 Signed-off-by: chlins --- .../event/handler/webhook/artifact/retention.go | 9 ++++++--- src/controller/event/metadata/retention.go | 2 ++ src/controller/event/topic.go | 2 ++ 3 files changed, 10 insertions(+), 3 deletions(-) diff --git a/src/controller/event/handler/webhook/artifact/retention.go b/src/controller/event/handler/webhook/artifact/retention.go index 551cc8c8f5c..7f145943d9f 100644 --- a/src/controller/event/handler/webhook/artifact/retention.go +++ b/src/controller/event/handler/webhook/artifact/retention.go @@ -119,8 +119,8 @@ func (r *RetentionHandler) constructRetentionPayload(ctx context.Context, event Operator: execution.Trigger, EventData: &model.EventData{ Retention: &evtModel.Retention{ - Total: task.Total, - Retained: task.Retained, + Total: event.Total, + Retained: event.Retained, HarborHostname: hostname, ProjectName: event.Deleted[0].Target.Namespace, RetentionPolicyID: execution.PolicyID, @@ -138,8 +138,11 @@ func (r *RetentionHandler) constructRetentionPayload(ctx context.Context, event } if len(target.Tags) != 0 { deletedArtifact.NameAndTag = target.Repository + ":" + target.Tags[0] + } else { + // use digest if no tag + deletedArtifact.NameAndTag = target.Repository + "@" + target.Digest } - payload.EventData.Retention.DeletedArtifact = []*evtModel.ArtifactInfo{deletedArtifact} + payload.EventData.Retention.DeletedArtifact = append(payload.EventData.Retention.DeletedArtifact, deletedArtifact) } for _, v := range md.Rules { diff --git a/src/controller/event/metadata/retention.go b/src/controller/event/metadata/retention.go index 49298514696..4343528e4b4 100644 --- a/src/controller/event/metadata/retention.go +++ b/src/controller/event/metadata/retention.go @@ -25,6 +25,8 @@ func (r *RetentionMetaData) Resolve(evt *event.Event) error { Status: r.Status, Deleted: r.Deleted, TaskID: r.TaskID, + Total: r.Total, + Retained: r.Retained, } evt.Topic = event2.TopicTagRetention diff --git a/src/controller/event/topic.go b/src/controller/event/topic.go index de318b2113c..b0d2dca6b56 100644 --- a/src/controller/event/topic.go +++ b/src/controller/event/topic.go @@ -353,6 +353,8 @@ type RetentionEvent struct { OccurAt time.Time Status string Deleted []*selector.Result + Total int + Retained int } func (r *RetentionEvent) String() string {