openapi: 3.1.0
info:
title: Voice API | Sinch
version: '1.0.1'
license:
name: MIT
url: "https://www.sinch.com/toc"
contact:
name: Support
url: www.sinch.com
email: "support@sinch.com"
description: "The Voice API exposes calling- and conference-related functionality in the Sinch Voice Platform."
servers:
- url: https://calling.api.sinch.com
description: redirected by Sinch to an appropriate region
- url: https://calling-use1.api.sinch.com
description: United States
- url: https://calling-euc1.api.sinch.com
description: Europe
- url: https://calling-sae1.api.sinch.com
description: South America
- url: https://calling-apse1.api.sinch.com
description: Southeast Asia 1
- url: https://calling-apse2.api.sinch.com
description: Southeast Asia 2
# x-explorer-enabled: false
# x-samples-enabled: true
# x-samples-languages:
# - curl
# - java
# - csharp
# - node
security:
- Basic: []
- Application: []
webhooks:
ice:
post:
operationId: ice
summary: Incoming Call Event
tags:
- Callbacks
description: |-
When a call reaches the Sinch platform, the system makes a POST request to the specified calling callback URL.
This event, called the **ICE** event, can be triggered by either an incoming data call or an incoming PSTN call. Look here for allowed [instructions](/docs/voice/api-reference/svaml/instructions) and [actions](/docs/voice/api-reference/svaml/actions).
If there is no response to the callback within the timeout period, an error message is played, and the call is disconnected.
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/iceRequest"
examples:
IceExample:
$ref: "#/components/examples/ICEexample"
responses:
"200":
description: |-
The Incoming Call Event (ICE) requires a valid SVAML object in response.
content:
application/json:
schema:
$ref: "#/components/schemas/SVAMLRequestBody"
examples:
sayExample:
$ref: "#/components/examples/IceSayResponse"
ace:
post:
operationId: ace
summary: Answered Call Event
tags:
- Callbacks
description: |-
This callback is made when the call is picked up by the callee (person receiving the call). It's a POST request to the specified calling callback URL. Look here for allowed [instructions](/docs/voice/api-reference/svaml/instructions) and [actions](/docs/voice/api-reference/svaml/actions).
If there is no response to the callback within the timeout period, the call is connected.
If you have [Answering Machine Detection](/docs/voice/api-reference/amd_v2) (AMD) enabled, the `amd` object will also be present on ACE callbacks.
Note: ACE Callbacks are not issued for InApp Calls (`destination:` `username`), only PSTN and SIP calls.
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/aceRequest"
responses:
"200":
description: The Answered Call Event (ACE) requires a valid SVAML object in response.
content:
application/json:
schema:
$ref: "#/components/schemas/SVAMLRequestBody"
examples:
hangup:
$ref: "#/components/examples/AceHangupResponse"
runMenu:
$ref: "#/components/examples/AcePlayMenuResponse"
dice:
post:
operationId: dice
summary: Disconnected Call Event
tags:
- Callbacks
description: |-
This callback is made when the call is disconnected. It's a POST request to the specified calling callback URL. This event doesn't support instructions and only supports the [hangup](/docs/voice/api-reference/svaml/actions/#hangup) action.
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/diceRequest"
examples:
DiceExample:
$ref: "#/components/examples/DICEexample"
responses:
"200":
description: Return a 200 status to indicate that the data was received successfully
pie:
post:
operationId: pie
summary: Prompt Input Event
tags:
- Callbacks
description: |-
This callback is triggered as a result of a [runMenu](/docs/voice/api-reference/svaml/actions/#runmenu) action. It can be triggered from either a user pressing a number of DTMF digits, or by the `return` command.
It's a POST request to the specified calling callback URL. Your application can respond with [SVAML](/docs/voice/api-reference/svaml/) logic.
Note: PIE callbacks are not issued for DATA Calls, only PSTN and SIP calls.
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/pieRequest"
examples:
PieExample:
$ref: "#/components/examples/PIEexample"
responses:
"200":
description: Return a 200 status to indicate that the data was received successfully
notify:
post:
operationId: notify
summary: Notification Event
tags:
- Callbacks
description: |-
This is the general callback used to send notifications. It's a POST request to the specified calling callback URL.
If there is no response to the callback within the timeout period, the notification is discarded.
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/notifyRequest"
examples:
notifyRecFinishExample:
$ref: "#/components/examples/NotifyRecordingFinishedExample"
notifyRecAvailableExample:
$ref: "#/components/examples/NotifyRecordingAvailableExample"
responses:
"200":
description: Return a 200 status to indicate that the data was received successfully
paths:
/calling/v1/callouts:
post:
tags:
- Callouts
- Conferences
description: Makes a call out to a phone number. The types of callouts currently supported are conference callouts, text-to-speech callouts, and custom callouts. The custom callout is the most flexible, but text-to-speech and conference callouts are more convenient.
summary: Callout Request
operationId: Callouts
requestBody:
$ref: '#/components/requestBodies/calloutRequest'
responses:
'200':
description: A success response, or an [Error](/docs/voice/api-reference/errors/).
content:
application/json:
schema:
$ref: "#/components/schemas/getCalloutResponseObj"
example:
callId: adf92089-df2a-4f14-a377-1e975f588fe4
/calling/v1/calls/id/{callId}:
parameters:
- $ref: '#/components/parameters/callId'
patch:
tags:
- Calls
summary: Update a call in progress
description: |-
This method is used to manage ongoing, connected calls. This method uses SVAML in the request body to perform various tasks related to the call. For more information about SVAML, see the [Callback API](/docs/voice/api-reference/svaml/) documentation.
This method can only be used for calls that originate from or terminate to PSTN or SIP networks.
operationId: Calling_UpdateCall
requestBody:
$ref: '#/components/requestBodies/updateCall'
responses:
'204':
description: A success response, or an [Error](/docs/voice/api-reference/errors/).
get:
tags:
- Calls
summary: Get information about a call
description: |-
You can retrieve information about an ongoing or completed call using a call ID. You can find the call ID of an ongoing call by viewing the response object from a callout request. You can find the call ID of a completed call by looking at your call logs in your Sinch [Dashboard](https://dashboard.sinch.com/voice/logs).
Note: You can only use this method for calls that terminate to PSTN or SIP networks from an In-app call.
operationId: Calling_GetCallResult
responses:
'200':
description: A success response, or an [Error](/docs/voice/api-reference/errors/).
content:
application/json:
schema:
$ref: '#/components/schemas/getCallResponseObj'
/calling/v1/calls/id/{callId}/leg/{callLeg}:
parameters:
- $ref: '#/components/parameters/callId'
- $ref: '#/components/parameters/callLeg'
patch:
tags:
- Calls
summary: Manage Call with `callLeg`
description: |-
This method is used to manage ongoing, connected calls. This method is only used when using the `PlayFiles` and `Say` instructions in the request body. This method uses SVAML in the request body to perform various tasks related to the call. For more information about SVAML, see the [Callback API](/docs/voice/api-reference/svaml/) documentation.
Note: You can only use this method for calls that originate from or terminate to PSTN or SIP networks.
operationId: Calling_ManageCallWithCallLeg
requestBody:
content:
application/json:
schema:
$ref: '#/components/schemas/SVAMLRequestBody'
examples:
hangupExample:
value:
instructions:
- name: say
text: Hello, the call is over, hanging up now. Goodbye
locale: en-US
action:
name: hangup
ivrExample:
value:
instructions:
- name: "playFiles"
ids:
- "welcome"
locale: "en-US"
action:
name: "hangup"
responses:
'200':
description: A success response, or an [Error](/docs/voice/api-reference/errors/).
content:
application/json:
example:
content: "200 Successful response"
/calling/v1/conferences/id/{conferenceId}:
parameters:
- $ref: '#/components/parameters/conferenceId'
get:
tags:
- Conferences
summary: Get Conference Info
description: Returns information about a conference that matches the provided conference ID.
operationId: Calling_GetConferenceInfo
responses:
'200':
description: A success response, or an [Error](/docs/voice/api-reference/errors/).
content:
application/json:
schema:
$ref: '#/components/schemas/getConferenceInfoResponse'
example:
participants:
- cli: "+46708168731"
id: "myConfId1"
duration: 14
muted: false
onhold: false
- cli: "myUserName"
id: "myConfId2"
duration: 12
muted: false
onhold: false
delete:
tags:
- Conferences
summary: Kick Conference All
description: Removes all participants from a conference.
operationId: Calling_KickConferenceAll
responses:
'204':
description: A success response, or an [Error](/docs/voice/api-reference/errors/).
/calling/v1/conferences/id/{conferenceId}/{callId}:
parameters:
- $ref: '#/components/parameters/callId'
- $ref: '#/components/parameters/conferenceId'
patch:
tags:
- Conferences
summary: "Manage Conference Participant "
description: >-
Manages conference participant in a specified conference:
* mute / unmute
* put on hold / resume.
operationId: Calling_ManageConferenceParticipant
requestBody:
content:
application/json:
schema:
$ref: '#/components/schemas/manageConferenceParticipantRequest'
examples:
mute:
$ref: "#/components/examples/muteParticipant"
unmute:
$ref: "#/components/examples/unmuteParticipant"
hold:
$ref: "#/components/examples/onHoldParticipant"
resume:
$ref: "#/components/examples/resumeParticipant"
responses:
'200':
description: A success response, or an [Error](/docs/voice/api-reference/errors/).
content:
application/json:
example:
content: "Successful response"
delete:
tags:
- Conferences
summary: Kick Conference Participant
description: Remove a specified conference participant from a specified conference.
operationId: Calling_KickConferenceParticipant
responses:
'200':
description: A success response, or an [Error](/docs/voice/api-reference/errors/).
content:
application/json:
example:
content: "200 Successful response"
/v1/configuration/numbers:
servers:
- url: https://callingapi.sinch.com
get:
tags:
- Applications
summary: Get Numbers
description: Get information about your numbers. It returns a list of numbers that you own. For the ones that are assigned to an app, it returns the application key of the app.
operationId: Configuration_GetNumbers
responses:
'200':
description: A success response, or an [Error](/docs/voice/api-reference/errors/).
content:
application/json:
schema:
$ref: "#/components/schemas/getNumbersResponseObj"
example:
numbers: [
{
number: +141511122233334",
capability: "voice"
},
{
number: "+14151112223333",
applicationkey: "2457b630-45ef-4939-be88-93ffaebf4346",
capability: "voice"
},
{
number: "+141511122233332",
applicationkey: "2457b656-45ed-4934-be77-88feaebe4238",
capability: "voice"
}
]
post:
tags:
- Applications
summary: Update Numbers
description: Assign a number or a list of numbers to an application.
operationId: Configuration_UpdateNumbers
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/updateNumbers"
responses:
'204':
description: A success response, or an [Error](/docs/voice/api-reference/errors/).
delete:
tags:
- Applications
summary: Un-assign number
description: Un-assign a number from an application.
operationId: Configuration_UnassignNumber
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/unassignNumbers"
responses:
'204':
description: A success response, or an [Error](/docs/voice/api-reference/errors/).
/v1/configuration/callbacks/applications/{applicationkey}:
servers:
- url: https://callingapi.sinch.com
parameters:
- $ref: '#/components/parameters/applicationkey'
get:
tags:
- Applications
summary: Get Callback URLs
description: Returns any callback URLs configured for the specified application.
operationId: Configuration_GetCallbackURLs
responses:
'200':
description: A success response, or an [Error](/docs/voice/api-reference/errors/).
content:
application/json:
schema:
$ref: "#/components/schemas/callbacks"
example:
url: {
primary: http://primarycallback.com,
fallback: http://fallbackcallback.com
}
post:
tags:
- Applications
summary: Update Callbacks
description: Update the configured callback URLs for the specified application.
operationId: Configuration_UpdateCallbackURLs
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/callbacks"
example:
url: {
primary: http://primarycallback.com,
fallback: http://fallbackcallback.com
}
responses:
'204':
description: A success response, or an [Error](/docs/voice/api-reference/errors/).
/v1/calling/query/number/{number}:
servers:
- url: https://callingapi.sinch.com
parameters:
- $ref: '#/components/parameters/number'
get:
tags:
- Applications
summary: Query number
description: Returns information about the requested number.
operationId: Calling_QueryNumber
responses:
'200':
description: A success response, or an [Error](/docs/voice/api-reference/errors/).
content:
application/json:
schema:
$ref: '#/components/schemas/getQueryNumber'
example:
number:
countryId: 'SE'
numberType: 'Mobile'
normalizedNumber: '+14151112223333'
restricted: false
rate:
currencyId: USD
amount: 0.368
components:
securitySchemes:
Basic:
type: http
scheme: basic
description: For more information about basic authentication, see [Basic Authentication](/docs/voice/api-reference/authentication#basic-authentication).
Application:
type: apiKey
in: header
name: Authentication
description: For more information about application request signing authentication, see [Request Signing](/docs/voice/api-reference/authentication/signed-request).
examples:
muteParticipant:
summary: Mute a participant
value:
command: "mute"
unmuteParticipant:
summary: Unmute a participant
value:
command: "unmute"
onHoldParticipant:
summary: Place a participant on hold
value:
command: "onhold"
moh: "music1"
resumeParticipant:
summary: Return participant to conference
value:
command: "resume"
hangupExample:
summary: Hang up a call
value:
instructions:
- name: "sendDtmf"
value: "1234#"
action:
name: "hangup"
parkCallExample:
summary: Put a call on hold
value:
instructions:
- name: "sendDtmf"
value: "1234#"
action:
name: "park"
introPrompt: "#tts[Welcome]"
holdPrompt: "#tts[Please wait, you are on hold]"
maxDuration: 180
confCalloutRequest:
summary: Add a participant to a conference
value:
method: conferenceCallout
conferenceCallout:
cli: '+14045001000'
destination:
type: number
endpoint: '+14045005000'
locale: en-US
greeting: Welcome to my conference
conferenceId: "MyConfId"
ttsCalloutRequestCall:
summary: Make a phone call
description: Place a phone call and use text to speech to convey a message.
value:
method: ttsCallout
ttsCallout:
cli: '+14045001000'
destination:
type: number
endpoint: '+14045005000'
locale: en-US
text: "Hello, this is a call from Sinch."
ttsCalloutRequestPrompt:
summary: Play a prompt with SSML
description: Place a phone call and use text to speech with SSML to convey a message.
value:
method: ttsCallout
ttsCallout:
cli: '+14045001000'
destination:
type: number
endpoint: '+14045005000'
locale: en-US
prompts: "#ssml[Your PIN code is 1234
Please enter it now
]"
ttsCalloutRequestPlayFile:
summary: Play a prompt with an external file
description: Place a phone call and use text to speech via an external file to convey a message. Please review the [External media support ](/docs/voice/api-reference/supported-audio-formats) page for Caching, Limits and Content-Type headers information.
value:
method: ttsCallout
ttsCallout:
cli: '+14045001000'
destination:
type: number
endpoint: '+14045005000'
locale: en-US
prompts: "#href[https://myhosting/myspeechfile.mp3]"
customCalloutRequest:
summary: Make a custom callout
description: An example of a custom callout to invoke an ICE and ACE request
value:
method: customCallout
pop: 'eu-central'
customCallout:
ice: '{"action": {"name": "connectPstn", "number": "+12233445566", "cli": "+12234325234"}}'
ace: '{"instructions": [{"name": "say", "text": "Hello, this is a call from Sinch!"}], "action": {"name": "hangup"}}'
customCalloutAMDRequest:
summary: Make a custom callout that enables AMD
description: An example of a custom callout that uses an ICE request to enable Answering Machine Detection
value:
method: customCallout
customCallout:
ice: '{"action": {"name": "connectPstn", "number": "+12233445566", "cli": "+12234325234", "amd": {"enabled": "true"}}}'
enableAce: true
enableDice: true
ICEexample:
summary: ICE Example
description: An example of an Incoming Call Event.
value:
event: "ice"
callId: "3b0a7ccd-05e1-4728-bafd-023b77c47784"
callResourceUrl: "https://calling-euc1.api.sinch.com/calling/v1/calls/id/3b0a7ccd-05e1-4728-bafd-023b77c47784"
timestamp: "2022-03-21T13:13:59"
version: 1
userRate:
currencyId: "USD"
amount: .03
cli: "31639136121"
to:
type: "did"
endpoint: "+3197121281500"
domain: "pstn"
applicationKey: "3b216e8d-e385-4ff9-ae80-5d11897006b0"
originationType: "PSTN"
DICEexample:
summary: DICE Example
description: An example of a Disconnected Call Event.
value:
event: "dice"
callId: "3b0a7ccd-05e1-4728-bafd-023b77c47784"
timestamp: "2022-03-21T13:14:19"
reason: "GENERALERROR"
result: "FAILED"
version: 1
debit:
currencyId: "USD"
amount: 0
userRate:
currencyId: "USD"
amount: 0.368
to:
type: "did"
endpoint: "3197121281500"
applicationKey: "3b216e8d-e274-4ff9-ae80-5d11897006b0"
from: "31639136121"
PIEexample:
summary: PIE Example
description: An example of a Prompt Input Event.
value:
event: "pie"
callId: "3b0a7ccd-05e1-4728-bafd-023b77c47784"
timestamp: "2022-03-21T13:14:19"
menuResult:
menuId: "sub"
type: "sequence"
value: "3576"
inputMethod: "dtmf"
version: 1
applicationKey: "3b216e8d-e274-4ff9-ae80-5d11897006b0"
NotifyRecordingFinishedExample:
summary: Recording finished notification
description: An example of a Notify Event that a recording is finished.
value:
event: "notify"
callId: "da2d576b-d35a-476a-93cc-09e083fe8729"
version: 1
type: "recording_finished"
NotifyRecordingAvailableExample:
summary: Recording available notification
description: An example of a Notify Event that a recording is available for download.
value:
event: "notify"
callId: "da2d576b-d35a-476a-93cc-09e083fe8729"
version: 1
type: "recording_available"
destination: "path/to/my/recording.mp3"
AceHangupResponse:
summary: Hangup response SVAML
description: A SVAML response to an Answered Call Event that plays a message to the callee and then hangs up the call.
value:
instructions:
- name: "say"
text: "This is a call from Sinch. This call will now end."
locale: "en-US"
action:
name: hangup
AcePlayMenuResponse:
summary: Play menu response SVAML
description: A SVAML response to an Answered Call Event that plays a menu to the callee.
value:
action:
name: "runMenu"
barge: true
menus:
- id: "main"
mainPrompt: "#tts[This is the main menu. Press 1 for support or 2 to continue to the next menu.]"
options:
- dtmf: "1"
action: "return(support)"
- dtmf: "2"
action: "menu(sub)"
- id: "sub"
mainPrompt: "#tts[This is the sub menu. Enter your 4-digit PIN]"
repeatPrompt: "#tts[Please enter your 4-digit pin.]"
repeats: 3
maxDigits: 4
IceSayResponse:
summary: Say response SVAML
description: A SVAML response to an Incoming Call Event that plays a message to the caller and then hangs up the call.
value:
instructions:
- name: "say"
text: "Thank you for calling Sinch! This call will now end."
action:
name: "hangup"
40001Example:
summary: 40001 error
description: A 40001 parameter validation error.
value:
status: 400 ParameterValidation
errorCode: 40001
message: Method needs to be `ttsCallout`, `conferenceCallout`, or `customCallout`
40002Example:
summary: 40002 error
description: A 40002 missing parameter error.
value:
status: 400 MissingParameter
errorCode: 40002
message: Bad request; method is missing a parameter
40003Example:
summary: 40003 error
description: A 40003 invalid request error.
value:
status: 400 InvalidRequest
errorCode: 40003
message: Request data missing
40004Example:
summary: 40004 error
description: A 40004 invalid authorization key error.
value:
status: 400 InvalidAuthorizationKey
errorCode: 40002
message: Invalid authorization key
40005Example:
summary: 40005 error
description: A 40005 number missing leading plus error.
value:
status: 400 NumberMissingLeadingPlus
errorCode: 40002
message: Phone number missing leading plus sign
40100Example:
summary: 40100 error
description: A 40100 authorization header error.
value:
status: 401 AuthorizationHeader
errorCode: 40100
message: Authorization header missing, illegal or invalid
40101Example:
summary: 40101 error
description: A 40101 timestamp header error.
value:
status: 401 TimestampHeader
errorCode: 40101
message: X-Timestamp request header invalid or missing
40102Example:
summary: 40102 error
description: A 40102 invalid signature error.
value:
status: 401 MissingParameter
errorCode: 40102
message: Request has invalid signature
40103Example:
summary: 40103 error
description: A 40103 already authorized error.
value:
status: 401 AlreadyAuthorized
errorCode: 40103
message: User is already authorized
40104Example:
summary: 40104 error
description: A 40104 authorization required error.
value:
status: 401 MissingParameter
errorCode: 40104
message: The request was not authorized and signed with the application secret
40105Example:
summary: 40105 error
description: A 40105 expired error.
value:
status: 401 Expired
errorCode: 40105
message: The request for authorization has expired
40107Example:
summary: 40107 error
description: A 40107 invalid authorization error.
value:
status: 401 InvalidAuthorization
errorCode: 40107
message: Wrong type of auth used or invalid password or key
40108Example:
summary: 40108 error
description: A 40108 invalid credentials error.
value:
status: 401 InvalidCredentials
errorCode: 40108
message: Credentials provided are invalid
40200Example:
summary: 40200 error
description: A 40200 not enough credit error.
value:
status: 402 PaymentRequired
errorCode: 40200
message: Not enough credit
40300Example:
summary: 40300 error
description: A 40300 forbidden request error.
value:
status: 403 ForbiddenRequest
errorCode: 40300
message: Resource destination is forbidden
40301Example:
summary: 40301 error
description: A 40301 invalid authorization scheme error.
value:
status: 403 InvalidScheme
errorCode: 40301
message: Invalid authorization scheme
40302Example:
summary: 40302 error
description: A 40302 insufficient privileges error.
value:
status: 401 InsufficientPrivileges
errorCode: 40302
message: Privileges are insufficient to access the resource
40303Example:
summary: 40303 error
description: A 40303 restricted action error.
value:
status: 401 RestrictedAction
errorCode: 40303
message: Requested action is restricted
40400Example:
summary: 40400 error
description: A 40400 resource not found error.
value:
status: 404 ResourceNotFound
errorCode: 40400
message: Requested resource not found
40900Example:
summary: 40900 error
description: A 40900 request conflict error.
value:
status: 409 RequestConflict
errorCode: 40900
message: The request could not be completed due to a conflict with the current resource
42200Example:
summary: 42200 error
description: A 40108 invalid credentials error.
value:
status: 401 InvalidCredentials
errorCode: 40108
message: Credentials provided are invalid
42201Example:
summary: 40108 error
description: A 40108 invalid credentials error.
value:
status: 401 InvalidCredentials
errorCode: 40108
message: Credentials provided are invalid
42202Example:
summary: 42200 error
description: A 40108 invalid credentials error.
value:
status: 401 InvalidCredentials
errorCode: 40108
message: Credentials provided are invalid
42900Example:
summary: 42900 error
description: A 42900 capacity exceeded error.
value:
status: 429 CapacityExceeded
errorCode: 42900
message: The number of requests has exceeded capacity
42901Example:
summary: 42901 error
description: A 42901 velocity constraint error.
value:
status: 429 VelocityConstraint
errorCode: 42901
message: The number of requests has exceeded velocity constraint
50000Example:
summary: 50000 error
description: A 50000 internal server error.
value:
status: 500 InternalError
errorCode: 50000
message: General error; try submitting request again
50300Example:
summary: 50300 error
description: A 50300 temporary down error.
value:
status: 503 TemporaryDown
errorCode: 50500
message: Service temporarily unavailable
50301Example:
summary: 50301 error
description: A 50301 configuration error.
value:
status: 503 ConfigurationError
errorCode: 50301
message: Server configuration error; try submitting request again
hangup:
summary: hangup example
description: The `hangup` action.
value:
action:
name: "hangup"
continue:
summary: continue example
description: The `continue` action.
value:
action:
name: "continue"
connectPstn:
summary: connectPstn example
description: The `connectPstn` action.
value:
action:
name: "connectPstn"
number: "+461234567890"
locale: "en-US"
maxDuration: 3000
dialTimeout: 10
cli: "+460987654321"
suppressCallbacks: false
indications: "se"
amd:
enabled: true
connectMxp:
summary: connectMxp example
description: The `connectMxp` action.
value:
action:
name: "connectMxp"
destination:
type: "username"
endpoint: "johndoe"
callHeaders:
- key: "foo"
value: "bar"
- key: "baz"
value: "qux"
connectSip:
summary: connectSip example
description: The `connectSip` action.
value:
action:
name: "connectSip"
destination:
endpoint: "46708000000@sip.foo.com"
type: "Sip"
maxDuration: 3000
cli: "private"
transport: "tls"
suppressCallbacks: false
callHeaders:
- key: "foo"
value: "bar"
- key: "baz"
value: "qux"
connectStream:
summary: connectStream example
description: The `connectStream` action.
value:
action:
name: "connectStream"
destination:
type: "Websocket"
endpoint: "wss://yourcompany.com/websocket-server"
maxDuration: 3000
callHeaders:
- key: "foo"
value: "bar"
- key: "baz"
value: "qux"
websocketExchangeRequest:
summary: Websocket Exchange request example
description: Websocket Init
value:
codec: "pcm"
sampleRate: 8000
callId: 1f21b71d-bdcd-430c-973f-c3b536e32ca0
timestamp: 2024-05-21T15:57:21.157027Z
applicationKey: 541c3e1c-09ac-4d4b-bdc8-76f90e0fc27f
version: 1
callHeaders:
"foo": "bar"
"baz": "qux"
websocketExchangeResponse:
summary: Websocket Exchange response example
description: Websocket Init response
value:
status: "ok"
connectConf:
summary: connectConf example
description: The `connectConf` action.
value:
action:
name: "connectConf"
conferenceId: "myConference"
moh: "ring"
runMenu:
summary: runMenu example
description: The `runMenu` action.
value:
action:
name: "runMenu"
barge: true
menus:
- id: "main"
mainPrompt: "#tts[Welcome to the main menu. Press 1 for support or 2 to continue.]"
options:
- dtmf: 1
action: "return(support)"
- dtmf: 2
action: "menu(sub)"
- id: "sub"
mainPrompt: "#tts[Welcome to the sub menu. Enter your 4-digit PIN.]"
options:
- dtmf: 1
action: "menu(main)"
park:
summary: park example
description: The `park` action.
value:
action:
name: "park"
introPrompt: "#tts[Welcome]"
holdPrompt: "#tts[Thank you for your patience, your call is very important to us.]"
maxDuration: 180
playFiles:
summary: playFiles example
description: The `playFiles` instruction.
value:
instructions:
- name: "playFiles"
ids:
- "[Welcome]"
locale: "en-US"
say:
summary: say example
description: The `say` instruction.
value:
instructions:
- name: "say"
text: "Hello, this is a text-to-speech message."
locale: "en-US"
sendDtmf:
summary: sendDtmf example
description: The `sendDtmf` instruction.
value:
instructions:
- name: "sendDtmf"
value: "1234#"
setCookie:
summary: setCookie example
description: The `setCookie` instruction.
value:
instructions:
- name: "setCookie"
key: "cookie_name"
value: "cookie_value"
answer:
summary: answer example
description: The `answer` instruction.
value:
instructions:
- name: "answer"
startRecording:
summary: startRecording example
description: The `startRecording` instruction.
value:
instructions:
- name: "startRecording"
options:
destination: "s3://my-bucket/"
credentials: "AKIAIOSFODNN7EXAMPLE:wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY:eu-central-1"
notificationEvents: true
stopRecording:
summary: stopRecording example
description: The `stopRecording` instruction.
value:
instructions:
- name: "stopRecording"
requestBodies:
updateCall:
content:
application/json:
schema:
$ref: '#/components/schemas/SVAMLRequestBody'
examples:
hangupExample:
$ref: '#/components/examples/hangupExample'
parkCallExample:
$ref: '#/components/examples/parkCallExample'
calloutRequest:
content:
application/json:
schema:
$ref: '#/components/schemas/CalloutRequest'
examples:
ttsCalloutRequestCall:
$ref: '#/components/examples/ttsCalloutRequestCall'
ttsCalloutRequestPrompt:
$ref: '#/components/examples/ttsCalloutRequestPrompt'
ttsCalloutRequestPlayFile:
$ref: '#/components/examples/ttsCalloutRequestPlayFile'
confCalloutRequest:
$ref: '#/components/examples/confCalloutRequest'
customCalloutRequest:
$ref: '#/components/examples/customCalloutRequest'
customCalloutAmdRequest:
$ref: "#/components/examples/customCalloutAMDRequest"
parameters:
number:
in: path
name: number
schema:
type: string
required: true
description: The phone number you want to query.
example: '+46730170101'
callId:
in: path
name: callId
schema:
type: string
required: true
description: The unique identifier of the call. This value is generated by the system.
example: 4398599d1ba84ef3bde0a82dfb61abed
conferenceId:
in: path
name: conferenceId
schema:
type: string
required: true
description: The unique identifier of the conference. The user sets this value.
example: "MyConfId"
applicationkey:
name: applicationkey
in: path
schema:
type: string
required: true
description: The unique identifying key of the application.
example: 94983f76-1161-6655-9515-4785c7b67dd8
callLeg:
name: callLeg
in: path
schema:
type: string
enum:
- "caller"
- "callee"
- "both"
required: true
description: "Specifies which part of the call will be managed. This option is used only by the `PlayFiles` and `Say` instructions to indicate which channel the sound will be played on. Valid options are `caller`, `callee` or `both`. If not specified, the default value is `caller`.The `callLeg` identifier is ignored for calls that are part of a conference and calls initiated using the Callout API."
example: "caller"
"type":
in: path
name: type
schema:
type: string
required: true
description: The type of endpoint on which you want to report. The value can be either `number` or `username`.
example: 'number'
endpoint:
in: path
name: endpoint
schema:
type: string
required: true
description: The value of the endpoint of the call. For calls on the PSTN, this is a phone number. For app-to-app calls, this is a username.
example: '+46730170101'
domain:
in: path
name: domain
schema:
type: string
required: false
description: An optional parameter that specifies the terminating pattern. Can be either `data` or `pstn`.
example: 'data'
id:
in: path
name: id
schema:
type: string
required: true
description: A predefined ID string. This must be set up in cooperation with the Sinch support team.
example: 'currentCalls'
schemas:
Error:
type: object
properties:
status:
type: string
description: A summary of the HTTP error code and error type.
example: "404 Not Found"
errorCode:
type: string
description: The HTTP error code.
example: "40400"
message:
type: string
description: A simple description of the cause of the error.
example: "Call not found"
reference:
type: string
description: If applicable, a reference ID for support to use with diagnosing the error.
example: "a2028355-5164-41b6-aae9-2b8a546e0784"
callResult:
type: string
x-enumDescriptions:
ANSWERED: The call was answered.
BUSY: The line called was busy.
NOANSWER: The line called failed to answer.
FAILED: The call failed.
enum:
- 'N/A'
- 'ANSWERED'
- 'BUSY'
- 'NOANSWER'
- 'FAILED'
description: Contains the result of a call.
example: "ANSWERED"
destination:
type: object
description: The type of device and number or endpoint to call.
required:
- type
- endpoint
properties:
type:
$ref: '#/components/schemas/destinationType'
endpoint:
type: string
description: If the type is `number` the value of the endpoint is a phone number. If the type is `username` the value is the username for a data endpoint.
format: e164
example: +12125550123
updateNumbers:
type: object
example:
numbers: '+14151112223333'
applicationkey: '11983f76-12c8-1111-9515-4785c7b67ca8'
capability: 'voice'
properties:
numbers:
type: array
description:
The phone number or list of numbers in E.164 format.
items:
type: string
minItems: 1
maxItems: 100
example: ["+14151112223333", "+14151112223333"]
applicationkey:
description: "indicates the application where the number(s) will be assigned. If empty, the application key that is used to sign the request will be used."
type: string
example: "11983f76-12c8-1111-9515-4785c7b67ca8"
capability:
type: string
enum:
- 'voice'
- 'sms'
description: "indicates the DID capability that needs to be assigned to the chosen application. Valid values are 'voice' and 'sms'. Please note that the DID needs to support the selected capability."
example: "voice"
unassignNumbers:
type: object
example:
numbers: '+14151112223333'
applicationkey: '11983f76-12c8-1111-9515-4785c7b67ca8'
capability: 'voice'
properties:
number:
type: string
description: The phone number in E.164 format (https://en.wikipedia.org/wiki/E.164)
example: ["+14151112223333", "+14151112223334"]
applicationkey:
description: "Indicates the application where the number(s) was assigned. If empty, the application key that is used to sign the request will be used."
type: string
example: "11983f76-12c8-1111-9515-4785c7b67ca8"
capability:
type: string
enum:
- 'voice'
- 'sms'
description: "(optional) indicates the DID capability that was assigned to the chosen application. Please note that the DID needs to support the selected capability."
example: "voice"
getCallResponseObj:
type: object
properties:
from:
$ref: "#/components/schemas/destination"
to:
$ref: "#/components/schemas/destination"
domain:
type: string
enum:
- 'pstn'
description: Must be `pstn` for PSTN.
example: "pstn"
callId:
type: string
description: The unique identifier of the call.
example: 801a3ba3-1dbd-4daf-b0b3-46e1e1fb9f52
duration:
type: integer
description: The duration of the call in seconds.
example: 60
status:
type: string
enum:
- 'ONGOING'
- 'FINAL'
description: The status of the call. Either `ONGOING` or `FINAL`
example: "ONGOING"
result:
$ref: "#/components/schemas/callResult"
reason:
type: string
enum:
- 'N/A'
- 'TIMEOUT'
- 'CALLERHANGUP'
- 'CALLEEHANGUP'
- 'BLOCKED'
- 'NOCREDITPARTNER'
- 'MANAGERHANGUP'
- 'CANCEL'
- 'GENERALERROR'
- 'INVALIDSVAMLACTION'
description: Contains the reason why a call ended.
example: N/A
timestamp:
$ref: "#/components/schemas/timeStamp"
custom:
type: string
description: A string that can be used to pass custom information related to the call.
userRate:
$ref: "#/components/schemas/price"
debit:
$ref: "#/components/schemas/price"
callbacks:
type: object
properties:
url:
description: Gets primary and if configured fallback callback URLs
type: object
properties:
primary:
type: string
description: 'Your primary callback URL'
example: http://primary.yourcallback.com/
fallback:
type: string
description: 'Your fallback callback URL (returned if configured). It is used only if Sinch platform gets a timeout or error from your primary callback URL.'
example: http://fallback.yourcallback.com/
getQueryNumber:
type: object
properties:
number:
type: object
description: The number object.
properties:
countryId:
type: string
description: The ISO 3166-1 formatted country code.
example: "SE"
numberType:
type: string
enum:
- 'Unknown'
- 'Fixed'
- 'Mobile'
- 'Other'
description: The type of the number.
example: "Fixed"
normalizedNumber:
type: string
description: The number in E.164 format.
example: "+46730170101"
restricted:
type: boolean
description: Concerns whether the call is restricted or not.
example: false
rate:
$ref: "#/components/schemas/price"
getRecordingFileInfo:
type: object
properties:
key:
type: string
url:
type: string
createdOn:
type: string
format: timestamp
expiresOn:
type: string
format: timestamp
headers:
type: object
getNumbersResponseObj:
type: object
properties:
numbers:
type: array
default: numbers
description: The object type. Will always be list of numbers, associated application keys and capabilities
items:
type: object
properties:
number:
type: string
description: Numbers that you own in E.164 format.
example: '+11400000000'
applicationkey:
type: string
description: Indicates the application where the number(s) will be assigned. If no number is assigned the applicationkey will not be returned.
capability:
type: string
enum:
- 'voice'
description: "indicates the DID capability that needs to be assigned to the chosen application. Valid values are 'voice'. Please note that the DID needs to support the selected capability."
example: "voice"
getConferenceInfoResponse:
type: object
description: The response returns information about the participants in the conference.
properties:
participants:
type: array
items:
type: object
properties:
cli:
type: string
description: The phone number of the PSTN participant that was connected in the conference, or whatever was passed as CLI for data originated/terminated calls.
example: "+46708168731"
id:
type: string
description: The callId of the call leg that the participant joined the conference.
example: "abcabcabcabca"
duration:
type: integer
description: The number of seconds that the participant has been connected to the conference.
muted:
type: boolean
onhold:
type: boolean
manageConferenceParticipantRequest:
type: object
example:
command: unmute
description: ""
required:
- command
properties:
command:
type: string
description: "Action to apply on conference participant."
x-enumDescriptions:
mute: Mutes participant.
unmute: Unmutes participant.
onhold: Puts participant on hold.
resume: Returns participant to conference.
moh:
type: string
description: Means "music on hold". If this optional parameter is included, plays music to the first participant in a conference while they're alone and waiting for other participants to join. If `moh` isn't specified, the user will only hear silence while alone in the conference. This property is only available to use with the `onhold` command.
x-enumDescriptions:
ring: Plays a progress tone.
music1: Plays music choice 1.
music2: Plays music choice 2.
music3: Plays music choice 3.
CalloutRequest:
type: object
description: "Currently three types of callouts are supported: conference callouts, text-to-speech callouts and custom callouts. The custom callout is the most flexible, but text-to-speech and conference callouts are more convenient."
required:
- method
properties:
method:
type: string
description: Sets the type of callout.
enum:
- conferenceCallout
- ttsCallout
- customCallout
example: conferenceCallout
conferenceCallout:
$ref: "#/components/schemas/conferenceCalloutRequest"
ttsCallout:
$ref: "#/components/schemas/ttsCalloutRequest"
customCallout:
$ref: "#/components/schemas/customCalloutRequest"
conferenceCalloutRequest:
type: object
description: The conference callout calls a phone number or a user. When the call is answered, it's connected to a conference room.
required:
- destination
- conferenceId
properties:
cli:
type: string
format: e.164
description: The number that will be displayed as the incoming caller. To set your own CLI, you may use your verified number or your Dashboard number. The number must be in [E.164](https://community.sinch.com/t5/Glossary/E-164/ta-p/7537) format.
example: '14151112223333'
destination:
$ref: '#/components/schemas/destination'
conferenceId:
type: string
description: The conferenceId of the conference to which you want the callee to join. If the conferenceId doesn't exist a conference room will be created.
conferenceDtmfOptions:
type: object
description: Options to control how DTMF signals are used by the participant in the conference. For information on how to use this feature, read more [here](../../../conference-dtmf).
properties:
mode:
type: string
description: Determines what DTMF mode the participant will use in the call.
x-enumDescriptions:
ignore: Nothing is done with the participant's DTMF signals. This is the default mode. Any DTMF signals that the participant sends can still be heard by all participants, but no action will be performed.
forward: The participant's DTMF signals are forwarded to all other participants in the conference.
detect: The participant's DTMF signals are detected by the conference and sent to your backend server using a [Prompt Input Event](../../tag/Callbacks/#tag/Callbacks/operation/pie) (PIE) callback.
default: ignore
maxDigits:
type: integer
description: |-
The maximum number of accepted digits before sending the collected input via a PIE callback. The default value is `1`. If the value is greater than `1`, the PIE callback is triggered by one of the three following events:
- No additional digit is entered before the `timeoutMills` timeout period has elapsed.
- The `#` character is entered.
- The maximum number of digits has been entered.
default: 1
timeoutMills:
type: integer
description: The number of milliseconds that the system will wait between entered digits before triggering the PIE callback. The default value is `3000`.
default: 3000
dtmf:
type: string
description: 'When the destination picks up, this DTMF tones will be played to the callee. Valid characters in the string are "0"-"9", "#" and "w". A "w" will render a 500 ms pause. Example: "ww1234#w#" will render a 1s pause, the DTMF tones "1", "2", "3", "4" and "#" followed by a 0.5s pause and finally the DTMF tone for "#". This can be used if the callout destination for instance require a conference PIN code or an extension to be entered.'
maxDuration:
type: integer
enableAce:
type: boolean
description: If `enableAce` is set to true and the application has a callback URL specified, you will receive an ACE callback when the call is answered. When the callback is received, your platform must respond with a svamlet containing the `connectConf` action in order to add the call to a conference or create the conference if it's the first call. If it's set to false, no ACE event will be sent to your backend.
Note if the call is towards an InApp destination `type:` `username`, then no ACE will be issued when the call is connected, even if `enableAce` is present in the callout request.
default: false
example: false
enableDice:
type: boolean
description: If `enableDice` is set to true and the application has a callback URL specified, you will receive a DiCE callback when the call is disconnected. If it's set to false, no DiCE event will be sent to your backend.
Note if the call is towards an InApp destination `type:` `username`, then no DICE will be issued at the end of the call, even if `enableDice` is present in the callout request.
default: false
example: false
enablePie:
type: boolean
description: If `enablePie` is set to true and the application has a callback URL specified, you will receive a PIE callback after a `runMenu` action, with the information of the action that the user took. If it's set to false, no PIE event will be sent to your backend.
default: false
example: false
locale:
type: string
format: ISO 639
description: The voice and language you want to use for the prompts. This can either be defined by the ISO 639 locale and language code or by specifying a particular voice. Supported languages and voices are detailed [here](../../../voice-locales/)
default: en-US
example: en-US
greeting:
type: string
description: The text that will be spoken as a greeting.
example: "Welcome to the conference"
mohClass:
type: string
description: |-
Means "music-on-hold." It's an optional parameter that specifies what the first participant should listen to while they're alone in the conference, waiting for other participants to join. It can take one of these pre-defined values:
- `ring` (progress tone)
- `music1` (music file)
- `music2` (music file)
- `music3` (music file)
If no “music-on-hold” is specified, the user will only hear silence.
example: ring
custom:
type: string
description: Used to input custom data.
domain:
$ref: "#/components/schemas/domain"
ttsCalloutRequest:
type: object
description: The text-to-speech callout calls a phone number and plays a synthesized text messages or pre-recorded sound files.
required:
- "destination"
properties:
cli:
type: string
format: e.164
description: The number that will be displayed as the incoming caller. To set your own CLI, you may use your verified number or your Dashboard number. The number must be in [E.164](https://community.sinch.com/t5/Glossary/E-164/ta-p/7537) format.
example: '+14155552223333'
destination:
$ref: '#/components/schemas/destination'
dtmf:
type: string
description: When the destination picks up, this DTMF tones will be played to the callee. Valid characters in the string are "0"-"9", "#", and "w". A "w" will render a 500 ms pause. For example, "ww1234#w#" will render a 1s pause, the DTMF tones "1", "2", "3", "4" and "#" followed by a 0.5s pause and finally the DTMF tone for "#". This can be used if the callout destination for instance require a conference PIN code or an extension to be entered.
example: "ww1234#w#"
domain:
type: string
enum:
- 'pstn'
- 'mxp'
description: Can be either `pstn` for PSTN endpoint or `mxp` for data (app or web) clients.
example: "pstn"
custom:
type: string
description: Can be used to input custom data.
locale:
type: string
description: The voice and language you want to use for the text-to-speech message. This can either be defined by the ISO 639 locale and language code or by specifying a particular voice. Supported languages and voices are detailed [here](../../../voice-locales/).
example: en-US
text:
type: string
description: |
The text that will be spoken in the text-to-speech message.
_Every application's default maximum characters allowed in text-to-speech is 600 characters. Contact support if you wish this limit to be changed._
prompts:
type: string
description: |
An advanced alternative to using ```text```.
__TTS__ _Text To Speech:_ The equivalent of text but within the prompt property.
Example: _```#tts[Hello from Sinch]```_
__TTS with SSML__ _Text To Speech with Speech Synthesis Markup Language (SSML)._ This is an XML-based markup language for assisting the generation of synthetic speech in the Web and other applications. AWS Polly supports a sub-set of SSML. This allows us to use SSML-enhanced text for additional control over how Polly generates speech from the text. Details and examples of supported tags are [here](https://docs.aws.amazon.com/polly/latest/dg/supportedtags.html)
__Externally hosted media:__ Provide a URL to your own hosted media. Please check [here](../../../supported-audio-formats/#limits) to read about audio content type and usage limits.
_Every application's default maximum allowed in TTS or TTS SSML is 600 characters. Contact support if you wish this limit to be changed._
_Several prompts can be used, separated by a semi-colon_ ```;```
Example: ```#tts[Hello from Sinch];#ssml[Have a great day!]```
__Note__: We recommend that you prepare a test call for all ttsCallout text to speech messages using `prompts` to ensure you can hear it before you deploy in production.
If the `prompts` contains an SSML syntax error or is missing `#tts[]` or `#ssml[]`, __you will not be alerted to this and the message will not play when the call arrives__.
enableAce:
type: boolean
description: If `enableAce` is set to `true` and the application has a callback URL specified, you will receive an ACE callback when the call is answered. When the callback is received, your platform must respond with a svamlet, containing the “connectconf” action in order to add the call to a conference or create the conference if it's the first call. If it's set to `false`, no ACE event will be sent to your backend.
default: false
example: false
enableDice:
type: boolean
description: If `enableDice` is set to `true` and the application has a callback URL specified, you will receive a DiCE callback when the call is disconnected. If it's set to `false`, no DiCE event will be sent to your backend.
default: false
example: false
enablePie:
type: boolean
description: |-
Note: PIE callbacks are not available for DATA Calls; only PSTN and SIP calls.
If `enablePie` is set to `true` and the application has a callback URL specified, you will receive a PIE callback after the `runMenu` action executes and after the configured menu timeout has elapsed with no input. If it's set to `false`, no PIE events will be sent to your backend.
customCalloutRequest:
type: object
description: The custom callout, the server initiates a call from the servers that can be controlled by specifying how the call should progress at each call event.
properties:
cli:
type: string
format: e.164
description: The number that will be displayed as the incoming caller, to set your own CLI, you may use your verified number or your Dashboard virtual number, it must be in [E.164](https://community.sinch.com/t5/Glossary/E-164/ta-p/7537) format.
example: '+14155552223333'
destination:
$ref: "#/components/schemas/destination"
dtmf:
type: string
description: When the destination picks up, this DTMF tones will be played to the callee. Valid characters in the string are "0"-"9", "#", and "w". A "w" will render a 500 ms pause. For example, "ww1234#w#" will render a 1s pause, the DTMF tones "1", "2", "3", "4" and "#" followed by a 0.5s pause and finally the DTMF tone for "#". This can be used if the callout destination for instance require a conference PIN code or an extension to be entered.
example: "ww1234#w#"
custom:
type: string
description: Can be used to input custom data.
maxDuration:
type: integer
description: The maximum amount of time in seconds that the call will last.
example: 600
ice:
type: string
description: |
You can use inline [SVAML](../../../svaml/) to replace a callback URL when using custom callouts. Ensure that the JSON object is escaped correctly. If inline ICE SVAML is passed, exclude *cli* and *destination* properties from the *customCallout* request body.
Example: ```"{\"action\":{\"name\":\"connectPstn\",\"number\":\"46000000001\",\"maxDuration\":90}}"```
ace:
type: string
description: |
You can use inline [SVAML](../../../svaml/) to replace a callback URL when using custom callouts. Ensure that the JSON object is escaped correctly.
Example: ```"{\"action\": {\"name\": \"RunMenu\",\"locale\": \"en-US\",\"menus\": [{\"id\": \"main\",\"mainPrompt\": \"#tts[ Welcome to the main menu. Press 1 for a callback or 2 for a cancel<\/speak>]\",\"timeoutMills\": 5000,\"options\": [ {\"dtmf\": \"1\",\"action\": \"return(callback)\"}, {\"dtmf\": \"2\",\"action\": \"return(cancel)\"}]}]}}"```
pie:
type: string
description: |
Note: PIE callbacks are not available for DATA Calls; only PSTN and SIP calls.
You can use inline [SVAML](../../../svaml/) to replace a callback URL when using custom callouts. Ensure that the JSON object is escaped correctly. A PIE event will contain a value chosen from an IVR choice. Usually a PIE event wil contain a URL to a callback sever that will receive the choice and be able to parse it. This could result in further SVAML or some other application logic function.
Example: ```"https://your-application-server-host/application"```
getCalloutResponseObj:
type: object
description: The returned call ID.
properties:
callId:
type: string
description: The returned call identifier.
example: 'adf92089-d9e8-4f14-a377-1e975f588fe4'
svaml.instruction:
type: object
description: Instructions allow an application to play a message or file, start recording, and various other tasks. For more information about instructions, see the [SVAML](../../svaml/) documentation.
anyOf:
- $ref: "#/components/schemas/svaml.instruction.playFiles"
- $ref: "#/components/schemas/svaml.instruction.say"
- $ref: "#/components/schemas/svaml.instruction.sendDtmf"
- $ref: "#/components/schemas/svaml.instruction.setCookie"
- $ref: "#/components/schemas/svaml.instruction.answer"
- $ref: "#/components/schemas/svaml.instruction.startRecording"
- $ref: "#/components/schemas/svaml.instruction.stopRecording"
discriminator:
propertyName: name
mapping:
playFiles: "#/components/schemas/svaml.instruction.playFiles"
say: "#/components/schemas/svaml.instruction.say"
sendDtmf: "#/components/schemas/svaml.instruction.sendDtmf"
setCookie: "#/components/schemas/svaml.instruction.setCookie"
answer: "#/components/schemas/svaml.instruction.answer"
startRecording: "#/components/schemas/svaml.instruction.startRecording"
stopRecording: "#/components/schemas/svaml.instruction.stopRecording"
svaml.action:
type: object
description: The action that will control the call. Each SVAML object can only include one action.
anyOf:
- $ref: "#/components/schemas/svaml.action.hangup"
- $ref: "#/components/schemas/svaml.action.continue"
- $ref: "#/components/schemas/svaml.action.connectPstn"
- $ref: "#/components/schemas/svaml.action.connectMxp"
- $ref: "#/components/schemas/svaml.action.connectConf"
- $ref: "#/components/schemas/svaml.action.connectSip"
- $ref: "#/components/schemas/svaml.action.connectStream"
- $ref: "#/components/schemas/svaml.action.runMenu"
- $ref: "#/components/schemas/svaml.action.park"
discriminator:
propertyName: name
mapping:
hangup: "#/components/schemas/svaml.action.hangup"
continue: "#/components/schemas/svaml.action.continue"
connectPstn: "#/components/schemas/svaml.action.connectPstn"
connectMxp: "#/components/schemas/svaml.action.connectMxp"
connectConf: "#/components/schemas/svaml.action.connectConf"
connectSip: "#/components/schemas/svaml.action.connectSip"
connectStream: "#/components/schemas/svaml.action.connectStream"
runMenu: "#/components/schemas/svaml.action.runMenu"
park: "#/components/schemas/svaml.action.park"
SVAMLRequestBody:
type: object
description: SVAML is a call control markup language. When a server receives a callback event from the Sinch platform, it can respond with a SVAML object to control the voice call. The following is an example of a SVAML object type and its contents.
properties:
instructions:
type: array
description: The collection of instructions that can perform various tasks during the call. You can include as many instructions as necessary.
items:
$ref: "#/components/schemas/svaml.instruction"
action:
$ref: "#/components/schemas/svaml.action"
svaml.action.hangup:
type: object
description: Hangs up a call. Available to use in a response to an [Incoming Call Event](../../../docs/voice/api-reference/voice/tag/Callbacks/#tag/Callbacks/operation/ice) callback or an [Answered Call Event](../../../docs/voice/api-reference/voice/tag/Callbacks/#tag/Callbacks/operation/ace) callback.
required:
- name
properties:
name:
type: string
description: The name property. Must have the value `hangup`.
enum:
- hangup
default: "hangup"
svaml.action.continue:
type: object
description: Continues to set up a call. Available to use in a response to an [Answered Call Event](../../../voice/tag/Callbacks/#tag/Callbacks/operation/ace) callback.
required:
- name
properties:
name:
type: string
description: The name property. Must have the value `continue`.
enum:
- continue
default: "continue"
svaml.action.connectPstn:
type: object
description: Determines how a PSTN call is connected. Available to use in a response to an [Incoming Call Event](../../voice/tag/Callbacks/#tag/Callbacks/operation/ice) callback.
required:
- name
properties:
name:
type: string
description: The name property. Must have the value `connectPstn`.
enum:
- connectPstn
default: "connectPstn"
number:
type: string
description: Used to override where PSTN call is connected. If not specified, the extension the client called is used.
example: "+461234567890"
locale:
type: string
description: Specifies the locale. Uses the language code according to `ISO 639`, a dash (`-`), and a country code according to `ISO 3166-1 alpha-2`. If not specified, the default locale of `en-US` is used.
default: "en-US"
maxDuration:
type: integer
description: The max duration of the call in seconds (max 14400 seconds). If the call is still connected at that time, it will be automatically disconnected.
example: 3000
dialTimeout:
type: integer
description: The max duration the call will wait in ringing unanswered state before terminating with ```TIMEOUT/NO ANSWER``` on PSTN leg and ```NA/BUSY```on MXP leg.
example: 3000
cli:
type: string
description: Used to override the CLI (or caller ID) of the client. The phone number of the person who initiated the call is shown as the CLI. To set your own CLI, you may use your verified number or your Dashboard virtual number.
example: "private"
suppressCallbacks:
type: boolean
description: If enabled, suppresses [ACE](../../voice/tag/Callbacks/#tag/Callbacks/operation/ace) and [DICE](../../voice/tag/Callbacks/#tag/Callbacks/operation/dice) callbacks for the call.
example: "false"
dtmf:
type: string
description: |-
A string that determines the DTMF tones to play to the callee when the call is picked up.
Valid characters are: `0-9`, `#`, and `w`. `w` renders a 500ms pause. For example, the string `ww1234#w#`, plays a 1 second pause, the DTMF tones for `1`, `2`, `3`, `4`, and `#`, followed by a 500ms pause and finally the `#` tone.
This is useful if the callout destination requires a conference PIN code or an extension. If there is a calling party, it will hear progress while the DTMF is sent.
example: "ww1234#w#"
indications:
type: string
description: The locale's tone to play while ringing.
x-enumDescriptions:
at: Austria
au: Australia
bg: Bulgaria
br: Brazil
be: Belgium
ch: Switzerland
cl: Chile
cn: China
cz: Czech Republic
de: Germany
dk: Denmark
ee: Estonia
es: Spain
fi: Finland
fr: France
gr: Greece
hu: Hungary
il: Israel
in: India
it: Italy
lt: Lithuania
jp: Japan
mx: Mexico
my: Malaysia
nl: Netherlands
no: Norway
nz: New Zealand
ph: Philippines
pl: Poland
pt: Portugal
ru: Russia
se: Sweden
sg: Singapore
th: Thailand
uk: United Kingdom
us: United States
tw: Taiwan
ve: Venezuela
za: South Africa
example: "us"
amd:
type: object
description: An optional property used to enable [Answering Machine Detection](/docs/voice/api-reference/amd_v2) (AMD).
properties:
enabled:
type: boolean
description: Sets whether AMD is enabled.
example: true
svaml.action.connectMxp:
type: object
description: Determines how an application-to-application call is connected. Available to use in a response to an [Incoming Call Event](../../voice/tag/Callbacks/#tag/Callbacks/operation/ice) callback.
required:
- name
properties:
name:
type: string
description: The name property. Must have the value `connectMxp`.
enum:
- connectMxp
default: "connectMxp"
destination:
$ref: "#/components/schemas/destination"
callheaders:
type: array
description: An optional parameter that allows you to specify or override call headers provided to the receiving Sinch SDK client. Read more about call headers [here](../../call-headers/).
items:
$ref: "#/components/schemas/callHeader"
svaml.action.connectConf:
type: object
description: Connects an incoming call to a conference. Available to use in a response to an [Incoming Call Event](../../voice/tag/Callbacks/#tag/Callbacks/operation/ice) callback.
required:
- name
- conferenceId
properties:
name:
type: string
description: The name property. Must have the value `connectConf`.
enum:
- connectConf
default: "connectConf"
conferenceId:
type: string
description: The unique identifier of the conference. Shouldn't exceed 64 characters.
example: "myConference"
conferenceDtmfOptions:
type: object
description: Options to control how DTMF signals are used by the participant in the conference. For information on how to use this feature, read more [here](../../conference-dtmf).
properties:
mode:
type: string
description: Determines what DTMF mode the participant will use in the call.
x-enumDescriptions:
ignore: Nothing is done with the participant's DTMF signals. This is the default mode. Any DTMF signals that the participant sends can still be heard by all participants, but no action will be performed.
forward: The participant's DTMF signals are forwarded to all other participants in the conference.
detect: The participant's DTMF signals are detected by the conference and sent to your backend server using a [Prompt Input Event](../../voice/tag/Callbacks/#tag/Callbacks/operation/pie) (PIE) callback.
default: ignore
maxDigits:
type: integer
description: |-
The maximum number of accepted digits before sending the collected input via a PIE callback. The default value is `1`. If the value is greater than `1`, the PIE callback is triggered by one of the three following events:
- No additional digit is entered before the `timeoutMills` timeout period has elapsed.
- The `#` character is entered.
- The maximum number of digits has been entered.
default: 1
timeoutMills:
type: integer
description: The number of milliseconds that the system will wait between entered digits before triggering the PIE callback. The default value is `3000`.
default: 3000
moh:
type: string
description: Means "music on hold". If this optional parameter is included, plays music to the first participant in a conference while they're alone and waiting for other participants to join. If `moh` isn't specified, the user will only hear silence while alone in the conference.
x-enumDescriptions:
ring: Plays a progress tone.
music1: Plays music choice 1.
music2: Plays music choice 2.
music3: Plays music choice 3.
svaml.action.connectSip:
type: object
description: Determines how to route a call to a SIP server. Available to use in a response to an [Incoming Call Event](../../../voice/tag/Callbacks/#tag/Callbacks/operation/ice) callback.
required:
- name
- destination
properties:
name:
type: string
description: The name property. Must have the value `connectSip`.
enum:
- connectSip
default: "connectSip"
destination:
type: object
description: Specifies where to route the SIP call.
required:
- endpoint
properties:
endpoint:
type: string
description: The SIP address.
example: "46708000000@sip.foo.com"
maxDuration:
type: integer
description: The max duration of the call in seconds (max 14400 seconds). If the call is still connected at that time, it will be automatically disconnected.
example: 3000
cli:
type: string
description: Used to override the CLI (or caller ID) of the client. The phone number of the person who initiated the call is shown as the CLI. To set your own CLI, you may use your verified number or your Dashboard virtual number.
example: "private"
transport:
type: string
description: An optional parameter to specify the SIP transport protocol. If unspecified, UDP is used.
x-enumDescriptions:
UDP: User Datagram Protocol
TCP: Transmission Control Protocol
TLS: Transport Layer Security
suppressCallbacks:
type: boolean
description: If enabled, suppresses [ACE](../../voice/tag/Callbacks/#tag/Callbacks/operation/ace) and [DICE](../../voice/tag/Callbacks/#tag/Callbacks/operation/dice) callbacks for the call.
example: "false"
callHeaders:
type: array
description: "[Private SIP headers](../../sip-trunking/#receiving-calls-from-sinch-platform-to-your-sip-infrastructure) to send with the call."
items:
$ref: "#/components/schemas/callHeader"
moh:
type: string
description: Means "music on hold". If this optional parameter is included, plays music to the connected participant if the SIP call is placed on hold. If `moh` isn't specified and the SIP call is placed on hold, the user will only hear silence while during the holding period .
x-enumDescriptions:
ring: Plays a progress tone.
music1: Plays music choice 1.
music2: Plays music choice 2.
music3: Plays music choice 3.
svaml.action.connectStream:
type: object
description: Determines how to route a call to a Stream/websocket server. Available to use in a response to an [Incoming Call Event](../../../voice/tag/Callbacks/#tag/Callbacks/operation/ice) callback.
required:
- name
- destination
properties:
name:
type: string
description: The name property. Must have the value `connectStream`.
enum:
- connectStream
default: "connectStream"
destination:
type: object
description: Specifies where to route the Stream call.
required:
- type
- endpoint
properties:
type:
type: string
description: This attribute defines the streaming protocol - currently only Websocket is supported.
example: "Websocket"
endpoint:
type: string
description: The Stream/Websocket server address.
example: "wss://yourcompany.com/websocket-server"
maxDuration:
type: integer
description: The max duration of the call in seconds (max 14400 seconds). If the call is still connected at that time, it will be automatically disconnected.
example: 3000
callHeaders:
type: array
description: "These custom parameters (headers/messages) are sent to your WebSocket server in the initial message when the ConnectStream is established."
items:
$ref: "#/components/schemas/callHeader"
svaml.action.runMenu:
type: object
description: Plays an interactive voice response (IVR) menu to the callee. This menu can play pre-recorded files or text-to-speech messages, collect DTMF tones, and trigger the [Prompt Input Event](../../voice/tag/Callbacks/#tag/Callbacks/operation/pie) (PIE) callback towards your backend, notifying you of the actions the callee took. Available to use in a response to an [Incoming Call Event](../../voice/tag/Callbacks/#tag/Callbacks/operation/ice) callback or an [Answered Call Event](../../voice/tag/Callbacks/#tag/Callbacks/operation/ace) callback. Also be used in combination with the [Conferences](/docs/voice/api-reference/voice/tag/Conferences/#tag/Conferences) endpoint of the Calling API.
required:
- name
properties:
name:
type: string
description: The name property. Must have the value `runMenu`.
enum:
- runMenu
default: "runMenu"
barge:
type: boolean
description: "'Barging' means that the user can press a DTMF digit before the prompt has finished playing. If a valid input is pressed, the message will stop playing and accept the input. If `barge` is disabled, the user must listen to the entire prompt before input is accepted. By default, barging is enabled."
default: true
locale:
type: string
description: "The voice and language you want to use for the text-to-speech message. This can either be defined by the ISO 639 locale and language code or by specifying a particular voice. Supported languages and voices are detailed [here](../../voice-locales). If using the `enableVoice` to enable voice detection, the `locale` property is required in order to select the input language."
example: "en-US"
mainMenu:
type: string
description: "Selects the menu item from the `menus` array to play first."
example: "main"
enableVoice:
type: boolean
description: Enables voice detection. If enabled, users can say their answers to prompts in addition to entering them using the keypad.
menus:
type: array
description: The list of menus available. The menu with the `id` value of `main` will always play first. If no menu has an `id` value of `main`, an error is returned.
items:
$ref: "#/components/schemas/menu"
svaml.action.park:
type: object
description: Parks the call and places the caller on hold. The caller is placed into a loop, listening to an IVR prompt (either a pre-recorded audio file or generated by text to speech). If the call is unparked, prompts will stop playing immediately. If the max duration is reached, the last prompt will be fully played until the call ends.
required:
- name
properties:
name:
type: string
description: The name property. Must have the value `park`.
enum:
- park
default: "park"
locale:
type: string
description: "The voice and language you want to use for the text-to-speech message. This can either be defined by the ISO 639 locale and language code or by specifying a particular voice. Supported languages and voices are detailed [here](../../voice-locales)."
example: "en-US"
introPrompt:
type: string
description: That prompt that is played when the call is first answered. You can use text-to-speech using the `#tts[]` element, SSML commands using the `#ssml[]` element.
example: "#tts[Welcome]"
holdPrompt:
type: string
description: The prompt that is played on repeat until the call is unparked or the until the `maxDuration` value is reached. You can use text-to-speech using the `#tts[]` element, SSML commands using the `#ssml[]` element.
example: "#tts[Thank you for your patience, your call is very important to us.]"
maxDuration:
type: integer
description: The maximum amount of time in seconds that the `holdPrompt` will be played.
example: 180
svaml.instruction.playFiles:
type: object
description: Plays Interactive Voice Response (IVR) files for the supported locale or SSML commands at the Sinch backend. An IVR message is played only on the caller's side.
required:
- name
- ids
- locale
properties:
name:
type: string
description: The `name` property. Must have the value `playFiles`.
enum:
- playFiles
default: "playFiles"
ids:
type: array
description: The IDs of the files which will be played. These can be a URL to a file, SSML commands using the `#ssml[]` element, or text using the `#tts[]` element.
examples:
- ["Welcome", "https://path/to/file"]
- ["#ssml[Thank you for calling Sinch!]"]
locale:
type: string
description: If using SSML or TTS, this is a required field. The voice and language you want to use for the text-to-speech message. This can either be defined by the ISO 639 locale and language code or by specifying a particular voice. Supported languages and voices are detailed [here](../../voice-locales).
example: "en-US"
svaml.instruction.say:
type: object
description: Plays a synthesized text-to-speech message to the end user. The message is provided in the text field.
properties:
name:
type: string
description: The `name` property. Must have the value `say`.
enum:
- say
default: "say"
text:
type: string
description: Contains the message that will be spoken. Default maximum length is 600 characters. To change this limit, please contact support.
example: "Hello, thank you for calling Sinch!"
locale:
type: string
description: The voice and language you want to use for the text-to-speech message. This can either be defined by the ISO 639 locale and language code or by specifying a particular voice. Supported languages and voices are detailed [here](../../voice-locales).
example: "en-US"
svaml.instruction.sendDtmf:
type: object
description: Plays DTMF tones in the call.
properties:
name:
type: string
description: The `name` property. Must have the value `sendDtmf`.
enum:
- sendDtmf
default: "sendDtmf"
value:
type: string
description: |-
A string that determines the DTMF tones to play to the callee when the call is picked up.
Valid characters are: `0-9`, `#`, and `w`. `w` renders a 500ms pause. For example, the string `ww1234#w#`, plays a 1 second pause, the DTMF tones for `1`, `2`, `3`, `4`, and `#`, followed by a 500ms pause and finally the `#` tone.
This is useful if the callout destination requires a conference PIN code or an extension. If there is a calling party, it will hear progress while the DTMF is sent.
example: "ww1234#w#"
svaml.instruction.setCookie:
type: object
description: Creates a cookie for the duration of the call.
properties:
name:
type: string
description: The `name` property. Must have the value `setCookie`.
enum:
- setCookie
default: "setCookie"
key:
type: string
description: The name of the cookie you want to set.
example: "cookie_name"
value:
type: string
description: The value of the cookie you want to set.
example: "cookie_value"
svaml.instruction.answer:
type: object
description: Forces the callee to answer the call.
properties:
name:
type: string
description: The `name` property. Must have the value `answer`.
enum:
- answer
default: "answer"
svaml.instruction.startRecording:
type: object
description: Starts a recording of the call.
properties:
name:
type: string
description: The `name` property. Must have the value `startRecording`.
enum:
- startRecording
default: "startRecording"
options:
$ref: "#/components/schemas/svaml.instruction.startRecordingOptions"
svaml.instruction.startRecordingOptions:
type: object
description: An object that specifies details about the recording. For more details, see [Recording Options](../../recording/#recording-options).
properties:
destinationUrl:
type: string
credentials:
type: string
format:
type: string
notificationEvents:
type: boolean
transcriptionOptions:
type: object
properties:
enabled:
type: boolean
locale:
type: string
svaml.instruction.stopRecording:
type: object
description: Stops the recording of the call.
properties:
name:
type: string
description: The `name` property. Must have the value `stopRecording`.
enum:
- stopRecording
default: "stopRecording"
menu:
type: object
description: An IVR menu that contains an audio prompt as well as configured options.
required:
- id
properties:
id:
type: string
description: The identifier of a menu. One menu must have the ID value of `main`.
example: "main"
mainPrompt:
type: string
description: |-
The main voice prompt that the user hears when the menu starts the first time.
You can use text-to-speech using the `#tts[]` element, SSML commands using the `#ssml[]` element, pre-recorded messages, or URL references to external media resources. You can use multiple prompts by separating each prompt with a semi-colon (`;`). If multiple prompts are used, they will be played in the order they are specified, without any pauses between playback. For external media resources, you can use an `#href[...]` or directly specify the full URL. Check the [Supported audio formats](/docs/voice/api-reference/supported-audio-formats) section for more information.
repeatPrompt:
type: string
description: |-
The prompt that will be played if valid or expected DTMF digits are not entered.
You can use text-to-speech using the `#tts[]` element, SSML commands using the `#ssml[]` element, pre-recorded messages, or URL references to external media resources. You can use multiple prompts by separating each prompt with a semi-colon (`;`). If multiple prompts are used, they will be played in the order they are specified, without any pauses between playback. For external media resources, you can use an `#href[...]` or directly specify the full URL. Check the [Supported audio formats](/docs/voice/api-reference/supported-audio-formats) section for more information.
repeats:
type: integer
description: The number of times that the `repeatPrompt` is played.
example: 3
maxDigits:
type: integer
description: The maximum number of digits expected for a user to enter. Once these digits are collected, a [Prompt Input Event (PIE)](../../voice/tag/Callbacks/#tag/Callbacks/operation/pie) is triggered containing these digits.
timeoutMills:
type: integer
description: Determines silence for the purposes of collecting a DTMF or voice response in milliseconds. If the timeout is reached, the response is considered completed and will be submitted.
default: 5000
maxTimeoutMills:
type: integer
description: Sets a limit for the maximum amount of time allowed to collect voice input.
default: 20000
options:
type: array
description: The set of options available in the menu.
items:
$ref: "#/components/schemas/option"
option:
type: object
description: A configured option that the user can trigger to perform an action.
required:
- dtmf
- action
properties:
dtmf:
type: string
description: A DTMF digit the user can press to trigger the configured action.
example: "1"
action:
type: string
description: Determines which action is taken when the DTMF digit is pressed.
x-enumDescriptions:
return: Triggers a [Prompt Input Event](../../voice/tag/Callbacks/#tag/Callbacks/operation/pie) (PIE).
menu: Navigates to the named menu.
example: "menu(sub)"
callHeader:
type: object
description: |-
Call Headers can be used to pass custom data from a Sinch SDK client to another, or specified in an ICE response to be made available to the receiving client. Further, if Call Headers is specified they will be available in ICE and DICE events.
properties:
key:
type: string
description: The call header key of the key value pair.
value:
type: string
description: The call header value of the key value pair.
aceRequest:
type: object
description: The request body of an Answered Call Event.
properties:
event:
type: string
description: Must have the value `ace`.
default: "ace"
callId:
type: string
description: The unique ID assigned to this call.
timestamp:
$ref: "#/components/schemas/timeStamp"
version:
type: integer
description: The current API version.
custom:
type: string
description: A string that can be used to pass custom information related to the call.
amd:
type: object
description: If [Answering Machine Detection](/docs/voice/api-reference/amd_v2) (AMD) is enabled, this object contains information about whether the call was answered by a machine.
properties:
status:
type: string
description: The determination by the system of who answered the call.
x-enumDescriptions:
machine: An answering machine was detected as answering the call.
human: A human was detected as answering the call.
notsure: The system was unable to determine who answered the call.
hangup: The call was hung up.
example: machine
reason:
type: string
description: The reason that the system used to determine who answered the call.
x-enumDescriptions:
longgreeting: If the greeting is too long, this could be indicative of an answering machine.
initialsilence: If there is an initial silence after the call is answered before the greeting starts, this could be indicative of an answering machine.
example: longgreeting
duration:
type: integer
description: The length of the call.
example: 3
iceRequest:
type: object
description: The request body of an Incoming Call Event.
properties:
event:
type: string
description: Must have the value `ice`.
default: "ice"
callId:
type: string
description: The unique ID assigned to this call.
callResourceUrl:
type: string
description: The path of the API resource.
timestamp:
$ref: "#/components/schemas/timeStamp"
version:
type: integer
description: The current API version.
custom:
type: string
description: A string that can be used to pass custom information related to the call.
userRate:
type: object
description: The rate that will be charged for the call established to the original destination. If the SVAML response specifies another destination, the same rate may not apply.
$ref: "#/components/schemas/money"
cli:
type: string
description: The number that will be displayed to the recipient of the call. To set your own CLI, you may use your verified number or your Dashboard virtual number and add it to the `connectPSTN` SVAML response to the Incoming Call Event request. It must be in [E.164](https://community.sinch.com/t5/Glossary/E-164/ta-p/7537) format.
to:
type: object
description: An object containing information about the recipient of the call.
properties:
type:
type: string
description: The type of the destination.
endpoint:
type: string
description: The phone number, user name, or other identifier of the destination.
domain:
type: string
description: The domain destination of the incoming call.
x-enumDescriptions:
pstn: The call will be connected to a number in the PSTN.
conference: The call will be connected to a conference.
mxp: The call will be connected to a Sinch SDK client.
applicationKey:
type: string
description: The unique application key. You can find it in the Sinch [dashboard](https://dashboard.sinch.com/voice/apps).
originationType:
type: string
description: The origination domain of the incoming call.
x-enumDescriptions:
pstn: If the incoming call comes the PSTN (a local phone number mapped to your application).
mxp: If the incoming call comes from one of the Sinch SDKs (iOS, Android, or JavaScript) through a data connection.
duration:
type: integer
description: The duration of the call in seconds.
rdnis:
type: string
description: The redirected dialled number identification service.
callHeaders:
type: array
description: If the call is initiated by a Sinch SDK client, call headers are the headers specified by the *caller* client. Read more about call headers [here](../../../call-headers).
items:
$ref: "#/components/schemas/callHeader"
diceRequest:
type: object
description: The request body of a Disconnected Call Event.
properties:
event:
type: string
description: Must have the value `dice`.
default: "dice"
callId:
type: string
description: The unique ID assigned to this call.
timestamp:
$ref: "#/components/schemas/timeStamp"
reason:
type: string
description: The reason the call was disconnected.
x-enumDescriptions:
N/A: Not applicable.
TIMEOUT: The call exceeded the configured timeout.
CALLERHANGUP: The caller hung up the call.
CALLEEHANGUP: The callee hung up the call.
BLOCKED: The call was blocked.
MANAGERHANGUP: The call manager hung up the call.
NOCREDITPARTNER: No sufficient credit to make the call.
GENERALERROR: A non-specified error ended the call.
CANCEL: The call was canceled.
USERNOTFOUND: The user was not found.
CALLBACKERROR: An error with the callback ended the call.
result:
type: string
description: The result of the call.
x-enumDescriptions:
ANSWERED: The call was answered.
BUSY: The line called was busy.
NOANSWER: The line called failed to answer.
FAILED: The call failed.
version:
type: integer
description: The current API version.
custom:
type: string
description: A string that can be used to pass custom information related to the call.
debit:
type: object
description: An object containg currency and total amount charged for the call.
$ref: "#/components/schemas/money"
userRate:
type: object
description: An object containg currency and rate per minute for the call.
$ref: "#/components/schemas/money"
to:
type: object
description: An object containing information about the recipient of the call.
properties:
type:
type: string
description: The type of the destination.
endpoint:
type: string
description: The phone number, user name, or other identifier of the destination.
duration:
type: integer
description: The duration of the call in seconds.
from:
type: string
description: Information about the initiator of the call.
callHeaders:
type: array
description: If the call was initiated by a Sinch SDK client, call headers are the headers specified by the *caller* client. Read more about call headers [here](../../../call-headers/).
items:
$ref: "#/components/schemas/callHeader"
applicationKey:
type: string
description: The unique application key. You can find it in the Sinch [dashboard](https://dashboard.sinch.com/voice/apps).
pieRequest:
type: object
description: The request body of a Prompt Input Event.
properties:
event:
type: string
description: Must have the value `pie`.
default: "pie"
callId:
type: string
description: The unique ID assigned to this call.
timestamp:
$ref: "#/components/schemas/timeStamp"
menuResult:
type: object
description: An object containing information about the returned menu result.
properties:
menuId:
type: string
description: The ID of the menu that triggered the prompt input event.
type:
type: string
description: The type of information that's returned.
x-enumDescriptions:
Error: Returned if there's an error with the input.
Return: Returned when the event has been triggered from a `return` command.
Sequence: Returned when the event has been triggered from collecting DTMF digits.
Timeout: Returned when the timeout period has elapsed.
Hangup: Returned when the call is hung up.
InvalidInput: Returned when the value of the input is invalid.
value:
type: string
description: The value of the returned information.
inputMethod:
type: string
description: The type of input received.
x-enumDescriptions:
dtmf: The input is key presses of specified digits.
voice: The input is voice answers.
version:
type: integer
description: The current API version.
applicationKey:
type: string
description: The unique application key. You can find it in the Sinch [dashboard](https://dashboard.sinch.com/voice/apps).
notifyRequest:
type: object
description: The request body of a Notify Event.
properties:
event:
type: string
description: Must have the value `notify`.
default: "notify"
callId:
type: string
description: The unique ID assigned to this call.
version:
type: integer
description: The current API version.
type:
type: string
description: The type of information communicated in the notification.
custom:
type: string
description: An optional parameter containing notification-specific information.
notifyErrorRequest:
type: object
description: The request body of Notify Event notifying of an error.
properties:
event:
type: string
description: Must have the value `notify`.
version:
type: integer
description: The current API version.
type:
type: string
description: The type of information communicated in the notification. Must have the value `callingerror`.
callId:
type: string
description: The unique ID assigned to this call.
errorCode:
type: integer
description: The error code of the error.
errorMsg:
type: string
description: The error message of the error.
user:
type: string
description: The user ID that initiated the call.
custom:
type: string
description: An optional parameter containing notification-specific information.
domain:
type: string
enum:
- 'pstn'
- 'mxp'
- 'PSTN'
- 'MXP'
description: Can be either `pstn` for PSTN endpoint or `mxp` for data (app or web) clients.
example: "pstn"
destinationType:
type: string
description: Can be of type `number` for PSTN endpoints or of type `username` for data endpoints.
enum:
- number
- Number
- username
- Username
- sip
- did
example: number
price:
type: object
properties:
currencyId:
type: string
amount:
type: number
format: float
timeStamp:
type: string
description: |-
The timestamp in UTC format.
**Note:** The formatting does not respect `ISO-8601` and the returned value has the format `YYYY-MM-DDThh:mm:ss.SSS`. If you need to parse this value into a specific date object in your programming language, please append `Z` (Zulu time = UTC) at the end of the date value to match the `ISO-8601` format: `YYYY-MM-DDThh:mm:ss.SSSZ`.
example: "2023-04-21T14:45:51"
money:
type: object
properties:
currencyId:
type: string
description: The ID of the currency.
example: "USD"
amount:
type: number
description: The amount charged.
example: .15
tags:
- name: Callouts
description: A callout is a call made to a phone number or app using the API.
- name: Calls
description: Using the Calls endpoint, you can manage on-going calls or retrieve information about a call.
- name: Conferences
description: Using the Conferences endpoint, you can perform tasks like retrieving information about an on-going conference, muting or unmuting participants, or removing participants from a conference.
- name: Applications
description: You can use the API to manage features of applications in your project.
- name: Callbacks
description: |-
Controlling a call from your application backend is done by responding to callbacks from the Sinch platform and/or by calling REST APIs in the Sinch platform from your application's backend.
Read more about how callbacks work [here](/docs/voice/api-reference/callbacks).