-
Notifications
You must be signed in to change notification settings - Fork 82
/
wait_criteria.go
115 lines (95 loc) · 3.53 KB
/
wait_criteria.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
// 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.
// DevOps API
//
// Use the DevOps API to create DevOps projects, configure code repositories, add artifacts to deploy, build and test software applications, configure target deployment environments, and deploy software applications. For more information, see DevOps (https://docs.cloud.oracle.com/Content/devops/using/home.htm).
//
package devops
import (
"encoding/json"
"fmt"
"github.com/oracle/oci-go-sdk/v65/common"
"strings"
)
// WaitCriteria Specifies wait criteria for the Wait stage.
type WaitCriteria interface {
}
type waitcriteria struct {
JsonData []byte
WaitType string `json:"waitType"`
}
// UnmarshalJSON unmarshals json
func (m *waitcriteria) UnmarshalJSON(data []byte) error {
m.JsonData = data
type Unmarshalerwaitcriteria waitcriteria
s := struct {
Model Unmarshalerwaitcriteria
}{}
err := json.Unmarshal(data, &s.Model)
if err != nil {
return err
}
m.WaitType = s.Model.WaitType
return err
}
// UnmarshalPolymorphicJSON unmarshals polymorphic json
func (m *waitcriteria) UnmarshalPolymorphicJSON(data []byte) (interface{}, error) {
if data == nil || string(data) == "null" {
return nil, nil
}
var err error
switch m.WaitType {
case "ABSOLUTE_WAIT":
mm := AbsoluteWaitCriteria{}
err = json.Unmarshal(data, &mm)
return mm, err
default:
common.Logf("Recieved unsupported enum value for WaitCriteria: %s.", m.WaitType)
return *m, nil
}
}
func (m waitcriteria) 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 waitcriteria) ValidateEnumValue() (bool, error) {
errMessage := []string{}
if len(errMessage) > 0 {
return true, fmt.Errorf(strings.Join(errMessage, "\n"))
}
return false, nil
}
// WaitCriteriaWaitTypeEnum Enum with underlying type: string
type WaitCriteriaWaitTypeEnum string
// Set of constants representing the allowable values for WaitCriteriaWaitTypeEnum
const (
WaitCriteriaWaitTypeAbsoluteWait WaitCriteriaWaitTypeEnum = "ABSOLUTE_WAIT"
)
var mappingWaitCriteriaWaitTypeEnum = map[string]WaitCriteriaWaitTypeEnum{
"ABSOLUTE_WAIT": WaitCriteriaWaitTypeAbsoluteWait,
}
var mappingWaitCriteriaWaitTypeEnumLowerCase = map[string]WaitCriteriaWaitTypeEnum{
"absolute_wait": WaitCriteriaWaitTypeAbsoluteWait,
}
// GetWaitCriteriaWaitTypeEnumValues Enumerates the set of values for WaitCriteriaWaitTypeEnum
func GetWaitCriteriaWaitTypeEnumValues() []WaitCriteriaWaitTypeEnum {
values := make([]WaitCriteriaWaitTypeEnum, 0)
for _, v := range mappingWaitCriteriaWaitTypeEnum {
values = append(values, v)
}
return values
}
// GetWaitCriteriaWaitTypeEnumStringValues Enumerates the set of values in String for WaitCriteriaWaitTypeEnum
func GetWaitCriteriaWaitTypeEnumStringValues() []string {
return []string{
"ABSOLUTE_WAIT",
}
}
// GetMappingWaitCriteriaWaitTypeEnum performs case Insensitive comparison on enum value and return the desired enum
func GetMappingWaitCriteriaWaitTypeEnum(val string) (WaitCriteriaWaitTypeEnum, bool) {
enum, ok := mappingWaitCriteriaWaitTypeEnumLowerCase[strings.ToLower(val)]
return enum, ok
}