TM API — различия между версиями
(→Запрос информации о состоянии заказа) |
|||
Строка 1404: | Строка 1404: | ||
} | } | ||
} | } | ||
+ | </pre> | ||
+ | |||
+ | == Описание протокола TMTAPI Версия 1.0 == | ||
+ | |||
+ | === Общее описание протокола === | ||
+ | |||
+ | ==== Формат запроса ==== | ||
+ | |||
+ | TM API принимает входящие запросы по протоколу HTTPS. В URI запроса после ip адреса и порта, который будет слушать TM API, должно идти название API (tm_tapi) и версия API. | ||
+ | |||
+ | Пример: | ||
+ | |||
+ | <pre> | ||
+ | GET https://ip:port/tm_tapi/1.0/get_info_by_phone HTTP/1.1 | ||
+ | </pre> | ||
+ | |||
+ | Для получения данных из БД используются запросы типа GET. Для записи данных в БД используются запросы типа POST. В запросе типа GET параметры запроса передаются в URI. | ||
+ | |||
+ | Пример: | ||
+ | |||
+ | <pre> | ||
+ | GET https://ip:port/tm_tapi/1.0/get_info_by_phone?phone=89058800565&fields=PHONE_TYPEPHONE_ | ||
+ | TO_DIAL&signature=661ce071eeefcb4f7fc8bc1f17bd520b HTTP/1.1 | ||
+ | </pre> | ||
+ | |||
+ | В запросе типа POST параметры передаются в теле запроса в формате application/x-wwwform- | ||
+ | urlencoded. | ||
+ | |||
+ | Пример: | ||
+ | |||
+ | <pre> | ||
+ | POST https://ip:port/tm_tapi/1.0/change_order_state HTTP/1.1 | ||
+ | Content-Type: application/x-www-form-urlencoded | ||
+ | Content-Length: 71 | ||
+ | |||
+ | order_id=98798&need_state=12&signature=a204c50c7e48f0c6849a87485fe5e171 | ||
+ | </pre> | ||
+ | |||
+ | В любом запросе обязательно, с другими полями, должно передаваться поле signature. В нем передается MD5 хэш, рассчитанный для строки, которая получается сцеплением строки параметров запроса с секретным ключом. Секретный ключ задается в настройках модуля TMAPI в Такси-Мастер. | ||
+ | |||
+ | Пример: | ||
+ | |||
+ | <pre> | ||
+ | Запрос: | ||
+ | GET https://ip:port/tm_tapi/1.0/get_info_by_phone?phone=89058800565&fields=PHONE_TYPE | ||
+ | &signature=ef17ea682d09e452af544a5758dba396 HTTP/1.1 | ||
+ | |||
+ | Секретный ключ: | ||
+ | 321 | ||
+ | |||
+ | Signature = MD5("phone=89058800565&fields=PHONE_TYPE" + "321") = ef17ea682d09e452af544a5758dba396 | ||
+ | HTTP/1.1 | ||
+ | </pre> | ||
+ | |||
+ | ==== Формат ответа ==== | ||
+ | TM API всегда возвращает HTTP код 200 ОК. Результат выполнения запроса содержится в теле ответа в формате XML. Общий вид возвращаемого результата: | ||
+ | |||
+ | <pre> | ||
+ | <response> | ||
+ | <code>Числовой код результата</code> | ||
+ | <descr>Строковое описание результата</descr> | ||
+ | <data>Дополнительная информация</data> | ||
+ | </response> | ||
+ | </pre> | ||
+ | |||
+ | Существуют общие для всех запросов коды результатов: | ||
+ | {| | ||
+ | ! Код | ||
+ | ! Описание | ||
+ | |- | ||
+ | |0 | ||
+ | |Успешное выполнение запроса | ||
+ | |- | ||
+ | |1 | ||
+ | |Неизвестная ошибка | ||
+ | |- | ||
+ | |2 | ||
+ | |Неизвестный тип API | ||
+ | |- | ||
+ | |3 | ||
+ | |API отключено в настройках модуля TM API в Такси-Мастер | ||
+ | |- | ||
+ | |4 | ||
+ | |Не совпадает секретный ключ | ||
+ | |- | ||
+ | |5 | ||
+ | |Неподдерживаемая версия API | ||
+ | |- | ||
+ | |6 | ||
+ | |Неизвестное название запроса | ||
+ | |- | ||
+ | |7 | ||
+ | |Неверный тип запроса GET | ||
+ | |- | ||
+ | |8 | ||
+ | |Не хватает входного параметра (в доп. информации ответа будет название | ||
+ | отсутствующего параметра) | ||
+ | |- | ||
+ | |9 | ||
+ | |Некорректный входной параметр (в доп. информации ответа будет название некорректного параметра) | ||
+ | |- | ||
+ | |10 | ||
+ | |Внутренняя ошибка обработки запроса | ||
+ | |} | ||
+ | |||
+ | |||
+ | === Описание запросов === | ||
+ | |||
+ | === Запрос информации по номеру телефона === | ||
+ | Метод: GET | ||
+ | |||
+ | Название запроса: get_info_by_phone | ||
+ | |||
+ | Параметры: | ||
+ | |||
+ | {| | ||
+ | !Параметр | ||
+ | !Тип | ||
+ | !Описание | ||
+ | |- | ||
+ | |colspan="3"|Обязательные параметры | ||
+ | |- | ||
+ | |phone | ||
+ | |Строка, <= 16 символов | ||
+ | |Номер телефона | ||
+ | |- | ||
+ | |fields | ||
+ | |Строка Список полей, которые необходимо вернуть. Поля перечисляются через ''-'' | ||
+ | |- | ||
+ | |signature | ||
+ | |Строка | ||
+ | |Поле для проверки секретного ключа. | ||
+ | |} | ||
+ | |||
+ | Специальные возвращаемые коды: нет | ||
+ | Возвращаемые данные в случае успешного выполнения запроса: зависит от того какие поля были переданы в поле fields. | ||
+ | |||
+ | {| | ||
+ | !Параметр | ||
+ | !Тип | ||
+ | !Описание | ||
+ | |- | ||
+ | |PHONE_TYPE | ||
+ | |Целое | ||
+ | |Тип телефона звонящего | ||
+ | (1 - если звонит водитель; 2 - если звонит физлицо; 3 - если звонит юрлицо; 4 - если звонит номер из справочника телефоны; 0 - неизвестный номер) | ||
+ | |- | ||
+ | |PHONE_TO_DIAL | ||
+ | |Строка, <= 16 символов | ||
+ | |Номер телефона для отзвона по заказу | ||
+ | |- | ||
+ | |CREW_ID | ||
+ | |Целое | ||
+ | |ИД экипажа | ||
+ | |- | ||
+ | |IS_PRIOR | ||
+ | |true или false | ||
+ | |Признак предварительного заказа | ||
+ | |- | ||
+ | |ORDER_CLIENT_ID | ||
+ | |Целое | ||
+ | |ИД клиента из заказа | ||
+ | |- | ||
+ | |DRIVER_PHONE | ||
+ | |Строка, <= 16 символов | ||
+ | |Номер телефона водителя | ||
+ | |- | ||
+ | |CREW_SYSTEMSTATE | ||
+ | |Целое | ||
+ | |Состояние экипажа | ||
+ | |- | ||
+ | |CLIENT_ID | ||
+ | |Целое | ||
+ | |ИД клиента. | ||
+ | |- | ||
+ | |CLIENT_TYPE | ||
+ | |Целое | ||
+ | |Тип клиента | ||
+ | |- | ||
+ | |CATEGORY | ||
+ | |Целое | ||
+ | |Пользовательское значение категории телефона | ||
+ | |- | ||
+ | |PHONE_SYSTEM_CAT_EGORY | ||
+ | |Целое | ||
+ | |Системное значение категории телефона (0 - обычный, 1 - черный, 2 - белый, 3 - серый) | ||
+ | |- | ||
+ | |ORDER_ID | ||
+ | |Целое | ||
+ | |ИД заказа | ||
+ | |- | ||
+ | |DRIVER_ID | ||
+ | |Целое | ||
+ | |ИД водителя | ||
+ | |- | ||
+ | |ORDER_STATE | ||
+ | |Целое | ||
+ | |Состояние заказа | ||
+ | |- | ||
+ | |DRIVER_REMAINDER | ||
+ | |Дробное | ||
+ | |Баланс счета водителя | ||
+ | |- | ||
+ | |DISCOUNTEDSUMM | ||
+ | |Строка | ||
+ | |Сумма заказа с учетом всех скидок | ||
+ | |- | ||
+ | |CREW_GROUP_ID | ||
+ | |Целое | ||
+ | |ИД группы экипажа | ||
+ | |- | ||
+ | |CLIENT_BALANCE | ||
+ | |Дробное | ||
+ | |Баланс клиента | ||
+ | |- | ||
+ | |DRIVER_TIMECOUNT | ||
+ | |Целое | ||
+ | |Время пути водителя до адреса подачи в минутах | ||
+ | |- | ||
+ | |SOURCE_TIMECOUNT | ||
+ | |Целое | ||
+ | |Время оставшееся до подачи в минутах | ||
+ | |- | ||
+ | |SOUND_COLOR | ||
+ | |Строка | ||
+ | |Запись с информацией о цвете | ||
+ | |- | ||
+ | |SOUND_GOSNUMBER | ||
+ | |Строка | ||
+ | |Запись с информацией о государственном номере автомобиля | ||
+ | |- | ||
+ | |SOUND_MARK | ||
+ | |Строка | ||
+ | |Запись с информацией о марке автомобиля | ||
+ | |- | ||
+ | |GOSNUMBER | ||
+ | |Строка | ||
+ | |Государственный номер автомобиля | ||
+ | |- | ||
+ | |CAR_COLOR | ||
+ | |Строка | ||
+ | |Цвет автомобиля | ||
+ | |- | ||
+ | |CAR_MARK | ||
+ | |Строка | ||
+ | |Марка автомобиля | ||
+ | |} | ||
+ | |||
+ | Пример: | ||
+ | |||
+ | <pre> | ||
+ | Запрос: | ||
+ | GET https://ip:port/tm_tapi/1.0/get_info_by_phone?phone=89058800565l&fields=PHONE_TYPEPHONE_ | ||
+ | TO_DIAL-CREW_ID-ORDER_ID&signature=d35ab2765f2968d48c096d5f5327db26 HTTP/1.1 | ||
+ | |||
+ | Ответ: | ||
+ | |||
+ | <response> | ||
+ | <code>0</code> | ||
+ | <descr>OK</descr> | ||
+ | <data> | ||
+ | <PHONE_TYPE>0</PHONE_TYPE> | ||
+ | <PHONE_TO_DIAL></PHONE_TO_DIAL> | ||
+ | <CREW_ID>3</CREW_ID> | ||
+ | <ORDER_ID>6</ORDER_ID> | ||
+ | </data> | ||
+ | </response> | ||
+ | </pre> | ||
+ | |||
+ | ==== Запрос информации по ИД заказа ==== | ||
+ | |||
+ | Метод: GET | ||
+ | Название запроса: get_info_by_order_id | ||
+ | Параметры: | ||
+ | |||
+ | {| | ||
+ | !Параметр | ||
+ | !Тип | ||
+ | !Описание | ||
+ | |- | ||
+ | |colspan="3"|Обязательные параметры | ||
+ | |- | ||
+ | |order_id | ||
+ | |Целое | ||
+ | |ИД заказа | ||
+ | |- | ||
+ | |fields | ||
+ | |Строка | ||
+ | |Список полей, которые необходимо вернуть. Поля перечисляются через ''-'' | ||
+ | |- | ||
+ | |signature | ||
+ | |Строка | ||
+ | |Поле для проверки секретного ключа. | ||
+ | |} | ||
+ | |||
+ | Специальные возвращаемые коды: нет | ||
+ | Возвращаемые данные в случае успешного выполнения запроса: зависит от того какие поля были переданы в поле fields. | ||
+ | |||
+ | {| | ||
+ | !Параметр | ||
+ | !Тип | ||
+ | !Описание | ||
+ | |- | ||
+ | |DRIVER_SOURCETIME | ||
+ | |Строка, <= 16 символов | ||
+ | |Время до подачи в минутах, указанное водителем | ||
+ | |- | ||
+ | |SOUND_COLOR | ||
+ | |Строка | ||
+ | |Запись с информацией о цвете | ||
+ | |- | ||
+ | |MARK | ||
+ | |Строка | ||
+ | |Марка автомобиля | ||
+ | |- | ||
+ | |COLOR | ||
+ | |Строка | ||
+ | |Цвет автомобиля | ||
+ | |- | ||
+ | |GOSNUMBER | ||
+ | |Строка | ||
+ | |Государственный номер автомобиля | ||
+ | |- | ||
+ | |SOUND_MARK | ||
+ | |Строка | ||
+ | |Запись с информацией о марке автомобиля | ||
+ | |- | ||
+ | |CREWGROUPID | ||
+ | |Целое | ||
+ | |ИД группы экипажа | ||
+ | |- | ||
+ | |IS_PRIOR | ||
+ | |true или false | ||
+ | |Признак предварительного заказа | ||
+ | |- | ||
+ | |DISCOUNTEDSUMM | ||
+ | |Строка | ||
+ | |Сумма заказа с учетом всех скидок | ||
+ | |- | ||
+ | |MOBILE_PHONE | ||
+ | |Строка, <= 16 символов | ||
+ | |Номер телефона водителя | ||
+ | |- | ||
+ | |CATEGORYID | ||
+ | |Целое | ||
+ | |ИД категории телефона | ||
+ | |- | ||
+ | |SOURCE_TIME | ||
+ | |Целое | ||
+ | |Время до подачи в минутах | ||
+ | |} | ||
+ | |||
+ | Пример: | ||
+ | |||
+ | <pre> | ||
+ | Запрос: | ||
+ | |||
+ | GET https://ip:port/tm_tapi/1.0/get_info_by_order_id?order_id=60&fields=DRIVER_SOURCETIME-MARKCOLOR-GOSNUMBER-IS_PRIOR-MOBILE_PHONE-SOURCE_TIME&signature=fdcd04e570443b56176b83f44748dc23 | ||
+ | HTTP/1.1 | ||
+ | |||
+ | Ответ: | ||
+ | |||
+ | <response> | ||
+ | <code>0</code> | ||
+ | <descr>OK</descr> | ||
+ | <data> | ||
+ | <DRIVER_SOURCETIME></DRIVER_SOURCETIME> | ||
+ | <MARK></MARK> | ||
+ | <COLOR></COLOR> | ||
+ | <GOSNUMBER></GOSNUMBER> | ||
+ | <IS_PRIOR></IS_PRIOR> | ||
+ | <MOBILE_PHONE></MOBILE_PHONE> | ||
+ | <SOURCE_TIME></SOURCE_TIME> | ||
+ | </data> | ||
+ | </response> | ||
+ | </pre> | ||
+ | |||
+ | ==== Смена состояния заказа ==== | ||
+ | Метод: POST | ||
+ | |||
+ | Название запроса: change_order_state | ||
+ | |||
+ | Параметры: | ||
+ | |||
+ | {| | ||
+ | !Параметр | ||
+ | !Тип | ||
+ | !Описание | ||
+ | |- | ||
+ | |colspan="3"|Обязательные параметры | ||
+ | |- | ||
+ | |order_id | ||
+ | |Целое | ||
+ | |ИД заказа | ||
+ | |- | ||
+ | |need_state | ||
+ | |Целое | ||
+ | |Новое состояние заказа | ||
+ | |- | ||
+ | |signature | ||
+ | |Строка | ||
+ | |Поле для проверки секретного ключа. | ||
+ | |} | ||
+ | |||
+ | Специальные возвращаемые коды: | ||
+ | |||
+ | {| | ||
+ | !Код | ||
+ | !Описание | ||
+ | |- | ||
+ | |100 | ||
+ | |Заказ с таким ИД не найден. | ||
+ | |- | ||
+ | |101 | ||
+ | |Изменение состояния не соответствует необходимым условиям. | ||
+ | |} | ||
+ | |||
+ | Возвращаемые данные в случае успешного выполнения запроса | ||
+ | |||
+ | {| | ||
+ | !Параметр | ||
+ | !Тип | ||
+ | !Описание | ||
+ | |- | ||
+ | |ORDER_ID | ||
+ | |Целое | ||
+ | |ИД созданного заказа | ||
+ | |- | ||
+ | |NEW_STATE | ||
+ | |Целое | ||
+ | |Новое состояние заказа | ||
+ | |} | ||
+ | |||
+ | Пример: | ||
+ | |||
+ | <pre> | ||
+ | Запрос: | ||
+ | |||
+ | POST https://ip:port/tm_tapi/1.0/change_order_state HTTP/1.1 | ||
+ | Content-Type: application/x-www-form-urlencoded | ||
+ | Content-Length: 71 | ||
+ | |||
+ | order_id=18561&need_state=14&signature=3e8107e0c044e55d983db1fbed82fd8c | ||
+ | |||
+ | Ответ: | ||
+ | |||
+ | <response> | ||
+ | <code>0</code> | ||
+ | <descr>OK</descr> | ||
+ | <data> | ||
+ | <ORDER_ID>18561</ORDER_ID> | ||
+ | <NEW_STATE>14</NEW_STATE> | ||
+ | </data> | ||
+ | </response> | ||
+ | </pre> | ||
+ | |||
+ | ==== Запись пути к файлу разговора в базу данных ==== | ||
+ | |||
+ | Метод: POST | ||
+ | |||
+ | Название запроса: create_record_link | ||
+ | |||
+ | Параметры: | ||
+ | |||
+ | {| | ||
+ | !Параметр | ||
+ | !Тип | ||
+ | !Описание | ||
+ | |- | ||
+ | |colspan="3"|Обязательные параметры | ||
+ | |- | ||
+ | |RECORD_DATE | ||
+ | |ГГГГММДДччммсс | ||
+ | |Дата записи | ||
+ | |- | ||
+ | |RECORD_LENGTH | ||
+ | |Целое | ||
+ | |Продолжительность записи (в секундах) | ||
+ | |- | ||
+ | |PHONE | ||
+ | |Строка, <= 16 символов | ||
+ | |Номер телефона | ||
+ | |- | ||
+ | |ORDERID | ||
+ | |Целое | ||
+ | |Заказ, с которого сделана запись | ||
+ | |- | ||
+ | |USERID | ||
+ | |Целое | ||
+ | |Пользователь, сделавший запись | ||
+ | |- | ||
+ | |FILE_PATH | ||
+ | |Строка,<=255 символов | ||
+ | |Путь к файлу записи | ||
+ | |- | ||
+ | |RECORD_GUID | ||
+ | |Строка,<= 80 символов | ||
+ | |GUID звонка | ||
+ | |- | ||
+ | |signature | ||
+ | |Строка | ||
+ | |Поле для проверки секретного ключа. | ||
+ | |} | ||
+ | |||
+ | Специальные возвращаемые коды: нет | ||
+ | Возвращаемые данные в случае успешного выполнения запроса | ||
+ | |||
+ | {| | ||
+ | !Параметр | ||
+ | !Тип | ||
+ | !Описание | ||
+ | |- | ||
+ | |RECORD_ID | ||
+ | |Целое | ||
+ | |ИД созданной записи | ||
+ | |} | ||
+ | |||
+ | Пример: | ||
+ | |||
+ | <pre> | ||
+ | Запрос: | ||
+ | |||
+ | POST https://ip:port/tm_tapi/1.0/create_record_link HTTP/1.1 | ||
+ | Content-Type: application/x-www-form-urlencoded | ||
+ | Content-Length: 206 | ||
+ | RECORD_DATE=20121108145953&RECORD_LENGTH=6546&PHONE=654321&ORDERID=654&USERID=564&FILE_PATH=d%3A | ||
+ | %5CProjects%5Ctrunk%5C%5Ftrunk%5CTM%5CBin | ||
+ | %5C&RECORD_GUID=GUID456258&signature=cd11d50d65fa7e8ad73f80cdc7d296c7 | ||
+ | |||
+ | Ответ: | ||
+ | |||
+ | <response> | ||
+ | <code>0</code> | ||
+ | <descr>OK</descr> | ||
+ | <data> | ||
+ | <RECORD_ID>25</RECORD_ID> | ||
+ | </data> | ||
+ | </response> | ||
+ | </pre> | ||
+ | |||
+ | ==== Создать новый заказ ==== | ||
+ | |||
+ | Метод: POST | ||
+ | |||
+ | Название запроса: make_new_order | ||
+ | |||
+ | Параметры: | ||
+ | |||
+ | {| | ||
+ | !Параметр | ||
+ | !Тип | ||
+ | !Описание | ||
+ | |- | ||
+ | |colspan="3"|Обязательные параметры | ||
+ | |- | ||
+ | |PHONE | ||
+ | |Строка, <= 16 символов | ||
+ | |Номер телефона | ||
+ | |- | ||
+ | |ORDER_STATE_ID | ||
+ | |Целое | ||
+ | |ИД состояния заказа | ||
+ | |- | ||
+ | |signature | ||
+ | |Строка | ||
+ | |Поле для проверки секретного ключа. | ||
+ | |- | ||
+ | |colspan="3"|Необязательные параметры | ||
+ | |- | ||
+ | |CREW_GROUP_ID | ||
+ | |Целое | ||
+ | |ИД группы экипажа | ||
+ | |- | ||
+ | |TARIFF_ID | ||
+ | |Целое | ||
+ | |ИД тарифа | ||
+ | |- | ||
+ | |PHONE_PREFIX | ||
+ | |Строка | ||
+ | |Префикс, отрезаемый от номера телефона при поиске в базе данных. Для входящих звонков это код города с префиксом входящих номеров, обычно "8". Например, "83412" | ||
+ | |- | ||
+ | |DISCOUNTED_SU MM | ||
+ | |Строка | ||
+ | |Фиксированная сумма за заказ | ||
+ | |} | ||
+ | |||
+ | Специальные возвращаемые коды: | ||
+ | |||
+ | {| | ||
+ | !Код | ||
+ | !Описание | ||
+ | |- | ||
+ | |100 | ||
+ | |Клиент не найден | ||
+ | |} | ||
+ | |||
+ | Возвращаемые данные в случае успешного выполнения запроса | ||
+ | |||
+ | {| | ||
+ | !Параметр | ||
+ | !Тип | ||
+ | !Описание | ||
+ | |- | ||
+ | |ORDER_ID | ||
+ | |Целое | ||
+ | |ИД созданного заказа | ||
+ | |} | ||
+ | |||
+ | Пример: | ||
+ | |||
+ | <pre> | ||
+ | Запрос: | ||
+ | |||
+ | POST https://ip:port/tm_tapi/1.0/make_new_order HTTP/1.1 | ||
+ | Content-Type: application/x-www-form-urlencoded | ||
+ | Content-Length: 206 | ||
+ | |||
+ | PHONE=89058770593&ORDER_STATE_ID=10&DISCOUNTED_SUMM=100&signature=afc947f610eba380df6d0e441b03ddad | ||
+ | |||
+ | Ответ: | ||
+ | |||
+ | <response> | ||
+ | <code>0</code> | ||
+ | <descr>OK</descr> | ||
+ | <data> | ||
+ | <order_id>27</order_id> | ||
+ | </data> | ||
+ | </response> | ||
</pre> | </pre> | ||
[[Категория:ТМ2]] | [[Категория:ТМ2]] |
Версия 15:25, 14 декабря 2012
TM API - специальный набор инструментов Такси-Мастер, который позволит объединить систему с вашим сайтом и различными полезными сервисами. Он предоставляется вам на свободных условиях.
Благодаря этому набору вы сможете:
- Создать механизм приема заказов через интернет.
- Сделать ваш сайт более информативным: публиковать полезную для клиентов информацию прямо из системы - список ближайших экипажей, предварительный расчет стоимости поездки, мониторинг движения автомобиля такси в процессе выполнения заказа, карты города и контактную информацию.
- Расширить возможности своей службы за счет популярного онлайн-сервиса Яндекс Такси.
Содержание
- 1 Параметры TM API
- 2 Общее описание протокола
- 3 Описание запросов
- 3.1 Запрос-пинг
- 3.2 Запрос списка групп экипажей
- 3.3 Запрос списка служб ЕДС
- 3.4 Запрос списка тарифов
- 3.5 Запрос списка услуг
- 3.6 Запрос списка скидок
- 3.7 Создание нового заказа
- 3.8 Расчет суммы заказа
- 3.9 Запрос информации о водителе
- 3.10 Запрос информации об автомобиле
- 3.11 Запрос координат экипажей
- 3.12 Запрос адресов, содержащих нужную строку
- 3.13 Анализ маршрута
- 3.14 Запрос информации о состоянии заказа
- 4 Описание протокола TMTAPI Версия 1.0
Параметры TM API
Задать настройки для корректной работы TM API вы сможете в программе Такси-Мастер в меню Настройки в одноименной ветке TM API . Параметры организуют и контролируют работу модуля «Интернет-заказы».
- Установите флажок Использовать TM API , чтобы приступить к его использованию.
- В поле Локальный порт введите номер порта подключения к интернету, на котором работает и будет ожидать запросы о новых заказах TMServer. Рекомендуется оставить номер порта по умолчанию.
- Установите флажок Можно использовать данное рабочее место TMServer для распознавания адресов для того, чтобы конкретно с данного рабочего места происходило распознавание адресов модулем "Интернет-заказы".
- Перезапустите Такси-Мастер и TMServer для запуска работы модуля.
Ветка «Открытое API»
В данной ветке регулируется доступ к синхронизации Такси-Мастер со сторонним сервисом (сайтом), с помощью которого клиенты будут создавать интернет-заказы. С примером кода для работы вы можете ознакомиться в данной статье в разделе Общее описание протокола.
- Установите флажок Использовать открытое API для того, чтобы запустить работу по обслуживанию модуля «Интернет-заказы». При установленном флажке сервер модуля «Интернет-заказы» запускается и ожидает запросы о новых заказах.
- В поле Секретный ключ укажите номер секретного ключа для работы с модулем «Интернет-заказы», который будет выслан вам в письме от менеджера.
- Перезапустите Такси-Мастер и TMServer для запуска работы модуля.
Ветка «API для телефонии»
В данной ветке регулируются настройки API для телефонии, т.е. взаимодействие Такси-Мастер с call-центром через программный интерфейс. С его помощью call-центр может дать команду Такси-Мастер создать заказ или запросить информацию о статусе текущего заказа.
- Установите флажок Использовать открытое API для телефонии для того, чтобы запустить работу по обслуживанию телефонии через API.
- В поле Секретный ключ укажите номер секретного ключа для работы.
- Перезапустите Такси-Мастер и TMServer для запуска работы модуля.
Ветка «Платежные терминалы»
Параметры этой ветки отвечают за работу модуля интеграции с платежными системами.
- Установите флажок Включить прием терминальных платежей . Данная функция позволит отображать все платежные операции по приходу средств от водителей через терминалы в базе данных программы.
- В поле Секретный ключ укажите номер секретного ключа для работы с платежными системами и сверки платежей, который будет выслан вам в письме от менеджера. Секретный ключ - это определенный набор символов, необходимый для формирования подписи при передаче информации о платеже.
- В полях Логин и Пароль введите данные учетной записи на сайте http://term.bitmaster.ru.
- Кнопка Задать всем водителям терминальный аккаунт по их ИД служит для соединения TM API с сервером Такси-Мастер. В результате соединения записи о терминальных аккаунтах генерируются, заносятся (для тех водителей, у которых они отсутствуют) и обновляются (для тех водителей, у которых уже существуют терминальные аккаунты) в Такси-Мастер.
- Перезапустите Такси-Мастер и TMServer для запуска работы модуля.
Общее описание протокола
Формат запроса
TMAPI принимает входящие запросы по протоколу HTTPS. В URI запроса после ip адреса и порта, который будет слушать TMWeb, должно идти название API (common_api) и версия API. Пример:
GET https://ip:port/common_api/1.0/get_crew_groups_list HTTP/1.1
Для получения данных из БД используются запросы типа GET. Для записи данных в базу данных используются запросы типа POST. В запросе типа GET параметры запроса передаются в URI. Пример:
GET https://ip:port/common_api/1.0/calc_order_cost?tariff_id=1&distance_city=10 HTTP/1.1 Signature: <...>
В запросе типа POST параметры передаются в теле запроса в формате application/x-wwwform-urlencoded. Пример:
POST https://ip:port/common_api/1.0/create_order HTTP/1.1 Signature: <...> Content-Type: application/x-www-form-urlencoded Content-Length: 118 phone=89123456789&source=SOURCE&source_time=20120501100000&dest=DEST&customer=CUSTOMER& comment=COMMENT&crew_group_id=1
В любом запросе обязательно должен быть заголовок Signature. В нем передается MD5 хэш, рассчитанный для строки, которая получается сцеплением строки параметров запроса с секретным ключом. Секретный ключ задается в настройках модуля TMWeb в ТМ2. Пример:
Запрос: GET https://ip:port/common_api/1.0/calc_order_cost?tariff_id=1&distance_city=10 HTTP/1.1 Секретный ключ: 1234567890 Signature = MD5("tariff_id=1&distance_city=10" + "1234567890") = d7b8fb11b5499b64d750b8efe53e2877
Формат ответа
TMWeb всегда возвращает HTTP код 200 ОК. Результат выполнения запроса содержится в теле ответа в формате JSON. Общий вид возвращаемого результата:
{ "code":<Числовой код результата>, "descr":"<Строковое описание результата>", "data":{<Дополнительная информация>} }
Существуют общие для всех запросов коды результатов:
Код | Описание |
---|---|
0 | Успешное выполнение запроса |
1 | Неизвестная ошибка |
2 | Неизвестный тип API |
3 | API отключено в настройках TMWeb |
4 | Не совпадает секретный ключ |
5 | Неподдерживаемая версия API |
6 | Неизвестное название запроса |
7 | Неверный тип запроса GET/POST |
8 | Не хватает входного параметра (в доп. информации ответа будет название отсутствующего параметра) |
9 | Некорректный входной параметр (в доп. информации ответа будет название некорректного параметра) |
10 | Внутренняя ошибка обработки запроса |
Описание запросов
Запрос-пинг
Для данного запроса не проверяется версия API, секретный ключ и тип запроса GET/ POST.
Метод: GET или POST
Название запроса: ping
Параметры: нет
Специальные возвращаемые коды: нет
Возвращаемые данные в случае успешного выполнения запроса: нет
Пример:
Запрос: GET https://ip:port/common_api/1.0/ping HTTP/1.1 Ответ: { "code":0, "descr":"OK", "data":{} }
Запрос списка групп экипажей
Метод: GET
Название запроса: get_crew_groups_list
Параметры: нет
Специальные возвращаемые коды: нет
Возвращаемые данные в случае успешного выполнения запроса:
Параметр | Тип | Описание |
---|---|---|
crew_groups | Массив | Список групп экипажей |
• id | Целое | ИД группы экипажей |
• name | Строка | Название группы экипажей |
Пример:
Запрос: GET https://ip:port/common_api/1.0/get_crew_groups_list HTTP/1.1 Signature: <...> Ответ: { "code":0, "descr":"OK", "data":{ "crew_groups":[ { "id":1, "name":"CREW_GROUP1" }, { "id":2, "name":"CREW_GROUP2" } ] } }
Запрос списка служб ЕДС
Метод: GET
Название запроса: get_uds_list
Параметры: нет
Специальные возвращаемые коды: нет
Возвращаемые данные в случае успешного выполнения запроса:
Параметр | Тип | Описание |
---|---|---|
uds | Массив | Список служб ЕДС |
• id | Целое | ИД службы ЕДС |
• name | Строка | Название службы ЕДС |
Пример:
Запрос: GET https://ip:port/common_api/1.0/get_uds_list HTTP/1.1 Signature: <...> Ответ: { "code":0, "descr":"OK", "data":{ "uds":[ { "id":1, "name":"UDS1" }, { "id":2, "name":"UDS2" } ] } }
Запрос списка тарифов
Метод: GET Название запроса: get_tariffs_list
Параметры: нет
Специальные возвращаемые коды: нет
Возвращаемые данные в случае успешного выполнения запроса:
Параметр | Тип | Описание |
---|---|---|
tariffs | Массив | Список тарифов |
• id | Целое | ИД тарифа |
• name | Строка | Название тарифа |
Пример:
Запрос: GET https://ip:port/common_api/1.0/get_tariffs_list HTTP/1.1 Signature: <...> Ответ: { "code":0, "descr":"OK", "data":{ "tariffs":[ { "id":1, "name":"TARIFF1" }, { "id":2, "name":"TARIFF2" } ] } }
Запрос списка услуг
Метод: GET
Название запроса: get_services_list
Параметры: нет
Специальные возвращаемые коды: нет
Возвращаемые данные в случае успешного выполнения запроса:
Параметр | Тип | Описание |
---|---|---|
services | Массив | Список услуг |
• id | Целое | ИД услуги |
• name | Строка | Название услуги |
• sum | Дробное | Абсолютна сумма услуги, руб |
• percent | Дробное | Процент услуги от стоимости заказа, % |
Пример:
Запрос: GET https://ip:port/common_api/1.0/get_services_list HTTP/1.1 Signature: <...> Ответ: { "code":0, "descr":"OK", "data":{ "services":[ { "id":1, "name":"SERVICE1", "sum":100, "percent":0 }, { "id":2, "name":"SERVICE2" "sum":0, "percent":10 } ] } }
Запрос списка скидок
Метод: GET
Название запроса: get_discounts_list
Параметры: нет
Специальные возвращаемые коды: нет
Возвращаемые данные в случае успешного выполнения запроса:
Параметр | Тип | Описание |
---|---|---|
services | Массив | Список скидок |
• id | Целое | ИД скидки |
• name | Строка | Название скидки |
• sum | Дробное | Абсолютна сумма скидки, руб |
• percent | Дробное | Процент скидки от стоимости заказа, % |
Пример:
Запрос: GET https://ip:port/common_api/1.0/get_discounts_list HTTP/1.1 Signature: <...> Ответ: { "code":0, "descr":"OK", "data":{ "discounts":[ { "id":1, "name":"DISCOUNT1", "sum":100, "percent":0 }, { "id":2, "name":"DISCOUNT2" "sum":0, "percent":10 } ] } }
Создание нового заказа
Метод: POST
Название запроса: create_order
Параметры:
Параметр | Тип | Описание |
---|---|---|
Обязательные параметры | ||
phone | Строка, <= 16 символов | Номер телефона |
source | Строка | Адрес подачи |
source_time | ГГГГММДДччммсс | Время подачи |
Необязательные параметры | ||
dest | Строка | Адрес назначения |
customer | Строка | Заказчик |
comment | Строка | Комментарий |
crew_group_id | Целое | ИД группы экипажей |
uds_id | Целое | ИД службы ЕДС |
Специальные возвращаемые коды:
Код | Описание |
---|---|
100 | Заказ с такими параметрами уже создан |
Возвращаемые данные в случае успешного выполнения запроса:
Параметр | Тип | Описание |
---|---|---|
order_id | Целое | ИД созданного заказа |
Пример:
Запрос: POST https://ip:port/common_api/1.0/create_order HTTP/1.1 Signature: <...> Content-Type: application/x-www-form-urlencoded Content-Length: 127 phone=89123456789&source=SOURCE&source_time=20120501100000&dest=DEST&customer=CUSTOMER& comment=COMMENT&crew_group_id=1&uds_id=1 Ответ: { "code":0, "descr":"OK", "data":{ "order_id":12345 } }
Расчет суммы заказа
Метод: GET
Название запроса: calc_order_cost
Параметры:
Параметр | Тип | Описание |
---|---|---|
Обязательные параметры | ||
tariff_id | Целое | ИД тарифа |
Необязательные параметры | ||
source_time | ГГГГММДДччммсс | Время подачи |
is_prior | true или false | Предварительный заказ |
client_id | Целое | ИД клиента |
discount_id | Целое | ИД скидки |
disc_card_id | Целое | ИД дисконтной карты |
source_zone_id | Целое | ИД района подачи |
dest_zone_id | Целое | ИД района назначения |
distance_city | Дробное | Километраж по городу |
distance_country | Дробное | Километраж за городом |
source_distance_country | Дробное | Километраж до подачи за городом |
is_country | true или false | Загородный заказ |
waiting_minutes | Целое | Время ожидания посадки клиента в минутах |
is_hourly | true или false | Почасовой заказ |
hourly_minutes | Целое | Длительность почасового заказа в минутах |
is_prize | true или false | Призовой заказ |
back_way | true или false | Обратный путь за городом |
services | Строка | Список ИД услуг через точку с запятой, пример: «1;2;3» |
Специальные возвращаемые коды:
Код | Описание |
---|---|
Тариф не найден | Ошибка при расчете по тарифу |
Возвращаемые данные в случае успешного выполнения запроса:
Параметр | Тип | Описание |
---|---|---|
sum | Дробное | Рассчитанная общая сумма заказа |
info | Массив | Дополнительная информация по расчету суммы заказа |
• comment | Строка | Описание позиции дополнительной информации по расчету суммы заказа |
• sum | Строка | Сумма позиции дополнительной информации по расчету суммы заказа |
Пример:
Запрос: GET https://ip:port/common_api/1.0/get_crew_info?crew_id=1 HTTP/1.1 Signature: <...> Ответ: { "code":0, "descr":"OK", "data":{ "crew_id":1, "code":"123", "name":"CREW_NAME", "driver_id":1, "car_id":1, "crew_group_id":1 } }
Запрос информации о водителе
Метод: GET
Название запроса: get_driver_info
Параметры:
Параметры | Тип | Описание |
---|---|---|
Обязательные параметры | ||
driver_id | Целое | ИД водителя |
Необязательные параметры | ||
need_photo | true или false | Нужна ли фотография водителя |
Специальные возвращаемые коды:
Код | Описание |
---|---|
100 | Водитель не найден |
Возвращаемые параметры в случае успешного выполнения запроса:
Параметр | Тип | Описание |
---|---|---|
driver_id | Целое | ИД водителя |
name | Целое | ФИО водителя |
birthday | ДД.ММ.ГГГГ | День рождения водителя |
car_id | Целое | ИД основного автомобиля водителя |
license | Строка | Удостоверение водителя |
home_phone | Строка | Домашний телефон водителя |
mobile_phone | Строка | Мобильный телефон водителя |
is_locked | true или false | Водитель заблокирован |
is_dismissed | true или false | Водитель уволен |
driver_photo | Base64 | Фото водителя (только если need_photo = true) |
Пример:
Запрос: GET https://ip:port/common_api/1.0/get_driver_info?driver_id=1&need_photo=false HTTP/1.1 Signature: <...> Ответ: { "code":0, "descr":"OK", "data":{ "driver_id":1, "name":"DRIVER_NAME", "birthday":"01.01.1980", "car_id":1, "license":"1234567890", "home_phone":"123456", "mobile_phone":"+79123456789", "is_locked":false, "is_dismissed":false } }
Запрос информации об автомобиле
Метод: GET
Название запроса: get_car_info
Параметры:
Параметры | Тип | Описание |
---|---|---|
Обязательные параметры | ||
car_id | Целое | ИД автомобиля |
Необязательные параметры | ||
need_photo | true или false | Нужна ли фотография автомобиля |
Специальные возвращаемые коды:
Код | Описание |
---|---|
100 | Автомобиль не найден |
Возвращаемые данные в случае успешного выполнения запроса:
Параметр | Тип | Описание |
---|---|---|
car_id | Целое | ИД автомобиля |
name | Строка | Наименование автомобиля |
code | Строка | Позывной автомобиля |
gos_number | Строка | Государственный номер автомобиля |
color | Строка | Цвет автомобиля |
mark | Строка | Марка автомобиля |
short_name | Строка | Краткое название автомобиля |
production_year | true или false | Год выпуска автомобиля |
car_photo | Base64 | Фото автомобиля (только если need_photo = true) |
Пример:
Запрос: GET https://ip:port/common_api/1.0/get_car_info?car_id=1&need_photo=false HTTP/1.1 Signature: <...> Ответ: { "code":0, "descr":"OK", "data":{ "car_id":1, "code":"123", "name":"CAR_NAME", "gos_number":"a123bc", "color":"COLOR", "mark":"MARK", "model":"MODEL", "short_name":"SHORT_NAME", "production_year":2000 } }
Запрос координат экипажей
Метод: GET
Название запроса: get_crews_coords
Параметры:
Параметры | Тип | Описание |
---|---|---|
Необязательные параметры | ||
crew_id | Целое | ИД экипажа, по которому нужно вернуть координаты. Если не задано, то будут возвращены координаты всех экипажей на линии. |
Специальные возвращаемые коды:
Код | Описание |
---|---|
100 | Координаты не найдены |
Возвращаемые данные в случае успешного выполнения запроса:
Параметр | Тип | Описание |
---|---|---|
crews_coords | Массив | Список координат экипажей |
• crew_id | Целое | ИД экипажа |
• crew_code | Строка | Позывной экипажа |
• coords_time | ГГГГММДДччммсс | Время получения координат |
• lat | Дробное | Долгота |
• lon | Дробное | Широта |
• state_kind | Строка | Тип состояния экипажа. Может принимать значения:
• "not_available" — экипаж не на линии • "waiting" — экипаж свободен, ожидает заказы • "on_order" — экипаж на заказе • "on_break" — экипаж на перерыве |
Пример:
Запрос: GET https://ip:port/common_api/1.0/get_crews_coords HTTP/1.1 Signature: <...> Ответ: { "code":0, "descr":"OK", "data":{ "crews_coords":[ { "crew_id":1, "crew_code":"111", "coords_time":"20120101101010", "lat":11.111111, "lon":22.222222, "state_kind":"waiting" }, { "crew_id":2, "crew_code":"222", "coords_time":"20120101101010", "lat":33.333333, "lon":44.444444, "state_kind":"on_order" } ] } } Запрос: GET https://ip:port/common_api/1.0/get_crews_coords?crew_id=1 HTTP/1.1 Signature: <...> Ответ: { "code":0, "descr":"OK", "data":{ "crews_coords":[ { "crew_id":1, "crew_code":"111", "coords_time":"20120101101010", "lat":11.111111, "lon":22.222222, "state_kind":"waiting" } ] } }
Запрос адресов, содержащих нужную строку
Метод: GET
Название запроса: get_addresses_like
Параметры:
Параметры | Тип | Описание |
---|---|---|
Обязательные параметры | ||
get_streets | true или false | Искать улицы |
get_houses | true или false | Искать пункты |
get_streets | true или false | Искать дома. Не может быть равно true, если get_streets = true или get_points = true. |
street | Строка | Часть названия улицы или пункта, если идет поиск улиц или пунктов, или полное название улицы, если идет поиск домов |
Необязательные параметры | ||
house | Строка | Часть номера дома. Нужно только если get_houses = true. |
max_addresses_count | Целое | Максимальное количество адресов в ответе |
Специальные возвращаемые коды:
Код | Описание |
---|---|
100 | Подходящие адреса не найдены |
Возвращаемые данные в случае успешного выполнения запроса:
Параметр | Тип | Описание |
---|---|---|
addresses | Массив | Список подходящих адресов |
• street | Строка | Название улицы или пункта |
• house | Строка | Номер дома |
• kind | Строка | Тип адреса. Может принимать значения:
• "street" — улица • "house" — дом • "point" — пункт |
• comment | Строка | Комментарий |
Пример:
Запрос: GET https://ip:port/common_api/1.0/get_addresses_like?get_streets=true&get_points=true& get_houses=false&street=STREE HTTP/1.1 Signature: <...> Ответ: { "code":0, "descr":"OK", "data":{ "addresses":[ { "street":"STREET1", "house":"", "kind":"street", "comment":"" }, { "street":"STREET2", "house":"", "kind":"street", "comment":"" }, { "street":"POINT_STREET1", "house":"", "kind":"point", "comment":"Point at street STREET1" } ] } } Запрос: GET https://ip:port/common_api/1.0/get_addresses_like?get_streets=false&get_points=false& get_houses=true&street=STREET1&house=1&max_addresses_count=10 HTTP/1.1 Signature: <...> Ответ: { "code":0, "descr":"OK", "data":{ "addresses":[ { "street":"STREET1", "house":"1", "kind":"house", "comment":"" }, { "street":"STREET1", "house":"10", "kind":"house", "comment":"" }, { "street":"STREET1", "house":"11", "kind":"house", "comment":"" } ] } }
Анализ маршрута
Метод: GET
Название запроса: analyze_route
Параметры:
Параметры | Тип | Описание |
---|---|---|
Обязательные параметры | ||
source | Строка | Адрес подачи |
dest | Строка | Адрес назначения |
Специальные возвращаемые коды:
Код | Описание |
---|---|
100 | Адрес подачи не распознан |
101 | Адрес назначения не распознан |
102 | Маршрут не распознан |
Возвращаемые данные в случае успешного выполнения запроса:
Параметр | Тип | Описание |
---|---|---|
source_lat | Дробное | Широта адреса подачи |
source_lon | Целое | Долгота адреса подачи |
source_zone_id | Целое | ИД района подачи |
dest_lat | Дробное | Широта адреса назначения |
dest_lon | Дробное | Долгота адреса назначения |
dest_zone_id | Целое | ИД района назначения |
city_dist | Дробное | Километраж по городу |
country_dist | Дробное | Километраж за городом |
source_country_dist | Дробное | Километраж до адреса подачи, если адрес подачи за городом |
Пример:
Запрос: GET https://ip:port/common_api/1.0/analyze_route?source=STREET1,1&dest=STREET2,2 HTTP/1.1 Signature: <...> Ответ: { "code":0, "descr":"OK", "data":{ "source_lat":11.111111, "source_lon":22.222222, "source_zone_id":1, "dest_lat":33.333333, "dest_lon":44.444444, "dest_zone_id":2, "city_dist":1.1, "country_dist":2.2, "source_country_dist":3.3 } }
Запрос информации о состоянии заказа
Метод: GET
Название запроса: get_order_state
Параметры:
Параметры | Тип | Описание |
---|---|---|
Обязательные параметры | ||
order_id | Целое | ИД заказа |
Специальные возвращаемые коды:
Код | Описание |
---|---|
100 | Заказ не найден |
Возвращаемые данные в случае успешного выполнения запроса:
Параметр | Тип | Описание |
---|---|---|
order_id | Целое | ИД заказа |
state_id | Целое | ИД состояния заказа |
state_kind | Строка | Тип состояния заказа. Может принимать значения:
• "new_order" — новый заказ • "driver_assigned" — водитель назначен • "car_at_place" — машина подъехала на место • "client_inside" — клиент в машине • "finished" — заказ успешно завершен • "aborted" — заказ прекращен |
crew_id | Целое | ИД экипажа |
driver_id | Целое | ИД водителя |
car_id | Целое | ИД автомобиля |
Пример:
Запрос: GET https://ip:port/common_api/1.0/get_order_state?order_id=1 HTTP/1.1 Signature: <...> Ответ: { "code":0, "descr":"OK", "data":{ "order_id":1, "state_id":12, "state_kind":"car_at_place", "crew_id":1, "driver_id":2, "car_id":3 } }
Описание протокола TMTAPI Версия 1.0
Общее описание протокола
Формат запроса
TM API принимает входящие запросы по протоколу HTTPS. В URI запроса после ip адреса и порта, который будет слушать TM API, должно идти название API (tm_tapi) и версия API.
Пример:
GET https://ip:port/tm_tapi/1.0/get_info_by_phone HTTP/1.1
Для получения данных из БД используются запросы типа GET. Для записи данных в БД используются запросы типа POST. В запросе типа GET параметры запроса передаются в URI.
Пример:
GET https://ip:port/tm_tapi/1.0/get_info_by_phone?phone=89058800565&fields=PHONE_TYPEPHONE_ TO_DIAL&signature=661ce071eeefcb4f7fc8bc1f17bd520b HTTP/1.1
В запросе типа POST параметры передаются в теле запроса в формате application/x-wwwform- urlencoded.
Пример:
POST https://ip:port/tm_tapi/1.0/change_order_state HTTP/1.1 Content-Type: application/x-www-form-urlencoded Content-Length: 71 order_id=98798&need_state=12&signature=a204c50c7e48f0c6849a87485fe5e171
В любом запросе обязательно, с другими полями, должно передаваться поле signature. В нем передается MD5 хэш, рассчитанный для строки, которая получается сцеплением строки параметров запроса с секретным ключом. Секретный ключ задается в настройках модуля TMAPI в Такси-Мастер.
Пример:
Запрос: GET https://ip:port/tm_tapi/1.0/get_info_by_phone?phone=89058800565&fields=PHONE_TYPE &signature=ef17ea682d09e452af544a5758dba396 HTTP/1.1 Секретный ключ: 321 Signature = MD5("phone=89058800565&fields=PHONE_TYPE" + "321") = ef17ea682d09e452af544a5758dba396 HTTP/1.1
Формат ответа
TM API всегда возвращает HTTP код 200 ОК. Результат выполнения запроса содержится в теле ответа в формате XML. Общий вид возвращаемого результата:
<response> <code>Числовой код результата</code> <descr>Строковое описание результата</descr> <data>Дополнительная информация</data> </response>
Существуют общие для всех запросов коды результатов:
Код | Описание |
---|---|
0 | Успешное выполнение запроса |
1 | Неизвестная ошибка |
2 | Неизвестный тип API |
3 | API отключено в настройках модуля TM API в Такси-Мастер |
4 | Не совпадает секретный ключ |
5 | Неподдерживаемая версия API |
6 | Неизвестное название запроса |
7 | Неверный тип запроса GET |
8 | Не хватает входного параметра (в доп. информации ответа будет название
отсутствующего параметра) |
9 | Некорректный входной параметр (в доп. информации ответа будет название некорректного параметра) |
10 | Внутренняя ошибка обработки запроса |
Описание запросов
Запрос информации по номеру телефона
Метод: GET
Название запроса: get_info_by_phone
Параметры:
Параметр | Тип | Описание |
---|---|---|
Обязательные параметры | ||
phone | Строка, <= 16 символов | Номер телефона |
fields | Строка Список полей, которые необходимо вернуть. Поля перечисляются через - | |
signature | Строка | Поле для проверки секретного ключа. |
Специальные возвращаемые коды: нет Возвращаемые данные в случае успешного выполнения запроса: зависит от того какие поля были переданы в поле fields.
Параметр | Тип | Описание |
---|---|---|
PHONE_TYPE | Целое | Тип телефона звонящего
(1 - если звонит водитель; 2 - если звонит физлицо; 3 - если звонит юрлицо; 4 - если звонит номер из справочника телефоны; 0 - неизвестный номер) |
PHONE_TO_DIAL | Строка, <= 16 символов | Номер телефона для отзвона по заказу |
CREW_ID | Целое | ИД экипажа |
IS_PRIOR | true или false | Признак предварительного заказа |
ORDER_CLIENT_ID | Целое | ИД клиента из заказа |
DRIVER_PHONE | Строка, <= 16 символов | Номер телефона водителя |
CREW_SYSTEMSTATE | Целое | Состояние экипажа |
CLIENT_ID | Целое | ИД клиента. |
CLIENT_TYPE | Целое | Тип клиента |
CATEGORY | Целое | Пользовательское значение категории телефона |
PHONE_SYSTEM_CAT_EGORY | Целое | Системное значение категории телефона (0 - обычный, 1 - черный, 2 - белый, 3 - серый) |
ORDER_ID | Целое | ИД заказа |
DRIVER_ID | Целое | ИД водителя |
ORDER_STATE | Целое | Состояние заказа |
DRIVER_REMAINDER | Дробное | Баланс счета водителя |
DISCOUNTEDSUMM | Строка | Сумма заказа с учетом всех скидок |
CREW_GROUP_ID | Целое | ИД группы экипажа |
CLIENT_BALANCE | Дробное | Баланс клиента |
DRIVER_TIMECOUNT | Целое | Время пути водителя до адреса подачи в минутах |
SOURCE_TIMECOUNT | Целое | Время оставшееся до подачи в минутах |
SOUND_COLOR | Строка | Запись с информацией о цвете |
SOUND_GOSNUMBER | Строка | Запись с информацией о государственном номере автомобиля |
SOUND_MARK | Строка | Запись с информацией о марке автомобиля |
GOSNUMBER | Строка | Государственный номер автомобиля |
CAR_COLOR | Строка | Цвет автомобиля |
CAR_MARK | Строка | Марка автомобиля |
Пример:
Запрос: GET https://ip:port/tm_tapi/1.0/get_info_by_phone?phone=89058800565l&fields=PHONE_TYPEPHONE_ TO_DIAL-CREW_ID-ORDER_ID&signature=d35ab2765f2968d48c096d5f5327db26 HTTP/1.1 Ответ: <response> <code>0</code> <descr>OK</descr> <data> <PHONE_TYPE>0</PHONE_TYPE> <PHONE_TO_DIAL></PHONE_TO_DIAL> <CREW_ID>3</CREW_ID> <ORDER_ID>6</ORDER_ID> </data> </response>
Запрос информации по ИД заказа
Метод: GET Название запроса: get_info_by_order_id Параметры:
Параметр | Тип | Описание |
---|---|---|
Обязательные параметры | ||
order_id | Целое | ИД заказа |
fields | Строка | Список полей, которые необходимо вернуть. Поля перечисляются через - |
signature | Строка | Поле для проверки секретного ключа. |
Специальные возвращаемые коды: нет Возвращаемые данные в случае успешного выполнения запроса: зависит от того какие поля были переданы в поле fields.
Параметр | Тип | Описание |
---|---|---|
DRIVER_SOURCETIME | Строка, <= 16 символов | Время до подачи в минутах, указанное водителем |
SOUND_COLOR | Строка | Запись с информацией о цвете |
MARK | Строка | Марка автомобиля |
COLOR | Строка | Цвет автомобиля |
GOSNUMBER | Строка | Государственный номер автомобиля |
SOUND_MARK | Строка | Запись с информацией о марке автомобиля |
CREWGROUPID | Целое | ИД группы экипажа |
IS_PRIOR | true или false | Признак предварительного заказа |
DISCOUNTEDSUMM | Строка | Сумма заказа с учетом всех скидок |
MOBILE_PHONE | Строка, <= 16 символов | Номер телефона водителя |
CATEGORYID | Целое | ИД категории телефона |
SOURCE_TIME | Целое | Время до подачи в минутах |
Пример:
Запрос: GET https://ip:port/tm_tapi/1.0/get_info_by_order_id?order_id=60&fields=DRIVER_SOURCETIME-MARKCOLOR-GOSNUMBER-IS_PRIOR-MOBILE_PHONE-SOURCE_TIME&signature=fdcd04e570443b56176b83f44748dc23 HTTP/1.1 Ответ: <response> <code>0</code> <descr>OK</descr> <data> <DRIVER_SOURCETIME></DRIVER_SOURCETIME> <MARK></MARK> <COLOR></COLOR> <GOSNUMBER></GOSNUMBER> <IS_PRIOR></IS_PRIOR> <MOBILE_PHONE></MOBILE_PHONE> <SOURCE_TIME></SOURCE_TIME> </data> </response>
Смена состояния заказа
Метод: POST
Название запроса: change_order_state
Параметры:
Параметр | Тип | Описание |
---|---|---|
Обязательные параметры | ||
order_id | Целое | ИД заказа |
need_state | Целое | Новое состояние заказа |
signature | Строка | Поле для проверки секретного ключа. |
Специальные возвращаемые коды:
Код | Описание |
---|---|
100 | Заказ с таким ИД не найден. |
101 | Изменение состояния не соответствует необходимым условиям. |
Возвращаемые данные в случае успешного выполнения запроса
Параметр | Тип | Описание |
---|---|---|
ORDER_ID | Целое | ИД созданного заказа |
NEW_STATE | Целое | Новое состояние заказа |
Пример:
Запрос: POST https://ip:port/tm_tapi/1.0/change_order_state HTTP/1.1 Content-Type: application/x-www-form-urlencoded Content-Length: 71 order_id=18561&need_state=14&signature=3e8107e0c044e55d983db1fbed82fd8c Ответ: <response> <code>0</code> <descr>OK</descr> <data> <ORDER_ID>18561</ORDER_ID> <NEW_STATE>14</NEW_STATE> </data> </response>
Запись пути к файлу разговора в базу данных
Метод: POST
Название запроса: create_record_link
Параметры:
Параметр | Тип | Описание |
---|---|---|
Обязательные параметры | ||
RECORD_DATE | ГГГГММДДччммсс | Дата записи |
RECORD_LENGTH | Целое | Продолжительность записи (в секундах) |
PHONE | Строка, <= 16 символов | Номер телефона |
ORDERID | Целое | Заказ, с которого сделана запись |
USERID | Целое | Пользователь, сделавший запись |
FILE_PATH | Строка,<=255 символов | Путь к файлу записи |
RECORD_GUID | Строка,<= 80 символов | GUID звонка |
signature | Строка | Поле для проверки секретного ключа. |
Специальные возвращаемые коды: нет Возвращаемые данные в случае успешного выполнения запроса
Параметр | Тип | Описание |
---|---|---|
RECORD_ID | Целое | ИД созданной записи |
Пример:
Запрос: POST https://ip:port/tm_tapi/1.0/create_record_link HTTP/1.1 Content-Type: application/x-www-form-urlencoded Content-Length: 206 RECORD_DATE=20121108145953&RECORD_LENGTH=6546&PHONE=654321&ORDERID=654&USERID=564&FILE_PATH=d%3A %5CProjects%5Ctrunk%5C%5Ftrunk%5CTM%5CBin %5C&RECORD_GUID=GUID456258&signature=cd11d50d65fa7e8ad73f80cdc7d296c7 Ответ: <response> <code>0</code> <descr>OK</descr> <data> <RECORD_ID>25</RECORD_ID> </data> </response>
Создать новый заказ
Метод: POST
Название запроса: make_new_order
Параметры:
Параметр | Тип | Описание |
---|---|---|
Обязательные параметры | ||
PHONE | Строка, <= 16 символов | Номер телефона |
ORDER_STATE_ID | Целое | ИД состояния заказа |
signature | Строка | Поле для проверки секретного ключа. |
Необязательные параметры | ||
CREW_GROUP_ID | Целое | ИД группы экипажа |
TARIFF_ID | Целое | ИД тарифа |
PHONE_PREFIX | Строка | Префикс, отрезаемый от номера телефона при поиске в базе данных. Для входящих звонков это код города с префиксом входящих номеров, обычно "8". Например, "83412" |
DISCOUNTED_SU MM | Строка | Фиксированная сумма за заказ |
Специальные возвращаемые коды:
Код | Описание |
---|---|
100 | Клиент не найден |
Возвращаемые данные в случае успешного выполнения запроса
Параметр | Тип | Описание |
---|---|---|
ORDER_ID | Целое | ИД созданного заказа |
Пример:
Запрос: POST https://ip:port/tm_tapi/1.0/make_new_order HTTP/1.1 Content-Type: application/x-www-form-urlencoded Content-Length: 206 PHONE=89058770593&ORDER_STATE_ID=10&DISCOUNTED_SUMM=100&signature=afc947f610eba380df6d0e441b03ddad Ответ: <response> <code>0</code> <descr>OK</descr> <data> <order_id>27</order_id> </data> </response>