shardingsphere-operator/pkg/controllers/proxyconfig_controller.go (78 lines of code) (raw):

/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package controllers import ( "context" shardingspherev1alpha1 "github.com/apache/shardingsphere-on-cloud/shardingsphere-operator/api/v1alpha1" "github.com/go-logr/logr" reconcile "github.com/apache/shardingsphere-on-cloud/shardingsphere-operator/pkg/reconcile/proxyconfig" v1 "k8s.io/api/core/v1" "k8s.io/apimachinery/pkg/api/equality" apierrors "k8s.io/apimachinery/pkg/api/errors" "k8s.io/apimachinery/pkg/runtime" ctrl "sigs.k8s.io/controller-runtime" "sigs.k8s.io/controller-runtime/pkg/client" ) const ( proxyConfigControllerName = "proxyconfig_controller" ) // ProxyConfigReconciler reconciles a ShardingSphereProxyServerConfig object type ProxyConfigReconciler struct { client.Client Scheme *runtime.Scheme Log logr.Logger } // +kubebuilder:rbac:groups=shardingsphere.apache.org,resources=shardingsphereproxyserverconfigs,verbs=get;list;watch;create;update;patch;delete // +kubebuilder:rbac:groups=shardingsphere.apache.org,resources=shardingsphereproxyserverconfigs/status,verbs=get;update;patch // +kubebuilder:rbac:groups=shardingsphere.apache.org,resources=shardingsphereproxyserverconfigs/finalizers,verbs=update // +kubebuilder:rbac:groups="",resources=configmaps,verbs=get;list;watch;create;update;patch;delete // Reconcile the ProxyConfig func (r *ProxyConfigReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctrl.Result, error) { logger := r.Log.WithValues(proxyConfigControllerName, req.NamespacedName) run := &shardingspherev1alpha1.ShardingSphereProxyServerConfig{} err := r.Get(ctx, req.NamespacedName, run) if apierrors.IsNotFound(err) { logger.Info("Resource in work queue no longer exists!") return ctrl.Result{}, nil } else if err != nil { logger.Error(err, "Error getting CRD resource") return ctrl.Result{}, err } cm := &v1.ConfigMap{} configmap := reconcile.ConstructCascadingConfigmap(run) err = r.Get(ctx, req.NamespacedName, cm) if apierrors.IsNotFound(err) { logger.Info("Creating cascaded configmap") err = r.Create(ctx, configmap) if err != nil { logger.Error(err, "Error creating cascaded configmap") return ctrl.Result{}, err } run.SetMetadataRepository(run.Spec.ClusterConfig.Repository.Type) err = r.Status().Update(ctx, run) if err != nil { logger.Error(err, "Error updating CRD resource status") return ctrl.Result{}, err } return ctrl.Result{}, nil } else if err != nil { logger.Error(err, "Error getting cascaded configmap") return ctrl.Result{}, err } if !equality.Semantic.DeepEqual(configmap.Data, cm.Data) { cm = configmap logger.Info("Update or correct the configmap") err = r.Update(ctx, configmap) if err != nil { logger.Error(err, "Error updating cascaded configmap") return ctrl.Result{Requeue: true}, err } } if run.Status.MetadataRepository != run.Spec.ClusterConfig.Repository.Type || run.Status.MetadataRepository == "" { run.SetMetadataRepository(run.Spec.ClusterConfig.Repository.Type) err = r.Status().Update(ctx, run) if err != nil { logger.Error(err, "Error updating CRD resource status") return ctrl.Result{}, err } } return ctrl.Result{}, nil } // SetupWithManager sets up the controller with the Manager. func (r *ProxyConfigReconciler) SetupWithManager(mgr ctrl.Manager) error { return ctrl.NewControllerManagedBy(mgr). For(&shardingspherev1alpha1.ShardingSphereProxyServerConfig{}). Owns(&v1.ConfigMap{}). Complete(r) }