This repository has been archived by the owner on Nov 23, 2021. It is now read-only.
/
controller.go
78 lines (72 loc) · 3.25 KB
/
controller.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
package openshift_controller_manager
import (
"context"
kubeinformers "k8s.io/client-go/informers"
"k8s.io/client-go/tools/cache"
"sigs.k8s.io/controller-runtime/pkg/manager"
configclient "github.com/openshift/client-go/config/clientset/versioned"
configinformers "github.com/openshift/client-go/config/informers/externalversions"
"github.com/openshift/cluster-openshift-controller-manager-operator/pkg/operator/configobservation"
"github.com/openshift/cluster-openshift-controller-manager-operator/pkg/operator/configobservation/builds"
"github.com/openshift/cluster-openshift-controller-manager-operator/pkg/operator/configobservation/deployimages"
"github.com/openshift/cluster-openshift-controller-manager-operator/pkg/operator/configobservation/images"
"github.com/openshift/library-go/pkg/operator/configobserver"
"github.com/openshift/library-go/pkg/operator/events"
"github.com/openshift/hypershift-toolkit/pkg/cmd/cpoperator"
"github.com/openshift/hypershift-toolkit/pkg/controllers"
)
func Setup(cfg *cpoperator.ControlPlaneOperatorConfig) error {
targetCfg := cfg.TargetConfig()
kubeInformers := kubeinformers.NewSharedInformerFactoryWithOptions(cfg.TargetKubeClient(), controllers.DefaultResync, kubeinformers.WithNamespace("openshift-controller-manager-operator"))
configClient, err := configclient.NewForConfig(targetCfg)
if err != nil {
return err
}
configInformers := configinformers.NewSharedInformerFactory(configClient, controllers.DefaultResync)
operatorClient := &cmOperatorClient{
Client: cfg.KubeClient(),
Namespace: cfg.Namespace(),
Logger: cfg.Logger().WithName("OpenShiftControllerManagerClient"),
}
recorder := events.NewLoggingEventRecorder("openshift-controller-manager-observers")
c := configobserver.NewConfigObserver(
operatorClient,
recorder,
configobservation.Listers{
ImageConfigLister: configInformers.Config().V1().Images().Lister(),
BuildConfigLister: configInformers.Config().V1().Builds().Lister(),
NetworkLister: configInformers.Config().V1().Networks().Lister(),
ConfigMapLister: kubeInformers.Core().V1().ConfigMaps().Lister(),
PreRunCachesSynced: []cache.InformerSynced{
configInformers.Config().V1().Images().Informer().HasSynced,
configInformers.Config().V1().Builds().Informer().HasSynced,
configInformers.Config().V1().Networks().Informer().HasSynced,
kubeInformers.Core().V1().ConfigMaps().Informer().HasSynced,
},
},
images.ObserveInternalRegistryHostname,
builds.ObserveBuildControllerConfig,
deployimages.ObserveControllerManagerImagesConfig,
)
cfg.Manager().Add(manager.RunnableFunc(func(stopCh <-chan struct{}) error {
configInformers.Start(stopCh)
return nil
}))
cfg.Manager().Add(manager.RunnableFunc(func(stopCh <-chan struct{}) error {
kubeInformers.Start(stopCh)
return nil
}))
cfg.Manager().Add(manager.RunnableFunc(func(stopCh <-chan struct{}) error {
ctx, cancel := context.WithCancel(context.Background())
go func() {
<-stopCh
cancel()
}()
c.Run(ctx, 1)
return nil
}))
configInformers.Config().V1().Images().Informer().AddEventHandler(c.EventHandler())
configInformers.Config().V1().Builds().Informer().AddEventHandler(c.EventHandler())
kubeInformers.Core().V1().ConfigMaps().Informer().AddEventHandler(c.EventHandler())
return nil
}