Quantcast
Channel: IP АТС Asterisk
Viewing all articles
Browse latest Browse all 1135

Asterisk Auto Dialer GUI

$
0
0

Asterisk Auto Dialer GUI

Приложение сырое, но рабочее. Представлено, как примерреализации веб-интерфейса.
Если кто-нибудь сделает кнопку удаления кампании, поделитесь, плиззз, с другими пользователями.
delete from Campaign where CampaignName like 'имя кампании';

Оригнальный код by @navaismo

Веб интерфейс - Автообзвон абонентов

Приложение для автоматического обзвона абонентов по списку из базы данных.

  • Установка кол-ва одновременных вызовов.
  • Установка кол-ва попыток.
  • Интервал между повторами.
  • Статус и кол-во выполненных попыток.
  • Импорт списка абонентов из CSV фалов.
  • Назначение точки приема вызова.

Для оригинации вызовов используется метод Call Files Asterisk.

Вызываемый абонент может быть соединен с любым приложением Asterisk.

Руководство пользователя

http://ip_address/dialer

В примере: admin/admin

  • Campaign Name - уникальное имя кампании.
  • Import CSV File - импорт файла со списком вызываемых абонентов.

формат CSV

Name,Last Name,Number

Test,Testov,8121234567
Testy,Testova,8127654321

  • Maximum calls - Кол-во одновременных вызовов
  • Maximum Retries - Кол-во попыток дозвона на уникальный номер.
  • Retry Time - Интервал между попытками.
  • Endpoint - Назначение для приема вызова (Например, у вас есть очередь номер 701 назначенная в интерфейсе FreePBX, тогда вы пишите: 701@from-internal)

Установка

MySQL

 mysqladmin -u root -p create dialerdb;
 mysql -u root -p -e "GRANT ALL PRIVILEGES ON dialerdb.* TO user1@localhost IDENTIFIED BY 'pass1';"
 mysql -u root -p -e "flush privileges;"
 mysql -u root -p
 mysql> use dialerdb;
DROP TABLE IF EXISTS `Campaign`;
   CREATE TABLE `Campaign` (
  `ID` int(11) NOT NULL AUTO_INCREMENT,
  `CampaignName` varchar(80) CHARACTER SET utf8 NOT NULL,
  `LastIdDial` varchar(80) CHARACTER SET utf8 NOT NULL,
  `MaxCalls` varchar(80) CHARACTER SET utf8 NOT NULL,
  `destination` varchar(80) CHARACTER SET utf8 NOT NULL,
  PRIMARY KEY (`ID`)
) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8;
CREATE TABLE `login_admin` (
  `user_name` varchar(50) CHARACTER SET utf8 NOT NULL,
  `user_pass` varchar(50) CHARACTER SET utf8 NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

Создадим пользователя

 INSERT INTO login_admin(user_name,user_pass) VALUES('admin',SHA1('admin'));

HTML

Скачать

http://sourceforge.net/projects/asteriskautodialer/files/

tar zxvf dialersrc.tar.gz
cd dialersrc

Создадим веб директорию:

 mkdir /var/www/html/dialer

Скопируем файлы:

 cp -r HTML/* /var/www/html/dialer
 chown -R asterisk. /var/www/html/dialer

Добавим контекст в диалплан Asterisk:

 cat Asterisk/extensions_custom.conf >> /etc/asterisk/extensions_custom.conf

Модифицируйте контекст для ваших условий:

SIP/sip_trunk_name - замените на транк в вашей системе, например DAHDI/g1/${NUM}, если вы используете DAHDI.

[dialercheck]
exten => s,1,NoOp("**Dialerchek** Вызывает номер: ${NUM})
same => n,Set(CDR(accountcode)=DIALER)
same => n,Set(CDR(userfield)=${NUM})
same => n,Dial(SIP/sip_trunk_name/${NUM},60)
same => n, NoOp(SIP return code : ${HASH(SIP_CAUSE,${CDR(dstchannel)})})
same => n,NoOp(${DIALSTATUS})
same => n,Set(SIPC=${HASH(SIP_CAUSE,${CDR(dstchannel)})})

Скопируем AGI скрипты:

 cp -r AGI/* /var/lib/asterisk/agi-bin/
 chown -R asterisk. /var/lib/asterisk/agi-bin/DialerCamps
 chmod -R a+x /var/lib/asterisk/agi-bin/DialerCamps
 chown  asterisk. /var/lib/asterisk/agi-bin/di*
 chmod  a+x /var/lib/asterisk/agi-bin/di*

Config

 nano /var/www/html/dialer/config.php
	$host="localhost";
	$user="user1";
	$pass="pass1";
	$db="dialerdb";

Viewing all articles
Browse latest Browse all 1135

Trending Articles



<script src="https://jsc.adskeeper.com/r/s/rssing.com.1596347.js" async> </script>