-
Notifications
You must be signed in to change notification settings - Fork 459
/
types_controllerinstallation.go
72 lines (63 loc) · 2.94 KB
/
types_controllerinstallation.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
// SPDX-FileCopyrightText: 2024 SAP SE or an SAP affiliate company and Gardener contributors
//
// SPDX-License-Identifier: Apache-2.0
package core
import (
corev1 "k8s.io/api/core/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/runtime"
)
// +genclient
// +genclient:nonNamespaced
// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
// ControllerInstallation represents an installation request for an external controller.
type ControllerInstallation struct {
metav1.TypeMeta
// Standard object metadata.
metav1.ObjectMeta
// Spec contains the specification of this installation.
// If the object's deletion timestamp is set, this field is immutable.
Spec ControllerInstallationSpec
// Status contains the status of this installation.
Status ControllerInstallationStatus
}
// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
// ControllerInstallationList is a collection of ControllerInstallations.
type ControllerInstallationList struct {
metav1.TypeMeta
// Standard list object metadata.
metav1.ListMeta
// Items is the list of ControllerInstallations.
Items []ControllerInstallation
}
// ControllerInstallationSpec is the specification of a ControllerInstallation.
type ControllerInstallationSpec struct {
// RegistrationRef is used to reference a ControllerRegistration resource.
// The name field of the RegistrationRef is immutable.
RegistrationRef corev1.ObjectReference
// SeedRef is used to reference a Seed resource. The name field of the SeedRef is immutable.
SeedRef corev1.ObjectReference
// DeploymentRef is used to reference a ControllerDeployment resource.
DeploymentRef *corev1.ObjectReference
}
// ControllerInstallationStatus is the status of a ControllerInstallation.
type ControllerInstallationStatus struct {
// Conditions represents the latest available observations of a ControllerInstallations's current state.
Conditions []Condition
// ProviderStatus contains type-specific status.
// +optional
ProviderStatus *runtime.RawExtension
}
const (
// ControllerInstallationHealthy is a condition type for indicating whether the controller is healthy.
ControllerInstallationHealthy ConditionType = "Healthy"
// ControllerInstallationInstalled is a condition type for indicating whether the controller has been installed.
ControllerInstallationInstalled ConditionType = "Installed"
// ControllerInstallationProgressing is a condition type for indicating whether the controller is progressing.
ControllerInstallationProgressing ConditionType = "Progressing"
// ControllerInstallationValid is a condition type for indicating whether the installation request is valid.
ControllerInstallationValid ConditionType = "Valid"
// ControllerInstallationRequired is a condition type for indicating that the respective extension controller is
// still required on the seed cluster as corresponding extension resources still exist.
ControllerInstallationRequired ConditionType = "Required"
)