Documentation ¶
Overview ¶
Package featureflag implements simple feature-flagging. Feature flags can become an anti-pattern if abused. We should try to use them for two use-cases:
- `Preview` feature flags enable a piece of functionality we haven't yet fully baked. The user needs to 'opt-in'. We expect these flags to be removed at some time. Normally these will default to false.
- Escape-hatch feature flags turn off a default that we consider risky (e.g. pre-creating DNS records). This lets us ship a behaviour, and if we encounter unusual circumstances in the field, we can allow the user to turn the behaviour off. Normally these will default to true.
Index ¶
Constants ¶
View Source
const (
// Name is the name of the environment variable which encapsulates feature flags
Name = "KOPS_FEATURE_FLAGS"
)
Variables ¶
View Source
var ( // CacheNodeidentityInfo enables NodeidentityInfo caching // in order to reduce the number of EC2 DescribeInstance calls. CacheNodeidentityInfo = new("CacheNodeidentityInfo", Bool(false)) // EnableSeparateConfigBase allows a config-base that is different from the state store EnableSeparateConfigBase = new("EnableSeparateConfigBase", Bool(false)) // ExperimentalClusterDNS allows for setting the kubelet dns flag to experimental values. ExperimentalClusterDNS = new("ExperimentalClusterDNS", Bool(false)) // GoogleCloudBucketACL means the ACL will be set on a bucket when using GCS GoogleCloudBucketACL = new("GoogleCloudBucketAcl", Bool(false)) // SpecOverrideFlag allows setting spec values on create SpecOverrideFlag = new("SpecOverrideFlag", Bool(false)) // Spotinst toggles the use of Spotinst integration. Spotinst = new("Spotinst", Bool(false)) // SpotinstOcean toggles the use of Spotinst Ocean instance group implementation. SpotinstOcean = new("SpotinstOcean", Bool(false)) // SpotinstOceanTemplate toggles the use of Spotinst Ocean object as a template for Virtual Node Groups. SpotinstOceanTemplate = new("SpotinstOceanTemplate", Bool(false)) // SpotinstHybrid toggles between hybrid and full instance group implementations. SpotinstHybrid = new("SpotinstHybrid", Bool(false)) // SpotinstController toggles the installation of the Spotinst controller addon. SpotinstController = new("SpotinstController", Bool(true)) // VFSVaultSupport enables setting Vault as secret/keystore VFSVaultSupport = new("VFSVaultSupport", Bool(false)) // VPCSkipEnableDNSSupport if set will make that a VPC does not need DNSSupport enabled. VPCSkipEnableDNSSupport = new("VPCSkipEnableDNSSupport", Bool(false)) // SkipEtcdVersionCheck will bypass the check that etcd-manager is using a supported etcd version SkipEtcdVersionCheck = new("SkipEtcdVersionCheck", Bool(false)) // ClusterAddons activates experimental cluster-addons support ClusterAddons = new("ClusterAddons", Bool(false)) // Azure toggles the Azure support. Azure = new("Azure", Bool(false)) // KopsControllerStateStore enables fetching the kops state from kops-controller, instead of requiring access to S3/GCS/etc. KopsControllerStateStore = new("KopsControllerStateStore", Bool(false)) // APIServerNodes enables ability to provision nodes that only run the kube-apiserver. APIServerNodes = new("APIServerNodes", Bool(false)) // UseAddonOperators activates experimental addon operator support UseAddonOperators = new("UseAddonOperators", Bool(false)) // TerraformManagedFiles enables rendering managed files into the Terraform configuration. TerraformManagedFiles = new("TerraformManagedFiles", Bool(true)) // AlphaAllowGCE is a feature flag that gates GCE support while it is alpha. AlphaAllowGCE = new("AlphaAllowGCE", Bool(false)) // Karpenter enables karpenter-managed Instance Groups Karpenter = new("Karpenter", Bool(false)) // ImageDigest remaps all manifests with image digests ImageDigest = new("ImageDigest", Bool(true)) // Hetzner toggles the Hetzner Cloud support. Hetzner = new("Hetzner", Bool(false)) )
Functions ¶
func ParseFlags ¶
func ParseFlags(f string)
ParseFlags responsible for parse out the feature flag usage
Types ¶
type FeatureFlag ¶
type FeatureFlag struct { Key string // contains filtered or unexported fields }
FeatureFlag defines a feature flag
func (*FeatureFlag) Enabled ¶
func (f *FeatureFlag) Enabled() bool
Enabled checks if the flag is enabled
Click to show internal directories.
Click to hide internal directories.