forked from sfreiberg/gotwilio
-
Notifications
You must be signed in to change notification settings - Fork 0
/
webhooks.go
221 lines (197 loc) · 9.76 KB
/
webhooks.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
package gotwilio
import (
"encoding/json"
"net/url"
"time"
"github.com/gorilla/schema"
)
var formDecoder *schema.Decoder
func init() {
formDecoder = schema.NewDecoder()
formDecoder.SetAliasTag("form")
}
func DecodeWebhook(data url.Values, out interface{}) error {
return formDecoder.Decode(out, data)
}
type InteractionData struct {
Body string `json:"body"`
}
// https://www.twilio.com/docs/proxy/api/proxy-webhooks
// https://www.twilio.com/docs/proxy/api/proxy-webhooks#callbackurl
// These webhooks are fired for each new interaction and are informational only.
type ProxyCallbackWebhook struct {
OutboundResourceStatus string `form:"outboundResourceStatus"`
OutboundResourceType string `form:"outboundResourceType"`
InteractionDateUpdated time.Time `form:"interactionDateUpdated"`
InteractionData string `form:"interactionData"`
InteractionDateCreated time.Time `form:"interactionDateCreated"`
InboundResourceURL string `form:"inboundResourceUrl"`
InteractionServiceSid string `form:"interactionServiceSid"`
OutboundParticipantSid string `form:"outboundParticipantSid"`
InteractionType string `form:"interactionType"`
InteractionAccountSid string `form:"interactionAccountSid"`
InboundParticipantSid string `form:"inboundParticipantSid"`
InboundResourceStatus string `form:"inboundResourceStatus"`
OutboundResourceSid string `form:"outboundResourceSid"`
OutboundResourceURL string `form:"outboundResourceUrl"`
InboundResourceType string `form:"inboundResourceType"`
InboundResourceSid string `form:"inboundResourceSid"`
InteractionSessionSid string `form:"interactionSessionSid"`
InteractionSid string `form:"interactionSid"`
}
func (p ProxyCallbackWebhook) GetInteractionData() (InteractionData, error) {
var out InteractionData
err := json.Unmarshal([]byte(p.InteractionData), &out)
return out, err
}
// https://www.twilio.com/docs/proxy/api/proxy-webhooks#interceptcallbackurl
// Fires on each interaction. If responded to with a 403 to this webhook we
// will abort/block the interaction. Any other status or timeout the interaction continues
type ProxyInterceptCallbackWebhook struct {
InteractionDateUpdated time.Time `form:"interactionDateUpdated"`
InteractionData string `form:"interactionData"`
InteractionDateCreated time.Time `form:"interactionDateCreated"`
InboundResourceURL string `form:"inboundResourceUrl"`
InteractionServiceSid string `form:"interactionServiceSid"`
InteractionType string `form:"interactionType"`
InteractionAccountSid string `form:"interactionAccountSid"`
InboundParticipantSid string `form:"inboundParticipantSid"`
InboundResourceStatus string `form:"inboundResourceStatus"`
InboundResourceType string `form:"inboundResourceType"`
InboundResourceSid string `form:"inboundResourceSid"`
InteractionSessionSid string `form:"interactionSessionSid"`
InteractionSid string `form:"interactionSid"`
}
func (p ProxyInterceptCallbackWebhook) GetInteractionData() (InteractionData, error) {
var out InteractionData
err := json.Unmarshal([]byte(p.InteractionData), &out)
return out, err
}
// https://www.twilio.com/docs/proxy/api/proxy-webhooks#outofsessioncallbackurl
// A URL to send webhooks to when an action (inbound call or SMS) occurs where
// there is no session or a closed session. If your server (or a Twilio function)
// responds with valid TwiML, this will be processed.
// This means it is possible to e.g. play a message for a call, send an automated
// text message response, or redirect a call to another number.
type ProxyOutOfSessionCallbackWebhook struct {
AccountSid string `form:"AccountSid"`
SessionUniqueName string `form:"sessionUniqueName"`
SessionAccountSid string `form:"sessionAccountSid"`
SessionServiceSid string `form:"sessionServiceSid"`
SessionSid string `form:"sessionSid"`
SessionStatus string `form:"sessionStatus"`
SessionMode string `form:"sessionMode"`
SessionDateCreated time.Time `form:"sessionDateCreated"`
SessionDateStarted time.Time `form:"sessionDateStarted"`
SessionDateUpdated time.Time `form:"sessionDateUpdated"`
SessionDateEnded time.Time `form:"sessionDateEnded"`
SessionDateLastInteraction time.Time `form:"sessionDateLastInteraction"`
SessionClosedReason string `form:"sessionClosedReason"`
TTL string `form:"ttl"`
// SMS Specific
Body string `form:"Body"`
SmsSid string `form:"SmsSid"`
MessageSid string `form:"MessageSid"`
NumMedia string `form:"NumMedia"`
NumSegments string `form:"NumSegments"`
SmsStatus string `form:"SmsStatus"`
SmsMessageSid string `form:"SmsMessageSid"`
To string `form:"To"`
ToCity string `form:"ToCity"`
ToState string `form:"ToState"`
ToZip string `form:"ToZip"`
ToCountry string `form:"ToCountry"`
From string `form:"From"`
FromCity string `form:"FromCity"`
FromState string `form:"FromState"`
FromZip string `form:"FromZip"`
FromCountry string `form:"FromCountry"`
InboundParticipantSid string `form:"inboundParticipantSid"`
InboundParticipantIdentifier string `form:"inboundParticipantIdentifier"`
InboundParticipantFriendlyName string `form:"inboundParticipantFriendlyName"`
InboundParticipantProxyIdentifier string `form:"inboundParticipantProxyIdentifier"`
InboundParticipantProxyIdentifierSid string `form:"inboundParticipantProxyIdentifierSid"`
InboundParticipantAccountSid string `form:"inboundParticipantAccountSid"`
InboundParticipantServiceSid string `form:"inboundParticipantServiceSid"`
InboundParticipantSessionSid string `form:"inboundParticipantSessionSid"`
InboundParticipantDateCreated time.Time `form:"inboundParticipantDateCreated"`
InboundParticipantDateUpdated time.Time `form:"inboundParticipantDateUpdated"`
OutboundParticipantSid string `form:"outboundParticipantSid"`
OutboundParticipantIdentifier string `form:"outboundParticipantIdentifier"`
OutboundParticipantFriendlyName string `form:"outboundParticipantFriendlyName"`
OutboundParticipantProxyIdentifier string `form:"outboundParticipantProxyIdentifier"`
OutboundParticipantProxyIdentifierSid string `form:"outboundParticipantProxyIdentifierSid"`
OutboundParticipantAccountSid string `form:"outboundParticipantAccountSid"`
OutboundParticipantServiceSid string `form:"outboundParticipantServiceSid"`
OutboundParticipantSessionSid string `form:"outboundParticipantSessionSid"`
OutboundParticipantDateCreated time.Time `form:"outboundParticipantDateCreated"`
OutboundParticipantDateUpdated time.Time `form:"outboundParticipantDateUpdated"`
CallSid string `form:"CallSid"`
CallStatus string `form:"CallStatus"`
Caller string `form:"Caller"`
CallerCity string `form:"CallerCity"`
CallerState string `form:"CallerState"`
CallerZip string `form:"CallerZip"`
CallerCountry string `form:"CallerCountry"`
Called string `form:"Called"`
CalledCity string `form:"CalledCity"`
CalledState string `form:"CalledState"`
CalledZip string `form:"CalledZip"`
CalledCountry string `form:"CalledCountry"`
Direction string `form:"Direction"`
AddOns string `form:"AddOns"`
APIVersion string `form:"ApiVersion"`
}
// https://www.twilio.com/docs/sms/twiml#request-parameters
// SMS webhooks received from inbound SMS messages. If your
// server (or a Twilio function) responds with valid TwiML,
// this will be processed.
// This means it is possible to send an automated text
// message response back.
type SMSWebhook struct {
AccountSid string `json:"AccountSid"`
APIVersion string `json:"ApiVersion"`
// SMS Specific
Body string `json:"Body"`
SmsSid string `json:"SmsSid"`
MessageSid string `json:"MessageSid"`
NumMedia string `json:"NumMedia"`
NumSegments string `json:"NumSegments"`
SmsStatus string `json:"SmsStatus"`
SmsMessageSid string `json:"SmsMessageSid"`
To string `json:"To"`
ToCity string `json:"ToCity"`
ToState string `json:"ToState"`
ToZip string `json:"ToZip"`
ToCountry string `json:"ToCountry"`
From string `json:"From"`
FromCity string `json:"FromCity"`
FromState string `json:"FromState"`
FromZip string `json:"FromZip"`
FromCountry string `json:"FromCountry"`
// The ContentTypes for the Media stored at MediaUrl{N}.
// The order of MediaContentType{N} matches the order of MediaUrl{N}
// Let's define 10 items to be safe
MediaContentType0 string `json:"MediaContentType0"`
MediaUrl0 string `json:"MediaUrl0"`
MediaContentType1 string `json:"MediaContentType1"`
MediaUrl1 string `json:"MediaUrl1"`
MediaContentType2 string `json:"MediaContentType2"`
MediaUrl2 string `json:"MediaUrl2"`
MediaContentType3 string `json:"MediaContentType3"`
MediaUrl3 string `json:"MediaUrl3"`
MediaContentType4 string `json:"MediaContentType4"`
MediaUrl4 string `json:"MediaUrl4"`
MediaContentType5 string `json:"MediaContentType5"`
MediaUrl5 string `json:"MediaUrl5"`
MediaContentType6 string `json:"MediaContentType6"`
MediaUrl6 string `json:"MediaUrl6"`
MediaContentType7 string `json:"MediaContentType7"`
MediaUrl7 string `json:"MediaUrl7"`
MediaContentType8 string `json:"MediaContentType8"`
MediaUrl8 string `json:"MediaUrl8"`
MediaContentType9 string `json:"MediaContentType9"`
MediaUrl9 string `json:"MediaUrl9"`
MediaContentType10 string `json:"MediaContentType10"`
MediaUrl10 string `json:"MediaUrl10"`
}