-
Notifications
You must be signed in to change notification settings - Fork 0
/
api-snapshot-create.go
167 lines (139 loc) · 5.34 KB
/
api-snapshot-create.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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
package azgo
import (
"encoding/xml"
"reflect"
log "github.com/sirupsen/logrus"
)
// SnapshotCreateRequest is a structure to represent a snapshot-create Request ZAPI object
type SnapshotCreateRequest struct {
XMLName xml.Name `xml:"snapshot-create"`
AsyncPtr *bool `xml:"async"`
CommentPtr *string `xml:"comment"`
SnapmirrorLabelPtr *string `xml:"snapmirror-label"`
SnapshotPtr *string `xml:"snapshot"`
VolumePtr *string `xml:"volume"`
}
// SnapshotCreateResponse is a structure to represent a snapshot-create Response ZAPI object
type SnapshotCreateResponse struct {
XMLName xml.Name `xml:"netapp"`
ResponseVersion string `xml:"version,attr"`
ResponseXmlns string `xml:"xmlns,attr"`
Result SnapshotCreateResponseResult `xml:"results"`
}
// NewSnapshotCreateResponse is a factory method for creating new instances of SnapshotCreateResponse objects
func NewSnapshotCreateResponse() *SnapshotCreateResponse {
return &SnapshotCreateResponse{}
}
// String returns a string representation of this object's fields and implements the Stringer interface
func (o SnapshotCreateResponse) String() string {
return ToString(reflect.ValueOf(o))
}
// ToXML converts this object into an xml string representation
func (o *SnapshotCreateResponse) ToXML() (string, error) {
output, err := xml.MarshalIndent(o, " ", " ")
if err != nil {
log.Errorf("error: %v", err)
}
return string(output), err
}
// SnapshotCreateResponseResult is a structure to represent a snapshot-create Response Result ZAPI object
type SnapshotCreateResponseResult struct {
XMLName xml.Name `xml:"results"`
ResultStatusAttr string `xml:"status,attr"`
ResultReasonAttr string `xml:"reason,attr"`
ResultErrnoAttr string `xml:"errno,attr"`
}
// NewSnapshotCreateRequest is a factory method for creating new instances of SnapshotCreateRequest objects
func NewSnapshotCreateRequest() *SnapshotCreateRequest {
return &SnapshotCreateRequest{}
}
// NewSnapshotCreateResponseResult is a factory method for creating new instances of SnapshotCreateResponseResult objects
func NewSnapshotCreateResponseResult() *SnapshotCreateResponseResult {
return &SnapshotCreateResponseResult{}
}
// ToXML converts this object into an xml string representation
func (o *SnapshotCreateRequest) ToXML() (string, error) {
output, err := xml.MarshalIndent(o, " ", " ")
if err != nil {
log.Errorf("error: %v", err)
}
return string(output), err
}
// ToXML converts this object into an xml string representation
func (o *SnapshotCreateResponseResult) ToXML() (string, error) {
output, err := xml.MarshalIndent(o, " ", " ")
if err != nil {
log.Errorf("error: %v", err)
}
return string(output), err
}
// String returns a string representation of this object's fields and implements the Stringer interface
func (o SnapshotCreateRequest) String() string {
return ToString(reflect.ValueOf(o))
}
// String returns a string representation of this object's fields and implements the Stringer interface
func (o SnapshotCreateResponseResult) String() string {
return ToString(reflect.ValueOf(o))
}
// ExecuteUsing converts this object to a ZAPI XML representation and uses the supplied ZapiRunner to send to a filer
func (o *SnapshotCreateRequest) ExecuteUsing(zr *ZapiRunner) (*SnapshotCreateResponse, error) {
return o.executeWithoutIteration(zr)
}
// executeWithoutIteration converts this object to a ZAPI XML representation and uses the supplied ZapiRunner to send to a filer
func (o *SnapshotCreateRequest) executeWithoutIteration(zr *ZapiRunner) (*SnapshotCreateResponse, error) {
result, err := zr.ExecuteUsing(o, "SnapshotCreateRequest", NewSnapshotCreateResponse())
if result == nil {
return nil, err
}
return result.(*SnapshotCreateResponse), err
}
// Async is a 'getter' method
func (o *SnapshotCreateRequest) Async() bool {
r := *o.AsyncPtr
return r
}
// SetAsync is a fluent style 'setter' method that can be chained
func (o *SnapshotCreateRequest) SetAsync(newValue bool) *SnapshotCreateRequest {
o.AsyncPtr = &newValue
return o
}
// Comment is a 'getter' method
func (o *SnapshotCreateRequest) Comment() string {
r := *o.CommentPtr
return r
}
// SetComment is a fluent style 'setter' method that can be chained
func (o *SnapshotCreateRequest) SetComment(newValue string) *SnapshotCreateRequest {
o.CommentPtr = &newValue
return o
}
// SnapmirrorLabel is a 'getter' method
func (o *SnapshotCreateRequest) SnapmirrorLabel() string {
r := *o.SnapmirrorLabelPtr
return r
}
// SetSnapmirrorLabel is a fluent style 'setter' method that can be chained
func (o *SnapshotCreateRequest) SetSnapmirrorLabel(newValue string) *SnapshotCreateRequest {
o.SnapmirrorLabelPtr = &newValue
return o
}
// Snapshot is a 'getter' method
func (o *SnapshotCreateRequest) Snapshot() string {
r := *o.SnapshotPtr
return r
}
// SetSnapshot is a fluent style 'setter' method that can be chained
func (o *SnapshotCreateRequest) SetSnapshot(newValue string) *SnapshotCreateRequest {
o.SnapshotPtr = &newValue
return o
}
// Volume is a 'getter' method
func (o *SnapshotCreateRequest) Volume() string {
r := *o.VolumePtr
return r
}
// SetVolume is a fluent style 'setter' method that can be chained
func (o *SnapshotCreateRequest) SetVolume(newValue string) *SnapshotCreateRequest {
o.VolumePtr = &newValue
return o
}