Introduction

With Webex Connect’s Voice API, you can build a custom voice calling application that accesses our voice network using a HTTPS-based interface. Embed inbound and outbound voice capabilities via a set of well defined APIs

Develop voice-enabled applications by simply sending and receiving HTTPS requests. When an incoming call comes to a phone number associated with your tenant, we will notify your application via a webhook event. Your application can then respond with actions to launch any of our features.

Actions - Answer, Play, Collect input (includes DTMF and speech), Record and Call Patch.

Creating a Phone Call

To create an outbound call from a Webex Connect number, you must make a POST request to our API v1 Make call endpoint (hyperlink). After this call is answered by the user, Webex Connect will send an event to the Callback URL (part of the Make call request), expecting an action (Play, Record, Call patch and Hangup) in response to continue the call.

Receiving a Phone Call

To handle incoming calls via APIs, configure the callback URL as part of the numbers section (hyperlink) in the Webex Connect. Upon receiving call, Webex Connect will notify the callback URL with information about the caller and the dialed number, expecting an Action(hyperlink)(Answer, Play, Record, and Call patch and hangup) in response to continue the call. Answer event will be applicable only for inbound usecases and it needs to be used as a response to Accept event only.

Events

Event NameDescription
AcceptedAccepted Event is sent from Webex Connect to Developer applications when incoming calls are received on the configured TFN number. For this request, Developer can send Answer/Handup action.
AnsweredAnswered Event is send from Webex Connect to Developer application when the calls are answered. For answered event developer application can send any media action or hangup action.
DroppedDrop event send from Webex Connect to Developer application when the calls are disconnected/dropped.
PlayedPlayed event is sent from Webex Connect to Developer application , when ongoing play completed for a call.
StreamedStreamed event sent from Webex Connect to Developer application when ASR completed and got streamtotext response.
RecordedRecorded event sent from Webex Connect to the developer application when the ongoing menu record is completed.
FailureFor any action failed at Webex Connect it will send the FAILURE EVENT name, Status as failure and Failure reason
PatchedPatched event is sent from Webex Connect to developer application when trombone call is connected.
Collected DigitsCollected Digits event is sent from Webex Connect to developer application when multiple DTMF digits are received from the user.
Voicemail DetectedVoicemail Detected event is sent from Webex Connect to developer application when the call is answered by voicemail. This event is triggered within 5 to 7 seconds after the call is answered, and the anticipated response to the event is a Play Action.
{
  "event": "ACCEPTED",
  "callerId": "+4475XXXXXXXX",
  "dialedNumber": "+4474XXXXXXXX",
  "offeredTime": "2023-04-25T05:14:50.178Z",
  "eventTime": "2023-04-25T05:14:52.031Z",
  "sessionId": "c51e56af-0c71-4917-98dd-53d299012e46"
}

{
"event": "ANSWERED",
  		"callerId": "+1315XXXXXXXX",
  "dialedNumber": "+9185XXXXXXXX",
 		 "offeredTime": "2022-11-17T09:22:55.624Z",
  "answeredTime": "2022-11-17T09:23:06.139Z",  
  "eventTime": "2022-11-17T09:23:06.161Z",
  "sessionId": "a12c95ad-1999-4669-ba72-25ed04d2d7c2"
}

{
  			"event": "DROPPED",
 			 "status": "SUCCESS",
  			 "droppedBy": "CALLEE",
  			 "error": {
    				"code": "2008",
    				"message": "Call Dropped by Network/End user"
 				 },
  "eventTime": "2023-02-21T10:08:52.562Z",
  			"sessionId": "a4a45c38-0a4d-48e0-85a6-f1f96796b258"
}

{
  			"status": "SUCCESS",
 			 "playedDuration": 1,
 			 "event": "PLAYED",
  			"eventTime": "2023-04-26T13:12:47.233Z",
  			"sessionId": "64277de6-29fd-48e6-b48b-54392465376d",
  			"transactionId": "c63cab3c-622a-4fed-8529-2960395e811d"
}

{
  	"event": "STREAMED",
  "callerId": "+131XXXXXXXX",
 	 "dialedNumber": "+9189XXXXXXXX",
  	"status": "SUCCESS",
 	 "text": "credit card",
  	"eventTime": "2022-12-07T16:46:06.343Z",
 	 "sessionId": "a12c95ad-1999-4669-ba72-25ed04d2d7c2",
 	 "transactionId": "3afd709e-3bb8-4f19-b797-ba6bf2a4b366"
}

