in operator/controllers/operator/fetcher_controller.go [51:79]
func (r *FetcherReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctrl.Result, error) {
log := runtimelog.FromContext(ctx)
log.Info("=====================fetcher reconcile started================================")
fetcher := &operatorv1alpha1.Fetcher{}
if err := r.Client.Get(ctx, req.NamespacedName, fetcher); err != nil {
return ctrl.Result{}, client.IgnoreNotFound(err)
}
ff, err := r.FileRepo.GetFilesRecursive("templates")
if err != nil {
log.Error(err, "failed to load resource templates")
return ctrl.Result{}, err
}
app := kubernetes.Application{
Client: r.Client,
FileRepo: r.FileRepo,
CR: fetcher,
GVK: operatorv1alpha1.GroupVersion.WithKind("Fetcher"),
Recorder: r.Recorder,
}
if err := app.ApplyAll(ctx, ff, log); err != nil {
_ = r.UpdateStatus(ctx, fetcher, core.ConditionFalse, "Failed to apply resources")
return ctrl.Result{}, err
}
if err := r.UpdateStatus(ctx, fetcher, core.ConditionTrue, "Reconciled all of resources"); err != nil {
return ctrl.Result{}, err
}
return ctrl.Result{RequeueAfter: schedDuration}, nil
}