Skip to content

Commit

Permalink
Refactor requeue logic into controller.callbackFn
Browse files Browse the repository at this point in the history
Signed-off-by: Alper Rifat Ulucinar <ulucinar@users.noreply.github.com>
  • Loading branch information
ulucinar committed Jul 26, 2023
1 parent 1c53001 commit dfe3e46
Showing 1 changed file with 34 additions and 29 deletions.
63 changes: 34 additions & 29 deletions pkg/controller/api.go
Original file line number Diff line number Diff line change
Expand Up @@ -37,8 +37,9 @@ import (
)

const (
errGetFmt = "cannot get resource %s/%s after an async %s"
errUpdateStatusFmt = "cannot update status of resource %s/%s after an async %s"
errGetFmt = "cannot get resource %s/%s after an async %s"
errUpdateStatusFmt = "cannot update status of the resource %s/%s after an async %s"
errReconcileRequestFmt = "cannot request the reconciliation of the resource %s/%s after an async %s"
)

var _ CallbackProvider = &APICallbacks{}
Expand Down Expand Up @@ -89,7 +90,7 @@ type APICallbacks struct {
newTerraformed func() resource.Terraformed
}

func (ac *APICallbacks) callbackFn(name, op string) terraform.CallbackFn {
func (ac *APICallbacks) callbackFn(name, op string, requeue bool) terraform.CallbackFn {
return func(err error, ctx context.Context) error {
nn := types.NamespacedName{Name: name}
tr := ac.newTerraformed()
Expand All @@ -98,49 +99,53 @@ func (ac *APICallbacks) callbackFn(name, op string) terraform.CallbackFn {
}
tr.SetConditions(resource.LastAsyncOperationCondition(err))
tr.SetConditions(resource.AsyncOperationFinishedCondition())
return errors.Wrapf(ac.kube.Status().Update(ctx, tr), errUpdateStatusFmt, tr.GetObjectKind().GroupVersionKind().String(), name, op)
uErr := errors.Wrapf(ac.kube.Status().Update(ctx, tr), errUpdateStatusFmt, tr.GetObjectKind().GroupVersionKind().String(), name, op)
if requeue {
switch {
case err != nil:
// TODO: use the errors.Join from
// github.com/crossplane/crossplane-runtime.
if ok := ac.EventHandler.requestReconcile(name); !ok {
return errors.Errorf(errReconcileRequestFmt, tr.GetObjectKind().GroupVersionKind().String(), name, op)
}
default:
ac.EventHandler.rateLimiter.Forget(reconcile.Request{
NamespacedName: types.NamespacedName{
Name: name,
},
})
}
}
return uErr
}
}

// Create makes sure the error is saved in async operation condition.
func (ac *APICallbacks) Create(name string) terraform.CallbackFn {
return func(err error, ctx context.Context) error {
cErr := ac.callbackFn(name, "create")(err, ctx)
switch {
case err != nil:
ac.EventHandler.requestReconcile(name)
default:
ac.EventHandler.rateLimiter.Forget(reconcile.Request{
NamespacedName: types.NamespacedName{
Name: name,
},
})
}
return cErr
// requeue is set to true although the managed reconciler already
// requeues with exponential back-off during the creation phase
// because the upjet external client returns ResourceExists &
// ResourceUpToDate both set to true, if an async operation is
// in-progress immediately following a Create call. This will
// delay a reobservation of the resource (while being created)
// for the poll period.
return ac.callbackFn(name, "create", true)(err, ctx)
}
}

// Update makes sure the error is saved in async operation condition.
func (ac *APICallbacks) Update(name string) terraform.CallbackFn {
return func(err error, ctx context.Context) error {
cErr := ac.callbackFn(name, "update")(err, ctx)
switch {
case err != nil:
ac.EventHandler.requestReconcile(name)
default:
ac.EventHandler.rateLimiter.Forget(reconcile.Request{
NamespacedName: types.NamespacedName{
Name: name,
},
})
}
return cErr
return ac.callbackFn(name, "update", true)(err, ctx)
}
}

// Destroy makes sure the error is saved in async operation condition.
func (ac *APICallbacks) Destroy(name string) terraform.CallbackFn {
return ac.callbackFn(name, "destroy")
// requeue is set to false because the managed reconciler already requeues
// with exponential back-off during the deletion phase.
return ac.callbackFn(name, "destroy", false)
}

type eventHandler struct {
Expand Down

0 comments on commit dfe3e46

Please sign in to comment.