play

View as MarkdownOpen in Claude

Play file(s), ringtones, speech or silence.

Properties

play
objectRequired

An object that accepts the following properties. Accepts either a single URL or multiple URLs. See audio source below.

play.status_url
string

HTTP or HTTPS URL to deliver play status events. Learn more about status callbacks.

Audio source

The play object accepts one of the following properties to specify the audio source:

play.url
stringRequired

A single playable sound. Authentication can also be set in the url in the format of username:password@url.

Playable sounds

Audio file from a URL

To play an audio file from the web, simply list that audio’s URL. Specified audio file should be accessible with an HTTP GET request. HTTP and HTTPS URLs are supported. Authentication can also be set in the url in the format of username:password@url.

Example: https://cdn.signalwire.com/swml/audio.mp3

Ring

To play the standard ringtone of a certain country, use ring:[duration:]<country code>.

The total duration can be specified in seconds as an optional second parameter. When left unspecified, it will ring just once. The country code must be specified. It has values like us for United States, it for Italy. For the list of available country codes, refer to the supported ringtones section below. For example:

ring:us - ring with the US ringtone once ring:3.2:uk - ring with the UK ringtone for 3.2 seconds

Speak using a TTS

To speak using a TTS, use say:<text to speak>. When using say, you can optionally set say_voice, say_language and say_gender in the play or prompt properties. For the list of useable voices and languages, refer to the supported voices and languages section below.

Silence

To be silent for a certain duration, use silence:<duration>. The duration is in seconds.

Variables

Read by the method:

  • say_voice: (in) - Optional voice to use for text to speech.
  • say_language: (in) - Optional language to use for text to speech.
  • say_gender: (in) - Optional gender to use for text to speech.

Possible values for voice, language, and ringtone

Supported voices and languages

To learn more about the supported voices and languages, please visit the Supported Voices and Languages Documentation.

Supported ring tones

Parameter
urls.ringAvailable values are the following ISO 3166-1 alpha-2 country codes: at, au, bg, br, be, ch, cl, cn, cz, de, dk, ee, es, fi, fr, gr, hu, il, in, it, lt, jp, mx, my, nl, no, nz, ph, pl, pt, ru, se, sg, th, uk, us, us-old, tw, ve, za.

StatusCallbacks

A POST request will be sent to status_url with a JSON payload like the following:

event_type
string

The type of event. Always calling.call.play for this method.

event_channel
string

The channel for the event, includes the SWML session ID.

timestamp
number

Unix timestamp (float) when the event was generated.

project_id
string

The project ID associated with the call.

space_id
string

The Space ID associated with the call.

params
object

An object containing playback-specific parameters.

params.call_id
string

The call ID.

params.node_id
string

The node handling the call.

params.control_id
string

The control ID for this play operation.

params.state
string

The current playback state. Valid values: playing, paused, finished, error.

Raw JSON example

1{
2 "event_type": "calling.call.play",
3 "event_channel": "swml:xxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx",
4 "timestamp": 1640000000.123,
5 "project_id": "xxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx",
6 "space_id": "xxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx",
7 "params": {
8 "call_id": "xxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx",
9 "node_id": "xxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx",
10 "control_id": "xxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx",
11 "state": "finished"
12 }
13}

Examples

Playing a single URL

1version: 1.0.0
2sections:
3 main:
4 - play:
5 url: 'https://cdn.signalwire.com/swml/audio.mp3'

Playing multiple URLs

1version: 1.0.0
2sections:
3 main:
4 - play:
5 urls:
6 - 'https://cdn.signalwire.com/swml/audio.mp3'
7 - 'say: this is something to say'
8 - 'silence: 3.0'
9 - 'ring:10.0:us'

Playing multiple URLs with volume adjusted

1version: 1.0.0
2sections:
3 main:
4 - play:
5 volume: 20
6 urls:
7 - 'https://cdn.signalwire.com/swml/audio.mp3'
8 - 'say: this is something to say'
9 - 'silence: 3.0'
10 - 'ring:10.0:us'

Specifying a voice to use for speaking

Globally

1version: 1.0.0
2sections:
3 main:
4 - set:
5 say_voice: gcloud.en-US-Neural2-A
6 - play:
7 url: 'say:Hi, do I sound different?'
8 - play:
9 url: 'say:I don''t, do I?'

For just one instance

1version: 1.0.0
2sections:
3 main:
4 - play:
5 url: 'say:Hi, do I sound different?'
6 say_voice: gcloud.en-US-Neural2-A
7 - play:
8 url: 'say:I was down with the flu'