/
oracle_atp_write_attributes.go
100 lines (82 loc) · 3.07 KB
/
oracle_atp_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"
)
// OracleAtpWriteAttributes Properties to configure when writing to Oracle Autonomous Data Warehouse Cloud.
type OracleAtpWriteAttributes 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 OracleAtpWriteAttributes) 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 OracleAtpWriteAttributes) 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 OracleAtpWriteAttributes) MarshalJSON() (buff []byte, e error) {
type MarshalTypeOracleAtpWriteAttributes OracleAtpWriteAttributes
s := struct {
DiscriminatorParam string `json:"modelType"`
MarshalTypeOracleAtpWriteAttributes
}{
"ORACLE_ATP_WRITE_ATTRIBUTE",
(MarshalTypeOracleAtpWriteAttributes)(m),
}
return json.Marshal(&s)
}
// UnmarshalJSON unmarshals from json
func (m *OracleAtpWriteAttributes) 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
}