我正在使用Twilio.Device JS构建一个自动拨号器



我正在用Twilio构建一个自动拨号器,我有点卡住了。我成功地从浏览器接到2个出站电话,当第一个挂断或忙碌时,第二个开始时。但是我想在我的SQL DB中的各种电话中实现许多电话。

这是我的代码 - 我是从连接到Twilio并获得令牌的开始对于第一款手机和DB的下一部电话(如果存在),最后我启动了一个twilio.device.connect,当第一个断开第二次开始连接时:

status_progress.php

                /********TWILIO **********/
            $.getJSON('../../twilio/token.php').done(function (data) {
            console.log('Token: ' + data.token);
            console.log('Identity: ' + data.identity);
            // Setup Twilio.Device
            Twilio.Device.setup(data.token);
            Twilio.Device.ready(function (device) {
            console.log('Twilio.Device Ready!');
            });
            Twilio.Device.error(function (error) {
            console.log('Twilio.Device Error: ' + error.message);
            });
            Twilio.Device.connect(function (conn) {
            console.log('Successfully established call!');
            });
            Twilio.Device.disconnect(function (conn) {
            console.log('Call ended.');
            });


            Twilio.Device.incoming(function (conn) {
            console.log('Incoming connection from ' + conn.parameters.From);
            var archEnemyPhoneNumber = '+12099517118';
            if (conn.parameters.From === archEnemyPhoneNumber) {
            conn.reject();
            console.log('It's your nemesis. Rejected call.');
            } else {
            // accept the incoming connection and start two-way audio
            conn.accept();
            }
            });

            //setClientNameUI(data.identity);
            })
            .fail(function () {
            console.log('Could not get a token from server!');
            });


            // Bind button to hangup call
            document.getElementById('closeCall').onclick = function () {
            console.log('Hanging up...');
            Twilio.Device.disconnectAll();
            };
            $("#phoneThem").live("click", function() { 
            var arr = [];
            var i =0;
            $('.checkDeal:checked').each(function () {
            arr[i++] = $(this).val();
            });
            var arr_value = JSON.stringify(arr);
            var conected = 'no';
            $.ajax({
            type: "POST",
            url: 'make_call_list.php',
            data: {arr_checked : arr_value}, // serializes the form's elements.
            success: function(calls)
            {
            $.getJSON('make_a_call.php').done(function (data) {
            var arr = data.arr;

            var params = {
            To: data.phone + '-' + data.crm
            };
            console.log('Calling ' + params.To + '...' );
            var connection = Twilio.Device.connect(params);

            connection.on('disconnect', function(conn) {
            console.log("the call has ended");
            var params2 = {
            To: data.phone_next + '-' + data.crm
            };

            console.log('Calling ' + params2.To + '...' );
            var connection_2 = Twilio.Device.connect(params2);
            });
            });


            }, // SUCCES MAKE A CALL LIST 
            });


            });

这是Twiml代码:

<?php
 require_once 'twilio-php-master/Twilio/autoload.php';
 use TwilioTwiMLVoiceResponse;
 $break = $_POST['To'];

 $break_arr = explode('-',$break);
 $prefix = '+972';
 $response = new VoiceResponse();
 $dial = $response->dial('', ['callerId' => '+972 50-225-8234']);
 $break_arr[0] = ltrim($break_arr[0] , '0');
 $break_arr[0] = $prefix.$break_arr[0] ;
 $dial->number($break_arr[0], ['statusCallbackEvent' => 'initiated 
 ringing answered completed',
 'statusCallback' => 
 'https://crm.unic.co.il/crm_test_zone/handleDialCallStatus.php? 
  crm='.$break_arr[1].'',
  'statusCallbackMethod' => 'POST']);

  echo $response;
 ?>

twilio开发人员在这里。

您可以使用Twilio设备中的回调函数来依次拨打所有数字,而不是依次拨号。

我要做的就是将所有要拨入前端拨入的数字加载到数组中。

然后,我将创建一个函数,该函数需要两个参数。您要拨打的数字的当前索引和数字数组。该函数将检查以确保当前索引仍在数组中,并且如果未返回(所有数字均已拨打)。否则,它将生成对数组中的号码的调用。它还将为该电话设置一个听闻事件的侦听器。断开连接时,它再次调用相同的函数,但在1中移动索引。

最后,用0的初始索引和数字数组调用该功能。有点这样的东西:

const array = getArrayOfNumbers();
function dialNumber(index, array) {
  if (index > array.length) return; 
  const connection = Twilio.Device.connect({ number: array[index] });
  connection.on('disconnected', function() {
    dialNumber(index+1, array);
  });
}
dialNumber(0, array);

让我知道这是否有帮助。

最新更新