REST API для CDR Asterisk — список звонков, фильтры, скачивание записей
Project description
asterisk-cdr-api
REST API для Asterisk CDR — список звонков с фильтрами, сортировкой и скачиванием записей.
Доступы к БД читаются автоматически из конфигов Asterisk:
/etc/asterisk/cdr_adaptive_odbc.conf → res_odbc.conf → /etc/odbc.ini
Быстрая установка (Debian/Ubuntu)
curl -fsSL https://raw.githubusercontent.com/it-healer/asterisk-cdr-api/main/scripts/install.sh | sudo bash
Скрипт сам:
- Установит Python-зависимости
- Создаст virtualenv в
/opt/asterisk-cdr-api/ - Сгенерирует случайный API ключ
- Спросит IP и порт HTTP сервера (по умолчанию
0.0.0.0:8000) и сохранит их в systemd сервис - Зарегистрирует и запустит systemd сервис
После установки в консоли будет выведен URL и API ключ.
Неинтерактивная установка
Если запускаете через пайп (curl … | sudo bash), интерактивный ввод недоступен — передайте параметры через переменные окружения:
curl -fsSL https://raw.githubusercontent.com/it-healer/asterisk-cdr-api/main/scripts/install.sh \
| sudo CDR_HOST=127.0.0.1 CDR_PORT=9000 bash
Без переменных будут использованы значения по умолчанию 0.0.0.0:8000.
Изменить IP/порт после установки:
sudo nano /etc/systemd/system/asterisk-cdr-api.service
# Измените строки:
# Environment="CDR_HOST=0.0.0.0"
# Environment="CDR_PORT=8000"
sudo systemctl daemon-reload && sudo systemctl restart asterisk-cdr-api
Установка вручную
# 1. Системные зависимости
sudo apt-get install python3-venv python3-pip -y
# 2. Виртуальное окружение
sudo mkdir -p /opt/asterisk-cdr-api
sudo python3 -m venv /opt/asterisk-cdr-api/venv
# 3. Установка пакета с PyPI
sudo /opt/asterisk-cdr-api/venv/bin/pip install asterisk-cdr-api
# 4. Запуск для проверки
sudo CDR_API_KEY="мой-ключ" /opt/asterisk-cdr-api/venv/bin/asterisk-cdr-api
Настройка systemd
Скопировать сервис-файл:
sudo cp debian/asterisk-cdr-api.service /etc/systemd/system/
Задать API ключ:
sudo nano /etc/systemd/system/asterisk-cdr-api.service
# Изменить строку:
# Environment="CDR_API_KEY=change-me-please"
Запустить:
sudo systemctl daemon-reload
sudo systemctl enable asterisk-cdr-api
sudo systemctl start asterisk-cdr-api
sudo systemctl status asterisk-cdr-api
Логи:
journalctl -u asterisk-cdr-api -f
Переменные окружения
| Переменная | По умолчанию | Описание |
|---|---|---|
CDR_API_KEY |
change-me-please |
Секретный ключ API |
CDR_HOST |
0.0.0.0 |
Адрес для прослушивания |
CDR_PORT |
8000 |
Порт |
CDR_ROOT_PATH |
(пусто) | URL-префикс за reverse-proxy, например /asterisk-cdr-api |
API
Все запросы (кроме /health) требуют заголовок X-Api-Key.
Swagger UI
http://SERVER:8000/docs
Эндпоинты
| Метод | Путь | Описание |
|---|---|---|
| GET | /calls |
Список звонков с фильтрами |
| GET | /calls/{id} |
Один звонок |
| GET | /calls/{id}/download |
Скачать MP3 |
| GET | /stats |
Статистика |
| GET | /config |
Текущая конфигурация |
| GET | /health |
Проверка работы |
Параметры /calls
| Параметр | Описание | Пример |
|---|---|---|
src |
Номер звонящего | 613610 |
dst |
Номер назначения | 7903 |
disposition |
Статус | ANSWERED |
date_from |
Дата от | 2026-05-01 |
date_to |
Дата до | 2026-05-20 |
has_recording |
Есть запись | true |
order_by |
Сортировка | calldate, billsec |
order_dir |
Направление | asc, desc |
limit |
Записей на стр. | 50 |
offset |
Смещение | 0 |
Примеры запросов
# Список отвеченных звонков за май
curl -H "X-Api-Key: мой-ключ" \
"http://SERVER:8000/calls?disposition=ANSWERED&date_from=2026-05-01"
# Звонки с конкретного номера, с записями
curl -H "X-Api-Key: мой-ключ" \
"http://SERVER:8000/calls?src=613610&has_recording=true"
# Скачать запись звонка с id=42
curl -H "X-Api-Key: мой-ключ" \
"http://SERVER:8000/calls/42/download" -o call_42.mp3
# Статистика за неделю
curl -H "X-Api-Key: мой-ключ" \
"http://SERVER:8000/stats?date_from=2026-05-13"
# Что прочиталось из конфигов
curl -H "X-Api-Key: мой-ключ" \
"http://SERVER:8000/config"
Обновление на боевом сервере
После того как новая версия опубликована на PyPI:
curl -fsSL https://raw.githubusercontent.com/it-healer/asterisk-cdr-api/main/scripts/update.sh | sudo bash
Скрипт install.sh тоже идемпотентен — если запустить его повторно на уже установленной системе, он обновит пакет, сохранит существующий API ключ и подхватит существующие CDR_HOST/CDR_PORT/CDR_ROOT_PATH как дефолты. Это удобно, если нужно одновременно обновить версию и поменять конфигурацию (например, добавить URL-префикс):
# Сменить только префикс, остальное оставить как есть
curl -fsSL https://raw.githubusercontent.com/it-healer/asterisk-cdr-api/main/scripts/install.sh \
| sudo CDR_ROOT_PATH=/asterisk-cdr-api bash
# Или сменить всё сразу
curl -fsSL https://raw.githubusercontent.com/it-healer/asterisk-cdr-api/main/scripts/install.sh \
| sudo CDR_HOST=127.0.0.1 CDR_PORT=9000 CDR_ROOT_PATH=/asterisk-cdr-api bash
Или вручную:
sudo /opt/asterisk-cdr-api/venv/bin/pip install --upgrade asterisk-cdr-api
sudo systemctl restart asterisk-cdr-api
Проверить установленную версию:
curl -s http://localhost:8000/health
# {"status":"ok","service":"Asterisk CDR API","version":"1.0.1"}
Удаление
sudo bash scripts/uninstall.sh
Или одной строкой:
curl -fsSL https://raw.githubusercontent.com/it-healer/asterisk-cdr-api/main/scripts/uninstall.sh | sudo bash
Выпуск новой версии (для разработчика)
Версия пакета — единственный источник истины в asterisk_cdr_api/__init__.py (__version__); pyproject.toml подтягивает её через dynamic.
Самый простой путь — скрипт scripts/bump.sh:
./scripts/bump.sh patch # 1.0.0 → 1.0.1
./scripts/bump.sh minor # 1.0.0 → 1.1.0
./scripts/bump.sh major # 1.0.0 → 2.0.0
./scripts/bump.sh 1.2.3 # явная версия
Скрипт:
- Поднимает
__version__. - Делает
git commit -m "release: X.Y.Z". - Создаёт тег
vX.Y.Zи пушит его.
GitHub Actions workflow .github/workflows/publish.yml подхватывает тег, собирает пакет и публикует его на PyPI через Trusted Publishing (без токенов).
Первоначальная настройка Trusted Publisher на PyPI: Account → Publishing → Add a new pending publisher
| Поле | Значение |
|---|---|
| PyPI Project Name | asterisk-cdr-api |
| Owner | it-healer |
| Repository name | asterisk-cdr-api |
| Workflow name | publish.yml |
| Environment name | pypi |
Локальная сборка пакета
python -m pip install --upgrade build
python -m build
# В каталоге dist/ появятся файлы:
# asterisk_cdr_api-1.0.0-py3-none-any.whl
# asterisk_cdr_api-1.0.0.tar.gz
Лицензия
MIT — см. LICENSE.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file asterisk_cdr_api-1.0.5.tar.gz.
File metadata
- Download URL: asterisk_cdr_api-1.0.5.tar.gz
- Upload date:
- Size: 18.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
531b4c881ccef9227b4a9d01c237eb8b74f1324036f510796fdd354bf268c415
|
|
| MD5 |
9875c0a008be53666c72656be231e55c
|
|
| BLAKE2b-256 |
9da5c2c0151876d33f303ad3593286e66193fc28b3ea7292b64306ae24d79b4a
|
Provenance
The following attestation bundles were made for asterisk_cdr_api-1.0.5.tar.gz:
Publisher:
publish.yml on it-healer/asterisk-cdr-api
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
asterisk_cdr_api-1.0.5.tar.gz -
Subject digest:
531b4c881ccef9227b4a9d01c237eb8b74f1324036f510796fdd354bf268c415 - Sigstore transparency entry: 1585903648
- Sigstore integration time:
-
Permalink:
it-healer/asterisk-cdr-api@4746d599df7cc240c89a2d33f0943ca8b69524f0 -
Branch / Tag:
refs/tags/v1.0.5 - Owner: https://github.com/it-healer
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@4746d599df7cc240c89a2d33f0943ca8b69524f0 -
Trigger Event:
push
-
Statement type:
File details
Details for the file asterisk_cdr_api-1.0.5-py3-none-any.whl.
File metadata
- Download URL: asterisk_cdr_api-1.0.5-py3-none-any.whl
- Upload date:
- Size: 11.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0b861a552220438d5b56256113826aaa945e587e90c2f2b0bec98161cb0a6bf9
|
|
| MD5 |
809bcef8303cfd74c95a424c76fd3ae8
|
|
| BLAKE2b-256 |
2095735806a97f4ed3da0a66b550c9a9d15a24129c4abf2e10773aed729bf8a0
|
Provenance
The following attestation bundles were made for asterisk_cdr_api-1.0.5-py3-none-any.whl:
Publisher:
publish.yml on it-healer/asterisk-cdr-api
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
asterisk_cdr_api-1.0.5-py3-none-any.whl -
Subject digest:
0b861a552220438d5b56256113826aaa945e587e90c2f2b0bec98161cb0a6bf9 - Sigstore transparency entry: 1585903736
- Sigstore integration time:
-
Permalink:
it-healer/asterisk-cdr-api@4746d599df7cc240c89a2d33f0943ca8b69524f0 -
Branch / Tag:
refs/tags/v1.0.5 - Owner: https://github.com/it-healer
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@4746d599df7cc240c89a2d33f0943ca8b69524f0 -
Trigger Event:
push
-
Statement type: