Получение записи разговора по требованию
Иногда возникает необходимость в получении нескольких записей разговоров на почту. В данной статье будет рассмотрена возможность реализации данного функционала через сервисный код и скрипт php. Задача: при звонке на определённый сервисный код на почту звонящего должны быть отправлены 3 его последние записи разговоров (учитываются и входящие, и исходящие вызовы). Реализация: так как информация о звонках […]
Иногда возникает необходимость в получении нескольких записей разговоров на почту. В данной статье будет рассмотрена возможность реализации данного функционала через сервисный код и скрипт php.
Задача: при звонке на определённый сервисный код на почту звонящего должны быть отправлены 3 его последние записи разговоров (учитываются и входящие, и исходящие вызовы).
Реализация: так как информация о звонках и записи разговоров уже хранятся в таблице cdr, создадим таблицу соответствия внутренних номеров и почтовых адресов, на которые в дальнейшем будем отсылать записи разговоров.
Ранее мы уже рассматривали, как отсылать уведомления о пропущенных вызовах для определённых номеров на их почтовые адреса. Информацию о реализации данного функционала можно найти в данной статье.
После этого можем перейти к скрипту.
После этого можем перейти к скрипту.
<?php
$dsn = 'mysql:host=localhost; dbname=asteriskcdrdb';
$user = 'user';
$pass = 'password';
$path = '/var/spool/asterisk/monitor/';
try {
$dbh = new PDO($dsn, $user, $pass);
} catch (PDOException $e) {
die ('При подключении к базе данных возникла ошибка.' . $e->getMessage());
}
$number = isset($argv[1]) ? $argv[1] : "";
if ($number != ""){
$query_rec = "SELECT calldate, recordingfile FROM cdr WHERE (src = :num OR dst = :num) AND recordingfile != '' ORDER BY calldate DESC LIMIT 3";
$res = $dbh->prepare($query_rec);
$res->execute(array("num" => $number));
$result = $res->fetchAll(PDO::FETCH_ASSOC);
$query_email = "SELECT email FROM send_mail WHERE ext = :num";
$email_res = $dbh->prepare($query_email);
$email_res->execute(array("num" => $number));
$to = $email_res->fetchAll(PDO::FETCH_ASSOC);
$to = $to[0]['email'];
}else{
echo 'Ошибка! Номер не найден. Пожалуйста, проверьте номер и повторите запрос.';
}
$fileto = '';
foreach ($result as $value) {
$date_path = ParseQueryRec($value['calldate']);
$filename = $value['recordingfile'];
$file_path = $path . $date_path . "/" . $filename;
if (file_exists($file_path))
$fileto .= "-a " . $file_path . " ";
}
SendEmailRec($fileto, $to);
function ParseQueryRec($calldate){
$date = explode(" ", $calldate);
return str_replace("-", "/", $date[0]);
}
function SendEmailRec($fileto, $to){
exec("/usr/local/bin/sendEmail.pl -f [email protected] -t $to -u 'Записи разговоров' -m 'Во вложении к письму три последние записи разговоров для Вашего номера' $fileto -o message-charset=UTF-8");
}
?>
На этом остановимся и подробнее рассмотрим то, что прописано выше.
В переменную $dsn присваиваем данные для подключения к базе (хост и имя базы). Ниже прописываем логин и пароль от базы данных в переменные $user и $pass.
Также заведомо известно, что для данной задачи нам понадобится полный путь к записям разговоров. В нашем случае это /var/spool/asterisk/monitor/year/month/day. Однако год, месяц и день – динамические части полного пути. Поэтому путь мы будем создавать также из двух частей – статической и динамической. На этапе объявления переменных в $path присваиваем статическую часть пути — /var/spool/asterisk/monitor/.
Далее подключаемся к asteriskcdrdb. Если на данном шаге возникла ошибка, смотрим ошибку и перепроверяем подключение к mysql.
Теперь объявим переменную $number – она отвечает за номер, с которого в дальнейшем будем звонить на сервисный код. Её сразу же будем проверять на пустоту. В цикле ниже, если $number будет равен пустому значению, попросим перепроверить номер и повторить запрос. Если $number не пуст, пойдём по коду дальше.
В переменную $query_rec пропишем запрос. Этим запросом будем искать в таблице cdr поля calldate и recordingfile – последние три записи по номеру звонящего. На данном этапе сразу же убираем те записи таблицы, в которых поле recordingfile не будет содержать в себе имени аудиофайла.
Также здесь в переменную $query_email пропишем ещё один запрос, который будет вытаскивать email из таблицы send_mail для номера звонящего. Его запишем в переменную $to.
Далее объявим $fileto. В дальнейшем в неё будет помещён файл для отправки вместе с полным путём до него. На данном этапе же оставляем переменную пустой.
С помощью цикла foreach перебираем полученный в $result массив на такие элементы, как calldate и recordingfile. Здесь же из переменной $date_path вызываем функцию ParseQueryRec и передаём в неё calldate.
С помощью функции ParseQueryRec убираем из calldate время вызова. Также меняем все “-“.
Возвращаемся в foreach. После того, как в $filename передали recordingfile, формируем полный путь. Для этого в $file_path передаём $path, date_path и $filename. Не забываем указать “/” между путём до записи и именем записи.
Затем проверяем, существует ли файл. И, если файл существует, в $fileto добавляем перед именем файла ключ a, а после – пробел. Это нужно для отправки файла на почту.
Теперь, после foreach, вызываем функцию отправки – SendEmailRec. В неё должны быть переданы $fileto и $to.
В SendEmailRec с помощью sendEmail.pl произведём отправку записей на почту.
Чтобы проверить работоспособность скрипта, вызовем его в консоли. Для этого введём:
php -f send¬_rec.php 0008
0008 – номер звонящего.
После этого, если всё сделано верно, на почту придёт сообщение с файлами записей разговоров. Также, если используется sendEmail.pl, и настроено логирование, то в логе увидим следующее:
Также не забываем дать скрипту необходимые права для выполнения из под пользователя Asterisk.
chown -R asterisk:asterisk
Написание диалплана
После того, как убедились, что скрипт работает, перейдём к написанию диалплана. Делать это будем в файле extensions_custom.conf (/etc/asterisk).
Определимся с сервисным кодом. В примере это будет код *3132.
Подробнее о стандартных сервисных кодах можно прочитать в статье: «Сервисные коды Asterisk».
Также нам потребуется информация о месте размещения нашего скрипта. В примере это директория /usr/local/bin.
В контексте from-internal-custom пропишем следующий диалплан:
exten => *3132,1,Answer()
same => n,System(/usr/bin/php -f /usr/local/bin/send_rec.php ${CALLERID(num)})
same => n,Hangup()
После сохранения не забываем применить правки диалплана.
Теперь можно проверить работоспособность данного функционала. Для этого позвоним на сервисный код *3132.
Как видно из лога вызова, скрипт вызвался. Теперь перейдём на почту и проверим, не появились ли там новые письма.
На этом статья завершена.
Остались вопросы?
Я - Компаниец Никита, менеджер компании Voxlink. Хотите уточнить детали или готовы оставить заявку? Укажите номер телефона, я перезвоню в течение 3-х секунд.
категории
- DECT
- Linux
- Вспомогательный софт при работе с Asterisk
- Интеграция с CRM и другими системами
- Интеграция с другими АТС
- Использование Elastix
- Использование FreePBX
- Книга
- Мониторинг и траблшутинг
- Настройка Asterisk
- Настройка IP-телефонов
- Настройка VoIP-оборудования
- Новости и Статьи
- Подключение операторов связи
- Разработка под Asterisk
- Установка Asterisk
VoIP оборудование
ближайшие курсы
Новые статьи
10 доводов в пользу Asterisk
Распространяется бесплатно.
Asterisk – программное обеспечение с открытым исходным кодом, распространяется по лицензии GPL. Следовательно, установив один раз Asterisk вам не придется дополнительно платить за новых абонентов, подключение новых транков, расширение функционала и прочие лицензии. Это приближает стоимость владения станцией к нулю.
Безопасен в использовании.
Любое программное обеспечение может стать объектом интереса злоумышленников, в том числе телефонная станция. Однако, сам Asterisk, а также операционная система, на которой он работает, дают множество инструментов защиты от любых атак. При грамотной настройке безопасности у злоумышленников нет никаких шансов попасть на станцию.
Надежен в эксплуатации.
Время работы серверов некоторых наших клиентов исчисляется годами. Это значит, что Asterisk работает несколько лет, ему не требуются никакие перезагрузки или принудительные отключения. А еще это говорит о том, что в районе отличная ситуация с электроэнергией, но это уже не заслуга Asterisk.
Гибкий в настройке.
Зачастую возможности Asterisk ограничивает только фантазия пользователя. Ни один конструктор шаблонов не сравнится с Asterisk по гибкости настройки. Это позволяет решать с помощью Asterisk любые бизнес задачи, даже те, в которых выбор в его пользу не кажется изначально очевидным.
Имеет огромный функционал.
Во многом именно Asterisk показал какой должна быть современная телефонная станция. За многие годы развития функциональность Asterisk расширилась, а все основные возможности по-прежнему доступны бесплатно сразу после установки.
Интегрируется с любыми системами.
То, что Asterisk не умеет сам, он позволяет реализовать за счет интеграции. Это могут быть интеграции с коммерческими телефонными станциями, CRM, ERP системами, биллингом, сервисами колл-трекинга, колл-бэка и модулями статистики и аналитики.
Позволяет телефонизировать офис за считанные часы.
В нашей практике были проекты, реализованные за один рабочий день. Это значит, что утром к нам обращался клиент, а уже через несколько часов он пользовался новой IP-АТС. Безусловно, такая скорость редкость, ведь АТС – инструмент зарабатывания денег для многих компаний и спешка во внедрении не уместна. Но в случае острой необходимости Asterisk готов к быстрому старту.
Отличная масштабируемость.
Очень утомительно постоянно возвращаться к одному и тому же вопросу. Такое часто бывает в случае некачественного исполнения работ или выбора заведомо неподходящего бизнес-решения. С Asterisk точно не будет такой проблемы! Телефонная станция, построенная на Asterisk может быть масштабируема до немыслимых размеров. Главное – правильно подобрать оборудование.
Повышает управляемость бизнеса.
Asterisk дает не просто набор полезных функций, он повышает управляемость организации, качества и комфортности управления, а также увеличивает прозрачность бизнеса для руководства. Достичь этого можно, например, за счет автоматизации отчетов, подключения бота в Telegram, санкционированного доступа к станции из любой точки мира.
Снижает расходы на связь.
Связь между внутренними абонентами IP-АТС бесплатна всегда, независимо от их географического расположения. Также к Asterisk можно подключить любых операторов телефонии, в том числе GSM сим-карты и настроить маршрутизацию вызовов по наиболее выгодному тарифу. Всё это позволяет экономить с первых минут пользования станцией.