API SR-Box/SR-Board
Взаимодействие с SIM Roulette
Термины и определения
Управляющие команды SIM Roulette SR-Box
Модем
Аудио
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-Box
GSM-МОДЕМ
modem>on — включение модемов
пример: modem>on ответ: 1всегда
Модемы включаются группами по 4. Задержка между включениями групп модемов регулируется командой modem>set:delay
Примечание: при включенном модеме в статус-строке на экране устройства и в WEB-интерфейсе отображается пиктограмма молнии
modem>on[D] — включение диапазона модемов
пример: modem>on[1] ответ: 1всегда
1 группа модемов: 1-4, 2 группа: 5-8.
modem>off — выключение модемов
пример: modem>off ответ: 1всегда
Примечание: происходит автоматически при любых механических операциях устройства
modem>off[D] — выключение диапазона модемов
пример: modem>off[2] ответ: 1всегда
1 группа модемов: 1-4, 2 группа: 5-8.
modem>status — получение питания модема
пример: modem>status ответ: 1питание включено 0питание выключено
modem>select:D — выбор модема для взаимодействия (1-8)
пример: modem>select:D ответ: 3подтверждение выбранного номера модема
Примечание: при включенном режиме modem>set:echo=1 во время перехода к следующему модему в фоне продолжается прием ответов от предыдущего модема.
modem>set:echo — включение (modem>set:echo=1) или отключение (modem>set:echo=0) режима фонового опроса модема
примеры: modem>set:echo=1 ответ: 1подтверждение выбора
modem>set:delay — задержка (в миллисекундах) между включениями групп модемов / modem>set:delay=D — задать задержку
примеры: modem>set:delay ответ: 500текущая задержка
modem>set:delay=1000 ответ: 1000установленная задержка
modem>set:rate — скорость порта для обмена данными с модемами / modem>set:rate=D — задать битрейт
примеры: modem>set:rate ответ: 115200текущий битрейт
modem>set:rate=57600 ответ: 57600установленный битрейт
modem>set:mode — режим работы модемов / TXT (modem>set:mode=txt) или PDU (modem>set:mode=pdu)
примеры: modem>set:mode ответ: pduтекущий режим
modem>set:mode=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
modem>sms:D — пакетное получение всех SMS со всех 8 СИМ-карт
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;3;4;5;6;7;8 или 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#3##AT+COPS?
+COPS: 0,0,"TELE2"
OK
#1#4##AT+COPS?
+COPS: 0,0,"ROSTELECOM"
OK
#1#5##AT+COPS?
+COPS: 0,0,"MEGAFON"
OK
#1#6##AT+COPS?
+COPS: 0,0,"Bee Line GSM"
OK
#1#7##AT+COPS?
+COPS: 0,0,"MTS"
OK
#1#8##AT+COPS?
+COPS: 0,0,"TELE2"
OK
#1##1# — разделитель
АУДИО
audio>[D1]:[D2] — коммутатор аудио-гарнитур SR-Box-Voice
D1 — выбор аудио-интрефейcа 1 (модемы 1-4) / 2 (модемы 5-8)
D2 — выбор модема для выбранного интерфейса (1-4)
пример: audio>2:4 ответ: 2:4подтверждение ввода
К интерфейсу 2 (микрофон, наушники) будет подключен 8 модем
SMS
sms>discover — проверка наличия SMS на СИМ-карте
пример: sms>discover ответ: 1есть 0нет
sms>read — копирование одного 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ошибка синтаксиса в буфере
sms>clear — удаление всех SMS с СИМ-карты
пример: sms>clear ответ: 1всегда
БУФЕР
Текстовый буфер устройства — мощный инструмент для анализа входных данных, формирования выходных данных и команд.
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заданное количество символов не найдено
ЭКРАН
display>clear — очистить экран
пример: display>clear ответ: 1всегда
display=W — вывод на экран текста и специальных символов
W — параметры разделенные символами "::":
2 — выравнивание по левому краю (L), по центру (С), по правому краю (R)
3 — позиция по оси X (0 — 127)
4 — позиция по оси Y (0 — 63)
5 — текст (в зависимости от выбранного языка интерфейса можно показывать пользователю {английскую~русскую} версию)
(6) — необязательный параметр — разделитель "|" после которого можно дописать вывод второй, третьей и т.д. строк
примеры:
display=10::C::64::30::Текст|16::C::64::45::Ещё текст
display=10::C::64::35::{English text~Русский текст}! — в зависимости от выбранного языка будет использован соответсвующий вариант
ответ: 1всегда
display>com:W — включение/выключение инверсии экрана
W — параметр:
ЗВУК
sound:beep — короткий отрывистый звук
пример: sound:beep ответ: 1всегда
sound:error — продолжительный звук
пример: sound:error ответ: 1всегда
ПУЛЬТ
key>discover — проверка возможности управления с пульта (в SR Box взаимоисключающее управление пульт/интернет, для активации пульта при включении надо нажать на пульте любую кнопку)
пример: key>discover ответ: 1управление возможно 0управление невозможно
key — отпрос пульта (в ответе возвратится 1 если какая-либо кнопка была нажата, имя нажатой клавиши помещается в буфер)
пример: key ответ: 1кнопка нажата 0кнопка не нажата
варианты ответов в буфере: 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, menu, ok, up, down, left, right, star, hash
ПЕРЕМЕННЫЕ
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 Мегабайт.
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>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-Box, там же можно отслеживать ход выполнения запущенного макроса.
macro>stop (m>stop) — остановка выполнения текущего макроса
НАСТРОЙКИ
answer — разрешение (answer=1) или запрещение (answer=0) вывода ответов команд в выходной поток
пример: answer=1 ответ: 1подтверждение введенных данных
answer>clear — очистка буфера ответов
пример: answer>clear ответ: 1всегда
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 для взаимодействия с вашим ПО.
И конечно, вы всегда можете воспользоваться услугами наших программистов.