-
Notifications
You must be signed in to change notification settings - Fork 80
/
oracle_atp_write_attribute.go
102 lines (83 loc) · 3.08 KB
/
oracle_atp_write_attribute.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
// 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.
// Data Integration API
//
// Use the Data Integration API to organize your data integration projects, create data flows, pipelines and tasks, and then publish, schedule, and run tasks that extract, transform, and load data. For more information, see Data Integration (https://docs.oracle.com/iaas/data-integration/home.htm).
//
package dataintegration
import (
"encoding/json"
"fmt"
"github.com/oracle/oci-go-sdk/v65/common"
"strings"
)
// OracleAtpWriteAttribute Properties to configure writing to Oracle Autonomous Transaction Processing.
type OracleAtpWriteAttribute struct {
// The bucket name for the attribute.
BucketName *string `mandatory:"false" json:"bucketName"`
// The file name for the attribute.
StagingFileName *string `mandatory:"false" json:"stagingFileName"`
StagingDataAsset DataAsset `mandatory:"false" json:"stagingDataAsset"`
StagingConnection Connection `mandatory:"false" json:"stagingConnection"`
}
func (m OracleAtpWriteAttribute) 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 OracleAtpWriteAttribute) ValidateEnumValue() (bool, error) {
errMessage := []string{}
if len(errMessage) > 0 {
return true, fmt.Errorf(strings.Join(errMessage, "\n"))
}
return false, nil
}
// MarshalJSON marshals to json representation
func (m OracleAtpWriteAttribute) MarshalJSON() (buff []byte, e error) {
type MarshalTypeOracleAtpWriteAttribute OracleAtpWriteAttribute
s := struct {
DiscriminatorParam string `json:"modelType"`
MarshalTypeOracleAtpWriteAttribute
}{
"ORACLEATPWRITEATTRIBUTE",
(MarshalTypeOracleAtpWriteAttribute)(m),
}
return json.Marshal(&s)
}
// UnmarshalJSON unmarshals from json
func (m *OracleAtpWriteAttribute) UnmarshalJSON(data []byte) (e error) {
model := struct {
BucketName *string `json:"bucketName"`
StagingFileName *string `json:"stagingFileName"`
StagingDataAsset dataasset `json:"stagingDataAsset"`
StagingConnection connection `json:"stagingConnection"`
}{}
e = json.Unmarshal(data, &model)
if e != nil {
return
}
var nn interface{}
m.BucketName = model.BucketName
m.StagingFileName = model.StagingFileName
nn, e = model.StagingDataAsset.UnmarshalPolymorphicJSON(model.StagingDataAsset.JsonData)
if e != nil {
return
}
if nn != nil {
m.StagingDataAsset = nn.(DataAsset)
} else {
m.StagingDataAsset = nil
}
nn, e = model.StagingConnection.UnmarshalPolymorphicJSON(model.StagingConnection.JsonData)
if e != nil {
return
}
if nn != nil {
m.StagingConnection = nn.(Connection)
} else {
m.StagingConnection = nil
}
return
}