Create Call:
The notifications for the call being joined come back via Redis LIST as, you will use BRPOP or RPOP to retrieve these
RESTful API | #Restful with json body POST http://<server_url>/click2dial/calls # Payload prior to v3.0.0 { agent : <ext>, callee : <callee>, outbound_id: <outbound_id>, call_ref : <custom_call_ref> } # Payload from to v3.0.0 upwards, to fix spec design { agent : <ext>, callee : <callee>, outbound_id: <outbound_id>, contact_ref: <custom_call_ref> }
|
---|---|
WebRTC | From v3.0.0 Via SIP.js for this example: // Creates the user agent var userAgent = new SIP.UA({ uri : '<ext>@<server_url>', wsServers : ['ws://<server_url>:8088/ws'], authorizationUser: '<ext>', password : '<ext_password>', hackIpInContact : true }); // Call options var options = { media: { constraints: { audio: true, video: false }, render: { remote: { audio: document.getElementById('example-audio-tag'), }, }, }, extraHeaders : [ #SIP headers for Click2Dial Settings 'X-Platforma-Outbound-ID:<outbound_id>', 'X-Platforma-Contact-Ref:<custom_call_ref>' ] }; // Make the call var session = userAgent.invite('sip:<callee>@<server_url>', options); // Error while placing a call session.on('failed', function (request) { //http://sipjs.com/api/0.7.0/causes/ console.log('Call Failed'); //We send back special error messages for validation errors. var validationErrors = request.getHeaders('X-Platforma-Error'); if (0 < validationErrors.length) { validationErrors.forEach(function(error) { console.log('Validation Error: ', error); }); } });
|
Values:
<ext> | The agent extension number or the first number connected to the call
|
---|---|
<callee> | The number to dial: One of the following:
|
<outbound_id> | Number to use as caller ID: One of the following:
|
<custom_call_ref> | Your custom call reference specified for this call Alphanumeric and .-_~: Max length 230 characters, thereafter they are truncated |