Skip to content

Commit 3a30256

Browse files
authored
feat: Emit events when finalizers complete (#103)
1 parent a0fd766 commit 3a30256

File tree

1 file changed

+24
-8
lines changed

1 file changed

+24
-8
lines changed

status/controller.go

Lines changed: 24 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -31,6 +31,7 @@ type Controller[T Object] struct {
3131
kubeClient client.Client
3232
eventRecorder record.EventRecorder
3333
observedConditions sync.Map // map[reconcile.Request]ConditionSet
34+
observedFinalizers sync.Map // map[reconcile.Request]Finalizer
3435
terminatingObjects sync.Map // map[reconcile.Request]DeletionTimestamp
3536
emitDeprecatedMetrics bool
3637
ConditionDuration pmetrics.ObservationMetric
@@ -128,19 +129,40 @@ func (c *Controller[T]) reconcile(ctx context.Context, req reconcile.Request, o
128129
if deletionTS, ok := c.terminatingObjects.Load(req); ok {
129130
c.observeHistogram(c.TerminationDuration, TerminationDuration, time.Since(deletionTS.(*metav1.Time).Time).Seconds(), map[string]string{})
130131
}
132+
if finalizers, ok := c.observedFinalizers.LoadAndDelete(req); ok {
133+
for _, finalizer := range finalizers.([]string) {
134+
c.eventRecorder.Event(o, v1.EventTypeNormal, "Finalized", fmt.Sprintf("Finalized %s", finalizer))
135+
}
136+
}
131137
return reconcile.Result{}, nil
132138
}
133139
return reconcile.Result{}, fmt.Errorf("getting object, %w", err)
134140
}
135141

142+
// Detect and record terminations
143+
observedFinalizers, _ := c.observedFinalizers.Swap(req, o.GetFinalizers())
144+
if observedFinalizers != nil {
145+
for _, finalizer := range lo.Without(observedFinalizers.([]string), o.GetFinalizers()...) {
146+
c.eventRecorder.Event(o, v1.EventTypeNormal, "Finalized", fmt.Sprintf("Finalized %s", finalizer))
147+
}
148+
}
149+
150+
if o.GetDeletionTimestamp() != nil {
151+
c.setGaugeMetric(c.TerminationCurrentTimeSeconds, TerminationCurrentTimeSeconds, time.Since(o.GetDeletionTimestamp().Time).Seconds(), map[string]string{
152+
MetricLabelNamespace: req.Namespace,
153+
MetricLabelName: req.Name,
154+
})
155+
c.terminatingObjects.Store(req, o.GetDeletionTimestamp())
156+
}
157+
158+
// Detect and record condition counts
136159
currentConditions := o.StatusConditions()
137160
observedConditions := ConditionSet{}
138161
if v, ok := c.observedConditions.Load(req); ok {
139162
observedConditions = v.(ConditionSet)
140163
}
141164
c.observedConditions.Store(req, currentConditions)
142165

143-
// Detect and record condition counts
144166
for _, condition := range o.GetConditions() {
145167
c.setGaugeMetric(c.ConditionCount, ConditionCount, 1, map[string]string{
146168
MetricLabelNamespace: req.Namespace,
@@ -157,13 +179,7 @@ func (c *Controller[T]) reconcile(ctx context.Context, req reconcile.Request, o
157179
pmetrics.LabelReason: condition.Reason,
158180
})
159181
}
160-
if o.GetDeletionTimestamp() != nil {
161-
c.setGaugeMetric(c.TerminationCurrentTimeSeconds, TerminationCurrentTimeSeconds, time.Since(o.GetDeletionTimestamp().Time).Seconds(), map[string]string{
162-
MetricLabelNamespace: req.Namespace,
163-
MetricLabelName: req.Name,
164-
})
165-
c.terminatingObjects.Store(req, o.GetDeletionTimestamp())
166-
}
182+
167183
for _, observedCondition := range observedConditions.List() {
168184
if currentCondition := currentConditions.Get(observedCondition.Type); currentCondition == nil || currentCondition.Status != observedCondition.Status {
169185
c.deleteGaugeMetric(c.ConditionCount, ConditionCount, map[string]string{

0 commit comments

Comments
 (0)