# Документация администратора



# Групповой вызов абонентов

1\. Пример группового вызова абонентов

Set : DIALGROUP(group\_100,add)=PJSIP/user-101-domain  
Set : DIALGROUP(group\_100,add)=PJSIP/user-102-domain  
Set : DIALGROUP(group\_100,add)=PJSIP/user-103-domain  
Set : DIALGROUP(group\_100,add)=PJSIP/user-104-domain  
Set : DIALGROUP(group\_100,add)=PJSIP/user-105-domain  
Dial : ${DIALGROUP(group\_100)},60,tT

# Добавление нового абонента

1\. Настройка адреса записи

Канальный драйвер - Адрес записи.  
Добавить.

Наименование - Наименование адреса записи, Пример user-100-domain.  
Описание - Произвольное описание адреса записи.  
Идентификатор - Идентификатор адреса записи, является уникальным. Пример: user-100-domain.  
Контакт - Можно закрепить постоянный контакт за адресом записи.  
Истечение срока действия по умолчанию - Через какое время требовать регистрацию абонентского устройства. Пример 600.  
Почтовые ящики -   
Максимальное количество контактов - Максимальное количество контактов закрепленные за адресом записи.  
Минимальный срок действия - Минимальный срок действия регистрации.  
Удалить существующий - При повторной регистрации удаляет существующий контакт и заменяется новым.  
Частота квалификации - Время проверки абонентского устройства.  
Аутентификация квалификаций - Требуется ли аутентификация при квалификации.  
Максимальный срок действия - Максимальный срок действия регистрации.  
Исходящий прокси - Исходящий прокси.  
Квалификация контакта только при ответе со статусом 2xx - Квалификация контактов происходит если только ответ от другой стороны приходит со статусом 2xx.  
Поддержка Path - Включает поддержку Path для запросов регистрации.  
Таймаут квалификации - Время ожидания ответа от абонентского устройства.  
Расширение голосовой почты -  
Удалить недоступные - Удалить контакты если при проверке они являются не доступными.  
Группа - Группа в которую входит адрес записи.

2\. Настройка аутентификации

Канальный драйвер - Аутентификация  
Добавить

Наименование - Наименование аутентификации. Пример user-100-domain.  
Описание - Произвольное описание аутентификации.  
Идентификатор - Идентификатор аутентификации. Пример user-100-domain.  
Тип аутентификации - Какой тип аутентификации используется.  
Хэш md5 - Пароль в виде хэша md5.  
Пароль - Пароль  
Область - Область передаваемая в заголовках.  
Имя пользователя - Имя пользователя авторизации. Пример user-100-domain.  
Группа - Группа в которую входит аутентификация.

3\. Настройка конечной точки.

Канальный драйвер - Конечная точка.  
Добавить.

Наименование - Наименование конечная точки. Пример user-100-domain.  
Описание - Произвольное описание конечная точки.  
Идентификатор - Идентификатор конечная точки. Пример user-100-domain.  
Транспорт - Используемый транспорт  
Адрес записи - Используемый адрес записи  
Аутентификация - Используемая аутентификация.  
Маршрутизация - Используемая маршрутизация.  
Запрещенные кодеки - Запрещенные кодеки.  
Разрешенные кодеки - Разрешенные кодеки.  
Прямое медиа - Дает возможность соединять абонентов в обход станции.  
Режим DTMF - Режим DTMF.  
Использование обратного порта - Для инициализации звонка используется обратный порт.  
Поддержка ICE -  
Музыка на удержании - Музыка на удержании для абонента.  
Исходящая аутентификация - Исходящая аутентификация.  
Перезаписать контакт -   
Симметричный RTP -   
Заголовок P-Asserted-Identity -   
Заголовок Remote-Party-ID -   
Определитель номера - Определитель номера. Пример: User &lt;100&gt;  
Группа перехвата - Группа перехвата в которую входит конечная точка.  
Перехват групп - Какие группы может перехватывать конечная точка.  
Обнаружение факса -  
Поддержка T.38 -  
От домена - От какого домена отправлять запросы.  
От пользователя - От какого пользователя отправлять запросы.  
Таймаут RTP - Количество секунд после которых канал считается мертвым.  
Контроль доступа - IP адреса с которых разрешена регистрация абонентов.  
Индикаторы статуса -   
Поддержка WebRTC -  
Группа - Группа в которую входит конечная точка.

