/
nodepool_types.go
102 lines (81 loc) · 3.19 KB
/
nodepool_types.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
/*
Copyright 2020 The OpenYurt 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 v1alpha1
import (
v1 "k8s.io/api/core/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
)
type NodePoolType string
const (
Edge NodePoolType = "Edge"
Cloud NodePoolType = "Cloud"
)
// NodePoolSpec defines the desired state of NodePool
type NodePoolSpec struct {
// The type of the NodePool
// +optional
Type NodePoolType `json:"type,omitempty"`
// A label query over nodes to consider for adding to the pool
// +optional
Selector *metav1.LabelSelector `json:"selector,omitempty"`
// If specified, the Labels will be added to all nodes.
// NOTE: existing labels with samy keys on the nodes will be overwritten.
// +optional
Labels map[string]string `json:"labels,omitempty"`
// If specified, the Annotations will be added to all nodes.
// NOTE: existing labels with samy keys on the nodes will be overwritten.
// +optional
Annotations map[string]string `json:"annotations,omitempty"`
// If specified, the Taints will be added to all nodes.
// +optional
Taints []v1.Taint `json:"taints,omitempty"`
}
// NodePoolStatus defines the observed state of NodePool
type NodePoolStatus struct {
// Total number of ready nodes in the pool.
// +optional
ReadyNodeNum int32 `json:"readyNodeNum"`
// Total number of unready nodes in the pool.
// +optional
UnreadyNodeNum int32 `json:"unreadyNodeNum"`
// The list of nodes' names in the pool
// +optional
Nodes []string `json:"nodes,omitempty"`
}
// +kubebuilder:object:root=true
// +kubebuilder:resource:scope=Cluster,path=nodepools,shortName=np,categories=all
// +kubebuilder:printcolumn:name="Type",type="string",JSONPath=".spec.type",description="The type of nodepool"
// +kubebuilder:printcolumn:name="ReadyNodes",type="integer",JSONPath=".status.readyNodeNum",description="The number of ready nodes in the pool"
// +kubebuilder:printcolumn:name="NotReadyNodes",type="integer",JSONPath=".status.unreadyNodeNum"
// +kubebuilder:printcolumn:name="Age",type="date",JSONPath=".metadata.creationTimestamp"
// +kubebuilder:subresource:status
// +genclient:nonNamespaced
// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
// +genclient
// NodePool is the Schema for the nodepools API
type NodePool struct {
metav1.TypeMeta `json:",inline"`
metav1.ObjectMeta `json:"metadata,omitempty"`
Spec NodePoolSpec `json:"spec,omitempty"`
Status NodePoolStatus `json:"status,omitempty"`
}
// +kubebuilder:object:root=true
// NodePoolList contains a list of NodePool
type NodePoolList struct {
metav1.TypeMeta `json:",inline"`
metav1.ListMeta `json:"metadata,omitempty"`
Items []NodePool `json:"items"`
}
func init() {
SchemeBuilder.Register(&NodePool{}, &NodePoolList{})
}