Documentation ¶
Overview ¶
Package twiml provides Twilio Markup Language support for building web services with instructions for twilio how to handle incoming call or message.
Index ¶
- Constants
- Variables
- func AllowedCallbackEvent(events string, callbackValidator *regexp.Regexp) bool
- func AllowedLanguage(speaker string, language string) bool
- func AllowedMethod(field string) bool
- func Bind(cbRequest interface{}, r *http.Request) error
- func IntBetween(field int, high int, low int) bool
- func Numeric(field string) bool
- func NumericOpt(field string) bool
- func NumericOrWait(field string) bool
- func OneOf(field string, options ...string) bool
- func OneOfOpt(field string, options ...string) bool
- func Required(field string) bool
- func Validate(vf ...bool) bool
- type Client
- type Conference
- type Dial
- type DialActionRequest
- type Enqueue
- type Gather
- type Hangup
- type Leave
- type Markup
- type Number
- type Parameter
- type Pause
- type Play
- type Queue
- type Record
- type RecordActionRequest
- type RecordingStatusCallbackRequest
- type Redirect
- type Reject
- type Response
- type Say
- type Sip
- type Sms
- type TranscribeCallbackRequest
- type ValidationError
- type VoiceRequest
Constants ¶
const ( Man = "man" Woman = "woman" Alice = "alice" English = "en" French = "fr" Spanish = "es" German = "de" DanishDenmark = "da-DK" GermanGermany = "de-DE" EnglishAustralia = "en-AU" EnglishCanada = "en-CA" EnglishUK = "en-UK" EnglishIndia = "en-IN" EnglishUSA = "en-US" SpanishCatalan = "ca-ES" SpanishSpain = "es-ES" SpanishMexico = "es-MX" FinishFinland = "fi-FI" FrenchCanada = "fr-CA" FrenchFrance = "fr-FR" ItalianItaly = "it-IT" JapaneseJapan = "ja-JP" KoreanKorea = "ko-KR" NorwegianNorway = "nb-NO" DutchNetherlands = "nl-NL" PolishPoland = "pl-PL" PortugueseBrazil = "pt-BR" PortuguesePortugal = "pt-PT" RussianRussia = "ru-RU" SwedishSweden = "sv-SE" ChineseMandarin = "zh-CH" ChineseCantonese = "zh-HK" ChineseTaiwanese = "zh-TW" )
Language and speaker options
const ( Queued = "queued" Ringing = "ringing" InProgress = "in-progress" Completed = "completed" Busy = "busy" Failed = "failed" NoAnswer = "no-answer" Canceled = "canceled" )
Call status
const ( OutboundAPI = "outbound-api" Inbound = "inbound" OutboundDial = "outbound-dial" )
Call directions
const ( TrimSilence = "trim-silence" DoNotTrim = "do-not-trim" )
Trim options
Variables ¶
var ( // callback events valid for Sip TwiML block SipCallbackEvents = constructCallbackEventValidator([]string{"initiated", "ringing", "answered", "completed"}) // callback events valid for Conference TwiML block ConferenceCallbackEvents = constructCallbackEventValidator([]string{"start", "end", "join", "leave", "mute", "hold", "speaker"}) )
Functions ¶
func AllowedCallbackEvent ¶
AllowedCallbackEvent validates that the CallbackEvent is one of the allowed options
func AllowedLanguage ¶
AllowedLanguage validates that the combination of speaker and language is allowable
func AllowedMethod ¶
AllowedMethod validates that a method is either of type GET or POST (or empty string to default)
func Bind ¶
Bind will marshal a callback request from the Twilio API into the cbRequest struct provided
func IntBetween ¶
IntBetween validates that a field is an integer between high and low
func NumericOpt ¶
NumericOpt validates that the field is numeric or empty string (for optional fields)
func NumericOrWait ¶
NumericOrWait validates that a string contains only digits 0-9 or the wait key 'w'
func OneOfOpt ¶
OneOfOpt validates that a field is one of the options provided or the empty string (for optional fields)
Types ¶
type Client ¶
type Client struct { XMLName xml.Name `xml:"Client"` Name string `xml:",chardata"` Identity string `xml:"Identity,omitempty"` // same as name Method string `xml:"method,attr,omitempty"` URL string `xml:"url,attr,omitempty"` StatusCallback string `xml:"statusCallback,attr,omitempty"` StatusCallbackEvent string `xml:"statusCallbackEvent,attr,omitempty"` StatusCallbackMethod string `xml:"statusCallbackMethod,attr,omitempty"` Children []Markup `xml:",omitempty"` }
Twilio Client TwiML
type Conference ¶
type Conference struct { XMLName xml.Name `xml:"Conference"` ConferenceName string `xml:",chardata"` Muted bool `xml:"muted,attr,omitempty"` Beep string `xml:"beep,attr,omitempty"` StartConferenceOnEnter bool `xml:"startConferenceOnEnter,attr,omitempty"` EndConferenceOnExit bool `xml:"endConferenceOnExit,attr,omitempty"` WaitURL string `xml:"waitUrl,attr,omitempty"` WaitMethod string `xml:"waitMethod,attr,omitempty"` MaxParticipants int `xml:"maxParticipants,attr,omitempty"` Record string `xml:"record,attr,omitempty"` Region string `xml:"region,attr,omitempty"` Trim string `xml:"trim,attr,omitempty"` Coach string `xml:"coach,attr,omitempty"` StatusCallbackEvent string `xml:"statusCallbackEvent,attr,omitempty"` StatusCallback string `xml:"statusCallback,attr,omitempty"` StatusCallbackMethod string `xml:"statusCallbackMethod,attr,omitempty"` RecordingStatusCallback string `xml:"recordingStatusCallback,attr,omitempty"` RecordingStatusCallbackMethod string `xml:"recordingStatusCallbackMethod,attr,omitempty"` RecordingStatusCallbackEvent string `xml:"recordingStatusCallbackEvent,attr,omitempty"` EventCallbackURL string `xml:"eventCallbackUrl,attr,omitempty"` }
Conference TwiML
func (*Conference) Validate ¶
func (c *Conference) Validate() error
Validate returns an error if the TwiML is constructed improperly
type Dial ¶
type Dial struct { XMLName xml.Name `xml:"Dial"` Action string `xml:"action,attr,omitempty"` AnswerOnBridge bool `xml:"answerOnBridge,attr,omitempty"` CallerID string `xml:"callerId,attr,omitempty"` HangupOnStar bool `xml:"hangupOnStar,attr,omitempty"` Method string `xml:"method,attr,omitempty"` Record string `xml:"record,attr,omitempty"` RecordingStatusCallback string `xml:"recordingStatusCallback,attr,omitempty"` RecordingStatusCallbackMethod string `xml:"recordingStatusCallbackMethod,attr,omitempty"` RecordingStatusCallbackEvent string `xml:"recordingStatusCallbackEvent,attr,omitempty"` RingTone string `xml:"ringTone,attr,omitempty"` Timeout int `xml:"timeout,attr,omitempty"` TimeLimit int `xml:"timeLimit,attr,omitempty"` Trim string `xml:"trim,attr,omitempty"` Number string `xml:",chardata"` Children []Markup `xml:",omitempty"` }
Dial TwiML
type DialActionRequest ¶
type DialActionRequest struct { VoiceRequest DialCallStatus string DialCallSid string DialCallDuration int RecordingURL string `schema:"RecordingUrl"` QueueSid string DequeueResult string DequeuedCallSid string DequeuedCallQueueTime int DequeuedCallDuration int }
DialActionRequest represents a request as a result of declaring an `action` URL on the Dial verb
type Enqueue ¶
type Enqueue struct { XMLName xml.Name `xml:"Enqueue"` Action string `xml:"action,attr,omitempty"` Method string `xml:"method,attr,omitempty"` WaitURL string `xml:"waitUrl,attr,omitempty"` WaitURLMethod string `xml:"waitUrlMethod,attr,omitempty"` WorkflowSid string `xml:"workflowSid,attr,omitempty"` QueueName string `xml:",chardata"` }
Enqueue TwiML
type Gather ¶
type Gather struct { XMLName xml.Name `xml:"Gather"` Action string `xml:"action,attr,omitempty"` Method string `xml:"method,attr,omitempty"` Timeout int `xml:"timeout,attr,omitempty"` FinishOnKey string `xml:"finishOnKey,attr,omitempty"` NumDigits int `xml:"numDigits,attr,omitempty"` Input string `xml:"input,attr,omitempty"` Hints string `xml:"hints,attr,omitempty"` PartialResultCallback string `xml:"partialResultCallback,attr,omitempty"` Language string `xml:"language,attr,omitempty"` ProfanityFilter bool `xml:"profanityFilter,attr,omitempty"` SpeechTimeout int `xml:"speechTimeout,attr,omitempty"` Children []Markup `valid:"-"` }
Gather TwiML
type Markup ¶
type Markup interface { // Type returns the TwiML verb name for use in pattern-matching Type() string // Validate will verify that TwiML responses are properly constructed of allowed options for all fields Validate() error }
Markup interface is satisfied by valid TwiML verbs.
type Number ¶
type Number struct { XMLName xml.Name `xml:"Number"` SendDigits string `xml:"sendDigits,attr,omitempty"` URL string `xml:"url,attr,omitempty"` Method string `xml:"method,attr,omitempty"` Number string `xml:",chardata"` }
Number TwiML
type Parameter ¶ added in v1.1.3
type Parameter struct { XMLName xml.Name `xml:"Parameter"` Name string `xml:"name,attr,omitempty"` Value string `xml:"value,attr,omitempty"` }
Twilio Client Parameter TwiML
type Play ¶
type Play struct { XMLName xml.Name `xml:"Play"` Loop int `xml:"loop,attr,omitempty"` Digits string `xml:"digits,attr,omitempty"` URL string `xml:",chardata"` }
Play TwiML
type Queue ¶
type Queue struct { XMLName xml.Name `xml:"Queue"` URL string `xml:"url,attr,omitempty"` Method string `xml:"method,attr,omitempty"` ReservationSid string `xml:"reservationSid,attr,omitempty"` PostWorkActivitySid string `xml:"postWorkActivitySid,attr,omitempty"` Name string `xml:",chardata"` }
Queue TwiML
type Record ¶
type Record struct { XMLName xml.Name `xml:"Record"` Action string `xml:"action,attr,omitempty"` Method string `xml:"method,attr,omitempty"` Timeout int `xml:"timeout,attr,omitempty"` FinishOnKey string `xml:"finishOnKey,attr,omitempty"` MaxLength int `xml:"maxLength,attr,omitempty"` PlayBeep bool `xml:"playBeep,attr,omitempty"` Trim string `xml:"trim,attr,omitempty"` RecordingStatusCallback string `xml:"recordingStatusCallback,attr,omitempty"` RecordingStatusCallbackMethod string `xml:"recordingStatusCallbackMethod,attr,omitempty"` Transcribe bool `xml:"transcribe,attr,omitempty"` TranscribeCallback string `xml:"transcribeCallback,attr,omitempty"` }
Record TwiML
type RecordActionRequest ¶
type RecordActionRequest struct { VoiceRequest RecordingURL string `schema:"RecordingUrl"` RecordingDuration int Digits string }
RecordActionRequest represents a request as a result of declaring an `action` URL on a Record verb
type RecordingStatusCallbackRequest ¶
type RecordingStatusCallbackRequest struct { AccountSid string CallSid string RecordingSid string RecordingURL string `schema:"RecordingUrl"` RecordingStatus string RecordingDuration int RecordingChannels int RecordingSource string }
RecordingStatusCallbackRequest represents a request as a result of declaring a `recordingStatusCallback` on a Record verb
type Redirect ¶
type Redirect struct { XMLName xml.Name `xml:"Redirect"` Method string `xml:"method,attr,omitempty"` URL string `xml:",chardata"` }
Redirect TwiML
type Response ¶
type Response struct { XMLName xml.Name `xml:"Response"` IgnoreValidationErrors bool `xml:"-"` Children []Markup }
Response container for other TwiML verbs
func NewResponse ¶
func NewResponse() *Response
NewResponse creates new response container. Use Add() to chain together the response from allowed verbs.
func (*Response) Add ¶
Add appends TwiML verb structs to response. Valid verbs: Enqueue, Say, Leave, Message, Pause, Play, Record, Redirect, Reject, Hangup
func (*Response) Encode ¶
Encode returns an XML encoded response or a ValidationError if any markup fails validation.
type Say ¶
type Say struct { XMLName xml.Name `xml:"Say"` Voice string `xml:"voice,attr,omitempty"` Language string `xml:"language,attr,omitempty"` Loop int `xml:"loop,attr,omitempty"` Text string `xml:",chardata"` }
Say TwiML
type Sip ¶
type Sip struct { XMLName xml.Name `xml:"Sip"` Username string `xml:"username,attr,omitempty"` Password string `xml:"password,attr,omitempty"` URL string `xml:"url,attr,omitempty"` Method string `xml:"method,attr,omitempty"` StatusCallbackEvent string `xml:"statusCallbackEvent,attr,omitempty"` StatusCallback string `xml:"statusCallback,attr,omitempty"` StatusCallbackMethod string `xml:"statusCallbackMethod,attr,omitempty"` Address string `xml:",chardata"` }
Sip TwiML
type Sms ¶
type Sms struct { XMLName xml.Name `xml:"Message"` To string `xml:"to,attr,omitempty"` From string `xml:"from,attr,omitempty"` Action string `xml:"action,attr,omitempty"` Method string `xml:"method,attr,omitempty"` StatusCallback string `xml:"statusCallback,attr,omitempty"` Text string `xml:",chardata"` }
Sms TwiML sends an SMS message. Text is required. See the Twilio docs for an explanation of the default values of to and from.
type TranscribeCallbackRequest ¶
type TranscribeCallbackRequest struct { TranscriptionSid string TranscriptionText string TranscriptionStatus string TranscriptionURL string `schema:"TranscriptionUrl"` RecordingSid string RecordingURL string `schema:"RecordingUrl"` CallSid string AccountSid string From string To string CallStatus string APIVersion string `schema:"ApiVersion"` Direction string ForwardedFrom string }
TranscribeCallbackRequest represents a request as a result of declaring a `transcribeCallback` on a Record verb
type ValidationError ¶
type ValidationError struct {
Errors []error
}
ValidationError will return one or more errors encountered during validation
func (ValidationError) Error ¶
func (v ValidationError) Error() string
Error() returns a custom string representation of all errors encountered during validation
type VoiceRequest ¶
type VoiceRequest struct { CallSid string AccountSid string From string To string CallStatus string APIVersion string `schema:"ApiVersion"` Direction string ForwardedFrom string CallerName string FromCity string FromState string FromZip string FromCountry string ToCity string ToState string ToZip string ToCountry string }
VoiceRequest represents the standard request format for callbacks received from the Twilio API. This struct is embedded in other callback requests that return this common data format.