This is a Python library for Asterisk to work with Yandex voice models.
Project description
Набор приложений и Python-библиотека для работы Asterisk с голосовыми моделями Yandex. Пакет устанавливает в систему 4 запускаемых приложения:
astersay - скрипт инициализации рабочего каталога.
astersay-cgi - CGI(AGI) для прямого указания в диалплане астериска.
astersay-dev - эмулятор AGI для разработки диалогов в интерактивном режиме без участия Asterisk.
astersay-t2v - консольная команда для конвертации “text-to-voice”, возвращает на stdout путь к файлу голоса без его расширения.
Установка
Для продакшн-серверов с Asterisk:
pip3 install astersay
Для разработки диалогов и работы виртуального сервера DummyAsterisk необходим PyAudio. Для его установки нужно предварительно в системе иметь dev-пакеты.
Для Debian-based:
sudo apt install gcc portaudio19-dev
pip3 install astersay[dev]
Для RedHat-based:
sudo yum install gcc portaudio-devel
pip3 install astersay[dev]
Настройка
Проинициализируйте рабочий каталог.
astersay
# или
astersay -w ~/your-custom-work-directory
Откройте редактором JSON-файл подключения к Яндексу, который выдала программа и заполните в нём необходимые данные для авторизации в сервисе:
key_id
service_account_id
folder_id
Затем проверьте готовность к работе.
astersay --check
Вывод в консоли скажет о готовности.
Использование в диалплане
Для использования в диалплане для AGI получите полный путь к cgi-скрипту для своей системы.
which astersay-cgi
Полученный путь укажите в диалплане как AGI-программу. Для неё есть 2 необязательных параметра:
Путь к модели далога.
Путь к рабочему каталогу.
Консольная конвертация
Без запуска Asterisk на любом компьютере возможна конвертация текста в WAV-файлы. Для этого передайте команде “Text-To-Voice” текст одним из следующих способов:
astersay-t2v -t "Мой текст с пробелами."
astersay-t2v -f text.txt
astersay-t2v -f text.txt -w ~/my-work-directory
В выводе будет путь к голосовому файлу без расширения.
Для вывода справки по параметрам запустите:
astersay-t2v --help
Разработка диалогов
Запуск эмуляции Asterisk позволяет разрабатывать диалоги без реального сервера. Для этого запустите интерактивный режим командой:
astersay-dev
Остановите программу клавишами: Ctrl+C.
Для вывода справки по параметрам запустите:
astersay-dev --help
Найдите в рабочем каталоге файл dialogs/default.json, скопируйте его под другим именем в тот же каталог, например в dialogs/first_dialog.json или dialogs/subdir/first_dialog.json, и отредактируйте под свои нужды.
Запустите свой диалог так:
astersay-dev -m first_dialog
# или
astersay-dev -m ~/.config/astersay/dialogs/first_dialog.json
# или
astersay-dev -m first_dialog -w ~/my-work-directory
# или
astersay-dev -m subdir/first_dialog -w ~/my-work-directory
Расширение ‘.json’ можно не указывать.
Заметьте, что эмулятор отображает только ход процесса AGI, а не логгирует ошибки и информацию из диалога. Для отображения лог-файлов используйте консольную утилиту tail:
tail -f ~/my-work-directory/logs/*.log
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.