Files
open-cluster-management/pkg/features/feature.go
liuwei 2b4c9f1abd addon manager lease
Signed-off-by: liuwei <liuweixa@redhat.com>
2021-04-06 05:40:58 +00:00

50 lines
1.8 KiB
Go

package features
import (
"k8s.io/component-base/featuregate"
"k8s.io/klog/v2"
)
const (
// Every feature gate should add method here following this template:
//
// // owner: @username
// // alpha: v1.X
// MyFeature featuregate.Feature = "MyFeature"
// ClusterClaim will start a new controller in the spoke-agent to manage the cluster-claim
// resources in the managed cluster.
//
// The cluster-claim controller is majorly for collecting claims and updating claims field
// in managedcluster status. When it exceeds the limit specified by "--max-custom-cluster-claims",
// the extra claims will be truncated.
//
// If it is disabled, the user will see empty claims field in managedcluster status. The
// deployer who disable the feature may need to update claim field in managed cluster status
// itself to avoid impact to users.
ClusterClaim featuregate.Feature = "ClusterClaim"
// AddonManagement will start new controllers in the spoke-agent to manage the managed cluster addons
// registration and maintains the status of managed cluster addons through watching their leases.
AddonManagement featuregate.Feature = "AddonManagement"
)
var (
// DefaultMutableFeatureGate is made up of multiple mutable feature-gates.
DefaultMutableFeatureGate featuregate.MutableFeatureGate = featuregate.NewFeatureGate()
)
func init() {
if err := DefaultMutableFeatureGate.Add(defaultRegistrationFeatureGates); err != nil {
klog.Fatalf("Unexpected error: %v", err)
}
}
// defaultRegistrationFeatureGates consists of all known ocm-registration
// feature keys. To add a new feature, define a key for it above and
// add it here.
var defaultRegistrationFeatureGates = map[featuregate.Feature]featuregate.FeatureSpec{
ClusterClaim: {Default: true, PreRelease: featuregate.Beta},
AddonManagement: {Default: false, PreRelease: featuregate.Alpha},
}