# Запись звонков в многоканальном режиме

Начиная с версии 8.3.4

Для настройки записи в многоканальном режиме необходимо изменить глобальную переменную MIXMONITOR\_COMMAND в маршрутизации. Данный параметр можно изменить только в базе данных в таблице static\_extensions.

Значение переменной по умолчанию:  
/var/lib/asterisk/scripts/wavtompeg/script.php --uniqueid="^{UNIQUEID}"

Значение переменной для записи в многоканальном режиме:  
/var/lib/asterisk/scripts/wavtostereompeg/script.php --uniqueid="^{UNIQUEID}"

Для записи разговора используется приложение MixMonitor с параметрами:  
MixMonitor: ${UNIQUEID}.wav,,${MIXMONITOR\_COMMAND}

Настройки приложения для записи в многоканальном режиме  
MixMonitor: ${UNIQUEID}.wav,r(${UNIQUEID}\_receive.wav)t(${UNIQUEID}\_transmit.wav),${MIXMONITOR\_COMMAND}

Для изменения параметра во всей телефонной станции необходимо выполнить запрос:

Выбрать строки:  
SELECT \* FROM `realtime\_extensions` WHERE `app` = "MixMonitor";

Для записи в одноканальном режиме необходимо заменить строки выполнив следующий запрос:  
UPDATE `realtime\_extensions` SET `appdata` = "${UNIQUEID}.wav,,${MIXMONITOR\_COMMAND}" WHERE `app` = "MixMonitor";

Для записи в многоканальном режиме необходимо заменить строки выполнив следующий запрос:  
UPDATE `realtime\_extensions` SET `appdata` = "${UNIQUEID}.wav,r(${UNIQUEID}\_receive.wav)t(${UNIQUEID}\_transmit.wav),${MIXMONITOR\_COMMAND}" WHERE `app` = "MixMonitor";

# Настройка автоматического обзвона

1\. Предварительно необходимо настроить две маршрутизации. Для исходящих вызовов и для приветствия.

2\. Загрузите файл голосового приветствия на сервер через модуль Медиа -&gt; Аудиофайлы.

Назовите файл demo-domain.

3\. Настройка маршрутизации.

Пример маршрутизации проигрывания файла:

Маршрутизация: ivr-autodial-domain.

Расширение: s.

NoOp  
Answer  
Playback : demo-domain  
Hangup

Маршрутизация: outgoing-71234567890-domain.

Добавить расширение: h в исходящей маршрутизации.

NoOp : Переменные при завершении  
AGI : autodial/dialstatus.php,--dialstatus="${DIALSTATUS}",--contact\_uuid="${contact\_uuid}"  
Hangup

4\. После настройки маршрутизации можно переходить к настройкам автоматического обзвона.

# Настройка уведомлений Телеграм

1\. Авторизуемся на телефонной станции.

2\. Поиск идентификатора чата сотрудника.

Для поиска идентификатора чата, необходимо что бы сотрудник отписался боту телеграм.  
В телефонной станции заходим в меню Отладка - Телеграм.  
Если сотрудник отписался боту, то можно увидеть сообщение от данного сотрудника и его идентификатор чата.  
Данные об идентификаторе чата отображаются в течении последних 24 часов с момента написания телеграм боту.

3\. Настройка контактов получателей сообщений.

Заходим в меню Модули - Телеграм.  
Открываем список контактов получателей через Контакты в необходимой строке.  
Добавляем сотрудника в список контактов получателей:  
Наименование - Любое наименование.  
Описание - Описание контакта.  
Включен: Да.  
Идентификатор чата - идентификатор чата скопированный из отладки.

# Переадресация на сотовые номера сотрудников

#### Переадресация при входящих вызовах

Для настройка вызова на сотовый, необходимо использовать приложение Dial. Добавляется в место где необходимо произвести вызов на сотовый.

```
Dial: SIP/<Номер>@<Транк>,<Время>
```

Номер - Номер абонента  
Транк - Транк через который совершается вызов  
Время - Время дозвона абонента

Пример:

```
NoOp: Входящий вызов
...
...
...
Dial: SIP/user-110-office,15,tT
Dial: SIP/81234567890@peer-71234567890-office,60
Hangup
```

