-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmodel_node_pool.go
715 lines (544 loc) · 23.3 KB
/
model_node_pool.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
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
/*
* IONOS Cloud - Managed Stackable Data Platform API
*
* *Managed Stackable Data Platform* by IONOS Cloud provides a preconfigured Kubernetes cluster with pre-installed and managed Stackable operators. After the provision of these Stackable operators, the customer can interact with them directly and build his desired application on top of the Stackable platform. The Managed Stackable Data Platform by IONOS Cloud can be configured through the IONOS Cloud API in addition or as an alternative to the *Data Center Designer* (DCD). ## Getting Started To get your DataPlatformCluster up and running, the following steps needs to be performed. ### IONOS Cloud Account The first step is the creation of a IONOS Cloud account if not already existing. To register a **new account**, visit [cloud.ionos.com](https://cloud.ionos.com/compute/signup). ### Virtual Data Center (VDC) The Managed Stackable Data Platform needs a virtual data center (VDC) hosting the cluster. This could either be a VDC that already exists, especially if you want to connect the managed data platform to other services already running within your VDC. Otherwise, if you want to place the Managed Stackable Data Platform in a new VDC or you have not yet created a VDC, you need to do so. A new VDC can be created via the IONOS Cloud API, the IONOS Cloud CLI (`ionosctl`), or the DCD Web interface. For more information, see the [official documentation](https://docs.ionos.com/cloud/getting-started/basic-tutorials/data-center-basics). ### Get a authentication token To interact with this API a user specific authentication token is needed. This token can be generated using the IONOS Cloud CLI the following way: ``` ionosctl token generate ``` For more information, [see](https://docs.ionos.com/cli-ionosctl/subcommands/authentication/token/generate). ### Create a new DataPlatformCluster Before using the Managed Stackable Data Platform, a new DataPlatformCluster must be created. To create a cluster, use the [Create DataPlatformCluster](paths./clusters.post) API endpoint. The provisioning of the cluster might take some time. To check the current provisioning status, you can query the cluster by calling the [Get Endpoint](#/DataPlatformCluster/getCluster) with the cluster ID that was presented to you in the response of the create cluster call. ### Add a DataPlatformNodePool To deploy and run a Stackable service, the cluster must have enough computational resources. The node pool that is provisioned along with the cluster is reserved for the Stackable operators. You may create further node pools with resources tailored to your use case. To create a new node pool use the [Create DataPlatformNodepool](paths./clusters/{clusterId}/nodepools.post) endpoint. ### Receive Kubeconfig Once the DataPlatformCluster is created, the kubeconfig can be accessed by the API. The kubeconfig allows the interaction with the provided cluster as with any regular Kubernetes cluster. To protect the deployment of the Stackable distribution, the kubeconfig does not provide you with administration rights for the cluster. What that means is that your actions and deployments are limited to the **default** namespace. If you still want to group your deployments, you have the option to create subnamespaces within the default namespace. This is made possible by the concept of *hierarchical namespaces* (HNS). You can find more details [here](https://kubernetes.io/blog/2020/08/14/introducing-hierarchical-namespaces/). The kubeconfig can be downloaded with the [Get Kubeconfig](paths./clusters/{clusterId}/kubeconfig.get) endpoint using the cluster ID of the created DataPlatformCluster. ### Create Stackable Services You can leverage the `kubeconfig.json` file to access the Managed Stackable Data Platform cluster and manage the deployment of [Stackable data apps](https://stackable.tech/en/platform/). With the Stackable operators, you can deploy the [data apps](https://docs.stackable.tech/home/stable/getting_started.html#_deploying_stackable_services) you want in your Data Platform cluster. ## Authorization All endpoints are secured, so only an authenticated user can access them. As Authentication mechanism the default IONOS Cloud authentication mechanism is used. A detailed description can be found [here](https://api.ionos.com/docs/authentication/). ### Basic Auth The basic auth scheme uses the IONOS Cloud user credentials in form of a *Basic Authentication* header accordingly to [RFC 7617](https://datatracker.ietf.org/doc/html/rfc7617). ### API Key as Bearer Token The Bearer auth token used at the API Gateway is a user-related token created with the IONOS Cloud CLI (For details, see the [documentation](https://docs.ionos.com/cli-ionosctl/subcommands/authentication/token/generate)). For every request to be authenticated, the token is passed as *Authorization Bearer* header along with the request. ### Permissions and Access Roles Currently, an administrator can see and manipulate all resources in a contract. Furthermore, users with the group privilege `Manage Dataplatform` can access the API. ## Components The Managed Stackable Data Platform by IONOS Cloud consists of two components. The concept of a DataPlatformClusters and the backing DataPlatformNodePools the cluster is build on. ### DataPlatformCluster A DataPlatformCluster is the virtual instance of the customer services and operations running the managed services like Stackable operators. A DataPlatformCluster is a Kubernetes Cluster in the VDC of the customer. Therefore, it's possible to integrate the cluster with other resources as VLANs e.g. to shape the data center in the customer's need and integrate the cluster within the topology the customer wants to build. In addition to the Kubernetes cluster, a small node pool is provided which is exclusively used to run the Stackable operators. ### DataPlatformNodePool A DataPlatformNodePool represents the physical machines a DataPlatformCluster is build on top. All nodes within a node pool are identical in setup. The nodes of a pool are provisioned into virtual data centers at a location of your choice and you can freely specify the properties of all the nodes at once before creation. Nodes in node pools provisioned by the Managed Stackable Data Platform Cloud API are read-only in the customer's VDC and can only be modified or deleted via the API. ## References
*
* API version: 1.2.0
*/
// Code generated by OpenAPI Generator (https://openapi-generator.tech); DO NOT EDIT.
package ionoscloud
import (
"encoding/json"
)
// NodePool A DataPlatformNodePool of a DataPlatformCluster.
type NodePool struct {
// The name of your node pool. Must be 63 characters or less and must begin and end with an alphanumeric character (`[a-z0-9A-Z]`) with dashes (`-`), underscores (`_`), dots (`.`), and alphanumerics between.
Name *string `json:"name,omitempty"`
// The version of the data platform.
DataPlatformVersion *string `json:"dataPlatformVersion,omitempty"`
// The UUID of the virtual data center (VDC) the cluster is provisioned.
DatacenterId *string `json:"datacenterId,omitempty"`
// The number of nodes that make up the node pool.
NodeCount *int32 `json:"nodeCount,omitempty"`
// A valid CPU family name or `AUTO` if the platform shall choose the best fitting option. Available CPU architectures can be retrieved from the data center resource.
CpuFamily *string `json:"cpuFamily,omitempty"`
// The number of CPU cores per node.
CoresCount *int32 `json:"coresCount,omitempty"`
// The RAM size for one node in MB. Must be set in multiples of 1024 MB, with a minimum size is of 2048 MB.
RamSize *int32 `json:"ramSize,omitempty"`
AvailabilityZone *AvailabilityZone `json:"availabilityZone,omitempty"`
StorageType *StorageType `json:"storageType,omitempty"`
// The size of the volume in GB. The size must be greater than 10 GB.
StorageSize *int32 `json:"storageSize,omitempty"`
MaintenanceWindow *MaintenanceWindow `json:"maintenanceWindow,omitempty"`
// Key-value pairs attached to the node pool resource as [Kubernetes labels](https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/).
Labels *map[string]interface{} `json:"labels,omitempty"`
// Key-value pairs attached to node pool resource as [Kubernetes annotations](https://kubernetes.io/docs/concepts/overview/working-with-objects/annotations/).
Annotations *map[string]interface{} `json:"annotations,omitempty"`
AutoScaling *AutoScaling `json:"autoScaling,omitempty"`
}
// NewNodePool instantiates a new NodePool object
// This constructor will assign default values to properties that have it defined,
// and makes sure properties required by API are set, but the set of arguments
// will change when the set of required properties is changed
func NewNodePool() *NodePool {
this := NodePool{}
var cpuFamily string = "AUTO"
this.CpuFamily = &cpuFamily
var coresCount int32 = 4
this.CoresCount = &coresCount
var ramSize int32 = 4096
this.RamSize = &ramSize
var availabilityZone AvailabilityZone = AVAILABILITYZONE_AUTO
this.AvailabilityZone = &availabilityZone
var storageType StorageType = STORAGETYPE_SSD
this.StorageType = &storageType
var storageSize int32 = 20
this.StorageSize = &storageSize
return &this
}
// NewNodePoolWithDefaults instantiates a new NodePool object
// This constructor will only assign default values to properties that have it defined,
// but it doesn't guarantee that properties required by API are set
func NewNodePoolWithDefaults() *NodePool {
this := NodePool{}
var cpuFamily string = "AUTO"
this.CpuFamily = &cpuFamily
var coresCount int32 = 4
this.CoresCount = &coresCount
var ramSize int32 = 4096
this.RamSize = &ramSize
var availabilityZone AvailabilityZone = AVAILABILITYZONE_AUTO
this.AvailabilityZone = &availabilityZone
var storageType StorageType = STORAGETYPE_SSD
this.StorageType = &storageType
var storageSize int32 = 20
this.StorageSize = &storageSize
return &this
}
// GetName returns the Name field value
// If the value is explicit nil, the zero value for string will be returned
func (o *NodePool) GetName() *string {
if o == nil {
return nil
}
return o.Name
}
// GetNameOk returns a tuple with the Name field value
// and a boolean to check if the value has been set.
// NOTE: If the value is an explicit nil, `nil, true` will be returned
func (o *NodePool) GetNameOk() (*string, bool) {
if o == nil {
return nil, false
}
return o.Name, true
}
// SetName sets field value
func (o *NodePool) SetName(v string) {
o.Name = &v
}
// HasName returns a boolean if a field has been set.
func (o *NodePool) HasName() bool {
if o != nil && o.Name != nil {
return true
}
return false
}
// GetDataPlatformVersion returns the DataPlatformVersion field value
// If the value is explicit nil, the zero value for string will be returned
func (o *NodePool) GetDataPlatformVersion() *string {
if o == nil {
return nil
}
return o.DataPlatformVersion
}
// GetDataPlatformVersionOk returns a tuple with the DataPlatformVersion field value
// and a boolean to check if the value has been set.
// NOTE: If the value is an explicit nil, `nil, true` will be returned
func (o *NodePool) GetDataPlatformVersionOk() (*string, bool) {
if o == nil {
return nil, false
}
return o.DataPlatformVersion, true
}
// SetDataPlatformVersion sets field value
func (o *NodePool) SetDataPlatformVersion(v string) {
o.DataPlatformVersion = &v
}
// HasDataPlatformVersion returns a boolean if a field has been set.
func (o *NodePool) HasDataPlatformVersion() bool {
if o != nil && o.DataPlatformVersion != nil {
return true
}
return false
}
// GetDatacenterId returns the DatacenterId field value
// If the value is explicit nil, the zero value for string will be returned
func (o *NodePool) GetDatacenterId() *string {
if o == nil {
return nil
}
return o.DatacenterId
}
// GetDatacenterIdOk returns a tuple with the DatacenterId field value
// and a boolean to check if the value has been set.
// NOTE: If the value is an explicit nil, `nil, true` will be returned
func (o *NodePool) GetDatacenterIdOk() (*string, bool) {
if o == nil {
return nil, false
}
return o.DatacenterId, true
}
// SetDatacenterId sets field value
func (o *NodePool) SetDatacenterId(v string) {
o.DatacenterId = &v
}
// HasDatacenterId returns a boolean if a field has been set.
func (o *NodePool) HasDatacenterId() bool {
if o != nil && o.DatacenterId != nil {
return true
}
return false
}
// GetNodeCount returns the NodeCount field value
// If the value is explicit nil, the zero value for int32 will be returned
func (o *NodePool) GetNodeCount() *int32 {
if o == nil {
return nil
}
return o.NodeCount
}
// GetNodeCountOk returns a tuple with the NodeCount field value
// and a boolean to check if the value has been set.
// NOTE: If the value is an explicit nil, `nil, true` will be returned
func (o *NodePool) GetNodeCountOk() (*int32, bool) {
if o == nil {
return nil, false
}
return o.NodeCount, true
}
// SetNodeCount sets field value
func (o *NodePool) SetNodeCount(v int32) {
o.NodeCount = &v
}
// HasNodeCount returns a boolean if a field has been set.
func (o *NodePool) HasNodeCount() bool {
if o != nil && o.NodeCount != nil {
return true
}
return false
}
// GetCpuFamily returns the CpuFamily field value
// If the value is explicit nil, the zero value for string will be returned
func (o *NodePool) GetCpuFamily() *string {
if o == nil {
return nil
}
return o.CpuFamily
}
// GetCpuFamilyOk returns a tuple with the CpuFamily field value
// and a boolean to check if the value has been set.
// NOTE: If the value is an explicit nil, `nil, true` will be returned
func (o *NodePool) GetCpuFamilyOk() (*string, bool) {
if o == nil {
return nil, false
}
return o.CpuFamily, true
}
// SetCpuFamily sets field value
func (o *NodePool) SetCpuFamily(v string) {
o.CpuFamily = &v
}
// HasCpuFamily returns a boolean if a field has been set.
func (o *NodePool) HasCpuFamily() bool {
if o != nil && o.CpuFamily != nil {
return true
}
return false
}
// GetCoresCount returns the CoresCount field value
// If the value is explicit nil, the zero value for int32 will be returned
func (o *NodePool) GetCoresCount() *int32 {
if o == nil {
return nil
}
return o.CoresCount
}
// GetCoresCountOk returns a tuple with the CoresCount field value
// and a boolean to check if the value has been set.
// NOTE: If the value is an explicit nil, `nil, true` will be returned
func (o *NodePool) GetCoresCountOk() (*int32, bool) {
if o == nil {
return nil, false
}
return o.CoresCount, true
}
// SetCoresCount sets field value
func (o *NodePool) SetCoresCount(v int32) {
o.CoresCount = &v
}
// HasCoresCount returns a boolean if a field has been set.
func (o *NodePool) HasCoresCount() bool {
if o != nil && o.CoresCount != nil {
return true
}
return false
}
// GetRamSize returns the RamSize field value
// If the value is explicit nil, the zero value for int32 will be returned
func (o *NodePool) GetRamSize() *int32 {
if o == nil {
return nil
}
return o.RamSize
}
// GetRamSizeOk returns a tuple with the RamSize field value
// and a boolean to check if the value has been set.
// NOTE: If the value is an explicit nil, `nil, true` will be returned
func (o *NodePool) GetRamSizeOk() (*int32, bool) {
if o == nil {
return nil, false
}
return o.RamSize, true
}
// SetRamSize sets field value
func (o *NodePool) SetRamSize(v int32) {
o.RamSize = &v
}
// HasRamSize returns a boolean if a field has been set.
func (o *NodePool) HasRamSize() bool {
if o != nil && o.RamSize != nil {
return true
}
return false
}
// GetAvailabilityZone returns the AvailabilityZone field value
// If the value is explicit nil, the zero value for AvailabilityZone will be returned
func (o *NodePool) GetAvailabilityZone() *AvailabilityZone {
if o == nil {
return nil
}
return o.AvailabilityZone
}
// GetAvailabilityZoneOk returns a tuple with the AvailabilityZone field value
// and a boolean to check if the value has been set.
// NOTE: If the value is an explicit nil, `nil, true` will be returned
func (o *NodePool) GetAvailabilityZoneOk() (*AvailabilityZone, bool) {
if o == nil {
return nil, false
}
return o.AvailabilityZone, true
}
// SetAvailabilityZone sets field value
func (o *NodePool) SetAvailabilityZone(v AvailabilityZone) {
o.AvailabilityZone = &v
}
// HasAvailabilityZone returns a boolean if a field has been set.
func (o *NodePool) HasAvailabilityZone() bool {
if o != nil && o.AvailabilityZone != nil {
return true
}
return false
}
// GetStorageType returns the StorageType field value
// If the value is explicit nil, the zero value for StorageType will be returned
func (o *NodePool) GetStorageType() *StorageType {
if o == nil {
return nil
}
return o.StorageType
}
// GetStorageTypeOk returns a tuple with the StorageType field value
// and a boolean to check if the value has been set.
// NOTE: If the value is an explicit nil, `nil, true` will be returned
func (o *NodePool) GetStorageTypeOk() (*StorageType, bool) {
if o == nil {
return nil, false
}
return o.StorageType, true
}
// SetStorageType sets field value
func (o *NodePool) SetStorageType(v StorageType) {
o.StorageType = &v
}
// HasStorageType returns a boolean if a field has been set.
func (o *NodePool) HasStorageType() bool {
if o != nil && o.StorageType != nil {
return true
}
return false
}
// GetStorageSize returns the StorageSize field value
// If the value is explicit nil, the zero value for int32 will be returned
func (o *NodePool) GetStorageSize() *int32 {
if o == nil {
return nil
}
return o.StorageSize
}
// GetStorageSizeOk returns a tuple with the StorageSize field value
// and a boolean to check if the value has been set.
// NOTE: If the value is an explicit nil, `nil, true` will be returned
func (o *NodePool) GetStorageSizeOk() (*int32, bool) {
if o == nil {
return nil, false
}
return o.StorageSize, true
}
// SetStorageSize sets field value
func (o *NodePool) SetStorageSize(v int32) {
o.StorageSize = &v
}
// HasStorageSize returns a boolean if a field has been set.
func (o *NodePool) HasStorageSize() bool {
if o != nil && o.StorageSize != nil {
return true
}
return false
}
// GetMaintenanceWindow returns the MaintenanceWindow field value
// If the value is explicit nil, the zero value for MaintenanceWindow will be returned
func (o *NodePool) GetMaintenanceWindow() *MaintenanceWindow {
if o == nil {
return nil
}
return o.MaintenanceWindow
}
// GetMaintenanceWindowOk returns a tuple with the MaintenanceWindow field value
// and a boolean to check if the value has been set.
// NOTE: If the value is an explicit nil, `nil, true` will be returned
func (o *NodePool) GetMaintenanceWindowOk() (*MaintenanceWindow, bool) {
if o == nil {
return nil, false
}
return o.MaintenanceWindow, true
}
// SetMaintenanceWindow sets field value
func (o *NodePool) SetMaintenanceWindow(v MaintenanceWindow) {
o.MaintenanceWindow = &v
}
// HasMaintenanceWindow returns a boolean if a field has been set.
func (o *NodePool) HasMaintenanceWindow() bool {
if o != nil && o.MaintenanceWindow != nil {
return true
}
return false
}
// GetLabels returns the Labels field value
// If the value is explicit nil, the zero value for map[string]interface{} will be returned
func (o *NodePool) GetLabels() *map[string]interface{} {
if o == nil {
return nil
}
return o.Labels
}
// GetLabelsOk returns a tuple with the Labels field value
// and a boolean to check if the value has been set.
// NOTE: If the value is an explicit nil, `nil, true` will be returned
func (o *NodePool) GetLabelsOk() (*map[string]interface{}, bool) {
if o == nil {
return nil, false
}
return o.Labels, true
}
// SetLabels sets field value
func (o *NodePool) SetLabels(v map[string]interface{}) {
o.Labels = &v
}
// HasLabels returns a boolean if a field has been set.
func (o *NodePool) HasLabels() bool {
if o != nil && o.Labels != nil {
return true
}
return false
}
// GetAnnotations returns the Annotations field value
// If the value is explicit nil, the zero value for map[string]interface{} will be returned
func (o *NodePool) GetAnnotations() *map[string]interface{} {
if o == nil {
return nil
}
return o.Annotations
}
// GetAnnotationsOk returns a tuple with the Annotations field value
// and a boolean to check if the value has been set.
// NOTE: If the value is an explicit nil, `nil, true` will be returned
func (o *NodePool) GetAnnotationsOk() (*map[string]interface{}, bool) {
if o == nil {
return nil, false
}
return o.Annotations, true
}
// SetAnnotations sets field value
func (o *NodePool) SetAnnotations(v map[string]interface{}) {
o.Annotations = &v
}
// HasAnnotations returns a boolean if a field has been set.
func (o *NodePool) HasAnnotations() bool {
if o != nil && o.Annotations != nil {
return true
}
return false
}
// GetAutoScaling returns the AutoScaling field value
// If the value is explicit nil, the zero value for AutoScaling will be returned
func (o *NodePool) GetAutoScaling() *AutoScaling {
if o == nil {
return nil
}
return o.AutoScaling
}
// GetAutoScalingOk returns a tuple with the AutoScaling field value
// and a boolean to check if the value has been set.
// NOTE: If the value is an explicit nil, `nil, true` will be returned
func (o *NodePool) GetAutoScalingOk() (*AutoScaling, bool) {
if o == nil {
return nil, false
}
return o.AutoScaling, true
}
// SetAutoScaling sets field value
func (o *NodePool) SetAutoScaling(v AutoScaling) {
o.AutoScaling = &v
}
// HasAutoScaling returns a boolean if a field has been set.
func (o *NodePool) HasAutoScaling() bool {
if o != nil && o.AutoScaling != nil {
return true
}
return false
}
func (o NodePool) MarshalJSON() ([]byte, error) {
toSerialize := map[string]interface{}{}
if o.Name != nil {
toSerialize["name"] = o.Name
}
if o.DataPlatformVersion != nil {
toSerialize["dataPlatformVersion"] = o.DataPlatformVersion
}
if o.DatacenterId != nil {
toSerialize["datacenterId"] = o.DatacenterId
}
if o.NodeCount != nil {
toSerialize["nodeCount"] = o.NodeCount
}
if o.CpuFamily != nil {
toSerialize["cpuFamily"] = o.CpuFamily
}
if o.CoresCount != nil {
toSerialize["coresCount"] = o.CoresCount
}
if o.RamSize != nil {
toSerialize["ramSize"] = o.RamSize
}
if o.AvailabilityZone != nil {
toSerialize["availabilityZone"] = o.AvailabilityZone
}
if o.StorageType != nil {
toSerialize["storageType"] = o.StorageType
}
if o.StorageSize != nil {
toSerialize["storageSize"] = o.StorageSize
}
if o.MaintenanceWindow != nil {
toSerialize["maintenanceWindow"] = o.MaintenanceWindow
}
if o.Labels != nil {
toSerialize["labels"] = o.Labels
}
if o.Annotations != nil {
toSerialize["annotations"] = o.Annotations
}
if o.AutoScaling != nil {
toSerialize["autoScaling"] = o.AutoScaling
}
return json.Marshal(toSerialize)
}
type NullableNodePool struct {
value *NodePool
isSet bool
}
func (v NullableNodePool) Get() *NodePool {
return v.value
}
func (v *NullableNodePool) Set(val *NodePool) {
v.value = val
v.isSet = true
}
func (v NullableNodePool) IsSet() bool {
return v.isSet
}
func (v *NullableNodePool) Unset() {
v.value = nil
v.isSet = false
}
func NewNullableNodePool(val *NodePool) *NullableNodePool {
return &NullableNodePool{value: val, isSet: true}
}
func (v NullableNodePool) MarshalJSON() ([]byte, error) {
return json.Marshal(v.value)
}
func (v *NullableNodePool) UnmarshalJSON(src []byte) error {
v.isSet = true
return json.Unmarshal(src, &v.value)
}