-
Notifications
You must be signed in to change notification settings - Fork 67
/
zz_cassandradatacenter_types.go
executable file
·228 lines (173 loc) · 12.5 KB
/
zz_cassandradatacenter_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
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
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
// SPDX-FileCopyrightText: 2024 The Crossplane Authors <https://crossplane.io>
//
// SPDX-License-Identifier: Apache-2.0
// Code generated by upjet. DO NOT EDIT.
package v1beta1
import (
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/runtime/schema"
v1 "github.com/crossplane/crossplane-runtime/apis/common/v1"
)
type CassandraDatacenterInitParameters struct {
// Determines whether availability zones are enabled. Defaults to true.
AvailabilityZonesEnabled *bool `json:"availabilityZonesEnabled,omitempty" tf:"availability_zones_enabled,omitempty"`
// The key URI of the customer key to use for the encryption of the backup Storage Account.
BackupStorageCustomerKeyURI *string `json:"backupStorageCustomerKeyUri,omitempty" tf:"backup_storage_customer_key_uri,omitempty"`
// The fragment of the cassandra.yaml configuration file to be included in the cassandra.yaml for all nodes in this Cassandra Datacenter. The fragment should be Base64 encoded and only a subset of keys is allowed.
Base64EncodedYamlFragment *string `json:"base64EncodedYamlFragment,omitempty" tf:"base64_encoded_yaml_fragment,omitempty"`
// The ID of the delegated management subnet for this Cassandra Datacenter. Changing this forces a new Cassandra Datacenter to be created.
// +crossplane:generate:reference:type=github.com/upbound/provider-azure/apis/network/v1beta2.Subnet
// +crossplane:generate:reference:extractor=github.com/crossplane/upjet/pkg/resource.ExtractResourceID()
DelegatedManagementSubnetID *string `json:"delegatedManagementSubnetId,omitempty" tf:"delegated_management_subnet_id,omitempty"`
// Reference to a Subnet in network to populate delegatedManagementSubnetId.
// +kubebuilder:validation:Optional
DelegatedManagementSubnetIDRef *v1.Reference `json:"delegatedManagementSubnetIdRef,omitempty" tf:"-"`
// Selector for a Subnet in network to populate delegatedManagementSubnetId.
// +kubebuilder:validation:Optional
DelegatedManagementSubnetIDSelector *v1.Selector `json:"delegatedManagementSubnetIdSelector,omitempty" tf:"-"`
// Determines the number of p30 disks that are attached to each node.
DiskCount *float64 `json:"diskCount,omitempty" tf:"disk_count,omitempty"`
// The Disk SKU that is used for this Cassandra Datacenter. Defaults to P30.
DiskSku *string `json:"diskSku,omitempty" tf:"disk_sku,omitempty"`
// The Azure Region where the Cassandra Datacenter should exist. Changing this forces a new Cassandra Datacenter to be created.
Location *string `json:"location,omitempty" tf:"location,omitempty"`
// The key URI of the customer key to use for the encryption of the Managed Disk.
ManagedDiskCustomerKeyURI *string `json:"managedDiskCustomerKeyUri,omitempty" tf:"managed_disk_customer_key_uri,omitempty"`
// The number of nodes the Cassandra Datacenter should have. The number should be equal or greater than 3. Defaults to 3.
NodeCount *float64 `json:"nodeCount,omitempty" tf:"node_count,omitempty"`
// Determines the selected sku.
SkuName *string `json:"skuName,omitempty" tf:"sku_name,omitempty"`
}
type CassandraDatacenterObservation struct {
// Determines whether availability zones are enabled. Defaults to true.
AvailabilityZonesEnabled *bool `json:"availabilityZonesEnabled,omitempty" tf:"availability_zones_enabled,omitempty"`
// The key URI of the customer key to use for the encryption of the backup Storage Account.
BackupStorageCustomerKeyURI *string `json:"backupStorageCustomerKeyUri,omitempty" tf:"backup_storage_customer_key_uri,omitempty"`
// The fragment of the cassandra.yaml configuration file to be included in the cassandra.yaml for all nodes in this Cassandra Datacenter. The fragment should be Base64 encoded and only a subset of keys is allowed.
Base64EncodedYamlFragment *string `json:"base64EncodedYamlFragment,omitempty" tf:"base64_encoded_yaml_fragment,omitempty"`
// The ID of the Cassandra Cluster. Changing this forces a new Cassandra Datacenter to be created.
CassandraClusterID *string `json:"cassandraClusterId,omitempty" tf:"cassandra_cluster_id,omitempty"`
// The ID of the delegated management subnet for this Cassandra Datacenter. Changing this forces a new Cassandra Datacenter to be created.
DelegatedManagementSubnetID *string `json:"delegatedManagementSubnetId,omitempty" tf:"delegated_management_subnet_id,omitempty"`
// Determines the number of p30 disks that are attached to each node.
DiskCount *float64 `json:"diskCount,omitempty" tf:"disk_count,omitempty"`
// The Disk SKU that is used for this Cassandra Datacenter. Defaults to P30.
DiskSku *string `json:"diskSku,omitempty" tf:"disk_sku,omitempty"`
// The ID of the Cassandra Datacenter.
ID *string `json:"id,omitempty" tf:"id,omitempty"`
// The Azure Region where the Cassandra Datacenter should exist. Changing this forces a new Cassandra Datacenter to be created.
Location *string `json:"location,omitempty" tf:"location,omitempty"`
// The key URI of the customer key to use for the encryption of the Managed Disk.
ManagedDiskCustomerKeyURI *string `json:"managedDiskCustomerKeyUri,omitempty" tf:"managed_disk_customer_key_uri,omitempty"`
// The number of nodes the Cassandra Datacenter should have. The number should be equal or greater than 3. Defaults to 3.
NodeCount *float64 `json:"nodeCount,omitempty" tf:"node_count,omitempty"`
// A list of IP Address for the seed nodes in this Cassandra Datacenter.
SeedNodeIPAddresses []*string `json:"seedNodeIpAddresses,omitempty" tf:"seed_node_ip_addresses,omitempty"`
// Determines the selected sku.
SkuName *string `json:"skuName,omitempty" tf:"sku_name,omitempty"`
}
type CassandraDatacenterParameters struct {
// Determines whether availability zones are enabled. Defaults to true.
// +kubebuilder:validation:Optional
AvailabilityZonesEnabled *bool `json:"availabilityZonesEnabled,omitempty" tf:"availability_zones_enabled,omitempty"`
// The key URI of the customer key to use for the encryption of the backup Storage Account.
// +kubebuilder:validation:Optional
BackupStorageCustomerKeyURI *string `json:"backupStorageCustomerKeyUri,omitempty" tf:"backup_storage_customer_key_uri,omitempty"`
// The fragment of the cassandra.yaml configuration file to be included in the cassandra.yaml for all nodes in this Cassandra Datacenter. The fragment should be Base64 encoded and only a subset of keys is allowed.
// +kubebuilder:validation:Optional
Base64EncodedYamlFragment *string `json:"base64EncodedYamlFragment,omitempty" tf:"base64_encoded_yaml_fragment,omitempty"`
// The ID of the Cassandra Cluster. Changing this forces a new Cassandra Datacenter to be created.
// +crossplane:generate:reference:type=github.com/upbound/provider-azure/apis/cosmosdb/v1beta2.CassandraCluster
// +crossplane:generate:reference:extractor=github.com/crossplane/upjet/pkg/resource.ExtractResourceID()
// +kubebuilder:validation:Optional
CassandraClusterID *string `json:"cassandraClusterId,omitempty" tf:"cassandra_cluster_id,omitempty"`
// Reference to a CassandraCluster in cosmosdb to populate cassandraClusterId.
// +kubebuilder:validation:Optional
CassandraClusterIDRef *v1.Reference `json:"cassandraClusterIdRef,omitempty" tf:"-"`
// Selector for a CassandraCluster in cosmosdb to populate cassandraClusterId.
// +kubebuilder:validation:Optional
CassandraClusterIDSelector *v1.Selector `json:"cassandraClusterIdSelector,omitempty" tf:"-"`
// The ID of the delegated management subnet for this Cassandra Datacenter. Changing this forces a new Cassandra Datacenter to be created.
// +crossplane:generate:reference:type=github.com/upbound/provider-azure/apis/network/v1beta2.Subnet
// +crossplane:generate:reference:extractor=github.com/crossplane/upjet/pkg/resource.ExtractResourceID()
// +kubebuilder:validation:Optional
DelegatedManagementSubnetID *string `json:"delegatedManagementSubnetId,omitempty" tf:"delegated_management_subnet_id,omitempty"`
// Reference to a Subnet in network to populate delegatedManagementSubnetId.
// +kubebuilder:validation:Optional
DelegatedManagementSubnetIDRef *v1.Reference `json:"delegatedManagementSubnetIdRef,omitempty" tf:"-"`
// Selector for a Subnet in network to populate delegatedManagementSubnetId.
// +kubebuilder:validation:Optional
DelegatedManagementSubnetIDSelector *v1.Selector `json:"delegatedManagementSubnetIdSelector,omitempty" tf:"-"`
// Determines the number of p30 disks that are attached to each node.
// +kubebuilder:validation:Optional
DiskCount *float64 `json:"diskCount,omitempty" tf:"disk_count,omitempty"`
// The Disk SKU that is used for this Cassandra Datacenter. Defaults to P30.
// +kubebuilder:validation:Optional
DiskSku *string `json:"diskSku,omitempty" tf:"disk_sku,omitempty"`
// The Azure Region where the Cassandra Datacenter should exist. Changing this forces a new Cassandra Datacenter to be created.
// +kubebuilder:validation:Optional
Location *string `json:"location,omitempty" tf:"location,omitempty"`
// The key URI of the customer key to use for the encryption of the Managed Disk.
// +kubebuilder:validation:Optional
ManagedDiskCustomerKeyURI *string `json:"managedDiskCustomerKeyUri,omitempty" tf:"managed_disk_customer_key_uri,omitempty"`
// The number of nodes the Cassandra Datacenter should have. The number should be equal or greater than 3. Defaults to 3.
// +kubebuilder:validation:Optional
NodeCount *float64 `json:"nodeCount,omitempty" tf:"node_count,omitempty"`
// Determines the selected sku.
// +kubebuilder:validation:Optional
SkuName *string `json:"skuName,omitempty" tf:"sku_name,omitempty"`
}
// CassandraDatacenterSpec defines the desired state of CassandraDatacenter
type CassandraDatacenterSpec struct {
v1.ResourceSpec `json:",inline"`
ForProvider CassandraDatacenterParameters `json:"forProvider"`
// THIS IS A BETA FIELD. It will be honored
// unless the Management Policies feature flag is disabled.
// InitProvider holds the same fields as ForProvider, with the exception
// of Identifier and other resource reference fields. The fields that are
// in InitProvider are merged into ForProvider when the resource is created.
// The same fields are also added to the terraform ignore_changes hook, to
// avoid updating them after creation. This is useful for fields that are
// required on creation, but we do not desire to update them after creation,
// for example because of an external controller is managing them, like an
// autoscaler.
InitProvider CassandraDatacenterInitParameters `json:"initProvider,omitempty"`
}
// CassandraDatacenterStatus defines the observed state of CassandraDatacenter.
type CassandraDatacenterStatus struct {
v1.ResourceStatus `json:",inline"`
AtProvider CassandraDatacenterObservation `json:"atProvider,omitempty"`
}
// +kubebuilder:object:root=true
// +kubebuilder:subresource:status
// +kubebuilder:storageversion
// CassandraDatacenter is the Schema for the CassandraDatacenters API. Manages a Cassandra Datacenter.
// +kubebuilder:printcolumn:name="SYNCED",type="string",JSONPath=".status.conditions[?(@.type=='Synced')].status"
// +kubebuilder:printcolumn:name="READY",type="string",JSONPath=".status.conditions[?(@.type=='Ready')].status"
// +kubebuilder:printcolumn:name="EXTERNAL-NAME",type="string",JSONPath=".metadata.annotations.crossplane\\.io/external-name"
// +kubebuilder:printcolumn:name="AGE",type="date",JSONPath=".metadata.creationTimestamp"
// +kubebuilder:resource:scope=Cluster,categories={crossplane,managed,azure}
type CassandraDatacenter struct {
metav1.TypeMeta `json:",inline"`
metav1.ObjectMeta `json:"metadata,omitempty"`
// +kubebuilder:validation:XValidation:rule="!('*' in self.managementPolicies || 'Create' in self.managementPolicies || 'Update' in self.managementPolicies) || has(self.forProvider.location) || (has(self.initProvider) && has(self.initProvider.location))",message="spec.forProvider.location is a required parameter"
Spec CassandraDatacenterSpec `json:"spec"`
Status CassandraDatacenterStatus `json:"status,omitempty"`
}
// +kubebuilder:object:root=true
// CassandraDatacenterList contains a list of CassandraDatacenters
type CassandraDatacenterList struct {
metav1.TypeMeta `json:",inline"`
metav1.ListMeta `json:"metadata,omitempty"`
Items []CassandraDatacenter `json:"items"`
}
// Repository type metadata.
var (
CassandraDatacenter_Kind = "CassandraDatacenter"
CassandraDatacenter_GroupKind = schema.GroupKind{Group: CRDGroup, Kind: CassandraDatacenter_Kind}.String()
CassandraDatacenter_KindAPIVersion = CassandraDatacenter_Kind + "." + CRDGroupVersion.String()
CassandraDatacenter_GroupVersionKind = CRDGroupVersion.WithKind(CassandraDatacenter_Kind)
)
func init() {
SchemeBuilder.Register(&CassandraDatacenter{}, &CassandraDatacenterList{})
}