#### Переадресация при добавочных вызовах

Для настройки переадресации при наборе добавочного номера необходимо добавить в маршрутизацию добавочных номеров расширение 110.

Пример маршрутизации добавочного номера 110 с переадресацией на сотовый:

```
NoOp: Вызов на добавочный номер
Dial: SIP/user-110-office,15,t
Dial: SIP/81234567890@peer-71234567890-office,60
Hangup
```

#### Переадресация при внутренних вызовах

Для настройки переадресации при наборе внутреннего номера необходимо добавить в маршрутизацию внутренних номеров расширение 110.

Пример маршрутизации внутреннего номера 110 с переадресацией на сотовый:

```
NoOp: Вызов на внутренний номер
...
...
...
Dial: SIP/user-110-office,15,tT
Dial: SIP/81234567890@peer-71234567890-office,60
Hangup
```

# Перевод транспорта на статическую конфигурацию

1\. Отключение realtime для конфигурации транспорта.

update `static\_sorcery` set `commented` = 1 where `filename` = "sorcery.conf" and `category` = "res\_pjsip" and `var\_name` = "transport";

2\. Добавление статической конфигурации.

insert into static\_pjsip (cat\_metric,var\_metric,commented,filename,category,var\_name,var\_val) values (0,0,0,"pjsip.conf","transport-udp","type","transport");  
insert into static\_pjsip (cat\_metric,var\_metric,commented,filename,category,var\_name,var\_val) values (0,0,0,"pjsip.conf","transport-udp","protocol","udp");  
insert into static\_pjsip (cat\_metric,var\_metric,commented,filename,category,var\_name,var\_val) values (0,0,0,"pjsip.conf","transport-udp","bind","0.0.0.0:5060");  
insert into static\_pjsip (cat\_metric,var\_metric,commented,filename,category,var\_name,var\_val) values (0,0,0,"pjsip.conf","transport-udp","local\_net","192.168.0.0/24");  
insert into static\_pjsip (cat\_metric,var\_metric,commented,filename,category,var\_name,var\_val) values (0,0,0,"pjsip.conf","transport-udp","external\_media\_address","1.1.1.1");  
insert into static\_pjsip (cat\_metric,var\_metric,commented,filename,category,var\_name,var\_val) values (0,0,0,"pjsip.conf","transport-udp","external\_signaling\_address","1.1.1.1");  
insert into static\_pjsip (cat\_metric,var\_metric,commented,filename,category,var\_name,var\_val) values (0,0,0,"pjsip.conf","transport-udp","external\_signaling\_port","5060");  
insert into static\_pjsip (cat\_metric,var\_metric,commented,filename,category,var\_name,var\_val) values (0,0,0,"pjsip.conf","transport-udp","allow\_reload","yes");

insert into static\_pjsip (cat\_metric,var\_metric,commented,filename,category,var\_name,var\_val) values (0,0,0,"pjsip.conf","transport-tcp","type","transport");  
insert into static\_pjsip (cat\_metric,var\_metric,commented,filename,category,var\_name,var\_val) values (0,0,0,"pjsip.conf","transport-tcp","protocol","tcp");  
insert into static\_pjsip (cat\_metric,var\_metric,commented,filename,category,var\_name,var\_val) values (0,0,0,"pjsip.conf","transport-tcp","bind","0.0.0.0:5061");  
insert into static\_pjsip (cat\_metric,var\_metric,commented,filename,category,var\_name,var\_val) values (0,0,0,"pjsip.conf","transport-tcp","local\_net","192.168.0.0/24");  
insert into static\_pjsip (cat\_metric,var\_metric,commented,filename,category,var\_name,var\_val) values (0,0,0,"pjsip.conf","transport-tcp","external\_media\_address","1.1.1.1");  
insert into static\_pjsip (cat\_metric,var\_metric,commented,filename,category,var\_name,var\_val) values (0,0,0,"pjsip.conf","transport-tcp","external\_signaling\_address","1.1.1.1");  
insert into static\_pjsip (cat\_metric,var\_metric,commented,filename,category,var\_name,var\_val) values (0,0,0,"pjsip.conf","transport-tcp","external\_signaling\_port","5061");  
insert into static\_pjsip (cat\_metric,var\_metric,commented,filename,category,var\_name,var\_val) values (0,0,0,"pjsip.conf","transport-tcp","allow\_reload","yes");

