Files
open-cluster-management/pkg/operators/manager.go
2020-04-29 15:29:31 +08:00

40 lines
1.3 KiB
Go

package operators
import (
"context"
"time"
apiextensionsclient "k8s.io/apiextensions-apiserver/pkg/client/clientset/clientset"
"k8s.io/client-go/informers"
"k8s.io/client-go/kubernetes"
"github.com/openshift/library-go/pkg/controller/controllercmd"
"github.com/open-cluster-management/nucleus/pkg/operators/hub"
"github.com/open-cluster-management/nucleus/pkg/operators/spoke"
)
// RunNucleusOperator starts a new nucleus operator
func RunNucleusOperator(ctx context.Context, controllerContext *controllercmd.ControllerContext) error {
// Build kubclient client and informer for spoke cluster
kubeClient, err := kubernetes.NewForConfig(controllerContext.KubeConfig)
if err != nil {
return err
}
apiExtensionClient, err := apiextensionsclient.NewForConfig(controllerContext.KubeConfig)
if err != nil {
return err
}
kubeInformerFactory := informers.NewSharedInformerFactory(kubeClient, 5*time.Minute)
hubcontroller := hub.NewNucleusHubController(
kubeClient, apiExtensionClient, kubeInformerFactory, controllerContext.EventRecorder)
agentController := spoke.NewNucleusAgentController(kubeClient, kubeInformerFactory, controllerContext.EventRecorder)
go kubeInformerFactory.Start(ctx.Done())
go hubcontroller.Run(ctx, 1)
go agentController.Run(ctx, 1)
<-ctx.Done()
return nil
}