mirror of
https://github.com/ceph/ceph-csi.git
synced 2025-01-11 22:39:31 +00:00
70 lines
3.6 KiB
Go
70 lines
3.6 KiB
Go
|
/*
|
||
|
Copyright 2023 The Kubernetes Authors.
|
||
|
|
||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||
|
you may not use this file except in compliance with the License.
|
||
|
You may obtain a copy of the License at
|
||
|
|
||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||
|
|
||
|
Unless required by applicable law or agreed to in writing, software
|
||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||
|
See the License for the specific language governing permissions and
|
||
|
limitations under the License.
|
||
|
*/
|
||
|
|
||
|
package names
|
||
|
|
||
|
// Canonical controller names
|
||
|
//
|
||
|
// NAMING CONVENTIONS
|
||
|
// 1. naming should be consistent across the controllers
|
||
|
// 2. use of shortcuts should be avoided, unless they are well-known non-Kubernetes shortcuts
|
||
|
// 3. Kubernetes' resources should be written together without a hyphen ("-")
|
||
|
//
|
||
|
// CHANGE POLICY
|
||
|
// The controller names should be treated as IDs.
|
||
|
// They can only be changed if absolutely necessary. For example if an inappropriate name was chosen in the past, or if the scope of the controller changes.
|
||
|
// When a name is changed, the old name should be aliased in CCMControllerAliases, while preserving all old aliases.
|
||
|
// This is done to achieve backwards compatibility
|
||
|
//
|
||
|
// USE CASES
|
||
|
// The following places should use the controller name constants, when:
|
||
|
// 1. registering a controller in app.DefaultInitFuncConstructors or sample main.controllerInitializers:
|
||
|
// 1.1. disabling a controller by default in app.ControllersDisabledByDefault
|
||
|
// 1.2. checking if IsControllerEnabled
|
||
|
// 1.3. defining an alias in CCMControllerAliases (for backwards compatibility only)
|
||
|
// 2. used anywhere inside the controller itself:
|
||
|
// 2.1. [TODO] logger component should be configured with the controller name by calling LoggerWithName
|
||
|
// 2.2. [TODO] logging should use a canonical controller name when referencing a controller (Eg. Starting X, Shutting down X)
|
||
|
// 2.3. [TODO] emitted events should have an EventSource.Component set to the controller name (usually when initializing an EventRecorder)
|
||
|
// 2.4. [TODO] registering ControllerManagerMetrics with ControllerStarted and ControllerStopped
|
||
|
// 2.5. [TODO] calling WaitForNamedCacheSync
|
||
|
// 3. defining controller options for "--help" command or generated documentation
|
||
|
// 3.1. controller name should be used to create a pflag.FlagSet when registering controller options (the name is rendered in a controller flag group header)
|
||
|
// 3.2. when defined flag's help mentions a controller name
|
||
|
// 4. defining a new service account for a new controller (old controllers may have inconsistent service accounts to stay backwards compatible)
|
||
|
// 5. anywhere these controllers are used outside of this module (kube-controller-manager, cloud-provider sample)
|
||
|
const (
|
||
|
CloudNodeController = "cloud-node-controller"
|
||
|
ServiceLBController = "service-lb-controller"
|
||
|
NodeRouteController = "node-route-controller"
|
||
|
CloudNodeLifecycleController = "cloud-node-lifecycle-controller"
|
||
|
)
|
||
|
|
||
|
// CCMControllerAliases returns a mapping of aliases to canonical controller names
|
||
|
//
|
||
|
// These aliases ensure backwards compatibility and should never be removed!
|
||
|
// Only addition of new aliases is allowed, and only when a canonical name is changed (please see CHANGE POLICY of controller names)
|
||
|
func CCMControllerAliases() map[string]string {
|
||
|
// return a new reference to achieve immutability of the mapping
|
||
|
return map[string]string{
|
||
|
"cloud-node": CloudNodeController,
|
||
|
"service": ServiceLBController,
|
||
|
"route": NodeRouteController,
|
||
|
"cloud-node-lifecycle": CloudNodeLifecycleController,
|
||
|
}
|
||
|
|
||
|
}
|