# Приложение Record

#### Краткое содержание

Запись в файл.

#### Описание

Если имя файла содержит «%d», эти символы будут заменены числом, увеличивающимся на единицу при каждой записи файла. Пользователь может нажать «#», чтобы прекратить запись и перейти к следующему приоритету. Если пользователь повесит трубку во время записи, все данные будут потеряны и приложение закроется.

- RECORDED\_FILE - Будет установлено окончательное имя файла записи без расширения.
- RECORD\_STATUS - Это окончательный статус команды
    
    
    - DTMF- Был получен завершающий DTMF ('#' или '\*', в зависимости от опции 't')
    - SILENCE- В записи возникла максимальная тишина.
    - SKIP- На линию еще не ответили и была указана опция 's'.
    - TIMEOUT- Достигнута максимальная длина.
    - HANGUP- Канал завис.
    - ERROR- Произошла неисправимая ошибка, повлекшая за собой ПРЕДУПРЕЖДЕНИЕ в журналах.

#### Синтаксис

Record(filename.format,\[silence,\[maxduration,\[options\]\]\])

#### Аргументы

- filename
    
    
    - filename - **необходимый**
    - format - **требуется** - формат типа записываемого файла (wav, gsm и т. д.).
- silence - Количество секунд молчания, которое можно разрешить перед возвращением.
- maxduration - Максимальная продолжительность записи в секундах. Если отсутствует или равен 0, то максимума нет.
- options
    
    
    - a - Добавлять к существующей записи, а не заменять.
    - n - Не отвечайте, но все равно запишите, если на линии еще не ответили.
    - o - Выход при нажатии 0, установив для переменной **RECORD\_STATUS** значение «OPERATOR» вместо «DTMF».
    - q - тихо (не издавать звуковой сигнал).
    - s - пропустить запись, если на линии еще нет ответа.
    - t - используйте альтернативный ключ завершения '\*' (DTMF) вместо стандартного '#'
    - u - Не обрезайте записанное молчание.
    - x - Игнорировать все клавиши терминатора (DTMF) и продолжать запись до зависания.
    - k - Сохранять записанный файл после зависания.
    - y - Прекратить запись, если получена какая-либо цифра DTMF*.*

# Ручное резервное копирование автоматической телефонной станции

Заходим через putty на сервер.

Для удобства можно использовать приложение Midnight Commander.

\# mc

Создаем во временной папке \\tmp, папку куда будем заливать резервные копии, и в будущем заархивируем (например backup).

\# mkdir /tmp/backup

Копируем в нее, сохраняя всю структуру, папки:

etc/asterisk  
opt/evolvex  
var/lib/asterisk  
var/www/html

Ниже производим действие в консоли:

\# cd /tmp/backup  
\# mysqldump -p pbx &gt; pbx.sql (вводим пароль от базы)

В папке backup должен появиться файл pbx.sql

Теперь всю папку backup заархивируем - находясь в папке tmp пропишем в консоли:

\# cd /tmp  
\# tar czf archive.tar.gz /tmp/backup/

Полученный архив закачиваем на обменник, можно по ftp (логин@адрес\_фтп\_сервера) и вводим пароль пользователя.

# Ручное создание резервной копии АТС

1\. Запускается под администратором.

mkdir /tmp/backup  
mysqldump -upbx -ppassword pbx &gt; /tmp/backup/pbx.sql  
mkdir /tmp/backup/etc  
mkdir /tmp/backup/var  
mkdir /tmp/backup/var/lib  
mkdir /tmp/backup/var/www  
mkdir /tmp/backup/var/www/html  
cp -R /etc/asterisk /tmp/backup/etc/asterisk  
cp -R /var/lib/asterisk /tmp/backup/var/lib/asterisk  
cp -R /var/www/html/pbx /tmp/backup/var/www/html/pbx  
cp -R /opt /tmp/backup  
tar cfvz /tmp/backup.tar.gz /tmp/backup

2\. Скопировать резервную копию backup.tar.gz на другой носитель.

# Синтез речи

#### Введение

