/
add_auto_scale_policy_details.go
97 lines (84 loc) · 3.66 KB
/
add_auto_scale_policy_details.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
// Copyright (c) 2016, 2018, 2024, Oracle and/or its affiliates. All rights reserved.
// This software is dual-licensed to you under the Universal Permissive License (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl or Apache License 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose either license.
// Code generated. DO NOT EDIT.
// Big Data Service API
//
// REST API for Oracle Big Data Service. Use this API to build, deploy, and manage fully elastic Big Data Service clusters. Build on Hadoop, Spark and Data Science distributions, which can be fully integrated with existing enterprise data in Oracle Database and Oracle applications.
//
package bds
import (
"encoding/json"
"fmt"
"github.com/oracle/oci-go-sdk/v65/common"
"strings"
)
// AddAutoScalePolicyDetails Policy definition for the autoscale configuration.
// An autoscaling policy is part of an autoscaling configuration. For more information, see
// Autoscaling (https://docs.cloud.oracle.com/iaas/Content/bigdata/create-cluster.htm#cluster-autoscale)
// You can create following type of autoscaling policies:
// - **MetricBasedVerticalScalingPolicy:** Vertical autoscaling action is triggered when a performance metric exceeds a threshold
// - **MetricBasedHorizontalScalingPolicy:** Horizontal autoscaling action is triggered when a performance metric exceeds a threshold
// - **ScheduleBasedVerticalScalingPolicy:** Vertical autoscaling action is triggered at the specific times that you schedule.
// - **ScheduleBasedHorizontalScalingPolicy:** Horizontal autoscaling action is triggered at the specific times that you schedule.
// An autoscaling configuration can have one of above supported policies.
type AddAutoScalePolicyDetails interface {
}
type addautoscalepolicydetails struct {
JsonData []byte
PolicyType string `json:"policyType"`
}
// UnmarshalJSON unmarshals json
func (m *addautoscalepolicydetails) UnmarshalJSON(data []byte) error {
m.JsonData = data
type Unmarshaleraddautoscalepolicydetails addautoscalepolicydetails
s := struct {
Model Unmarshaleraddautoscalepolicydetails
}{}
err := json.Unmarshal(data, &s.Model)
if err != nil {
return err
}
m.PolicyType = s.Model.PolicyType
return err
}
// UnmarshalPolymorphicJSON unmarshals polymorphic json
func (m *addautoscalepolicydetails) UnmarshalPolymorphicJSON(data []byte) (interface{}, error) {
if data == nil || string(data) == "null" {
return nil, nil
}
var err error
switch m.PolicyType {
case "METRIC_BASED_HORIZONTAL_SCALING_POLICY":
mm := AddMetricBasedHorizontalScalingPolicyDetails{}
err = json.Unmarshal(data, &mm)
return mm, err
case "SCHEDULE_BASED_VERTICAL_SCALING_POLICY":
mm := AddScheduleBasedVerticalScalingPolicyDetails{}
err = json.Unmarshal(data, &mm)
return mm, err
case "SCHEDULE_BASED_HORIZONTAL_SCALING_POLICY":
mm := AddScheduleBasedHorizontalScalingPolicyDetails{}
err = json.Unmarshal(data, &mm)
return mm, err
case "METRIC_BASED_VERTICAL_SCALING_POLICY":
mm := AddMetricBasedVerticalScalingPolicyDetails{}
err = json.Unmarshal(data, &mm)
return mm, err
default:
common.Logf("Recieved unsupported enum value for AddAutoScalePolicyDetails: %s.", m.PolicyType)
return *m, nil
}
}
func (m addautoscalepolicydetails) String() string {
return common.PointerString(m)
}
// ValidateEnumValue returns an error when providing an unsupported enum value
// This function is being called during constructing API request process
// Not recommended for calling this function directly
func (m addautoscalepolicydetails) ValidateEnumValue() (bool, error) {
errMessage := []string{}
if len(errMessage) > 0 {
return true, fmt.Errorf(strings.Join(errMessage, "\n"))
}
return false, nil
}