-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathretention_flow_reason.go
139 lines (107 loc) · 3.11 KB
/
retention_flow_reason.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
// Code generated by go-swagger; DO NOT EDIT.
package models
// This file was generated by the swagger tool.
// Editing this file might prove futile when you re-run the swagger generate command
import (
"context"
"github.com/go-openapi/errors"
"github.com/go-openapi/strfmt"
"github.com/go-openapi/swag"
)
// RetentionFlowReason Retention Flow Reason
//
// swagger:model RetentionFlowReason
type RetentionFlowReason struct {
Entity
// The FID of the product or product group this applies to
AppliesToFid string `json:"appliesToFid,omitempty"`
// the key to pass through when starting a cancel flow
Key string `json:"key,omitempty"`
// The text displayed to an agent or customer
Reason string `json:"reason,omitempty"`
}
// UnmarshalJSON unmarshals this object from a JSON structure
func (m *RetentionFlowReason) UnmarshalJSON(raw []byte) error {
// AO0
var aO0 Entity
if err := swag.ReadJSON(raw, &aO0); err != nil {
return err
}
m.Entity = aO0
// AO1
var dataAO1 struct {
AppliesToFid string `json:"appliesToFid,omitempty"`
Key string `json:"key,omitempty"`
Reason string `json:"reason,omitempty"`
}
if err := swag.ReadJSON(raw, &dataAO1); err != nil {
return err
}
m.AppliesToFid = dataAO1.AppliesToFid
m.Key = dataAO1.Key
m.Reason = dataAO1.Reason
return nil
}
// MarshalJSON marshals this object to a JSON structure
func (m RetentionFlowReason) MarshalJSON() ([]byte, error) {
_parts := make([][]byte, 0, 2)
aO0, err := swag.WriteJSON(m.Entity)
if err != nil {
return nil, err
}
_parts = append(_parts, aO0)
var dataAO1 struct {
AppliesToFid string `json:"appliesToFid,omitempty"`
Key string `json:"key,omitempty"`
Reason string `json:"reason,omitempty"`
}
dataAO1.AppliesToFid = m.AppliesToFid
dataAO1.Key = m.Key
dataAO1.Reason = m.Reason
jsonDataAO1, errAO1 := swag.WriteJSON(dataAO1)
if errAO1 != nil {
return nil, errAO1
}
_parts = append(_parts, jsonDataAO1)
return swag.ConcatJSON(_parts...), nil
}
// Validate validates this retention flow reason
func (m *RetentionFlowReason) Validate(formats strfmt.Registry) error {
var res []error
// validation for a type composition with Entity
if err := m.Entity.Validate(formats); err != nil {
res = append(res, err)
}
if len(res) > 0 {
return errors.CompositeValidationError(res...)
}
return nil
}
// ContextValidate validate this retention flow reason based on the context it is used
func (m *RetentionFlowReason) ContextValidate(ctx context.Context, formats strfmt.Registry) error {
var res []error
// validation for a type composition with Entity
if err := m.Entity.ContextValidate(ctx, formats); err != nil {
res = append(res, err)
}
if len(res) > 0 {
return errors.CompositeValidationError(res...)
}
return nil
}
// MarshalBinary interface implementation
func (m *RetentionFlowReason) MarshalBinary() ([]byte, error) {
if m == nil {
return nil, nil
}
return swag.WriteJSON(m)
}
// UnmarshalBinary interface implementation
func (m *RetentionFlowReason) UnmarshalBinary(b []byte) error {
var res RetentionFlowReason
if err := swag.ReadJSON(b, &res); err != nil {
return err
}
*m = res
return nil
}