Diffuser un flux audio lors d'un appel
Cet extrait de code lit un flux audio dans l'appel spécifié.
Exemple
Remplacez les variables suivantes dans le code de l'exemple :
| Clé | Description |
|---|---|
VOICE_CALL_ID | The UUID of the call leg. |
VOICE_STREAM_URL | The URL of the audio file that will be streamed into an array. The URL must be in an array. |
Conditions préalables
Exécutez la commande suivante à l'invite de votre terminal pour créer le site JWT pour l'authentification :
export JWT=$(nexmo jwt:generate $PATH_TO_PRIVATE_KEY application_id=$NEXMO_APPLICATION_ID)Rédiger le code
Ajouter ce qui suit à play-audio-into-a-call.sh:
curl -X PUT https://api.nexmo.com/v1/calls/$VOICE_CALL_ID/stream \
-H "Authorization: Bearer $JWT"\
-H "Content-Type: application/json"\
-d '{"stream_url": ["'"$VOICE_STREAM_URL"'"]}'Exécutez votre code
Enregistrez ce fichier sur votre machine et exécutez-le :
Conditions préalables
npm install @vonage/server-sdkCréez un fichier nommé stream-audio-into-a-call.js et ajoutez le code suivant :
const { Vonage } = require('@vonage/server-sdk');
const vonage = new Vonage({
applicationId: VONAGE_APPLICATION_ID,
privateKey: VONAGE_PRIVATE_KEY,
});Rédiger le code
Ajouter ce qui suit à stream-audio-into-a-call.js:
vonage.voice.streamAudio(VOICE_CALL_ID, VOICE_STREAM_AUDIO, 0)
.then((resp) => console.log(resp))
.catch((error) => console.error(error));
const stopStream = () => {
vonage.voice.stopStreamAudio(VOICE_CALL_ID)
.then((resp) => console.log(resp))
.catch((error) => console.error(error));
};
setTimeout(stopStream, 5000); // delay 5 secondsExécutez votre code
Enregistrez ce fichier sur votre machine et exécutez-le :
Conditions préalables
Ajouter ce qui suit à build.gradle:
implementation 'com.vonage:server-sdk-kotlin:2.1.1'Créez un fichier nommé StreamAudioIntoCall et ajoutez le code suivant à la méthode main:
val client = Vonage {
applicationId(VONAGE_APPLICATION_ID)
privateKeyPath(VONAGE_PRIVATE_KEY_PATH)
}Rédiger le code
Ajouter ce qui suit à la méthode main du fichier StreamAudioIntoCall:
val call = client.voice.call(VOICE_CALL_ID)
var streamInfo = call.streamAudio(VOICE_STREAM_URL)
Thread.sleep(5000)
streamInfo = call.stopStream()Exécutez votre code
Nous pouvons utiliser le plugin Applications pour Gradle afin de simplifier l'exécution de notre application. Mettez à jour votre build.gradle avec ce qui suit :
apply plugin: 'application'
mainClassName = project.hasProperty('main') ? project.getProperty('main') : ''Exécutez la commande gradle suivante pour exécuter votre application, en remplaçant com.vonage.quickstart.kt.voice par le paquet contenant StreamAudioIntoCall:
Conditions préalables
Ajouter ce qui suit à build.gradle:
implementation 'com.vonage:server-sdk:9.3.1'Créez un fichier nommé StreamAudioToCall et ajoutez le code suivant à la méthode main:
VonageClient client = VonageClient.builder()
.applicationId(VONAGE_APPLICATION_ID)
.privateKeyPath(VONAGE_PRIVATE_KEY_PATH)
.build();Rédiger le code
Ajouter ce qui suit à la méthode main du fichier StreamAudioToCall:
var response = client.getVoiceClient().startStream(VOICE_CALL_ID, VOICE_STREAM_URL, 0);
Thread.sleep(5000);
response = client.getVoiceClient().stopStream(VOICE_CALL_ID);Exécutez votre code
Nous pouvons utiliser le plugin Applications pour Gradle afin de simplifier l'exécution de notre application. Mettez à jour votre build.gradle avec ce qui suit :
apply plugin: 'application'
mainClassName = project.hasProperty('main') ? project.getProperty('main') : ''Exécutez la commande gradle suivante pour exécuter votre application, en remplaçant com.vonage.quickstart.voice par le paquet contenant StreamAudioToCall:
Conditions préalables
Install-Package VonageRédiger le code
Ajouter ce qui suit à PlayAudioStreamIntoCall.cs:
var credentials = Credentials.FromAppIdAndPrivateKeyPath(VONAGE_APPLICATION_ID, VONAGE_PRIVATE_KEY_PATH);
var client = new VonageClient(credentials);
var command = new StreamCommand() { StreamUrl = new[] { VOICE_STREAM_URL } };
var response = await client.VoiceClient.StartStreamAsync(VOICE_CALL_ID, command);Conditions préalables
composer require vonage/clientExécutez votre code
Enregistrez ce fichier sur votre machine et exécutez-le :
Conditions préalables
pip install vonage python-dotenvExécutez votre code
Enregistrez ce fichier sur votre machine et exécutez-le :
Conditions préalables
gem install vonageExécutez votre code
Enregistrez ce fichier sur votre machine et exécutez-le :
Essayez-le
Lorsque vous exécutez le code, un flux audio provenant du fichier spécifié est lu dans l'appel identifié par l'UUID spécifié.
Pour en savoir plus
- Conférence téléphonique - Ce guide explique les deux concepts que Vonage associe à un appel, un segment et une conversation.