-
Notifications
You must be signed in to change notification settings - Fork 82
/
create_item_details.go
117 lines (97 loc) · 3.51 KB
/
create_item_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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
// Copyright (c) 2016, 2018, 2022, 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.
// Support Management API
//
// Use the Support Management API to manage support requests. For more information, see Getting Help and Contacting Support (https://docs.cloud.oracle.com/iaas/Content/GSG/Tasks/contactingsupport.htm). **Note**: Before you can create service requests with this API, you need to have an Oracle Single Sign On (SSO) account, and you need to register your Customer Support Identifier (CSI) with My Oracle Support.
//
package cims
import (
"encoding/json"
"fmt"
"github.com/oracle/oci-go-sdk/v65/common"
"strings"
)
// CreateItemDetails Details gathered during item creation.
// **Caution:** Avoid using any confidential information when you supply string values using the API.
type CreateItemDetails interface {
GetCategory() *CreateCategoryDetails
GetSubCategory() *CreateSubCategoryDetails
GetIssueType() *CreateIssueTypeDetails
// The display name of the item.
GetName() *string
}
type createitemdetails struct {
JsonData []byte
Category *CreateCategoryDetails `mandatory:"false" json:"category"`
SubCategory *CreateSubCategoryDetails `mandatory:"false" json:"subCategory"`
IssueType *CreateIssueTypeDetails `mandatory:"false" json:"issueType"`
Name *string `mandatory:"false" json:"name"`
Type string `json:"type"`
}
// UnmarshalJSON unmarshals json
func (m *createitemdetails) UnmarshalJSON(data []byte) error {
m.JsonData = data
type Unmarshalercreateitemdetails createitemdetails
s := struct {
Model Unmarshalercreateitemdetails
}{}
err := json.Unmarshal(data, &s.Model)
if err != nil {
return err
}
m.Category = s.Model.Category
m.SubCategory = s.Model.SubCategory
m.IssueType = s.Model.IssueType
m.Name = s.Model.Name
m.Type = s.Model.Type
return err
}
// UnmarshalPolymorphicJSON unmarshals polymorphic json
func (m *createitemdetails) UnmarshalPolymorphicJSON(data []byte) (interface{}, error) {
if data == nil || string(data) == "null" {
return nil, nil
}
var err error
switch m.Type {
case "tech":
mm := CreateTechSupportItemDetails{}
err = json.Unmarshal(data, &mm)
return mm, err
case "limit":
mm := CreateLimitItemDetails{}
err = json.Unmarshal(data, &mm)
return mm, err
default:
return *m, nil
}
}
//GetCategory returns Category
func (m createitemdetails) GetCategory() *CreateCategoryDetails {
return m.Category
}
//GetSubCategory returns SubCategory
func (m createitemdetails) GetSubCategory() *CreateSubCategoryDetails {
return m.SubCategory
}
//GetIssueType returns IssueType
func (m createitemdetails) GetIssueType() *CreateIssueTypeDetails {
return m.IssueType
}
//GetName returns Name
func (m createitemdetails) GetName() *string {
return m.Name
}
func (m createitemdetails) 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 createitemdetails) ValidateEnumValue() (bool, error) {
errMessage := []string{}
if len(errMessage) > 0 {
return true, fmt.Errorf(strings.Join(errMessage, "\n"))
}
return false, nil
}