-
Notifications
You must be signed in to change notification settings - Fork 80
/
oracle_adwc_write_attributes.go
100 lines (82 loc) · 3.08 KB
/
oracle_adwc_write_attributes.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
// 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.
// 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"
)
// OracleAdwcWriteAttributes Properties to configure when writing to Oracle Autonomous Data Warehouse Cloud.
type OracleAdwcWriteAttributes struct {
BucketSchema *Schema `mandatory:"false" json:"bucketSchema"`
// 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 OracleAdwcWriteAttributes) 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 OracleAdwcWriteAttributes) 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 OracleAdwcWriteAttributes) MarshalJSON() (buff []byte, e error) {
type MarshalTypeOracleAdwcWriteAttributes OracleAdwcWriteAttributes
s := struct {
DiscriminatorParam string `json:"modelType"`
MarshalTypeOracleAdwcWriteAttributes
}{
"ORACLE_ADWC_WRITE_ATTRIBUTE",
(MarshalTypeOracleAdwcWriteAttributes)(m),
}
return json.Marshal(&s)
}
// UnmarshalJSON unmarshals from json
func (m *OracleAdwcWriteAttributes) UnmarshalJSON(data []byte) (e error) {
model := struct {
BucketSchema *Schema `json:"bucketSchema"`
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.BucketSchema = model.BucketSchema
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
}