Skip to content

Commit

Permalink
controller: add feature gate detection
Browse files Browse the repository at this point in the history
  • Loading branch information
djoshy committed Dec 19, 2023
1 parent fe3294a commit e6696b6
Show file tree
Hide file tree
Showing 2 changed files with 44 additions and 0 deletions.
1 change: 1 addition & 0 deletions cmd/machine-config-controller/start.go
Original file line number Diff line number Diff line change
Expand Up @@ -209,6 +209,7 @@ func createControllers(ctx *ctrlcommon.ControllerContext) []ctrlcommon.Controlle
ctx.KubeMAOSharedInformer.Core().V1().Secrets(),
ctx.ConfigInformerFactory.Config().V1().Infrastructures(),
ctx.KubeInformerFactory.Core().V1().Nodes(),
ctx.FeatureGateAccess,
),
)

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import (

configinformersv1 "github.com/openshift/client-go/config/informers/externalversions/config/v1"
configlistersv1 "github.com/openshift/client-go/config/listers/config/v1"
"github.com/openshift/library-go/pkg/operator/configobserver/featuregates"
corev1 "k8s.io/api/core/v1"
apierrors "k8s.io/apimachinery/pkg/api/errors"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
Expand Down Expand Up @@ -66,6 +67,9 @@ type Controller struct {
enqueueMachineSet func(*machinev1beta1.MachineSet)

queue workqueue.RateLimitingInterface

featureGateAccess featuregates.FeatureGateAccess
featureEnabled bool
}

const (
Expand All @@ -92,6 +96,7 @@ func New(
maoSecretInformer coreinformersv1.SecretInformer,
infraInformer configinformersv1.InfrastructureInformer,
nodeInformer coreinformersv1.NodeInformer,
featureGateAccess featuregates.FeatureGateAccess,
) *Controller {
eventBroadcaster := record.NewBroadcaster()
eventBroadcaster.StartLogging(klog.Infof)
Expand Down Expand Up @@ -131,6 +136,28 @@ func New(
ctrl.infraListerSynced = infraInformer.Informer().HasSynced
ctrl.nodeListerSynced = nodeInformer.Informer().HasSynced

ctrl.featureGateAccess = featureGateAccess

ctrl.featureEnabled = false
ctrl.featureGateAccess.SetChangeHandler(func(featureChange featuregates.FeatureChange) {
klog.InfoS("FeatureGates changed", "enabled", featureChange.New.Enabled, "disabled", featureChange.New.Disabled)

var prevfeatureEnabled bool
if featureChange.Previous == nil {
// When the initial featuregate is set, the previous version is nil. Default to the feature being disabled.
prevfeatureEnabled = false
} else {
prevfeatureEnabled = featuregates.NewFeatureGate(featureChange.Previous.Enabled, featureChange.Previous.Disabled).
Enabled(osconfigv1.FeatureGateManagedBootImages)
}
ctrl.featureEnabled = featuregates.NewFeatureGate(featureChange.New.Enabled, featureChange.New.Disabled).
Enabled(osconfigv1.FeatureGateManagedBootImages)
if !prevfeatureEnabled && ctrl.featureEnabled {
klog.Info("Trigger a sync as this feature was turned on")
ctrl.enqueueAllMachineSets()
}
})

return ctrl
}

Expand Down Expand Up @@ -193,6 +220,10 @@ func (ctrl *Controller) handleErr(err error, key interface{}) {
}

func (ctrl *Controller) addMachineSet(obj interface{}) {
// No-op if feature is disabled
if !ctrl.featureEnabled {
return
}
machineSet := obj.(*machinev1beta1.MachineSet)
klog.Infof("MachineSet %s added", machineSet.Name)

Expand All @@ -209,6 +240,10 @@ func (ctrl *Controller) addMachineSet(obj interface{}) {
// Perhaps worth implementing a diff check before starting the sync?

func (ctrl *Controller) updateMachineSet(old, cur interface{}) {
// No-op if feature is disabled
if !ctrl.featureEnabled {
return
}
oldMachineSet := old.(*machinev1beta1.MachineSet)
klog.Infof("MachineSet %s updated, reconciling all machinesets", oldMachineSet.Name)

Expand All @@ -222,6 +257,10 @@ func (ctrl *Controller) updateMachineSet(old, cur interface{}) {
}

func (ctrl *Controller) addConfigMap(obj interface{}) {
// No-op if feature is disabled
if !ctrl.featureEnabled {
return
}
configMap := obj.(*corev1.ConfigMap)

// Take no action if this isn't the "golden" config map
Expand All @@ -242,6 +281,10 @@ func (ctrl *Controller) addConfigMap(obj interface{}) {
// TODO: This callback happens every ~15 minutes or so even if the configmap contents is not updated
// Perhaps worth implementing a diff check before starting the sync?
func (ctrl *Controller) updateConfigMap(old, cur interface{}) {
// No-op if feature is disabled
if !ctrl.featureEnabled {
return
}
oldConfigMap := old.(*corev1.ConfigMap)

// Take no action if this isn't the "golden" config map
Expand Down

0 comments on commit e6696b6

Please sign in to comment.