Внедрение отчета о доставке в Kannel

Я настроил Kannel в Ubuntu Server 14.04.3 LTS. Пока я могу отправлять сообщения, но мне еще предстоит выяснить, как реализовать отчет о доставке. Для этого у меня есть следующая конфигурация канала, в которой я определил тип хранилища, группу подключения mysql и свойства подключения к mysql.

include = "/etc/kannel/modems.conf"

group = core
admin-port = 13000
smsbox-port = 13001
admin-password = 12345
admin-deny-ip = “*.*.*.*”
admin-allow-ip = “127.0.0.1″
box-deny-ip = “*.*.*.*”
box-allow-ip = “127.0.0.1″
log-file = /var/log/kannel/bearerbox.log
log-level = 0
dlr-storage = mysql

group = smsc
smsc = at
smsc-id = GSM
my-number = xxxxxxxxxxxx
modemtype = auto
device = /dev/ttyUSB0

group = smsbox
bearerbox-host = 127.0.0.1
sendsms-port = 13013
global-sender =13013
log-file = /var/log/kannel/smsbox.log
log-level = 0

group = smsbox-route
smsbox-id = smsbox
smsc-id = GSM

group = sendsms-user
username = user
password = user
concatenation= true
max-messages = 10
user-deny-ip = “*.*.*.*”
user-allow-ip = “127.0.0.1;”
dlr-url = "http://127.0.0.1/dlr.php"

group = sms-service
keyword = default
catch-all = yes
accepted-smsc = usb1-modem
max-messages = 0
get-url = http://localhost/sms?phone=%p&text=%a

group = mysql-connection
id = mydlr
host = localhost
port = 3306
username = root
password = 00000
database = dlr
max-connections = 1

group = dlr-db
id = mydlr
table = dlr
field-smsc = smsc
field-timestamp = ts
field-destination = destination
field-source = source
field-service = service
field-url = url
field-mask = mask
field-status = status
field-boxc-id = boxc

Теперь мой вопрос:

  1. Как записать в базу данных таблицу dlr? Это делается kannel или мы должны сделать это через скрипт?

Я попытался передать dlr-mask и dlr-url в URL-адресе sendsms, но ничего не происходит.

http://127.0.0.1:13013/cgi-bin/sendsms?username=user&password=user&to=xxxxxxxx&text=hello&dlr-mask=31&dlr-url=http%3A%2F%2F127.0.0.1%2Fdlr.php%3FmyId%3D123456%26type%3D%25d

Прежде всего, я не понимаю, как обрабатывается "id" сообщения. Насколько я понимаю, я считаю, что kannel должен вставлять каждую информацию об отправке в базу данных, а затем статус сообщения должен возвращаться в соответствии с идентификатором в базе данных. Но в таблице нет такого поля как id.

Я застрял на пару дней с этой проблемой, так как в руководстве пользователя нет исчерпывающих указаний, а на форумах kannel нет хороших тем по этому поводу. Пожалуйста, просветите меня с подробной процедурой реализации отчета о доставке.


person raaman    schedule 14.08.2015    source источник
comment
вам придется создать таблицу dlr вручную. kannel автоматически создает только send_sms и send_sms   -  person Asad Nauman    schedule 18.09.2015


Ответы (2)


Вы должны написать свой собственный скрипт (dlr.php) для обработки ответа DLR и сохранения статуса, об идентификаторе, который вы можете сгенерировать, используя метку времени или автоинкремент. Наконец, ваш запрос на отправку смс должен выглядеть примерно так

 $dlrURL="http://www.xxxxx.com:/dlr.php?dlr=%d&answer=%A&to=%p&ts=%T&smsID=$yourOwnID";

    /* Build Kannel Request */
    $request  = "http://localhost:13013/cgi-bin/sendsms?";
    $request .= "smsc="      ."smppgw1";
    $request .= "&username=" ."someuser";
    $request .= "&password=" ."somepass";
    $request .= "&from="     .$fromNumber;
    $request .= "&to="       .trim($somenumber);
    $request .= "&text="     .urlencode($in_msg);
    $request .= "&dlr-mask=31&dlr-url="     .urlencode($dlrURL);

С уважением, Горки

person Gorki    schedule 14.04.2016

Самый стабильный способ получить и сохранить отчеты DLR и отчеты MO, MT в базе данных — это использовать дополнительный дополнительный блок под названием SQLBOX. Вы также можете отправить SMS, вставив его в таблицу SQLBOX. Вы можете найти исходный код в дополнении. каталог в основном проекте kannel

person Vinayak    schedule 25.06.2018