Обработка SMS-сообщений с помощью GSM-модема Huawei e1550 и smstools на Debian 9 Stretch

В поисках решения организации SMS шлюза, посредством GSM-модема (прим. Huawei E1550), наткнулся на пакет «smstools», который прекрасно справляется со своими обязанностями (отправка\получение SMS).

 

Рассмотрим как развернуть пакет «smstools» на Debian 9 Stretch и настроить его на GSM-модема Huawei e1550 (так же тестировал ниже описанное на e3372h с прошивкой stick).

 

Подготовка системы

Обновляем систему до актуального состояния:

 

Устанавливаем необходимые для работы пакеты:

 

Подключаем GSM-модем Huawei E1550, проверяем появились ли устройства ttyUSB*:

 

Установка и настройка smstools

Скачиваем исходники «smstools», распаковываем их и переходим в распакованный каталог:

 

Компилируем исходники и выполняем установку пакета:

 

После установки, сразу создадим необходимые каталоги:

 

Конфигурация «smstools» производится в файле (/etc/smsd.conf). Моя типовая конфигурация выглядит так:

Файл кон­фи­гу­ра­ции раз­де­лен на две части. Сна­чала идут гло­баль­ные опции, а потом сек­ция (прим. [GSM1]) с опци­ями для GSM-модема. Опи­са­ние всех опций файла кон­фи­гу­ра­ции можно найти на офи­ци­аль­ном сайте пакета «smstools».

 

Заострю внимание на опциях checkhandlereventhandlereventhandler_ussd:

  • В строке «checkhandler» зада­ется обра­бот­чик исходящих SMS-сообщений.
  • В строке «eventhandler» зада­ется обра­бот­чик вхо­дя­щих SMS-сообщений.
  • В строке «eventhandler_ussd» зада­ется обра­бот­чик отве­тов на USSD-запросы.

В моем слу­чае я использую это один и тот же скрипт «sms_smshandler.sh», в котором описывается обработка тех или иных событий.

 

Теперь можно запустить демон smstools:

 

Отправка SMS-сообщений

Для отправки исполь­зу­ется скрипт «sendsms», который иду­щий в ком­плекте пакета «smstools».

В версии smstools 3.1.21, сообщения нормально отправляются на кириллице, перекодировка реализована на уровне скрипта sendsms. 

 

Команда «sendsms» формирует текстовый файл в каталоге «outgoing», который затем будет автоматически обработан сервисом smsd и отправлен, после чего перемещен в каталог «sent».

 

Прием SMS-сообщений

Входящие SMS попадают в каталог «incoming». В случае если сообщение на кириллице, то оно будет закодировано в UCS2 формат, чтобы его прочесть, требуется перекодировать его (прим. в формат UFT-8).

 

Рассмотрим скрипт «sms_smshandler.sh», указанный в файле конфигурации (/etc/smsd.conf) в опциях «eventhandler», «eventhandler_ussd», который будет обрабатывать события.

 

В скрипте обрабатывается два пере­дан­ных пара­метра ($1, $2):

  • Пер­вый ($1) — это тип собы­тия, возможные зна­че­ния «CALL, RECEIVED, USSD, SENT, FAILED, REPORT».
  • Вто­рой ($2) — это имя файла с SMS-сообщением.

 

Создаем файл скрипта:

Добавим в него следующие содержание:

Делаем скрипт исполняемым:

 

В скрипте для примера показано, как можно обрабатывать события и как перекодировать SMS-сообщение в читаемый вид, с последующей записью в файл.

 

Дальше только полет вашей фантазии, как вы будите использовать «smstools». Лично я вижу в этом хороший инструмент для удаленного управления сервером, путем посыла SMS-сообщений с определенными командами. Так же можно заставить систему мониторинга (прим. Zabbix) отправлять уведомления в SMS-сообщении, что как мне кажется будет более надежным способом оповещения.

 

Дополнительно (возможные проблемы)

Опишу ситуацию, с которой я столкнулся в ходе тестирования «smstools».

 

На GSM-модеме Huawei e1550, «smstools» не получал входящие SMS-сообщения. Проблема оказалась в том, что «smstools» обращался по-умолчанию к памяти на SIM-карте (SM), а в параметрах GSM-модема было указано использование внутренней памяти (ME).

 

Посмотреть текущую настройку GSM-модема, можно командой (AT+CPMS=?) выполненной в терминальном подключении к GSM-модема.

 

Для решения данной проблемы, можно указать в файле конфигурации (/etc/smsd.conf), в секции описания GSM-модема (прим. [GSM1]), какой тип памяти использовать:

После внесения изменений в файле конфигурации (/etc/smsd.conf), не забываем перезагрузить демона «smstools» (/etc/init.d/sms3 restart)

Так же рекомендую, найти какой нибудь старый телефон, который точно не будет подключатся к сети оператора и изменить IMEI GSM-модема на IMEI телефона. Теперь оператор будет видеть, что SMS-сообщения будут ходить через IMEI телефона.

 

Так же в логах «smstools» заметил что сыпется много сообщений вида:

 

На работу GSM-модема это никак не влияло, SMS успешно отправлялись и принимались, но не нравилось что лог-файл засоряется этими сообщениями. Решил данную проблему путем отключения вывода «boot» сообщений.

 

В файле конфигурации (/etc/smsd.conf), в секции описания GSM-модема (прим. [GSM1]), указываем параметр:

 

Понравилась или оказалась полезной статья, поблагодари автора

 

БесполезноСлабоватоПриемлемоОтличноПревосходно (2 голос(ов), в среднем: 3,00 из 5)
Загрузка...

Всего комментариев: 4 Комментировать

  1. Realmagnum /

    Спасибо, самый дружелюбный и полезный контент по теме.
    Вместе со скриптом https://github.com/Shumaher/huawei-ussd
    получилось самое комфортное решение.

    1. Жаконда / Автор записи

      Рад что помог!

  2. Alexey /

    Для истории оставлю тут правки:
    1. вместо
    init = AT+CPMS=»ME»,»ME»,»ME»
    можно указать настройку
    memory_start = 0

    2. у меня модем спамит сообщениями типа
    Unexpected input: +CREG: 1, 189D, 1CFDB33 +CGREG: 0
    Unexpected input: ^RSSI:16

    Чтоб это отключить надо в настройки добавить
    init = AT^CURC=0

    1. Жаконда / Автор записи

      Спасибо, за дополнения 🙂

Оставить ответ

20 − 3 =

© IT-блог Жаконды All Rights Reserved.
Яндекс.Метрика