API SR-Organizer
Взаимодействие с SIM Roulette
Термины и определения
Управляющие команды SIM Roulette SR-Organizer
Модемы
SMS
Переменные
Файлы
Управление макросами
Настройки
Мониторинг
Интеграция SIM Roulette в ваш проект
Варианты взаимодействия с SIM Roulette
1). Прямой ввод команды через терминал WEB-интерфейса SIM Roulette.
2). Формирование через WEB-интерфейс SIM Roulette списков команд (Макросов) и последующее их выполнение устройством.
3). GET или POST запрос к SIM Roulette вида http://XXX.XXX.XXX.XXX/port?data=token||step||command
XXX.XXX.XXX.XXX — IP-адрес SIM Roulette
|| — разделитель
token — кодовое слово заданное через WEB-интерфейс агрегатора
step — порядковый номер команды (шаг)
command — команда
Ответ SIM Roulette возвращает в текстовом виде. Пример: step#!#result
#!# — разделитель
step — ответ на запрос с номером (шагом)
data — результат выполнения команды (для большинства команд 1-удача, NULL-неудача), также, в зависимости от команды, это может быть число либо текст. 0 всегда кодируется как NULL.
запрос: http://192.168.1.2/port?data=12345||123||sound:beep
Важно! При GET запросе параметр data в URL должен быть закодирован на стороне клиента функцией urlencode.
После кодировки URL должен выглядеть так: http://192.168.1.2/port?data=12345%7C%7C123%7C%7Csound%3Abeep
ответ: 122#!#1шаг_предыдущего_запроса#!#результат_выполнения_запроса
4). Обращение SIM Roulette к серверу (вашему WEB-сайту) с GET запросом по указанному в WEB-интерфейсе адресу.
Например, http://site.ru/sr/io.php
SIM Roulette передает GET-параметры:
step — ответ на запрос с номером (шаг)
data — результат выполнения команды
и получает с сервера следующую команду в виде текста:
{data}step#!#command
Важно! {data} — необходимый префикс для того, чтобы Sim Roulette понимал что сервер возвращает корректные данные.
Термины и определения
Ответы SIM Roulette отдает асинхронно.
Каждый ответ содержит номер (шаг) команды.
Буфер ответов SIM Roulette динамический, может содержать результаты десятка команд.
0 всегда кодируется как NULL.
Большинство команд возвращают: 1 — удача, NULL — неудача.
Далее по тексту:
D — число
W — слово
X — числовые либо символьные данные
(в скобках) указывается необязательный параметр команды
Управляющие команды SIM Roulette SR-Organizer
МОДЕМЫ
modem>on — включение модемов
пример: modem>on ответ: 1всегда
Примечание: при включенном модеме в статус-строке на экране устройства и в WEB-интерфейсе отображается пиктограмма молнии
modem>off — выключение модемов
пример: modem>off ответ: 1всегда
modem>status — получение статуса питания модемов
пример: modem>status ответ: 1питание включено 0питание выключено
modem>activation[:D] — подключение к СИМ-карте и активация указанного [D] модема или обоих модемов с проверкой
примеры:
modem>activation ответ: 1;MTS;1;MEGAFON;9успешный статус подключения к сети 1 модема;оператор 1 модема;успешный статус подключения к сети 2 модема;оператор 2 модема;затраченное время в секундах 4;;0;;7ошибка подключения к сети 1 модема;;ошибка подключения к сети 2 модема;;затраченное время в секундах
modem>activation:2 ответ: 1;MTS;9успешный статус подключения к сети 2 модема;оператор 2 модема;затраченное время в секундах 4;;0;;7ошибка подключения к сети 2 модема;;затраченное время в секундах
подробнее о статусах
modem>select:D — выбор модема для взаимодействия по умолчанию (1-2)
пример: modem>select:2 ответ: 2подтверждение выбора 0неверный номер модема
modem>set:rate — скорость порта для обмена данными с модемами / modem>set:rate=D — задать битрейт
примеры: modem>set:rate ответ: 115200текущий битрейт
modem>set:rate=57600 ответ: 57600установленный битрейт
modem>set:mode — режим работы модемов pdu/txt / modem>set:mode=pdu — задать режим
примеры: modem>set:mode ответ: pduтекущий режим
modem>set:rate=txt ответ: txtустановленный режим
Примечание: информация о текущем режиме работы модемов нужна агрегатору для обработки некоторых команд взаимодействующих с модемами
modem>set:auto — режим автовключения модемов / включено (modem>set:auto=1) или отключено (modem>set:auto=0)
примеры: modem>set:auto ответ: 1текущий режим
modem>set:auto=1 ответ: 1автовключение установлено
modem>send:AT… — передача команды выбранному модему (таким образом модему передаются стандартные AT-команды)
пример: modem>send:ATD+79001234567; ответ: 1всегда
Обратите внимание: все команды начинающиеся с префикса AT агрегатор перенаправляет текущему модему и конструкция modem>send: не обязательна.
Примечание: ответы обоих модемов приходят асинхронно со Step (шагом) 0, ответы модема 1 с префиксом 1:, ответы модема 2 с префиксом 2:
modem[D]>send:AT… — передача команды указанному [D] модему
пример: modem[2]>send:ATD+79001234567; ответ: 1всегда
Примечание: ответы обоих модемов приходят асинхронно со Step (шагом) 0, ответы модема 1 с префиксом 1:, ответы модема 2 с префиксом 2:
modem>card:D — выбор карты (1-8) для модема по умолчанию
пример: modem>card:7 ответ: 7выбранная карта
modem[D]>card:D — выбор карты (1-8) для указанного [D] модема
пример: modem[2]>card:6 ответ: 6выбранная карта
modem>sms:D — пакетное получение всех SMS с обоих модемов
D — 0-выбирать все SMS, 1-только не прочитанные, 2-прочитанные, 3-не отправленные, 4-отправленные
пример: modem>sms:0 ответ:2## 30,0,"MTS",83
[текст SMS]#3#5##E#3#2 — номер модема, ## — разделитель, 30 — номер ячейки памяти SIM-карты, 0 — SMS не прочитана, "MTS" — отправитель, 83 — длина сообщения, #3# — разделитель между отчетами по модемам, 5 — номер модема, ## — разделитель ...
modem>pack:W##M##D — пакетное выполнение команды обоими модемами или указанным модемами
W — AT-команда
M — модемы, которые должны выполнить команду (1;2 или all)
D — 1-дождаться ответа и вернуть его, 0-только отправить команду на выполнение и не дожидаться ответов модемов
пример: modem>pack:AT+COPS?##all##1 ответ:1##AT+COPS?
+COPS: 0,0,"Bee Line GSM"
OK
#1#2##AT+COPS?
+COPS: 0,0,"MTS"
OK
#1##1# — разделитель
modem>download:URL;FILE[;SIZE] — скачивание файла с WEB-сайта и загрузка в память модема по умолчанию
пример: modem>download:sim-roulette.com/download/voice.amr;C:\User\voice.amr; ответ: 1выполнено 0ошибка
SMS
sms>discover — проверка флага наличия SMS на СИМ-картах подключенных к модемам
пример: sms>discover ответ: 1есть 0нет
Примечание: после смены карты в одном из модемов флаг поступившего сообщения сбрасывается
sms>read[:D] — копирование одного SMS с СИМ-карты подключенной к модему по умолчанию или указанному [D] в буфер и удаление скопированного SMS с СИМ-карты
пример: sms>read ответ: 1SMS скопировано 0SMS нет
sms>send:X;W — отправка SMS с модема по умолчанию
X — номер абонента
W — текст SMS (латинские/русские символы распознаются автоматически)
пример: sms>send:+79001234567;Текст SMS ответ: 1SMS отправлено 0ошибка синтаксиса команды
Примечание: команда позволяет отправлять одинарные SMS
sms>send>buffer — отправка SMS с модема по умолчанию из буфера (номер;текст)
пример: sms>send>buffer ответ: 1SMS отправлено 0ошибка синтаксиса в буфере
БУФЕР
Текстовый буфер устройства — мощный инструмент для анализа входных данных, формирования выходных данных и команд.
buffer>clear — очистка буфера
пример: buffer>clear ответ: 1всегда
buffer>view — вывод содержимого буфера в выходной поток, для формирования таблиц можно использовать bbcode: [table][tr][th][thc[thr][td][tdc][tdr]
пример: buffer>view ответ: ...содержимое буфера 0буфер пуст
buffer>raw — вывод содержимого буфера в выходной поток без обработки bbcode
пример: buffer>raw ответ: ...содержимое буфера 0буфер пуст
buffer>display — вывод содержимого буфера на дисплей устройства (в зависимости от объема данных устройство само настроит размер шрифта и, если нужно, постраничный вывод)
пример: buffer>display ответ: 1всегда
buffer>write=W — ввод новых данных в буфер
пример: buffer>write=Значение A: {a} ответ: 1всегда
Важно! Для подстановки значения переменной используется конструкция {a}, {b} и т.д., для подстановки символа {32}, {147} и т.д.
buffer>prefix=W — ввод данных, которые дополнят текущий текст спереди
пример: buffer>write=Начало строки{32} ответ: 1всегда
Важно! Для подстановки значения переменной используется конструкция {a}, {b} и т.д., для подстановки символа {32}, {147} и т.д.
buffer>postfix=W — ввод данных, которые дополнят текущий текст сзади
пример: buffer>write= конец строки ответ: 1всегда
Важно! Для подстановки значения переменной используется конструкция {a}, {b} и т.д., для подстановки символа {32}, {147} и т.д.
buffer>push — сохранение содержимого буфера в стеке (памяти устройства)
пример: buffer>push ответ: 1в буфере есть данные 0буфер пуст
buffer>pop — восстановление содержимого буфера из стека
пример: buffer>pop ответ: 1в буфере есть данные 0буфер пуст
buffer>swap — обмен местами содержимого буфера и сохраненной в стеке копии буфера
пример: buffer>swap ответ: 1в буфере есть данные 0буфер пуст
buffer>merge[=W] — склеивание буфера и сохраненной копии буфера из стека (результат остается в буфере)
W — необязательный параметр, текст, который будет добавлен между склеиваемыми частями
пример: buffer>merge={13}{10} ответ: 1всегда
Важно! Для подстановки значения переменной используется конструкция {a}, {b} и т.д., для подстановки символа {32}, {147} и т.д.
buffer>ussd — копирование в буфер последнего полученного модемом ответа на USSD-запрос (он хранится в отдельном USSD-потоке)
пример: buffer>ussd ответ: 1в буфере есть данные 0буфер пуст
buffer>ussd>clear — очистка USSD-потока
пример: buffer>ussd ответ: 1всегда
buffer>time — дополнение буфера текущим временем (HH:MM)
пример: buffer>time ответ: 1всегда
buffer>date — дополние буфера текущей датой (DD.MM.YYYY)
пример: buffer>date ответ: 1всегда
buffer>timestamp — запись в буфер внутреннего штампа времени (в секундах от 01.01.2000)
пример: buffer>timestamp ответ: 1всегда
buffer>fs>save>file:W — сохранение содержимого буфера в файл
пример: buffer>fs>save>file:/buffer.txt ответ: 1выполнено 0ошибка
buffer>fs>write>file:W — дописывание в файл содержимого буфера
пример: buffer>fs>write>file:/buffer.txt ответ: 1выполнено 0ошибка
buffer>fs>load>file:W[;D] — чтение содержимого файла в буфер
D — не обязательный параметр, считывание в буфер не всего файла, а только указанной строки
пример: buffer>fs>load>file:/buffer.txt;3 ответ: 1в буфере есть данные 0буфер пуст
buffer>sim>save>phone — запись содержимого буфера в 1 ячейку с именем "SR" телефонной книги текущей SIM-карты модема по умолчанию
пример: buffer>sim>save>phone ответ: 1выполнено 0ошибка
buffer>sim>load>phone — чтение в буфер номера из 1 ячейки с именем "SR" телефонной книги текущей SIM-карты модема по умолчанию
пример: buffer>sim>load>phone ответ: 1в буфере есть данные 0буфер пуст
buffer>modem:grab=D — включение (1) / отключение (0) захвата ответов модема в буфер
примеры: buffer>modem:grab=1 ответ: 1захват ответа модема включен
buffer>modem:grab=0 ответ: 0захват ответа модема выключен
buffer>answer:grab=D — включение (1) / отключение (0) захвата ответов устройства в буфер
примеры: buffer>answer:grab=1 ответ: 1захват ответа устройства включен
buffer>answer:grab=0 ответ: 0захват ответа устройства выключен
buffer>find:W — поиск в буфере комбинации символов, замена содержимого буфера на найденный фрагмент
W — поисковая строка:
* — заменяет любое количество произвольных символов, пример: buffer>find:баланс* — если в строке буфера содержится слово "баланс", в буфере останется текст от слова "баланс" до конца строки, ответ: 1найдена искомая строка 0совпадений нет
[dD] — поиск числа с заданным (D) количеством цифр, пример: buffer>find:[d10] ответ: 1найдено 10-значное число 0ничего не найдено — если число найдено, то в буфере останется только оно
[sD] — выборка заданного (D) количества символов сначала строки или (-D) с конца (русские символы занимают 2 байта), пример: buffer>find:[s10] — в буфере останутся только первые 10 символов, ответ: 1выполнено 0не выполнено
buffer>test:W — проверка наличия в буфере комбинации символов
W — поисковая строка:
* — заменяет любое количество произвольных символов, пример: buffer>test:баланс* ответ: 1найдена искомая строка 0совпадений нет
[dD] — проверка наличия числа с заданным (D) количеством цифр, пример: buffer>test:[d10] ответ: 1найдено 10-значное число 0ничего не найдено
[sD] — выборка заданного (D) количества символов сначала строки или (-D) с конца (русские символы занимают 2 байта), пример: buffer>cut:[s10] — в буфере останутся только первые 10 символов, ответ: 1в наличии заданное количество символов 0заданное количество символов не найдено
buffer>cut:W — поиск в буфере комбинации символов, удаление из содержимого буфера найденного фрагмента
W — поисковая строка:
* — заменяет любое количество произвольных символов, пример: buffer>cut:руб.* — если в строке буфера содержится слово "руб." оно и все что за ним будет удалено, ответ: 1искомая строка найдено и вырезана 0совпадений нет
[dD] — поиск числа с заданным (D) количеством цифр, пример: buffer>cut:[d10] ответ: 1найдено и вырезано 10-значное число 0ничего не найдено — если число найдено, то оно вырезается
[sD] — удаление заданного (D) количества символов сначала строки или (-D) с конца (русские символы занимают 2 байта), пример: buffer>cut:[s10] — из буфера будут вырезаны первые 10 символов, ответ: 1вырезано заданное количество символов 0заданное количество символов не найдено
ПЕРЕМЕННЫЕ
var>W[=D|+D|-D|*D|\D|==D|<D|>D] — работа с переменной
W — имя численной переменной (доступно 26 переменных от a до z)
примеры: var>a ответ: 123значение переменной a
=D — присвоение значения переменной
примеры: var>a=123 ответ: 123присвоенное значение переменной a, var>a=b ответ: присвоенное значение переменной a
+D — cложение
примеры: var>a+1 ответ: новое значение переменной a, var>a+b ответ: новое значение переменной a
-D — вычитание
примеры: var>a-2 ответ: новое значение переменной a, var>a-b ответ: новое значение переменной a
*D — умножение
примеры: var>a*3 ответ: новое значение переменной a, var>a*b ответ: новое значение переменной a
/D — деление
примеры: var>a/4 ответ: новое значение переменной a, var>a/b ответ: новое значение переменной a
==D — проверка тождественности
пример: var>a==33 ответ: 1выражение тождественно 0выражение не тождественно, var>a==b ответ: 1выражение тождественно 0выражение не тождественно
<D — проверка тождественности
примеры: var>a<33 ответ: 1выражение тождественно 0выражение не тождественно, var>a<b ответ: 1выражение тождественно 0выражение не тождественно
>D — проверка тождественности
примеры: var>a>33 ответ: 1выражение тождественно 0выражение не тождественно, var>a>b ответ: 1выражение тождественно 0выражение не тождественно
W — имя текстовой переменной (доступно 3 переменных str1, str2, str3)
пример: var>buffer=str1 ответ: ...содержимое переменной 0переменная пуста
var>str2=buffer — копирование в переменную str2 содержимого буфера
пример: var>str2=buffer ответ: 1всегда
var>buffer=str3 — копирование в буфер содержимого str3
пример: var>buffer=str3 ответ: 1всегда
Важно! Чтобы вставить значение переменной в буфер используйте конструкцию {a}, {b} ... {z}.
ФАЙЛЫ
Файловая система всех агрегаторов SIM Roulette использует внутреннюю FLASH-память контроллера. Объем доступного пространства, в зависимости от модели, от 1,5 до 2,5 Мегабайт.
В некоторых комплектациях SR Nano дополнительно может быть задействована внешняя карта памяти microSD.
fs>space:W — просмотр информации о состоянии памяти
W — параметр:
used — занято
total — всего
пример: fs>space:free ответ: 100000размер свободной памятив байтах
fs>list:W — просмотр содержимого папки
W — имя папки
пример: fs>list:/ ответ: ❰ СПИСОК ФАЙЛОВ ❱ 0ошибка
fs>view:W — просмотр файла
W — имя файла
пример: fs>view:/terminal.dat ответ: ❱❱ ПЕРЕХОД В РЕЖИМ ПРОСМОТРА 0ошибка
fs>edit:W — редактирование файла
W — имя файла
пример: fs>edit:/terminal.dat ответ: ❱❱ ПЕРЕХОД В РЕДАКТОР 0ошибка
fs>remove:W — удаление файла
W — имя файла
пример: fs>remove:/test/file.txt ответ: 1выполнено 0ошибка
fs>rename:W — переименование файла
W — текущий путь и имя файла _ новый путь и имя файла
пример: fs>rename:/terminal.dat /test/terminal.dat ответ: 1выполнено 0ошибка
fs>copy:W — копирование файла
W — имя файла-источника _ имя файла-приемника
пример: fs>copy:/terminal.dat /test/terminal.dat ответ: 1выполнено 0ошибка
fs>sd>copy:W — копирование файла из внутренней памяти на SD-карту
W — имя файла-источника _ имя файла-приемника
пример: fs>sd>copy:/terminal.dat /test/terminal.dat ответ: 1выполнено 0ошибка
fs>download:W — скачивание файла с WEB-сайта
W — адрес сайта;путь и имя файла в файловой системе агрегатора
пример: fs>download:sim-roulette.com/download/test /test/test ответ: 1выполнено 0ошибка
fs>upload:W — закачивание файла на WEB-сайт
W — адрес сайта;путь и имя файла в файловой системе агрегатора
пример: fs>upload:sim-roulette.com/upload/test /test/test ответ: 1выполнено 0ошибка
Важно! Для реализации механизма приема файла на ваш WEB-сервер вы можете воспользоваться готовым PHP-скриптом.
УПРАВЛЕНИЕ МАКРОСАМИ
macro:W (m:W) — запуск макроса с заданным именем из папки /m (допустимо использовать переменные)
примеры:
macro:filename ответ: ❱❱ ВЫПОЛНЕНИЕ МАКРОСА 0ошибка
m:filename ответ: ❱❱ ВЫПОЛНЕНИЕ МАКРОСА 0ошибка
macro:file_{a} ответ: ❱❱ ВЫПОЛНЕНИЕ МАКРОСА 0ошибка
Примечание: макросы можно редактировать и запускать в разделе Макросы WEB-интерфейса SR-Nano, там же можно отслеживать ход выполнения запущенного макроса.
macro>stop (m>stop) — остановка выполнения текущего макроса
НАСТРОЙКИ
answer — разрешение (answer=1) или запрещение (answer=0) вывода ответов команд в выходной поток
пример: answer=1 ответ: 1подтверждение введенных данных
answer>clear — очистка буфера ответов
пример: answer>clear ответ: 1всегда
busy_enable — разрешение (busy_enable=1) или запрещение (busy_enable=0) устройству игнорировать обращения к нему с запросами по сети во время выполнения
механических действий, введите busy_enable, чтобы посмотреть текущую настройку
пример: busy_enable ответ: 1разрешено 0запрещено
carrier_time — время (в секундах) простоя SIM Roulette между командами, по окончании таймера SIM Roulette заново подключается к сети
/ carrier_time=D — задать время
пример: carrier_time=60 ответ: 60подтверждение введенных данных
server_url — URL сервера
/ server_url=W — задать URL
пример: server_url=link.sim-roulette.com/?token=12345 ответ: link.sim-roulette.com/?token=12345подтверждение введенных данных
server_fr — Частота обращения к серверу
/ server_fr=D — задать частоту
пример: 1000 ответ: 1000подтверждение введенных данных
sms_check — интервал (в секундах) для проверки наличия SMS на активной СИМ-карте
/ sms_check=D — задать время (0 — надичие SMS не проверяется)
пример: sms_check=30 ответ: 30подтверждение введенных данных
pdu — включение (pdu=1) или отключение (pdu=0) автоконвертирования из PDU приходящих сообщений SMS и ответов на USSD-запросы, введите pdu, чтобы посмотреть текущую настройку
пример: pdu ответ: 1включено 0выключено
debug — разрешение (debug=1) или запрещение (debug=0) вывода отладочной информации (например, хода выполнения макросов) на экран устройства, введите debug, чтобы посмотреть текущую настройку
пример: debug ответ: 1включено 0выключено
version> — текущая версия ПО
пример: version ответ: 1.01текущая версия
save — Сохранение настроек в конфигурационном файле (без сохранения настройки действуют до перезагрузки устройства)
пример: save ответ: 1 всегда
МОНИТОРИНГ
request — команда для получения ответа (результата выполнения предыдущих команд) от устройства (команда никаких действий не производит)
email>send:[email];[topic] — отправка письма на E-mail
пример: email:user@mail.ru;Новая информация от SIM Roulette ответ: 1письмо отправлено 0неверные настройки
restart — Soft-reset устройства
пример: restart ответ: 1 ❱❱ ПЕРЕЗАГРУЗКА УСТРОЙСТВА
Интеграция SIM Roulette в ваш проект
Мы надеемся, что изложенная выше информация поможет без проблем интегровать SIM Roulette в ваш проект.
Для упрощения задачи рекомендуем использовать WEB-панель SR-Navigator и API для взаимодействия с вашим ПО.
И конечно, вы всегда можете воспользоваться услугами наших программистов.