forked from stolostron/multicluster-global-hub
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconstants.go
206 lines (176 loc) · 9.29 KB
/
constants.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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
package constants
// global hub common constants
const (
// GHDefaultNamespace defines default namespace for ACM hub and Global hub operator and manager
GHDefaultNamespace = "multicluster-global-hub"
// GHAgentNamespace defines global hub agent namespace
GHAgentNamespace = "multicluster-global-hub-agent"
// ManagerDeploymentName define the global hub manager deployment name
ManagerDeploymentName = "multicluster-global-hub-manager"
// AgentDeploymentName define the global hub agent deployment name
AgentDeploymentName = "multicluster-global-hub-agent"
// InventoryDeploymentName define the common inventory api deployment name
InventoryDeploymentName = "inventory-api"
InventoryRouteName = "inventory-api"
// GHConfigCMName is the name of configmap that stores important global hub settings
// eg. logLevel for both operator and manager.
GHConfigCMName = "multicluster-global-hub-config"
// GHAgentConfigCMName is the name of configmap that stores important global hub settings
// eg. aggregationLevel and enableLocalPolicy.
GHAgentConfigCMName = "multicluster-global-hub-agent-config"
// GlobalHubSchedulerName - placementrule scheduler name.
GlobalHubSchedulerName = "global-hub"
// OpenShift console namespace
OpenShiftConsoleNamespace = "openshift-console"
// OpenShift console route name
OpenShiftConsoleRouteName = "console"
// Observability grafana namespace
ObservabilityNamespace = "open-cluster-management-observability"
// Observability grafana route name
ObservabilityGrafanaRouteName = "grafana"
DefaultAgentQPS = float32(150)
DefaultAgentBurst = 300
DefaultClusterId = "00000000-0000-0000-0000-000000000000"
BackupKey = "cluster.open-cluster-management.io/backup"
BackupVolumnKey = "cluster.open-cluster-management.io/backup-hub-pvc"
BackupExcludeKey = "velero.io/exclude-from-backup"
BackupActivationValue = "cluster-activation"
BackupGlobalHubValue = "globalhub"
PostgresPvcLabelKey = "component"
PostgresPvcLabelValue = "multicluster-global-hub-operator"
// These annotation used to do prehook when backup pvc, which is provided by volsync
BackupPvcCopyTrigger = "volsync.backube/copy-trigger"
BackupPvcUserCopyTrigger = "volsync.backube/use-copy-trigger"
BackupPvcLatestCopyStatus = "volsync.backube/latest-copy-status"
BackupPvcWaitingForTrigger = "WaitingForTrigger"
BackupPvcCompletedTrigger = "Completed"
BackupPvcLatestCopyTrigger = "volsync.backube/latest-copy-trigger"
// The managedclusteraddon for Global Hub Agent
GHManagedClusterAddonName = "multicluster-global-hub-controller"
)
const (
// AnnotationAddonHostingClusterName is the annotation for indicating the hosting cluster name in the addon
AnnotationAddonHostingClusterName = "addon.open-cluster-management.io/hosting-cluster-name"
// AnnotationClusterHostingClusterName is the annotation for indicating the hosting cluster name in the cluster
AnnotationClusterHostingClusterName = "import.open-cluster-management.io/hosting-cluster-name"
AnnotationClusterDeployMode = "import.open-cluster-management.io/klusterlet-deploy-mode"
AnnotationClusterKlusterletDeployNamespace = "import.open-cluster-management.io/klusterlet-namespace"
ClusterDeployModeHosted = "Hosted"
ClusterDeployModeDefault = "Default"
)
const (
LocalClusterName = "local-cluster"
// lock the database
LockId = "1"
)
// global hub transport and storage secret and configmap names
const (
GHTransportSecretName = "multicluster-global-hub-transport" // #nosec G101
GHStorageSecretName = "multicluster-global-hub-storage" // #nosec G101
KafkaCertSecretName = "kafka-certs-secret" // #nosec G101
GHDefaultStorageRetention = "18m" // 18 months
)
// the global hub transport config secret for manager and agent
const (
GHTransportConfigSecret = "transport-config" // #nosec G101
GHStorageConfigSecret = "storage-config" // #nosec G101
)
// global hub console secret/configmap names
const (
CustomAlertName = "multicluster-global-hub-custom-alerting"
CustomGrafanaIniName = "multicluster-global-hub-custom-grafana-config"
)
const (
// identify the resource is managed by
GlobalHubOwnerLabelKey = "global-hub.open-cluster-management.io/managed-by"
GlobalHubOwnerLabelVal = "global-hub"
GlobalHubAddonOwnerLabelVal = "global-hub-addon"
GHAgentOwnerLabelValue = "global-hub-agent"
GHOperatorOwnerLabelVal = "global-hub-operator"
// Deprecated identify the resource is a local-resource
// GlobalHubLocalResource = "global-hub.open-cluster-management.io/local-resource"
// if the resource with this label, it will be synced to database and then propagated to managed hub
GlobalHubGlobalResourceLabel = "global-hub.open-cluster-management.io/global-resource"
GlobalHubMetricsLabel = "global-hub.open-cluster-management.io/metrics-resource"
)
// store all the annotations
const (
// identify the managed cluster is managed by the specified managed hub cluster
ManagedClusterManagedByAnnotation = "global-hub.open-cluster-management.io/managed-by"
// identify the resource is from the global hub cluster
OriginOwnerReferenceAnnotation = "global-hub.open-cluster-management.io/origin-ownerreference-uid"
// identy the kafka is upgrade from zookeeper mode
UpgradeKafkaFromZookeeperAnnotation = "global-hub.open-cluster-management.io/upgrade-from-zookeeper"
// resync the kafka client secret in agent
ResyncKafkaClientSecretAnnotation = "global-hub.open-cluster-management.io/resign-kafka-client-secret" // #nosec G101
)
// store all the finalizers
const (
// The finalizer is only for the global resource. The finalizer will be added if it has the
// GlobalHubGlobalResourceLabel or OriginOwnerReferenceAnnotation
GlobalHubCleanupFinalizer = "global-hub.open-cluster-management.io/resource-cleanup"
// indicate the removing the global hub finalizer, shouldn't add it back to the resource
// the value is a timestamp which is the expiration time of this label
GlobalHubFinalizerRemovingDeadline = "global-hub.open-cluster-management.io/finalizer-removing-deadline"
)
// store hub installation constants
const (
MultiClusterHubKind = "MultiClusterHub"
ManagedClusterKind = "ManagedCluster"
ManagedClusterMigrationKind = "ManagedClusterMigration"
// VersionClusterClaimName is a claim to record the ACM version
VersionClusterClaimName = "version.open-cluster-management.io"
// HubClusterClaimName is a claim to record the ACM Hub
HubClusterClaimName = "hub.open-cluster-management.io"
// the value of the HubClusterClaimName ClusterClaim
HubNotInstalled = "NotInstalled"
HubInstalledByUser = "InstalledByUser"
HubInstalledByGlobalHub = "InstalledByGlobalHub"
)
// message types
const (
ResyncMsgKey = "Resync"
// ManagedClustersLabelsMsgKey - managed clusters labels message key.
ManagedClustersLabelsMsgKey = "ManagedClustersLabels"
// GenericSpecMsgKey is the generic spec message key for the bundle
GenericSpecMsgKey = "Generic"
)
// event exporter reference object label keys
const (
// the label is added by the event exporter
PolicyEventRootPolicyIdLabelKey = "policy.open-cluster-management.io/root-policy-id"
// the label is added by the event exporter
PolicyEventClusterIdLabelKey = "policy.open-cluster-management.io/cluster-id"
// the label is added by the event exporter
PolicyEventComplianceLabelKey = "policy.open-cluster-management.io/compliance"
// the label is from the reference object itself
PolicyEventRootPolicyNameLabelKey = "policy.open-cluster-management.io/root-policy"
// the label is from the reference object itself
PolicyEventClusterNameLabelKey = "policy.open-cluster-management.io/cluster-name"
)
const (
// Managedcluster imported status type
ManagedClusterImportSucceeded = "ManagedClusterImportSucceeded"
)
const (
// ManagedClusterMigrationFinalizer is the finalizer for managed cluster migration
ManagedClusterMigrationFinalizer = "global-hub.open-cluster-management.io/migration-cleanup"
// ManagedClusterMigrating is under migrating so the global hub agent ignore reporting the status for the cluster
ManagedClusterMigrating = "global-hub.open-cluster-management.io/migrating"
// KlusterletAddonConfigAnnotation is an annotation which contains klusterletAddonConfig object
KlusterletAddonConfigAnnotation = "global-hub.open-cluster-management.io/klusterlet-addon-config"
// cloudevent source for global hub
CloudEventSourceGlobalHub = "global-hub"
// cloudevent extension keys
CloudEventExtensionKeyClusterName = "clustername"
// CloudEventTypeManagedClusterMigrationFrom is the cloud event type for managed cluster migration from
CloudEventTypeMigrationFrom = "io.open-cluster-management.operator.multiclusterglobalhubs.spec.migration.from"
// CloudEventTypeManagedClusterMigrationTo is the cloud event type for managed cluster migration to
CloudEventTypeMigrationTo = "io.open-cluster-management.operator.multiclusterglobalhubs.spec.migration.to"
)
const (
// InventoryResourceCreatingAnnotationlKey indicates the request is a create request
InventoryResourceCreatingAnnotationlKey = "global-hub.open-cluster-management.io/inventory-resource-creating"
// InventoryResourceFinalizer is added into managedcluster and policy for resource cleanup
InventoryResourceFinalizer = "global-hub.open-cluster-management.io/inventory-resource-cleanup"
)