in operator/controllers/operator/oapserver_controller.go [98:126]
func (r *OAPServerReconciler) checkState(ctx context.Context, log logr.Logger, oapServer *operatorv1alpha1.OAPServer) error {
overlay := operatorv1alpha1.OAPServerStatus{}
deployment := apps.Deployment{}
errCol := new(kubernetes.ErrorCollector)
if err := r.Client.Get(ctx, client.ObjectKey{Namespace: oapServer.Namespace, Name: oapServer.Name + "-oap"}, &deployment); err != nil && !apierrors.IsNotFound(err) {
errCol.Collect(fmt.Errorf("failed to get deployment: %w", err))
} else {
overlay.Conditions = deployment.Status.Conditions
overlay.AvailableReplicas = deployment.Status.AvailableReplicas
}
service := core.Service{}
if err := r.Client.Get(ctx, client.ObjectKey{Namespace: oapServer.Namespace, Name: oapServer.Name + "-oap"}, &service); err != nil && !apierrors.IsNotFound(err) {
errCol.Collect(fmt.Errorf("failed to get service: %w", err))
} else {
overlay.Address = fmt.Sprintf("%s.%s", service.Name, service.Namespace)
}
if apiequal.Semantic.DeepDerivative(overlay, oapServer.Status) {
log.Info("Status keeps the same as before")
return errCol.Error()
}
if err := r.updateStatus(ctx, oapServer, overlay, errCol); err != nil {
errCol.Collect(fmt.Errorf("failed to update status of oapServer: %w", err))
}
log.Info("updated Status sub resource")
return errCol.Error()
}