понедельник, 24 января 2028 г.

Разный софт для CentOS

Собственные скрипты и алиасы: sockstat, ipt
Загрузка диска: nmon, atop, iostat -x
Информация о железе (мать, проц, память и т.п.): dmidecode
Тестирование скорости жесткого диска: hdparm

четверг, 18 сентября 2025 г.

Щелчки в начале проигрыша сообщений в Астериск

 Возникают при конвертации RIFF файлов (.wav) в чистый a-law. Остается заголовок RIFF, который приводит к щелчку при проигрывании.

Решение: удалить заголовок. Например, с помощью RIFFStrip.

среда, 23 июля 2025 г.

Модификация приложения Record для отлавливания нужного кода DTMF

Продолжаем мучать app_record.c

Задача: отловить набор внутреннего номера. Номера начинаются с "4".

Т.е. нужно прервать запись только по нажатию "4", и сообщить об этом факте.

Добавим опцию "e" в приложение Record. Для этого:

понедельник, 14 июля 2025 г.

Распаковка initramfs

# mkdir initramfs_tmp

# cd initramfs_tmp

# cp /boot/initramfs-6.12.34-gentoo-dist.img .

# mv initramfs-6.12.34-gentoo-dist.img initramfs-6.12.34-gentoo-dist.xz

# unzstd initramfs-6.12.34-gentoo-dist.xz

# cat initramfs-6.12.34-gentoo-dist | cpio -idmv

вторник, 6 мая 2025 г.

Добавляем в CDR причину и инициатора разрыва соединения

 Добавляем в CDR две колонки:

- hangupcause (int4);

- hangupparty (varchar или сделать отдельный тип enum 'caller|callee').

Далее добавляем в app_dial.c переменную типа char buf_hangup_str[8], по очереди пишем в неё значения ast_channel_hangupcause(chan) и ast_check_hangup(chan), и сбрасываем в CDR через ast_cdr_setvar.

Соответствующий патч ниже.

среда, 2 апреля 2025 г.

Заметки по поводу настройки OpenSIPS

 0) Логирование

-xlog и acc в LOCAL4 и Postgres

-настройка syslog-ng на запись LOCAL4 в opensips.log

-do_accounting("db|log","cdr|missed|failed") на начальный INVITE


1) Чёрные листы

-partition надо задать параметром, default не работает

-данные берутся из кэша, считываются из БД на старте, обновление через address_reload в cli


2) Регистрация, аутентификация, привязка к IP

-для аутентификации используются модули auth_db для доступа к таблице subscriber и auth для самой аутентификации

-данные зарегистрированного клиента сохраняются в таблицу location функцией save модуля registrar

-используются модули usrloc, registrar, auth, auth_db, signaling, tm, sl

-после аутентификации INVITE не забывать вызывать функцию consume_credentials(), чтобы удалить реквизиты из заголовка Authentication при дальнейшей пересылке