-
Notifications
You must be signed in to change notification settings - Fork 12
/
socialexpression.go
223 lines (131 loc) · 6.16 KB
/
socialexpression.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
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
package platformclientv2
import (
"time"
"github.com/leekchan/timeutil"
"encoding/json"
"strconv"
"strings"
)
// Socialexpression
type Socialexpression struct {
// State - The connection state of this communication.
State *string `json:"state,omitempty"`
// Id - A globally unique identifier for this communication.
Id *string `json:"id,omitempty"`
// SocialMediaId - A globally unique identifier for the social media.
SocialMediaId *string `json:"socialMediaId,omitempty"`
// SocialMediaHub - The social network of the communication
SocialMediaHub *string `json:"socialMediaHub,omitempty"`
// SocialUserName - The user name for the communication.
SocialUserName *string `json:"socialUserName,omitempty"`
// PreviewText - The text preview of the communication contents
PreviewText *string `json:"previewText,omitempty"`
// RecordingId - A globally unique identifier for the recording associated with this chat.
RecordingId *string `json:"recordingId,omitempty"`
// Segments - The time line of the participant's chat, divided into activity segments.
Segments *[]Segment `json:"segments,omitempty"`
// Held - True if this call is held and the person on this side hears silence.
Held *bool `json:"held,omitempty"`
// DisconnectType - System defined string indicating what caused the communication to disconnect. Will be null until the communication disconnects.
DisconnectType *string `json:"disconnectType,omitempty"`
// StartHoldTime - The timestamp the chat was placed on hold in the cloud clock if the chat is currently on hold. Date time is represented as an ISO-8601 string. For example: yyyy-MM-ddTHH:mm:ss[.mmm]Z
StartHoldTime *time.Time `json:"startHoldTime,omitempty"`
// StartAlertingTime - The timestamp the communication has when it is first put into an alerting state. Date time is represented as an ISO-8601 string. For example: yyyy-MM-ddTHH:mm:ss[.mmm]Z
StartAlertingTime *time.Time `json:"startAlertingTime,omitempty"`
// ConnectedTime - The timestamp when this communication was connected in the cloud clock. Date time is represented as an ISO-8601 string. For example: yyyy-MM-ddTHH:mm:ss[.mmm]Z
ConnectedTime *time.Time `json:"connectedTime,omitempty"`
// DisconnectedTime - The timestamp when this communication disconnected from the conversation in the provider clock. Date time is represented as an ISO-8601 string. For example: yyyy-MM-ddTHH:mm:ss[.mmm]Z
DisconnectedTime *time.Time `json:"disconnectedTime,omitempty"`
// Provider - The source provider for the social expression.
Provider *string `json:"provider,omitempty"`
// ScriptId - The UUID of the script to use.
ScriptId *string `json:"scriptId,omitempty"`
// PeerId - The id of the peer communication corresponding to a matching leg for this communication.
PeerId *string `json:"peerId,omitempty"`
// Wrapup - Call wrap up or disposition data.
Wrapup *Wrapup `json:"wrapup,omitempty"`
// AfterCallWork - After-call work for the communication.
AfterCallWork *Aftercallwork `json:"afterCallWork,omitempty"`
// AfterCallWorkRequired - Indicates if after-call work is required for a communication. Only used when the ACW Setting is Agent Requested.
AfterCallWorkRequired *bool `json:"afterCallWorkRequired,omitempty"`
}
func (u *Socialexpression) MarshalJSON() ([]byte, error) {
// Redundant initialization to avoid unused import errors for models with no Time values
_ = timeutil.Timedelta{}
type Alias Socialexpression
StartHoldTime := new(string)
if u.StartHoldTime != nil {
*StartHoldTime = timeutil.Strftime(u.StartHoldTime, "%Y-%m-%dT%H:%M:%S.%fZ")
} else {
StartHoldTime = nil
}
StartAlertingTime := new(string)
if u.StartAlertingTime != nil {
*StartAlertingTime = timeutil.Strftime(u.StartAlertingTime, "%Y-%m-%dT%H:%M:%S.%fZ")
} else {
StartAlertingTime = nil
}
ConnectedTime := new(string)
if u.ConnectedTime != nil {
*ConnectedTime = timeutil.Strftime(u.ConnectedTime, "%Y-%m-%dT%H:%M:%S.%fZ")
} else {
ConnectedTime = nil
}
DisconnectedTime := new(string)
if u.DisconnectedTime != nil {
*DisconnectedTime = timeutil.Strftime(u.DisconnectedTime, "%Y-%m-%dT%H:%M:%S.%fZ")
} else {
DisconnectedTime = nil
}
return json.Marshal(&struct {
State *string `json:"state,omitempty"`
Id *string `json:"id,omitempty"`
SocialMediaId *string `json:"socialMediaId,omitempty"`
SocialMediaHub *string `json:"socialMediaHub,omitempty"`
SocialUserName *string `json:"socialUserName,omitempty"`
PreviewText *string `json:"previewText,omitempty"`
RecordingId *string `json:"recordingId,omitempty"`
Segments *[]Segment `json:"segments,omitempty"`
Held *bool `json:"held,omitempty"`
DisconnectType *string `json:"disconnectType,omitempty"`
StartHoldTime *string `json:"startHoldTime,omitempty"`
StartAlertingTime *string `json:"startAlertingTime,omitempty"`
ConnectedTime *string `json:"connectedTime,omitempty"`
DisconnectedTime *string `json:"disconnectedTime,omitempty"`
Provider *string `json:"provider,omitempty"`
ScriptId *string `json:"scriptId,omitempty"`
PeerId *string `json:"peerId,omitempty"`
Wrapup *Wrapup `json:"wrapup,omitempty"`
AfterCallWork *Aftercallwork `json:"afterCallWork,omitempty"`
AfterCallWorkRequired *bool `json:"afterCallWorkRequired,omitempty"`
*Alias
}{
State: u.State,
Id: u.Id,
SocialMediaId: u.SocialMediaId,
SocialMediaHub: u.SocialMediaHub,
SocialUserName: u.SocialUserName,
PreviewText: u.PreviewText,
RecordingId: u.RecordingId,
Segments: u.Segments,
Held: u.Held,
DisconnectType: u.DisconnectType,
StartHoldTime: StartHoldTime,
StartAlertingTime: StartAlertingTime,
ConnectedTime: ConnectedTime,
DisconnectedTime: DisconnectedTime,
Provider: u.Provider,
ScriptId: u.ScriptId,
PeerId: u.PeerId,
Wrapup: u.Wrapup,
AfterCallWork: u.AfterCallWork,
AfterCallWorkRequired: u.AfterCallWorkRequired,
Alias: (*Alias)(u),
})
}
// String returns a JSON representation of the model
func (o *Socialexpression) String() string {
j, _ := json.Marshal(o)
str, _ := strconv.Unquote(strings.Replace(strconv.Quote(string(j)), `\\u`, `\u`, -1))
return str
}