Transfer a call with inline NCCO
A code snippet that shows how to transfer control of the current call to control using inline NCCO.
Example
Replace the following variables in the example code:
Key | Description |
---|---|
UUID |
The UUID of the call leg |
Prerequisites
Modifying an existing call requires that the UUID
provided is a currently active call. To modify a call, you must use the same VONAGE_APPLICATION_ID
and private key that were used to create the call.
Execute the following command at your terminal prompt to create the JWT for authentication:
export JWT=$(nexmo jwt:generate $PATH_TO_PRIVATE_KEY application_id=$NEXMO_APPLICATION_ID)
Write the code
Add the following to transfer-call-inline-ncco.sh
:
curl -X PUT https://api.nexmo.com/v1/calls/$UUID \
-H "Authorization: Bearer "$JWT \
-H "Content-Type: application/json"\
-d '{"action": "transfer",
"destination": {"type": "ncco", "ncco": [{"action":"talk", "text":"This is a transfer action using an inline NCCO"}]}}'
Run your code
Save this file to your machine and run it:
bash transfer-call-inline-ncco.sh
Prerequisites
Modifying an existing call requires that the UUID
provided is a currently active call. To modify a call, you must use the same VONAGE_APPLICATION_ID
and private key that were used to create the call.
npm install @vonage/server-sdk
Create a file named transfer-call-with-ncco.js
and add the following code:
const Vonage = require('@vonage/server-sdk');
const vonage = new Vonage({
apiKey: VONAGE_API_KEY,
apiSecret: VONAGE_API_SECRET,
applicationId: VONAGE_APPLICATION_ID,
privateKey: VONAGE_PRIVATE_KEY
}, {
debug: true
});
Write the code
Add the following to transfer-call-with-ncco.js
:
vonage.calls.update(UUID, {
action: 'transfer',
destination: {
"type": "ncco",
"ncco": [
"action": 'talk',
"text": 'This is a transfer action using an inline NCCO'
]
}
}, (err, res) => {
if (err) {
console.error(err);
} else {
console.log(res);
}
});
Run your code
Save this file to your machine and run it:
node transfer-call-with-ncco.js
Prerequisites
Modifying an existing call requires that the UUID
provided is a currently active call. To modify a call, you must use the same VONAGE_APPLICATION_ID
and private key that were used to create the call.
Add the following to `build.gradle`:
compile 'com.vonage:client:5.5.0'
Create a class named TransferCallNCCO
and add the following code to the main
method:
import com.vonage.client.VonageClient;
import com.vonage.client.voice.Call;
import com.vonage.client.voice.CallEvent;
import com.vonage.client.voice.ncco.Ncco;
import com.vonage.client.voice.ncco.TalkAction;
Add the following to the main
method of the TransferCallNCCO
class:
VonageClient client = VonageClient.builder()
.applicationId(VONAGE_APPLICATION_ID)
.privateKeyPath(VONAGE_PRIVATE_KEY_PATH)
.build();
Write the code
Add the following to the main
method of the TransferCallNCCO
class:
/*
Establish a call for testing purposes.
*/
final String ANSWER_URL = "https://nexmo-community.github.io/ncco-examples/long-tts.json";
CallEvent call = client.getVoiceClient().createCall(new Call(
TO_NUMBER,
VONAGE_NUMBER,
ANSWER_URL
));
/*
Give them time to answer.
*/
Thread.sleep(10000);
TalkAction talkAction = TalkAction.builder("This is a transfer action using an inline NCCO.").build();
Ncco ncco = new Ncco(talkAction);
final String UUID = call.getUuid();
client.getVoiceClient().transferCall(UUID, ncco);
Run your code
We can use the application
plugin for Gradle to simplify the running of our application.
Update your build.gradle
with the following:
apply plugin: 'application'
mainClassName = project.hasProperty('main') ? project.getProperty('main') : ''
Run the following gradle
command to execute your application, replacing com.vonage.quickstart.voice
with the package containing TransferCallNCCO
:
gradle run -Pmain=com.vonage.quickstart.voice.TransferCallNCCO
Prerequisites
Modifying an existing call requires that the UUID
provided is a currently active call. To modify a call, you must use the same VONAGE_APPLICATION_ID
and private key that were used to create the call.
Install-Package Vonage
Create a file named TransferCallNcco.cs
and add the following code:
using Vonage;
using Vonage.Request;
using Vonage.Voice;
using Vonage.Voice.Nccos;
Add the following to TransferCallNcco.cs
:
var credentials = Credentials.FromAppIdAndPrivateKeyPath(VONAGE_APPLICATION_ID, VONAGE_PRIVATE_KEY_PATH);
var client = new VonageClient(credentials);
Write the code
Add the following to TransferCallNcco.cs
:
var talkAction = new TalkAction() { Text = "This is a transfer action using an inline NCCO" };
var ncco = new Ncco(talkAction);
var callEditCommand = new CallEditCommand()
{
Action = CallEditCommand.ActionType.transfer,
Destination = new Destination()
{
Ncco = ncco
}
};
var response = client.VoiceClient.UpdateCall(UUID, callEditCommand);
Prerequisites
Modifying an existing call requires that the UUID
provided is a currently active call. To modify a call, you must use the same VONAGE_APPLICATION_ID
and private key that were used to create the call.
composer require vonage/client
Create a file named index.php
and add the following code:
require_once __DIR__ . '/../../config.php';
require_once __DIR__ . '/../../vendor/autoload.php';
$keypair = new \Vonage\Client\Credentials\Keypair(file_get_contents(VONAGE_APPLICATION_PRIVATE_KEY_PATH), VONAGE_APPLICATION_ID);
$client = new \Vonage\Client($keypair);
Write the code
Add the following to index.php
:
try {
$call = $client->voice()->get(UUID);
$ncco = new \Vonage\Voice\NCCO\NCCO();
$ncco->addAction(new \Vonage\Voice\NCCO\Action\Talk('This call was transferred'));
$client->voice()->transferCall(
$call->getUuid(),
new \Vonage\Voice\NCCO\Action\Transfer($ncco)
);
} catch (\Vonage\Client\Exception\Request $e) {
error_log("Client error: " . $e->getMessage());
exit(1);
} catch (\Vonage\Client\Exception\Server $e) {
error_log("Server error: " . $e->getMessage());
exit(1);
}
Run your code
Save this file to your machine and run it:
php index.php
Prerequisites
Modifying an existing call requires that the UUID
provided is a currently active call. To modify a call, you must use the same VONAGE_APPLICATION_ID
and private key that were used to create the call.
pip install vonage
Create a file named transfer-call-inline-ncco.py
and add the following code:
client = vonage.Client(
application_id=os.getenv('VONAGE_APPLICATION_ID'),
private_key=os.getenv("VONAGE_PRIVATE_KEY")
)
Write the code
Add the following to transfer-call-inline-ncco.py
:
voice = vonage.Voice(client)
response = voice.create_call({
"to": [{"type": "phone", "number": os.getenv('TO_NUMBER')}],
"from": {"type": "phone", "number": os.getenv('FROM_NUMBER')},
"ncco": [
{
"action": "talk",
"text": "This is just a text whilst you tranfer to another NCCO"
}
]
})
response = voice.update_call(
response["uuid"], {
"action": "transfer",
"destination": {
"type": "ncco",
"ncco": [{"action": "talk", "text": "hello world"}]
}
}
)
print(response)
Run your code
Save this file to your machine and run it:
python3 transfer-call-inline-ncco.py
Prerequisites
Modifying an existing call requires that the UUID
provided is a currently active call. To modify a call, you must use the same VONAGE_APPLICATION_ID
and private key that were used to create the call.
gem install vonage
Create a file named transfer-a-call-ncco.rb
and add the following code:
client = Vonage::Client.new(
application_id: VONAGE_APPLICATION_ID,
private_key: File.read(VONAGE_APPLICATION_PRIVATE_KEY_PATH)
)
Write the code
Add the following to transfer-a-call-ncco.rb
:
ncco = {
"type": 'ncco',
"ncco": [
"action": 'talk',
"text": 'This is a transfer action using an inline NCCO'
]
}
response = client.voice.transfer(UUID, destination: ncco)
puts response.inspect
Run your code
Save this file to your machine and run it:
ruby transfer-a-call-ncco.rb
Try it out
You will need to:
- Set up a call and obtain the call UUID. You could use the 'connect an inbound call' code snippet to do this.
- Run the example code to transfer the call.
- Control will be transferred to a new NCCO, and you will hear a text-to-speech message to confirm this.