-
Notifications
You must be signed in to change notification settings - Fork 201
/
computenodegroup_types.go
170 lines (139 loc) · 7.32 KB
/
computenodegroup_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
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
// Copyright 2020 Google LLC
//
// 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.
// ----------------------------------------------------------------------------
//
// *** AUTO GENERATED CODE *** AUTO GENERATED CODE ***
//
// ----------------------------------------------------------------------------
//
// This file is automatically generated by Config Connector and manual
// changes will be clobbered when the file is regenerated.
//
// ----------------------------------------------------------------------------
// *** DISCLAIMER ***
// Config Connector's go-client for CRDs is currently in ALPHA, which means
// that future versions of the go-client may include breaking changes.
// Please try it out and give us feedback!
package v1beta1
import (
"github.com/GoogleCloudPlatform/k8s-config-connector/pkg/clients/generated/apis/k8s/v1alpha1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
)
type NodegroupAutoscalingPolicy struct {
/* Immutable. Maximum size of the node group. Set to a value less than or equal
to 100 and greater than or equal to min-nodes. */
// +optional
MaxNodes *int64 `json:"maxNodes,omitempty"`
/* Immutable. Minimum size of the node group. Must be less
than or equal to max-nodes. The default value is 0. */
// +optional
MinNodes *int64 `json:"minNodes,omitempty"`
/* Immutable. The autoscaling mode. Set to one of the following:
- OFF: Disables the autoscaler.
- ON: Enables scaling in and scaling out.
- ONLY_SCALE_OUT: Enables only scaling out.
You must use this mode if your node groups are configured to
restart their hosted VMs on minimal servers. Possible values: ["OFF", "ON", "ONLY_SCALE_OUT"]. */
// +optional
Mode *string `json:"mode,omitempty"`
}
type NodegroupMaintenanceWindow struct {
/* Immutable. instances.start time of the window. This must be in UTC format that resolves to one of 00:00, 04:00, 08:00, 12:00, 16:00, or 20:00. For example, both 13:00-5 and 08:00 are valid. */
StartTime string `json:"startTime"`
}
type NodegroupProjectMap struct {
/* The key of this project config in the parent map. */
IdRef v1alpha1.ResourceRef `json:"idRef"`
/* The project id/number should be the same as the key of this project
config in the project map. */
ProjectIdRef v1alpha1.ResourceRef `json:"projectIdRef"`
}
type NodegroupShareSettings struct {
/* Immutable. A map of project id and project config. This is only valid when shareType's value is SPECIFIC_PROJECTS. */
// +optional
ProjectMap []NodegroupProjectMap `json:"projectMap,omitempty"`
/* Immutable. Node group sharing type. Possible values: ["ORGANIZATION", "SPECIFIC_PROJECTS", "LOCAL"]. */
ShareType string `json:"shareType"`
}
type ComputeNodeGroupSpec struct {
/* Immutable. If you use sole-tenant nodes for your workloads, you can use the node
group autoscaler to automatically manage the sizes of your node groups. */
// +optional
AutoscalingPolicy *NodegroupAutoscalingPolicy `json:"autoscalingPolicy,omitempty"`
/* Immutable. An optional textual description of the resource. */
// +optional
Description *string `json:"description,omitempty"`
/* Immutable. The initial number of nodes in the node group. One of 'initial_size' or 'size' must be specified. */
// +optional
InitialSize *int64 `json:"initialSize,omitempty"`
/* Immutable. Specifies how to handle instances when a node in the group undergoes maintenance. Set to one of: DEFAULT, RESTART_IN_PLACE, or MIGRATE_WITHIN_NODE_GROUP. The default value is DEFAULT. */
// +optional
MaintenancePolicy *string `json:"maintenancePolicy,omitempty"`
/* Immutable. contains properties for the timeframe of maintenance. */
// +optional
MaintenanceWindow *NodegroupMaintenanceWindow `json:"maintenanceWindow,omitempty"`
/* The node template to which this node group belongs. */
NodeTemplateRef v1alpha1.ResourceRef `json:"nodeTemplateRef"`
/* Immutable. Optional. The name of the resource. Used for creation and acquisition. When unset, the value of `metadata.name` is used as the default. */
// +optional
ResourceID *string `json:"resourceID,omitempty"`
/* Immutable. Share settings for the node group. */
// +optional
ShareSettings *NodegroupShareSettings `json:"shareSettings,omitempty"`
/* Immutable. The total number of nodes in the node group. One of 'initial_size' or 'size' must be specified. */
// +optional
Size *int64 `json:"size,omitempty"`
/* Immutable. Zone where this node group is located. */
Zone string `json:"zone"`
}
type ComputeNodeGroupStatus struct {
/* Conditions represent the latest available observations of the
ComputeNodeGroup's current state. */
Conditions []v1alpha1.Condition `json:"conditions,omitempty"`
/* Creation timestamp in RFC3339 text format. */
// +optional
CreationTimestamp *string `json:"creationTimestamp,omitempty"`
/* ObservedGeneration is the generation of the resource that was most recently observed by the Config Connector controller. If this is equal to metadata.generation, then that means that the current reported status reflects the most recent desired state of the resource. */
// +optional
ObservedGeneration *int64 `json:"observedGeneration,omitempty"`
// +optional
SelfLink *string `json:"selfLink,omitempty"`
}
// +genclient
// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
// +kubebuilder:resource:categories=gcp,shortName=gcpcomputenodegroup;gcpcomputenodegroups
// +kubebuilder:subresource:status
// +kubebuilder:metadata:labels="cnrm.cloud.google.com/managed-by-kcc=true";"cnrm.cloud.google.com/stability-level=stable";"cnrm.cloud.google.com/system=true";"cnrm.cloud.google.com/tf2crd=true"
// +kubebuilder:printcolumn:name="Age",JSONPath=".metadata.creationTimestamp",type="date"
// +kubebuilder:printcolumn:name="Ready",JSONPath=".status.conditions[?(@.type=='Ready')].status",type="string",description="When 'True', the most recent reconcile of the resource succeeded"
// +kubebuilder:printcolumn:name="Status",JSONPath=".status.conditions[?(@.type=='Ready')].reason",type="string",description="The reason for the value in 'Ready'"
// +kubebuilder:printcolumn:name="Status Age",JSONPath=".status.conditions[?(@.type=='Ready')].lastTransitionTime",type="date",description="The last transition time for the value in 'Status'"
// ComputeNodeGroup is the Schema for the compute API
// +k8s:openapi-gen=true
type ComputeNodeGroup struct {
metav1.TypeMeta `json:",inline"`
metav1.ObjectMeta `json:"metadata,omitempty"`
Spec ComputeNodeGroupSpec `json:"spec,omitempty"`
Status ComputeNodeGroupStatus `json:"status,omitempty"`
}
// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
// ComputeNodeGroupList contains a list of ComputeNodeGroup
type ComputeNodeGroupList struct {
metav1.TypeMeta `json:",inline"`
metav1.ListMeta `json:"metadata,omitempty"`
Items []ComputeNodeGroup `json:"items"`
}
func init() {
SchemeBuilder.Register(&ComputeNodeGroup{}, &ComputeNodeGroupList{})
}