Для оперативного создания голосовых приветствий и интерактивных голосовых меню в версии 8.0.0 была реализована возможность синтезировать речь через Web интерфейс телефонной станции. Данный модуль использует синтез от компании Яндекс. Для подключения данного модуля необходимо получить Yandex IAM Token. Полученный токен необходимо ввести в Настройки - Яндекс - Yandex IAM Token.

#### Синтез речи

Для работы с синтезом речи необходимо открыть меню Медиа - Синтез речи. Откроется окно настроек синтеза речи.

[![image.png](https://docs.enxx.ru/uploads/images/gallery/2024-10/scaled-1680-/RnOY9Do05kuzBKhe-image.png)](https://docs.enxx.ru/uploads/images/gallery/2024-10/RnOY9Do05kuzBKhe-image.png)

Для выбора голоса и амплуа необходимо воспользоваться таблицей ниже.

<table id="bkmrk-%D0%93%D0%BE%D0%BB%D0%BE%D1%81-%D0%9F%D0%BE%D0%BB-%D0%90%D0%BC%D0%BF%D0%BB%D1%83%D0%B0-ale" style="width: 100%; height: 844px;"><thead><tr><th style="width: 27.0674%;">Голос</th><th style="width: 10.0112%;">Пол</th><th style="width: 62.9101%;">Амплуа</th></tr></thead><tbody><tr><td style="width: 27.0674%;">`alena` (по умолчанию)  
</td><td style="width: 10.0112%;">Ж</td><td style="width: 62.9101%;">(по умолчанию) нейтральная — `neutral`   
радостная — `good`   
</td></tr><tr><td style="width: 27.0674%;">`filipp`</td><td style="width: 10.0112%;">M</td><td style="width: 62.9101%;">—</td></tr><tr><td style="width: 27.0674%;">`ermil`</td><td style="width: 10.0112%;">M</td><td style="width: 62.9101%;">(по умолчанию) нейтральный — `neutral`   
радостный — `good`</td></tr><tr><td style="width: 27.0674%;">`jane`</td><td style="width: 10.0112%;">Ж</td><td style="width: 62.9101%;">(по умолчанию) нейтральная — `neutral`   
радостная — `good`   
раздраженная — `evil`</td></tr><tr><td style="width: 27.0674%;">`madirus`</td><td style="width: 10.0112%;">M</td><td style="width: 62.9101%;">—</td></tr><tr><td style="width: 27.0674%;">`omazh`</td><td style="width: 10.0112%;">Ж</td><td style="width: 62.9101%;">(по умолчанию) нейтральная — `neutral`   
раздраженная — `evil`</td></tr><tr><td style="width: 27.0674%;">`zahar`</td><td style="width: 10.0112%;">M</td><td style="width: 62.9101%;">(по умолчанию) нейтральный — `neutral`   
радостный — `good`</td></tr><tr><td style="width: 27.0674%;">`dasha`</td><td style="width: 10.0112%;">Ж</td><td style="width: 62.9101%;">(по умолчанию) нейтральная — `neutral`   
радостная — `good`  
дружелюбная — `friendly`</td></tr><tr><td style="width: 27.0674%;">`julia`</td><td style="width: 10.0112%;">Ж</td><td style="width: 62.9101%;">(по умолчанию) нейтральная — `neutral`   
строгая — `strict`</td></tr><tr><td style="width: 27.0674%;">`lera`</td><td style="width: 10.0112%;">Ж</td><td style="width: 62.9101%;">(по умолчанию) нейтральная — `neutral`   
дружелюбная — `friendly`</td></tr><tr><td style="width: 27.0674%;">`masha`</td><td style="width: 10.0112%;">Ж</td><td style="width: 62.9101%;">(по умолчанию) радостная — `good`   
строгая — `strict`   
дружелюбная — `friendly`</td></tr><tr><td style="width: 27.0674%;">`marina`</td><td style="width: 10.0112%;">Ж</td><td style="width: 62.9101%;">(по умолчанию) нейтральная — `neutral`   
шепот — `whisper`   
дружелюбная — `friendly`</td></tr><tr><td style="width: 27.0674%;">`alexander`</td><td style="width: 10.0112%;">M</td><td style="width: 62.9101%;">(по умолчанию) нейтральный — `neutral`   
радостный — `good`</td></tr><tr><td style="width: 27.0674%;">`kirill`</td><td style="width: 10.0112%;">M</td><td style="width: 62.9101%;">(по умолчанию) нейтральный — `neutral`   
строгий — `strict`   
радостный — `good`</td></tr><tr><td style="width: 27.0674%;">`anton`</td><td style="width: 10.0112%;">M</td><td style="width: 62.9101%;">(по умолчанию) нейтральный — `neutral`   
радостный — `good`</td></tr></tbody></table>

В текстовом поле добавить необходимый текст для синтеза и нажать кнопку "Синтезировать". Программа автоматически подготовит необходимый формат файла для телефонной станции, дополнительное конвертирование не нужно. В правой части окна в таблице "Список синтеза речи" добавится строка синтезированной речи.

[![synth-index-list.jpg](https://docs.enxx.ru/uploads/images/gallery/2024-10/scaled-1680-/LTnNYBT4J4zPPMVY-synth-index-list.jpg)](https://docs.enxx.ru/uploads/images/gallery/2024-10/LTnNYBT4J4zPPMVY-synth-index-list.jpg)

Для скачивания аудиофайла нажмите кнопку "Скачать".

Таблица заполняется по мере синтеза речи и хранит файлы за все время синтеза. При необходимости старые записи можно удалить.

#### Дополнительно

При необходимости данный модуль можно интегрировать с другими сервисами и приложениями. Для примера можно использовать интеграцию с CRM системой. При звонке в офис компании, голосовое приветствие будет синтезировано автоматически и система поприветствует клиента по имени и отчеству.

# Скрипт отслеживания службы

1\. Скрипт отслеживания службы

\#!/bin/sh  
\# Название процесса  
DAEMON="asterisk"  
\# "Убираем" grep из вывода  
EXCLUDE="grep"  
\# Минимальное количество процессов  
PROC\_NUM="0"  
\# Команда для перезапуска  
RESTART="/etc/init.d/asterisk restart"  
\# Утилита ps  
PS="/bin/ps"  
\# Утилита grep  
GREP="/usr/bin/grep"  
if \[ `$PS -ax | $GREP $DAEMON | $GREP -v $EXCLUDE | wc -l` -le "$PROC\_NUM" \]  
then  
 $RESTART  
fi

# Смена исходящей маршрутизации для внутреннего номера

1\. Меню - Канальный драйвер - Конечная точка

[![image.png](https://docs.enxx.ru/uploads/images/gallery/2025-02/scaled-1680-/2WEGbYKRDM3OeTxs-image.png)](https://docs.enxx.ru/uploads/images/gallery/2025-02/2WEGbYKRDM3OeTxs-image.png)

2\. Нажимаем редактировать напротив нужной конечной точки.

3\. Меняем параметр маршрутизация.

[![image.png](https://docs.enxx.ru/uploads/images/gallery/2025-02/scaled-1680-/dzP1T5Tu0C8t6sI2-image.png)](https://docs.enxx.ru/uploads/images/gallery/2025-02/dzP1T5Tu0C8t6sI2-image.png)

# Сообщение после звукового сигнала

#### Подготовка аудиофайла

Необходимо подготовить файл звукового приветствия, например "Оставьте сообщение после звукового сигнала".  
Через меню Медиа - Аудиофайлы загрузите файл с наименованием "message-office".  
Файл должен быть в формате wav (rate 8000 Hz, sample rate 16 bits, mono).

#### Настройка маршрутизации

Необходимо подготовить новую маршрутизацию, например "message-office"  
В созданной маршрутизации добавить расширение "s"

```
NoOp : Сообщение после звукового сигнала
Answer
Playback : message-office
Record : /tmp/${UNIQUEID}.wav,,300,k
Hangup
```

#### Настройка отправки на электронную почту

Добавить в маршрутизацию расширение "h"

```
NoOp : Отправка сообщения на электронную почту
AGI : email/attachment.php,--source="${CALLERID(number)}",--destination="Номер",--emails="mail@example.com",--attachment="/tmp/${UNIQUEID}.wav"
Hangup
```

#### Настройка перенаправления

В нужном месте маршрутизации добавьте приложение "GoTo"

```
NoOp : Входящий вызов
...
...
...
Goto : message-office,s,1
Hangup
```