{
  		"event": "RECORDED",
 		 "status": "SUCCESS",
 		 "recordingFileName": "https://anydomain.imiconnect.ca/voice-recordings/menu_1681891700_909100209630299_5.wav",
  		"recordingLength": 6,
  		"eventTime": "2023-04-19T08:08:32.132Z",
  		"sessionId": "133941b7-c052-450a-aa2c-026b790c2644",
  		"transactionId": "2bde1a0d-5f54-4afd-8ece-136893348466"
}

{
"event": "STREAMED",
  "callerId": "+13153055521",
  "dialedNumber": "+918919147207",
  "status": "FAILURE",
  "error": {
    "message": "HttpStream failed, error code 500"
  },
  "eventTime": "2022-12-07T16:48:12.891Z",
  "sessionId": "a12c95ad-1999-4669-ba72-25ed04d2d7c2",
  "transactionId": "1427e243-d3ed-453b-b5ab-7108f88a5084"
}

{
"event": "PATCHED",
  "eventTime": "2022-12-07T16:48:12.891Z",
  "sessionId": "a12c95ad-1999-4669-ba72-25ed04d2d7c2",
  "transactionId": "1427e243-d3ed-453b-b5ab-7108f88a5084",
  "status": "SUCCESS",
    "ConnectedOn":	"2022-12-07T16:48:15.891Z"
    "recordingFileName": [
    "1.wav","2.wav"
     ]
    "droppedBy":"CALLER"
            }


{
"event": "COLLECTED_DIGITS",
  "eventTime": "2022-12-07T16:48:12.891Z",
  "sessionId": "a12c95ad-1999-4669-ba72-25ed04d2d7c2",
  "transactionId": "1427e243-d3ed-453b-b5ab-7108f88a5084",
  "status": "SUCCESS",
    "numOfDigits":8
    "digitsReceived":"23458976",
    "terminationDigit":"1",
    "playedDuration":300,
            }

{
    "callerId": "+120XXX4345",
    "dialedNumber": "+447XXX22222",
    "event": "VMDETECTED",
    "eventTime": "2025-01-08T16:14:57.125Z",
    "sessionId": "870ab7d3-550f-46c3-8a20-2de285d2c8f5",
    "correlationId": "cpaastest12333333333333",
    "transactionId": "92332ada-2739-4cc1-axxbb-f3af37e443f0"
}

Actions

Action NameDescription
AnsweredAnswered action is sent from developer application to Webex Connect, to inform Webex Connect to answer the call
HangupHangup action is sent from developer application to Webex Connect, to inform Webex Connect to hang up or reject the call
PlayPlay action is sent from developer application to Webex Connect, to play the provided content file or to use TTS to play the audio corresponding to the TTS text which was specified.
PatchPatch action is sent from developer application to Webex Connect, to inform Webex Connect to perform call patch operation.
RecordRecord action is sent from developer application to Webex Connect, to inform Webex Connectt to perform record operation.
{
  "action": "ANSWER"
}


{
  "action": "REJECT",
  "reason": "Calltest Failed due to configured menu in reject state"
}

{
  "action": "PLAY",
  "audio": [
    {
      "type": "URL",
      "location": "https://www2.cs.uic.edu/~i101/SoundFiles/CantinaBand3.wav"
    },
    {
      "type": "TTS",
      "style": "NEURAL",
      "language": "en-US",
      "voice": "GuyNeural;Male",
      "gender": "MALE",
      "engine": "AZURE",
      "text": "greetings from cisco please enter 3 digits pin followed by # to patch "
    }
  ],
"collectInput":{
  "terminationDigit": "#",
  "maxDigits": 0,
  "digitTimeout": 5
},
"streamInput":{
  "timeout": 20,
  "maxsilence": 5,
  "model": "DEFAULT",
  "language": "en-US",
  "asrEngine": "GOOGLE",
    "recordStream": true,
	"singleUtterence":false,
"alternateLanguages":["fr-CA", "en-CA"]
}
          }
{
  "action": "PATCH",
  "recordCall": true,
  "holdAudio": {
    "type": "URL",
    "location": "https://www2.cs.uic.edu/~i101/SoundFiles/CantinaBand3.wav"
  },
  "greetingAudio": {
    "type": "TTS",
    "text": "thank you for waiting call is connected now"
  },
  "greetingRepeatCount": 0,
  "patchCallerId": "+15306544584",
  "dialedNumber": "+919985167784",
  "passDtmf": false
}

{
  "action": "RECORD",
  "audio": [
    {
      "type": "TTS",
      "style": "NEURAL",
      "language": "en-US",
      "voice": "GuyNeural;Male",
      "gender": "MALE",
      "engine": "AZURE",
      "text": " Hello buddy start recording now April 3rd 2023"
    }
  ],
  "timeoutSeconds": 20,
  "terminationDigit": "5"
}