Cliente em PHP para API da Totalvoice
- Gerenciamento das chamadas
- Consulta e envio de SMS
- Consulta e envio de TTS
- Consulta e envio de Audio
- Consulta e envio de Composto
- Consulta e envio de Conferência
- Gerenciamento da Conta
- Gerenciamento da Central
- Gerenciamento de DID
- PHP 5.5+
- Autoloader compatível com a PSR-4
- PHP deve estar compilado com a lib-curl
Para instalar a biblioteca basta adicioná-la via composer
composer require total-voice/php-client 1.*
Ou no composer.json
{
"total-voice/php-client": "1.*"
}
Podemos usar o composer para rodar os testes:
composer test
ou utilizando o .phar
php composer.phar test
Para utilizar esta biblioteca, primeiramente você deverá realizar um cadastro no site da Total Voice. Após a criação do cadastro será disponibilizado um AccessToken para acesso a API.
Com o AccessToken em mãos será possível realizar as consultas/cadastros conforme documentação da API
Os métodos da API que poderão ser invocados:
- audio
- central
- chamada
- composto
- conferencia
- conta
- perfil
- sms
- tts
A seguir um pequeno exemplo de como pode ser utilizada esta biblioteca.
<?php
// Consideramos que já existe um autoloader compatível com a PSR-4 registrado
use TotalVoice\Client as TotalVoiceClient;
$client = new TotalVoiceClient('access-token');
$response = $client->chamada->ligar('NUMERO-A', 'NUMERO-B');
echo $response->getContent();
<?php
// Considero que já existe um autoloader compatível com a PSR-4 registrado
use TotalVoice\Client as TotalVoiceClient;
$client = new TotalVoiceClient('access-token');
$response = $client->chamada->buscaChamada('ID_CHAMADA');
echo $response->getContent(); // {}
<?php
// Considero que já existe um autoloader compatível com a PSR-4 registrado
use TotalVoice\Client as TotalVoiceClient;
$client = new TotalVoiceClient('access-token');
$response = $client->chamada->encerrar('ID_CHAMADA');
echo $response->getContent(); // {}
<?php
// Considero que já existe um autoloader compatível com a PSR-4 registrado
use TotalVoice\Client as TotalVoiceClient;
$client = new TotalVoiceClient('access-token');
$response = $client->sms->enviar('NUMERO-DESTINO', 'SUA MENSAGEM');
echo $response->getContent(); // {}
<?php
// Considero que já existe um autoloader compatível com a PSR-4 registrado
use TotalVoice\Client as TotalVoiceClient;
$client = new TotalVoiceClient('access-token');
$response = $client->tts->enviar('NUMERO-DESTINO', 'SUA MENSAGEM');
echo $response->getContent(); // {}
<?php
// Considero que já existe um autoloader compatível com a PSR-4 registrado
use TotalVoice\Client as TotalVoiceClient;
$client = new TotalVoiceClient('access-token');
$response = $client->audio->enviar('NUMERO-DESTINO', 'SUA MENSAGEM');
echo $response->getContent(); // {}
<?php
// Considero que já existe um autoloader compatível com a PSR-4 registrado
use TotalVoice\Client as TotalVoiceClient;
$client = new TotalVoiceClient('access-token');
$response = $client->central->buscaRamal('ID-RAMAL');
echo $response->getContent(); // {}
<?php
// Considero que já existe um autoloader compatível com a PSR-4 registrado
use TotalVoice\Client as TotalVoiceClient;
$client = new TotalVoiceClient('access-token');
$response = $client->conta->buscaConta('ID_CONTA');
echo $response->getContent(); // {}
<?php
// Considero que já existe um autoloader compatível com a PSR-4 registrado
use TotalVoice\Client as TotalVoiceClient;
$client = new TotalVoiceClient('access-token');
$response = $client->perfil->consultaSaldo();
echo $response->getContent(); // {}
<?php
// Consideramos que já existe um autoloader compatível com a PSR-4 registrado
use TotalVoice\Client as TotalVoiceClient;
use TotalVoice\Api\Chamada;
$client = new TotalVoiceClient('access-token');
$service = new Chamada($client);
$response = $service->ligar('NUMERO-A', 'NUMERO-B');
echo $response->getContent();
<?php
// Consideramos que já existe um autoloader compatível com a PSR-4 registrado
use TotalVoice\Api\Chamada;
class MeuClient implements ClientInterface
{
}
$meuclient = new MeuClient('access-token');
$service = new Chamada($meuclient);
$response = $service->ligar('NUMERO-A', 'NUMERO-B');
<?php
// Consideramos que já existe um autoloader compatível com a PSR-4 registrado
use TotalVoice\Client as TotalVoiceClient;
use TotalVoice\Api\Chamada;
$client = new TotalVoiceClient('access-token', 'https://meuhost.com.br');
$service = new Chamada($client);
$response = $service->ligar('NUMERO-A', 'NUMERO-B');
<?php
use TotalVoice\Client as TotalVoiceClient;
use TotalVoice\Api\Chamada;
$client = new TotalVoiceClient('access-token');
$response = $client->did->listaEstoque();
<?php
use TotalVoice\Client as TotalVoiceClient;
use TotalVoice\Api\Chamada;
$client = new TotalVoiceClient('access-token');
$idDid = "10";
$response = $client->did->adquirir($idDid);
<?php
use TotalVoice\Client as TotalVoiceClient;
use TotalVoice\Api\Chamada;
$client = new TotalVoiceClient('access-token');
$didId = "11";
$uraId = null;
$response = $client->did->atualizar($idDid, $ramalId, $uraId);
<?php
use TotalVoice\Client as TotalVoiceClient;
use TotalVoice\Api\Chamada;
$client = new TotalVoiceClient('access-token');
$didId = "11";
$response = $client->did->excluir($didId);
<?php
use TotalVoice\Client as TotalVoiceClient;
use TotalVoice\Api\Chamada;
$client = new TotalVoiceClient('access-token');
$response = $client->did->lista();
Mais informações sobre os métodos disponíveis podem ser encontrados na documentação da API
Quer contribuir? clique aqui
Esta biblioteca segue os termos de uso da MIT