TM API | ТМ: Корпоративные поездки

TM API

В статье:
1. Запрос-пинг
2. Запрос списка групп экипажей
3. Запрос списка групп клиентов
4. Запрос списка тарифов
5. Запрос списка услуг
6. Запрос списка атрибутов
7. Запрос списка скидок
8. Создание нового заказа
9. Создание нового заказа 2
10. Расчет суммы заказа
11. Расчет суммы заказа 2
12. Изменение состояния заказа
13. Запрос информации об экипаже
14. Запрос информации об экипажах
15. Создание экипажа
16. Обновление информации об экипаже
17. Запрос информации о водителе
18. Запрос списка водителей
19. Создание водителя
20. Обновление информации о водителе
21. Запрос информации об автомобиле
22. Запрос списка автомобилей
23. Создание автомобиля
24. Обновить информацию об автомобиле
25. Запрос координат экипажей
26. Запрос адресов, содержащих нужную строку
27. Запрос адресов, содержащих нужную строку 2
28. Анализ маршрута
29. Анализ маршрута 2
30. Запрос информации о состоянии заказа
31. Создание задачи СМС серверу
32. Проверка авторизации
33. Регистрация клиента
34. Запрос информации по клиенту
35. Изменение информации по клиенту
36. Запрос текущих заказов
37. Запрос выполненных заказов
38. Проведение операции по клиенту
39. Запрос операций по клиенту
40. Проведение операции по водителю
41. Запрос операций по водителю
42. Назначение динамического приоритета водителю
43. Задание координат экипажей
44. Изменение информации по заказу
45. Анализ телефона
46. Показать сообщение в ТМ
47. Запрос списка купленных смен водителей
48. Запрос списка запланированных смен водителей
49. Продажа смены водителю
50. Сохранение отзыва клиента
51. Поиск экипажей по координатам
52. Подбор тарифа для заказа
53. Импорт марок автомобилей в БД
54. Импорт цветов автомобилей в БД
55. Запрос информации по сотруднику клиента
56. Создание сотрудника клиента
57. Обновление информации о сотруднике клиента
58. Запрос списка состояний заказа
59. Запрос списка состояний экипажа
60. Запрос информации по клиентам
61. Запрос информации о заявке спец. техники
62. Удаление заявки спец. техники
63. Запрос глобальных атрибутов
ОПИСАНИЕ ПРОТОКОЛА TMTAPI ВЕРСИЯ 1.0
1. Запрос информации по номеру телефона
2. Запрос информации по ИД заказа
3. Смена состояния заказа
4. Запись пути к файлу разговора в базу данных
5. Создать новый заказ
6. Поиск улицы в базе
7. Смена состояния заказа по результату автодозвона
8. Соединить клиента и водителя
9. Количество свободных экипажей на линии
10. Запрос пользователя по логину софтфона
11. Установить режим «Перерыв» для линий софтфона
12. Запрос телефонов водителя по позывному экипажа
13. Запрос информации о ключе защиты




TM API - специальный набор инструментов ТМ: Корпоративные поездки, который позволит объединить систему с различными полезными сервисами.

Параметры TM API

Задать настройки для корректной работы TM API вы сможете в ТМ в меню Настройки в одноименной ветке TM API.

  1. Установите флажок Использовать TM API.
  2. В поле Локальный порт введите номер порта подключения к интернету, на котором работает и будет ожидать запросы о новых заказах ТМ Сервер. Рекомендуется оставить номер порта по умолчанию.
  3. При необходимости установите флажок Использовать автопроброс порта с помощью UPnP, также укажите Внешний порт и Локальный IP.

Ветка "Открытое API"

В данной ветке регулируется доступ к синхронизации ТМ со сторонним сервисом.

  1. Установите флажок Использовать открытое API для того, чтобы запустить работу протокола TMCommonAPI.
  2. В поле Секретный ключ укажите произвольный номер. В дальнейшем этот номер следует использовать в API-запросах на сайте.
  3. В таблице "Пользователи CommonAPI" можно настроить доступ к CommonAPI. Для этого нужно создать пользователей, у которых будет отдельный секретный ключ, и отметить доступные запросы CommonAPI.

Ветка "API для телефонии"

В данной ветке регулируются настройки API для телефонии, т.е. взаимодействие ТМ с call-центром через программный интерфейс.

  1. Установите флажок Использовать открытое API для телефонии для того, чтобы запустить работу протокола TMTAPI.
  2. В поле Секретный ключ укажите номер секретного ключа для работы.

Ветка "TMK Пассажир API"

В данной ветке находятся параметры, необходимые для взаимосвязи клиентского приложения с программным комплексом ТМ: Корпоративные поездки.

Общее описание протокола

Формат запроса

TMAPI принимает входящие запросы по протоколу HTTPS. В URI запроса после ip адреса и порта, который будет слушать TM API, должно идти название 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 
Signature: <...>

В запросе типа POST параметры передаются в теле запроса в формате application/x-www-form-urlencoded или application/json в зависимости от запроса. Пример:

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 хэш, рассчитанный для строки, которая получается сцеплением строки параметров запроса с секретным ключом. Секретный ключ задается в Файл - Настройки - TM API - Открытое API. Пример:

Запрос:
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

Также в запросе может содержаться заголовок "X-User-Id" c ИД пользователя CommonAPI, если запрос делается от какого-то конкретного пользователя CommonAPI. Если будет передан этот заголовок, то секретный ключ будет проверяться именно для указанного пользователя CommonAPI, а также будут проверяться права доступа пользователя CommonAPI к данному запросу. Если заголовок "X-User-Id" не будет передан, то тогда будет проверяться общий секретный ключ CommonAPI, и будет разрешен доступ ко всем запросам CommonAPI. Пример запроса с указанием ИД пользователя:

POST https://ip:port/common_api/1.0/create_order HTTP/1.1
Signature: <...>
X-User-Id: 123
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

Формат ответа

TM API всегда возвращает HTTP код 200 ОК. Результат выполнения запроса содержится в теле ответа в формате JSON. Общий вид возвращаемого результата:

{
  "code":<Числовой код результата>,
  "descr":"<Строковое описание результата>",
  "data":{<Дополнительная информация>}
}

Существуют общие для всех запросов коды результатов:

КодОписание
0Успешное выполнение запроса
1Неизвестная ошибка
2Неизвестный тип API
3API отключено в настройках модуля TM API в ТМ2
4Не совпадает секретный ключ
5Неподдерживаемая версия API
6Неизвестное название запроса
7Неверный тип запроса GET/POST
8Не хватает входного параметра (в доп. информации ответа будет название отсутствующего параметра)
9Некорректный входной параметр (в доп. информации ответа будет название некорректного параметра)
10 Внутренняя ошибка обработки запроса
13 Не найден пользователь CommonAPI с ИД, указанным в заголовке X-User-Id
14 Запрос недоступен для пользователя CommonAPI с ИД, указанным в заголовке X-User-Id

Описание запросов

1. Запрос-пинг

Для данного запроса не проверяется версия API, секретный ключ и тип запроса GET/POST.

Метод: GET или POST

Название запроса: ping

Параметры: нет

Специальные возвращаемые коды: нет

Возвращаемые данные в случае успешного выполнения запроса: нет

Пример:

Запрос:
GET https://ip:port/common_api/1.0/ping HTTP/1.1 
Ответ:
{
  "code":0,
  "descr":"OK",
  "data":{}
}

2. Запрос списка групп экипажей

Метод: 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"
     }
    ]
  }
}

3. Запрос списка групп клиентов

Метод: GET

Название запроса: get_client_groups_list

Параметры: нет

Специальные возвращаемые коды: нет

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
client_groupsМассивСписок групп клиентов
• idЦелоеИД группы клиентов
• nameСтрокаНазвание группы клиентов

Пример:

Запрос:
GET https://ip:port/common_api/1.0/get_client_groups_list HTTP/1.1
Signature: <...>

Ответ:
{
  "code":0,
  "descr":"OK",
  "data":{
    "client_groups":[
      {
        "id":1,
        "name":"CLIENT_GROUP1"
      },
      {
        "id":2,
        "name":"CLIENT_GROUP2"
      }
    ]
  }
}

4. Запрос списка тарифов

Метод: GET

Название запроса: get_tariffs_list

Параметры: нет

Специальные возвращаемые коды: нет

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
tariffsМассивСписок тарифов
• idЦелоеИД тарифа
• nameСтрокаНазвание тарифа
• is_activetrue или falseАктивный тариф

Пример:

Запрос:

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"
        "is_active":true 
      },
      {
         "id":2,
         "name":"TARIFF2"
         "is_active":true
      }
    ]
  }
}

5. Запрос списка услуг

Запрос устарел. Рекомендуется использовать запрос списка параметров заказа

Метод: 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 } ] } }

6. Запрос списка атрибутов

Метод: GET

Название запроса: get_order_params_list

Параметры: нет

Специальные возвращаемые коды: нет

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
order_paramsМассивСписок параметров заказа
• idЦелоеИД параметра
• nameСтрокаНазвание параметра
• sumДробноеАбсолютная сумма параметра, руб. (Возвращает сумму только для логических атрибутов)
• percentДробноеПроцент параметра от стоимости заказа, %
• order_access_controltrue или falseРегулирует доступ к заказу

Пример:

Запрос:

GET https://ip:port/common_api/1.0/get_order_params_list HTTP/1.1
Signature: <...> Ответ: { "code":0, "descr":"OK", "data":{ "order_params":[ { "id":1, "name":"PARAM1", "sum":100, "percent":0, "order_access_control":true }, { "id":2, "name":"PARAM2", "sum":0, "percent":10, "order_access_control":false } ] } }

7. Запрос списка скидок

Метод: GET

Название запроса: get_discounts_list

Параметры: нет

Специальные возвращаемые коды: нет

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
discountsМассивСписок скидок
• 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 } ] } }

8. Создание нового заказа

Метод: POST

Название запроса: create_order

Параметры:

ПараметрТипОписание
Обязательные параметры
phoneСтрока, <= 30 символовНомер телефона
sourceСтрокаАдрес подачи
source_timeГГГГММДДччммссВремя подачи
Необязательные параметры
destСтрокаАдрес назначения
customerСтрокаЗаказчик
commentСтрокаКомментарий
crew_group_idЦелоеИД группы экипажей
tariff_idЦелоеИД тарифа
is_priortrue или falseПредварительный заказ
source_lonДробноеДолгота адреса подачи
source_latДробноеШирота адреса подачи
dest_lonДробноеДолгота адреса назначения
dest_latДробноеШирота адреса назначения

Специальные возвращаемые коды:

КодОписание
100Заказ с такими параметрами уже создан
101Тариф не найден
102Группа экипажа не найдена
110Клиент заблокирован
111Не найден клиент, который может использовать собственный счет для оплаты заказов
114Недостаточно средств на безналичном счете клиента в ТМ
115Отрицательный баланс на безналичном счете клиента в ТМ
116Для клиента запрещена оплата заказа наличными. Клиент должен максимально использовать в заказе безналичную оплату (оплату с основного счета)

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
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: <...>

phone=89123456789&source=SOURCE&source_time=20120501100000&dest=DEST&customer=CUSTOMER& comment=COMMENT&crew_group_id=1&uds_id=1&tariff_id=3&is_prior=false&source_lon=53.147836& source_lat=56.896817&dest_lon=53.226775&dest_lat=56.845452 Ответ: { "code":0, "descr":"OK", "data":{ "order_id":12345 } }

9. Создание нового заказа 2

Метод: POST

Название запроса: create_order2

Параметры в формате JSON:

ПараметрТипОписание
Обязательные параметры
phoneСтрока, <= 30 символовНомер телефона (необязателен, если client_id присутствует).
client_idЦелоеИД клиента (необязателен, если phone присутствует).
addressesМассивМассив адресов. Первый элемент — адрес подачи(обязательно), последний — адрес назначения, между ними — остановки.
• addressСтрокаАдрес подачи
• latДробноеШирота адреса
• lonДробноеДолгота адреса
• zone_idЦелоеИД района
• parking_idЦелоеИД стоянки
source_timeГГГГММДДччммссВремя подачи
Необязательные параметры
server_time_offsetЦелоеСмещения относительно серверного времени
passengerСтрокаПассажир
phone_to_dialСтрока, <= 30 символовТелефон для отзвона
customerСтрокаЗаказчик
commentСтрокаКомментарий
crew_group_idЦелоеИД группы экипажей
tariff_idЦелоеИД тарифа
is_priortrue или falseПредварительный заказ
check_duplicatetrue или falseПроверка на дубликат
servicesМассивМассив услуг. Устарело. Рекомендуется использовать параметр attribute_values.
ЦелоеИД услуги
crew_propsМассивМассив признаков экипажей. Устарело. Рекомендуется использовать параметр attribute_values.
ЦелоеИД признака экипажа
order_paramsМассивМассив параметров заказа. Устарело. Рекомендуется использовать параметр attribute_values.
ЦелоеИД параметра заказа
total_costДробноеСумма заказа
use_cashlesstrue или falseОплата по возможности всей суммы заказа с безналичного счета клиента (насколько хватает средств на счете).
use_bonustrue или falseОплата по возможности всей суммы заказа с бонусного счета клиента (насколько хватает средств на бонусном счете).
cashless_sumДробноеФиксированная сумма оплаты заказа с безналичного счета клиента (не используется, если use_cashless = true).
bonus_sumДробноеФиксированная сумма оплаты заказа с бонусного счета клиента (не используется, если use_bonus = true).
client_employee_idЦелоеИД сотрудника клиента (если задан client_id)
emailСтрокаEmail для отправки уведомлений
prior_to_current_before_minutesЦелоеВремя перехода из предварительного в текущие заказы, мин
flight_numberСтрокаНомер рейса
need_custom_validate true или false Использовать специальную проверку перед созданием заказа
attribute_values Массив Массив значений атрибутов
• id Целое Идентификатор атрибута
• bool_value true или false Значение, если тип атрибута «Логический»
• num_value Дробное Значение, если тип атрибута:
- «Число» (непосредственное значение)
- «Число (выбор из списка)» (непосредственное значение выбранного элемента списка)
- «Перечисляемый» (значение выбранного элемента перечисления)
- «Дата» и «Дата/время» (Unix-время, всегда целое число)
• str_value Строка Значение, если тип атрибута «Строка»
payment_pay_system Строка Тип платежной системы ("qr", либо пусто, если не используется)

Специальные возвращаемые коды:

КодОписание
100Заказ с такими параметрами уже создан
101Тариф не найден
102Группа экипажа не найдена
104Клиент не найден
105Район не найден
106Стоянка не найдена
107Сотрудник клиента не найден
108Атрибут не найден
109Атрибут не может быть привязан к заказу
110Клиент заблокирован
111Не найден клиент, который может использовать собственный счет для оплаты заказов
112 Сотрудник клиента заблокирован
113 Ошибка специальной проверки заказа перед созданием.
В ответе будет возвращаться:

 "data": {
    "message":"Текст ошибки для пользователя.",
    "can_create_order":true|false // можно ли создать заказ несмотря на ошибки проверки
  }
114 Недостаточно средств на безналичном счете клиента в ТМ
115 Отрицательный баланс на безналичном счете клиента в ТМ
116 Для клиента запрещена оплата заказа наличными. Клиент должен максимально использовать в заказе безналичную оплату (оплату с основного счета)

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
order_idЦелоеИД созданного заказа

Пример:

Запрос:
POST https://ip:port/common_api/1.0/create_order2 HTTP/1.1
Signature: <...>
Content-Type: application/json
Content-Length: <...>

{
  "server_time_offset":2,
  "source_time":"20140415172811",
  "is_prior":false,
  "check_duplicate":true,
  "phone":"123456",
  "phone_to_dial":"654321",
  "client_id":1,  
  "client_employee_id":4,  
  "customer":"CUSTOMER",
  "passenger":"PASSENGER",
  "comment":"COMMENT",
  "crew_group_id":1,
  "uds_id":1,
  "tariff_id":1,
  "addresses": [
      {
          "address": "SOURCE",
          "lat": 56.896817,
          "lon": 53.14783
          "zone_id": 1,
          "parking_id": 1
      },
      {
          "address": "STOP1",
          "lat": 56.845452,
          "lon": 53.226775
          "zone_id": 2,
          "parking_id": 2
      },
      {
          "address": "STOP2"
      },
      {
          "address": "DESTINATION",
          "lat": 56.86123,
          "lon": 53.24187
      }
  ]
  "services":[1,2],
  "crew_props":[1],
  "order_params":[3,4],
  "total_cost":370,
  "client_id":28,
  "use_cashless":false,
  "use_bonus":false,
  "cashless_sum":700,
  "bonus_sum":350,
  "email":"email@gmail.com",
  "prior_to_current_before_minutes":30,
  "flight_number":"130-qwe2",
  "need_custom_validate":false,
  "attribute_values": [
      {
            "id": 1,
            "bool_value": true
      },
      {
            "id": 2,
            "num_value": 1
      },
      {
            "id": 3,
            "num_value": 10
      },
      {
            "id": 4,
            "str_value": "строка"
      }
  ],
  "payment_pay_system": "qr"
} Ответ: { "code":0, "descr":"OK", "data":{ "order_id":1672 } }

10. Расчет суммы заказа

Метод: GET

Название запроса: calc_order_cost

Параметры:
ПараметрТипОписание
Обязательные параметры
tariff_idЦелоеИД тарифа
Необязательные параметры
source_timeГГГГММДДччммссВремя подачи
is_priortrue или falseПредварительный заказ
client_idЦелоеИД клиента
client_employee_idЦелоеИД сотрудника клиента
discount_idЦелоеИД скидки
disc_card_idЦелоеИД дисконтной карты
source_zone_idЦелоеИД района подачи
dest_zone_idЦелоеИД района назначения
distance_cityДробноеКилометраж по городу
distance_countryДробноеКилометраж за городом
source_distance_countryДробноеКилометраж до подачи за городом
is_countrytrue или falseЗагородный заказ
waiting_minutesЦелоеВремя ожидания посадки клиента в минутах
is_hourlytrue или falseПочасовой заказ
hourly_minutesЦелоеДлительность почасового заказа в минутах
is_prizetrue или falseПризовой заказ
back_waytrue или falseОбратный путь за городом
servicesСтрокаСписок ИД услуг через точку с запятой, пример: «1;2;3»

Устарело. Рекомендуется использовать параметр order_params.

order_paramsСтрокаСписок ИД параметров заказа через точку с запятой, пример: «1;2;3»
cashlesstrue или falseПризнак безналичного заказа

Специальные возвращаемые коды:

КодОписание
100Тариф не найден
101Ошибка при расчете по тарифу
102Скидка не найдена
103Клиент не найден
104Район подачи не найден
105Район назначения не найден
106Дисконтная карта не найдена
107Район остановки не найден
108Группа экипажа не найдена
110Дисконтная карта не действительна
111Не найден сотрудник клиента

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
sumДробноеРассчитанная общая сумма заказа
infoМассивДополнительная информация по расчету суммы заказа
• commentСтрокаОписание позиции дополнительной информации по расчету суммы заказа
• sumСтрокаСумма позиции дополнительной информации по расчету суммы заказа

Пример:

Запрос: 

GET https://ip:port/common_api/1.0/calc_order_cost?tariff_id=1&source_time=20120501100000&
is_prior=false&client_id=1&client_employee_id=11&discount_id=1&disc_card_id=1&source_zone_id=1&
dest_zone_id=2&distance_city=10&distance_country=20&source_distance_country=5&is_country=true&
waiting_minutes=10&is_hourly=false&hourly_minutes=60&is_prize=true&back_way=false&services=1;2;3&
order_params=1;2;3 HTTP/1.1
Signature: <...> Ответ: { "code":0, "descr":"OK", "data":{ "sum":1000, "info":[ { "comment":"SUM1", "sum":"100" }, { "comment":"SUM2", "sum":"200" } ] } }

11. Расчет суммы заказа 2

Метод: POST

Название запроса: calc_order_cost2

Параметры в формате JSON:

ПараметрТипОписание
Необязательные параметры
order_id
ЦелоеИД заказа
tariff_idЦелоеИД тарифа
source_timeГГГГММДДччммссВремя подачи
is_priortrue или falseПредварительный заказ
client_idЦелоеИД клиента
phoneСтрокаТелефон клиента
discount_idЦелоеИД скидки
disc_card_idЦелоеИД дисконтной карты
source_zone_idЦелоеИД района подачи
source_lonДробноеДолгота адреса подачи
source_latДробноеШирота адреса подачи
dest_zone_idЦелоеИД района назначения
dest_lonДробноеДолгота адреса назначения
dest_latДробноеШирота адреса назначения
distance_cityДробноеКилометраж по городу
distance_countryДробноеКилометраж за городом
source_distance_countryДробноеКилометраж до подачи за городом
is_countrytrue или falseЗагородный заказ
waiting_minutesЦелоеВремя ожидания посадки клиента в минутах
is_hourlytrue или falseПочасовой заказ
hourly_minutesЦелоеДлительность почасового заказа в минутах
is_prizetrue или falseПризовой заказ
back_waytrue или falseОбратный путь за городом
order_paramsМассивМассив параметров заказа. Устарело. Рекомендуется использовать параметр attribute_values.
ЦелоеИД параметра заказа
cashlesstrue или falseПризнак безналичного заказа
stopsМассивСписок остановок
• zone_idЦелоеИД района остановки
• latДробноеШирота адреса остановки
• lonДробноеДолгота адреса остановки
crew_group_idЦелоеИД группы экипажа
analyze_routetrue или falseНужно ли выполнять анализ адресов и маршрута. Если данный флаг установлен (analyze_route=true), то значения параметров: distance_city, distance_country, source_distance_country, переданные в данном запросе будут игнорироваться. Они автоматически будут рассчитаны в ходе выполнения запроса в результате анализа адресов и маршрута. Также перед анализом адресов будут автоматически найдены районы (по справочнику "Районы") для тех адресов, у которых район не указан явно (zone_id=0). Также по результатам анализа адресов автоматически будут определены флаги "Загородный заказ" (is_country) и "Межгород".
attribute_values Массив Массив значений атрибутов
• id Целое Идентификатор атрибута
• bool_value true или false Значение, если тип атрибута «Логический»
• num_value Дробное Значение, если тип атрибута:
- «Число» (непосредственное значение)
- «Число (выбор из списка)» (непосредственное значение выбранного элемента списка)
- «Перечисляемый» (значение выбранного элемента перечисления)
- «Дата» и «Дата/время» (Unix-время, всегда целое число)
• str_value Строка Значение, если тип атрибута «Строка»

Специальные возвращаемые коды:

КодОписание
100Тариф не найден
101Ошибка при расчете по тарифу
102Скидка не найдена
103Клиент не найден
104Район подачи не найден
105Район назначения не найден
106Дисконтная карта не найдена
107Район остановки не найден
108Группа экипажа не найдена
110Дисконтная карта не действительна
111Сотрудник клиента не найден
112 Атрибут не найден
113 Атрибут не может быть привязан к заказу
114 Заказ не найден

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
sumДробноеРассчитанная общая сумма заказа
infoМассивДополнительная информация по расчету суммы заказа
• commentСтрокаОписание позиции дополнительной информации по расчету суммы заказа
• sumСтрокаСумма позиции дополнительной информации по расчету суммы заказа

Пример:

Запрос: 

POST https://ip:port/common_api/1.0/calc_order_cost2 
Signature: <...>
Content-Type: application/json
Content-Length: <...>
{
  "tariff_id":1,
  "source_time":"20140415172811",
  "is_prior":false,
  "client_id":1,  
  "discount_id":1,
  "disc_card_id":1,
  "source_zone_id":1,,
  "source_lat":11.111111,
  "source_lon":22.222222,
  "dest_zone_id":2,,
  "dest_lat":33.333333,
  "dest_lon":44.444444,
  "distance_city":10,
  "distance_country":20,
  "source_distance_country":5,
  "is_country":true,
  "waiting_minutes":10,
  "is_hourly":false,
  "hourly_minutes":60,
  "is_prize":true,
  "back_way":false,
  "order_params":[3,4],
  "stops": [
      {
          "zone_id": 1,
          "lat": 11.111111,
          "lon": 22.222222
      },
      { 
          "zone_id": 2,
          "lat": 33.333333,
          "lon": 44.444444
      }
  ],
  "attribute_values": [
      {
            "id": 1,
            "bool_value": true
      },
      {
            "id": 2,
            "num_value": 1
      },
      {
            "id": 3,
            "num_value": 10
      },
      {
            "id": 4,
            "str_value": "строка"
      }
  ]
} Ответ: { "code":0, "descr":"OK", "data":{ "sum":1000, "info":[ { "comment":"SUM1", "sum":"100" }, { "comment":"SUM2", "sum":"200" } ] } }

12. Изменение состояния заказа

Метод: POST

Название запроса: change_order_state

Параметры:

ПараметрТипОписание
Обязательные параметры
order_id
ЦелоеИД заказа
new_state
ЦелоеНовое состояние заказа
Необязательные параметры
cancel_order_penalty_sum
ДробноеСумма штрафа клиента за отмену заказа. Если свойство new_state имеет тип "Прекращен" (выполняется отмена заказа) и при отмене заказа должен быть назначен штраф клиенту, то если данное значение штрафа указано (даже если указано значение 0), то оно имеет приоритет. Если данное значение не указано, то сумма штрафа будет определена автоматически по группе клиентов.

Специальные возвращаемые коды:

КодОписание
100Не найден заказ ИД=ORDER_ID
101Не найдено состояние заказа ИД=NEW_STATE
102Изменение состояния не соответствует необходимым условиям.

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
order_id
ЦелоеИД заказа
new_state
ЦелоеНовое состояние заказа

Пример:

Запрос: 

POST https://ip:port/common_api/1.0/change_order_state?order_id=6&new_state=4 HTTP/1.1
Signature: <...>

Ответ:

{
  "code":0,
  "descr":"OK",
  "data":{
    "order_id":6,
    "new_state":4
  }
} 

13. Запрос информации об экипаже

Метод: GET

Название запроса: get_crew_info

Параметры:

ПараметрТипОписание
Обязательные параметры
crew_idЦелоеИД экипажа
Необязательные параметры
fieldsСтрокаСписок возвращаемых полей через запятую

Специальные возвращаемые коды:

КодОписание
100Экипаж не найден

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
crew_idЦелоеИД экипажа
codeСтрокаПозывной экипажа
nameСтрокаНаименование экипажа
driver_idЦелоеИД водителя
car_idЦелоеИД автомобиля
crew_group_idЦелоеИД группы экипажа
crew_state_idЦелоеИД состояния экипажа
onlinetrue или falseВодитель подключен к серверу «Связи с водителями»
work_shift_sumДробноеСумма, списываемая за смену
min_balanceДробноеМинимальный баланс, при котором можно выйти на смену
common_priorityЦелоеОбщий приоритет
static_priorityЦелоеСтатический приоритет
dynamic_priorityЦелоеДинамический приоритет
rating_priorityЦелоеПриоритет по рейтингу
order_change_idЦелоеИндивидуальная сдача с заказа
has_light_housetrue или falseШашка
has_labeltrue или falseНаклейка
use_plan_shiftstrue или falseЗапрет работы вне запланированных смен
fuel_levelДробноеУровень топлива в автомобиле
order_paramsМассивМассив параметров экипажа. Устарело. Рекомендуется использовать параметр attribute_values.
ЦелоеИД параметра 
attribute_values Массив Массив значений атрибутов
• id Целое Идентификатор атрибута
• bool_value true или false Значение, если тип атрибута «Логический»
• num_value Дробное Значение, если тип атрибута:
- «Число» (непосредственное значение)
- «Число (выбор из списка)» (непосредственное значение выбранного элемента списка)
- «Перечисляемый» (значение выбранного элемента перечисления)
- «Дата» и «Дата/время» (Unix-время, всегда целое число)
•  str_value Строка Значение, если тип атрибута «Строка»

Пример:

Запрос: 

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,
    "crew_state_id":3,
    "online":true
    "work_shift_sum":0,
    "min_balance":10,
    "common_priority":0,
    "static_priority":0,
    "dynamic_priority":0,
    "rating_priority":0,
    "order_change_id":218,
    "has_light_house":false,
    "has_label":false,
    "fuel_level":8.15,
    "order_params":[
      1,
      2,
    ],
    "attribute_values": [
        {
              "id": 1,
              "bool_value": true
        },
        {
              "id": 2,
              "num_value": 1
        },
        {
              "id": 3,
              "num_value": 10
        },
        {
              "id": 4,
              "str_value": "строка"
        }
    ]
  }
}

14. Запрос информации об экипажах

Метод: GET

Название запроса: get_crews_info

Параметры:

ПараметрТипОписание
Необязательные параметры
not_working_crewstrue или falseНужно ли возвращать экипажи не на линии. По умолчанию возвращаются только экипажи на линии
fieldsСтрокаСписок возвращаемых полей через запятую

Специальные возвращаемые коды: нет

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
crews_infoМассивМассив экипажей
• crew_idЦелоеИД экипажа
• codeСтрокаПозывной экипажа
• nameСтрокаНаименование экипажа
• driver_idЦелоеИД водителя
• car_idЦелоеИД автомобиля
• crew_group_idЦелоеИД группы экипажа
• crew_state_idЦелоеИД состояния экипажа
• onlinetrue или falseВодитель подключен к серверу «Связи с водителями»
• work_shift_sumДробноеСумма, списываемая за смену
• min_balanceДробноеМинимальный баланс, при котором можно выйти на смену
• common_priorityЦелоеОбщий приоритет
• static_priorityЦелоеСтатический приоритет
• dynamic_priorityЦелоеДинамический приоритет
• rating_priorityЦелоеПриоритет по рейтингу
• order_change_idЦелоеИндивидуальная сдача с заказа
• has_light_housetrue или falseШашка
• has_labeltrue или falseНаклейка
• use_plan_shiftstrue или falseЗапрет работы вне запланированных смен
• fuel_levelДробноеУровень топлива в автомобиле
• order_paramsМассивМассив параметров экипажа. Устарело. Рекомендуется использовать параметр attribute_values.
• •ЦелоеИД параметра 
• attribute_values Массив Массив значений атрибутов
• • id Целое Идентификатор атрибута
• • bool_value true или false Значение, если тип атрибута «Логический»
• • num_value Дробное Значение, если тип атрибута:
- «Число» (непосредственное значение)
- «Число (выбор из списка)» (непосредственное значение выбранного элемента списка)
- «Перечисляемый» (значение выбранного элемента перечисления)
- «Дата» и «Дата/время» (Unix-время, всегда целое число)
• •  str_value Строка Значение, если тип атрибута «Строка»

Пример:

Запрос:
GET https://ip:port/common_api/1.0/get_crews_info HTTP/1.1
Signature: <...>

Ответ:
{
  "code":0,
  "descr":"OK",
  "data":{
    "crews_info":[
      {
        "crew_id":1,
        "code":"123",
        "name":"CREW_NAME1",
        "driver_id":1,
        "car_id":1,
        "crew_group_id":1,
        "crew_state_id":3
        "online":true,
        "work_shift_sum":0,
        "min_balance":10,
        "common_priority":10,
        "static_priority":10,
        "dynamic_priority":0,
        "rating_priority":0,
        "order_change_id":0,
        "has_light_house":false,
        "has_label":false,
        "use_plan_shifts":false,
        "fuel_level":8.15,
        "order_params":[
          1,
          5,
        ]
      },
      {
        "crew_id":12,
        "code":"777",
        "name":"CREW_NAME2",
        "driver_id":12,
        "car_id":12,
        "crew_group_id":2,
        "crew_state_id":1,
        "online":false,
        "work_shift_sum":0,
        "min_balance":10,
        "common_priority":15,
        "static_priority":15,
        "dynamic_priority":0,
        "rating_priority":0,
        "order_change_id":0,
        "has_light_house":false,
        "has_label":true,
        "use_plan_shifts":true,
        "fuel_level":null,
        "order_params":[]
      }
    ]
  }
}

15. Создание экипажа

Метод: POST

Название запроса: create_crew

Параметры в формате JSON:

ПараметрТипОписание
Обязательные параметры
car_idЦелоеИД автомобиля
driver_idЦелоеИД водителя
crew_group_idЦелоеИД группы экипажа
Необязательные параметры
codeСтрокаПозывной экипажа
work_shift_sumДробноеСумма, списываемая за смену
min_balanceДробноеМинимальный баланс, при котором можно выйти на смену
work_timeСтрокаВремя работы, формат: “6.00-10.30, 23:00-00:48”
has_light_housetrue или falseШашка
has_labeltrue или falseНаклейка
use_plan_shiftstrue или falseЗапрет работы вне запланированных смен
order_paramsМассивМассив параметров экипажа. Устарело. Рекомендуется использовать параметр attribute_values.
ЦелоеИД параметра
attribute_values Массив Массив значений атрибутов
• id Целое Идентификатор атрибута
• bool_value true или false Значение, если тип атрибута «Логический»
• num_value Дробное Значение, если тип атрибута:
- «Число» (непосредственное значение)
- «Число (выбор из списка)» (непосредственное значение выбранного элемента списка)
- «Перечисляемый» (значение выбранного элемента перечисления)
- «Дата» и «Дата/время» (Unix-время, всегда целое число)
• str_value Строка Значение, если тип атрибута «Строка»

Специальные возвращаемые коды:

КодОписание
100Автомобиль с ИД=ID не найден
101Водитель с ИД=ID не найден
102Группа экипажа с ИД=ID не найдена
103Параметр с ИД=ID не найден или не может быть привязан к экипажу
104Экипаж с таким водителем и автомобилем уже существует

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
crew_idЦелоеИД созданного экипажа

Пример:

Запрос:
POST https://ip:port/common_api/1.0/create_crew  HTTP/1.1
Signature: <...>
Content-Type: application/json
Content-Length: <...>

{
  "car_id":1,
  "driver_id":2,
  "crew_group_id":3,
  "code":"CODE",
  "use_shifts":true,
  "order_params":[3,4],
  "attribute_values": [
      {
            "id": 1,
            "bool_value": true
      },
      {
            "id": 2,
            "num_value": 1
      },
      {
            "id": 3,
            "num_value": 10
      },
      {
            "id": 4,
            "str_value": "строка"
      }
  ]
} Ответ: { "code":0, "descr":"OK", "data":{ "crew_id":1 } }

16. Обновление информации об экипаже

Метод: POST

Название запроса: update_crew_info

Параметры в формате JSON:

ПараметрТипОписание
Обязательные параметры
crew_idЦелоеИД экипажа
Необязательные параметры
car_idЦелоеИД автомобиля
driver_idЦелоеИД водителя
crew_group_idЦелоеИД группы экипажа
codeСтрокаПозывной экипажа
work_shift_sumДробноеСумма, списываемая за смену
min_balanceДробноеМинимальный баланс, при котором можно выйти на смену
work_timeСтрокаВремя работы, формат: “6.00-10.30, 23:00-00:48”
has_light_housetrue или falseШашка
has_labeltrue или falseНаклейка
crew_gps_idЦелоеGPS идентификатор экипажа
use_plan_shiftstrue или falseЗапрет работы вне запланированных смен
order_paramsМассивМассив параметров экипажа. Устарело. Рекомендуется использовать параметр attribute_values.
ЦелоеИД параметра
attribute_values Массив Массив значений атрибутов
• id Целое Идентификатор атрибута
• bool_value true или false Значение, если тип атрибута «Логический»
• num_value Дробное Значение, если тип атрибута:
- «Число» (непосредственное значение)
- «Число (выбор из списка)» (непосредственное значение выбранного элемента списка)
- «Перечисляемый» (значение выбранного элемента перечисления)
- «Дата» и «Дата/время» (Unix-время, всегда целое число)
• str_value Строка Значение, если тип атрибута «Строка»

Специальные возвращаемые коды:

КодОписание
100Автомобиль с ИД=ID не найден
101Водитель с ИД=ID не найден
102Группа экипажа с ИД=ID не найдена
103Параметр с ИД=ID не найден или не может быть привязан к экипажу
104Экипаж с таким водителем и автомобилем уже существует
106Экипаж с ИД=ID не найден
107Экипаж на линии, запрещено редактирование полей: водитель, автомобиль, позывной, группа экипажа, сумма за смену, минимальный баланс, запрет выхода вне запланированной смены.

Возвращаемые данные в случае успешного выполнения запроса: нет.

Пример:

Запрос:
POST https://ip:port/common_api/1.0/update_crew_info HTTP/1.1
Signature: <...>
Content-Type: application/json
Content-Length: <...>

{
  "crew_id":1,
  "car_id":1,
  "driver_id":3,
  "crew_group_id":3,
  "code":"CODE",
  "use_plan_shifts":true,
  "order_params":[3,4]
}

Ответ:
{
  "code":0,
  "descr":"OK",
  "data":{}
}

17. Запрос информации о водителе

Метод: GET

Название запроса: get_driver_info

Параметры:

ПараметрыТипОписание
Обязательные параметры
driver_idЦелоеИД водителя
Необязательные параметры
need_phototrue или falseНужна ли фотография водителя
fieldsСтрокаСписок возвращаемых полей через запятую

Специальные возвращаемые коды:

КодОписание
100Водитель не найден

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
driver_idЦелоеИД водителя
nameСтрокаФИО водителя
balanceДробноеБаланс основного счета водителя
birthdayДД.ММ.ГГГГДень рождения водителя
numberСтрокаТабельный номер
car_idЦелоеИД основного автомобиля водителя
driver_licenseСтрокаВодительское удостоверение
licenseСтрокаРазрешение на перевозку
home_phoneСтрокаЛюбой неосновной телефон водителя (устаревшее поле)
mobile_phoneСтрокаОсновной телефон водителя (устаревшее поле)
is_lockedtrue или falseВодитель заблокирован
is_dismissedtrue или falseВодитель уволен
self_employedtrue или falseВодитель самозанятый
innСтрокаИНН водителя
insurance_numberСтрокаСНИЛС водителя
passportСтрокаПаспортные данные
employee_typeЦелоеТип работника (0 - работник компании, 1 - частник)
start_dateГГГГММДДччммссДата приема на работу
lic_dateГГГГММДДччммссДата окончания договора
commentСтрокаОписание
driver_photoBase64Фото водителя (только если need_photo = true или поле driver_photo указано в списке фильтра полей fields)
order_paramsМассивМассив параметров водителя. Устарело. Рекомендуется использовать параметр attribute_values
ЦелоеИД параметра
phonesМассивМассив телефонов водителя
• phoneСтрокаНомер телефона
• is_defaulttrue или falseПризнак основного телефона
• use_for_calltrue или falseИспользовать для отзвона
term_accountСтрокаТерминальный аккаунт
name_for_taxophoneСтрокаИмя для мобильного приложения пассажира
accountsМассивМассив балансов счетов
•account_kindЦелоеТип счета
•balanceДробноеБаланс счета
attribute_values Массив Массив значений атрибутов
• id Целое Идентификатор атрибута
• bool_value true или false Значение, если тип атрибута «Логический»
• num_value Дробное Значение, если тип атрибута:
- «Число» (непосредственное значение)
- «Число (выбор из списка)» (непосредственное значение выбранного элемента списка)
- «Перечисляемый» (значение выбранного элемента перечисления)
- «Дата» и «Дата/время» (Unix-время, всегда целое число)
• str_value Строка Значение, если тип атрибута «Строка»
kpi Дробное Показатель эффективности (KPI) водителя

Пример:

Запрос:

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",
    "balance":100,
    "birthday":"01.01.1980",
    "number":"111",
    "car_id":1,
    "license":"1234567890",
    "home_phone":"79999999999",
    "mobile_phone":"79999999999",
    "is_locked":false,
    "is_dismissed":false,
    "order_params":[3,4],
    "phones":[
      {
        "phone":"79999999999",
        "is_default":true,
        “use_for_call”:true
      },
      {
        "phone":"79999999999",
        "is_default":false,
        “use_for_call”:false
      }
    ],
    "term_account":"00008",
    "name_for_taxophone":"NameForTaxoPhone",
    "accounts":
    [
      {
        "account_kind":0,
        "balance":1000993.00
      },
      {
        "account_kind":1000,
        "balance":600.00
      }
    ],
    "attribute_values": [
        {
              "id": 1,
              "bool_value": true
        },
        {
              "id": 2,
              "num_value": 1
        },
        {
              "id": 3,
              "num_value": 10
        },
        {
              "id": 4,
              "str_value": "строка"
        }
    ],
    "kpi":3.12
  }
}

18. Запрос списка водителей

Метод: GET

Название запроса: get_drivers_info

Параметры:

ПараметрТипОписание
Необязательные параметры
locked_driverstrue или falseВключить в ответ запроса заблокированных водителей (по умолчанию false)
dismissed_driverstrue или falseВключить в ответ запроса уволенных водителей (по умолчанию false)
fieldsСтрокаСписок возвращаемых полей через запятую


Специальные возвращаемые коды: нет

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
drivers_infoМассивМассив не удаленных водителей
• driver_idЦелоеИД водителя
• nameСтрокаФИО водителя
• balanceДробноеБаланс водителя
• birthdayДД.ММ.ГГГГДень рождения водителя
• numberСтрокаТабельный номер
• car_idЦелоеИД основного автомобиля водителя
• driver_licenseСтрокаВодительское удостоверение
• licenseСтрокаРазрешение на перевозку
• home_phoneСтрокаЛюбой неосновной телефон водителя (устаревшее поле)
• mobile_phoneСтрокаОсновной телефон водителя (устаревшее поле)
• is_lockedtrue или falseВодитель заблокирован
• is_dismissedtrue или falseВодитель уволен
• self_employedtrue или falseВодитель самозанятый
• innСтрокаИНН водителя
• insurance_numberСтрокаСНИЛС водителя
• passportСтрокаПаспортные данные
• employee_typeЦелоеТип работника (0 - работник компании, 1 - частник)
• start_dateГГГГММДДччммссДата приема на работу
• lic_dateГГГГММДДччммссДата окончания договора
• commentСтрокаОписание
• order_paramsМассивМассив параметров водителя. Устарело. Рекомендуется использовать параметр attribute_values
• •ЦелоеИД параметра
• phonesМассивМассив телефонов водителя
• • phoneСтрокаНомер телефона
• • is_defaulttrue или falseПризнак основного телефона
• • use_for_calltrue или falseИспользовать для отзвона
• term_accountСтрокаТерминальный аккаунт
• attribute_values Массив Массив значений атрибутов
• • id Целое Идентификатор атрибута
• • bool_value true или false Значение, если тип атрибута «Логический»
• • num_value Дробное Значение, если тип атрибута:
- «Число» (непосредственное значение)
- «Число (выбор из списка)» (непосредственное значение выбранного элемента списка)
- «Перечисляемый» (значение выбранного элемента перечисления)
- «Дата» и «Дата/время» (Unix-время, всегда целое число)
• • str_value Строка Значение, если тип атрибута «Строка»
• kpi Дробное Показатель эффективности (KPI) водителя

Пример:

Запрос:

GET https://ip:port/common_api/1.0/get_drivers_info?locked_drivers=true&dismissed_drivers=true HTTP/1.1
Signature: <...>


Ответ:

{
  "code":0,
  "descr":"OK",
  "data":{
    "drivers_info":[
      {
        "driver_id":1,
        "name":"DRIVER_NAME1",
        "balance":100.00,
        "birthday":"01.01.1980",
        "number":"111",
        "car_id":1,
        "license":"1234567890",
        "home_phone":"79999999999",
        "mobile_phone":"79999999999",
        "is_locked":false,
        "is_dismissed":false,
        "order_params":[3,4],
        "phones":[
          {
            "phone":"79999999999",
            "is_default":true,
            “use_for_call”: true

          },
          {
            "phone":"79999999999",
            "is_default":false,
            “use_for_call”: true

          }
        ],
        "term_account":"00008",
        "attribute_values": [
            {
                  "id": 3,
                  "num_value": 10
            },
            {
                  "id": 4,
                  "str_value": "строка"
            }
        ],
        "kpi":3.12
      },
      {
        "driver_id":2,
        "name":"DRIVER_NAME2",
        "balance":-50.00,
        "birthday":"01.01.1980",
        "number":"222",
        "car_id":2,
        "license":"1234567899",
        "is_locked":true,
        "is_dismissed":true,
        "order_params":[5,6],
        "phones":[
          {
            "phone":"79999999999",
            "is_default":true,
            “use_for_call”: true
          },
          {
            "phone":"79999999999",
            "is_default":false,
            “use_for_call”: false
          }
        ],
        "term_account":"00009",
        "attribute_values": [
            {
                  "id": 3,
                  "num_value": 10
            },
            {
                  "id": 4,
                  "str_value": "строка"
            }
        ],
        "kpi":3.12
      }
    ]
  }
}

19. Создание водителя

Метод: POST

Название запроса: create_driver

Параметры в формате JSON:

ПараметрТипОписание
Обязательные параметры
nameСтрокаФИО водителя
car_idЦелоеИД основного автомобиля
Необязательные параметры
passwordСтрокаПароль. Если не передали пароль, то он будет сгенерирован автоматически
home_phoneСтрокаНеосновной телефон водителя (устаревший параметр)
mobile_phoneСтрокаОсновной телефон водителя (устаревший параметр)
passportСтрокаПаспортные данные
driver_licenseСтрокаВодительское удостоверение
licenseСтрокаРазрешение на перевозку
employee_typeЦелоеТип работника (0 - работник компании, 1 - частник)
birthdayГГГГММДДччммссДень рождения
numberСтрокаТабельный номер
start_dateГГГГММДДччммссДата приема на работу
lic_dateГГГГММДДччммссДата окончания договора
term_accountСтрокаТерминальный аккаунт (если не указан, будет сгенерирован автоматически), должен состоять из 5 цифр
self_employedtrue или falseВодитель самозанятый
innСтрокаИНН водителя
insurance_numberСтрокаСНИЛС водителя
commentСтрокаОписание
order_paramsМассивМассив параметров водителя. Устарело. Рекомендуется использовать параметр attribute_values
ЦелоеИД параметра
driver_photoBase64Фотография водителя
phonesМассивМассив телефонов водителя
• phoneСтрокаНомер телефона
• is_defaulttrue или falseПризнак основного телефона
• use_for_calltrue или falseИспользовать для отзвона
name_for_taxophoneСтрокаИмя для мобильного приложения пассажира
attribute_values Массив Массив значений атрибутов
• id Целое Идентификатор атрибута
• bool_value true или false Значение, если тип атрибута «Логический»
• num_value Дробное Значение, если тип атрибута:
- «Число» (непосредственное значение)
- «Число (выбор из списка)» (непосредственное значение выбранного элемента списка)
- «Перечисляемый» (значение выбранного элемента перечисления)
- «Дата» и «Дата/время» (Unix-время, всегда целое число)
• str_value Строка Значение, если тип атрибута «Строка»

Специальные возвращаемые коды:

КодОписание
100Автомобиль с ИД=ID не найден
102Атрибут с ИД=ID не найден или не может быть привязан к водителю
103Терминальный аккаунт не уникален
104Некорректный терминальный аккаунт
107Основной телефон может быть только один
108Водитель должен иметь основной телефон
109Пароль водителя не соответствует политике паролей

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
driver_idЦелоеИД созданного водителя

Пример:

Запрос:
POST https://ip:port/common_api/1.0/create_driver HTTP/1.1
Signature: <...>
Content-Type: application/json
Content-Length: <...>

{
  "name":"NAME",
  "car_id":140,
  "password":"PASSWORD",
  "birthday":"19930218000000",
  "comment":"COMMENT",
  "order_params":[3,4],
  "name_for_taxophone":"NameForTaxoPhone",
  "phones":[
    {
      "phone":"79999999999",
      "is_default":true,
      “use_for_call”: true
    },
    {
      "phone":"79999999999",
      "is_default":false,
      “use_for_call”: true
    }
  ],
  "attribute_values": [
      {
            "id": 1,
            "bool_value": true
      },
      {
            "id": 2,
            "num_value": 1
      },
      {
            "id": 3,
            "num_value": 10
      },
      {
            "id": 4,
            "str_value": "строка"
      }
  ]
}

Ответ:
{
  "code":0,
  "descr":"OK",
  "data":{
  "driver_id":10
 }
}

20. Обновление информации о водителе

Метод: POST

Название запроса: update_driver_info

Параметры в формате JSON:

ПараметрТипОписание
Обязательные параметры
driver_idЦелоеИД редактируемого водителя
Необязательные параметры
nameСтрокаФИО водителя
car_idЦелоеИД основного автомобиля
passwordСтрокаПароль
home_phoneСтрокаНеосновной телефон водителя (устаревший параметр)
mobile_phoneСтрокаОсновной телефон водителя (устаревший параметр)
passportСтрокаПаспортные данные
driver_licenseСтрокаВодительское удостоверение
licenseСтрокаРазрешение на перевозку
employee_typeЦелоеТип работника (0 - работник компании, 1 - частник)
birthdayГГГГММДДччммссДень рождения
numberСтрокаТабельный номер
start_dateГГГГММДДччммссДата приема на работу
lic_dateГГГГММДДччммссДата окончания договора
term_accountСтрокаТерминальный аккаунт
commentСтрокаОписание
time_blockГГГГММДДччммссВременная блокировка до
is_lockedtrue или falseЗаблокирован
lock_descriptionСтрокаПричина блокировки
is_dismissedtrue или falseУволен
dismiss_descriptionСтрокаПричина увольнения
self_employed
true или false
Водитель самозанятый
inn
Строка
ИНН водителя
insurance_number
Строка
СНИЛС водителя
order_paramsМассивМассив параметров водителя. Устарело. Рекомендуется использовать параметр attribute_values
ЦелоеИД параметра
driver_photoBase64Фотография водителя
phonesМассивМассив телефонов водителя
• phoneСтрокаНомер телефона
• is_defaulttrue или falseПризнак основного телефона
• use_for_calltrue или falseИспользовать для отзвона
name_for_taxophoneСтрокаИмя для мобильного приложения пассажира
attribute_values Массив Массив значений атрибутов
• id Целое Идентификатор атрибута
• bool_value true или false Значение, если тип атрибута «Логический»
• num_value Дробное Значение, если тип атрибута:
- «Число» (непосредственное значение)
- «Число (выбор из списка)» (непосредственное значение выбранного элемента списка)
- «Перечисляемый» (значение выбранного элемента перечисления)
- «Дата» и «Дата/время» (Unix-время, всегда целое число)
• str_value Строка Значение, если тип атрибута «Строка»

Специальные возвращаемые коды:

КодОписание
100Автомобиль с ИД=ID не найден
102Параметр с ИД=ID не найден или не может быть привязан к водителю
103Терминальный аккаунт не уникален
104Некорректный терминальный аккаунт
105Водитель с ИД=ID не найден
106Экипаж на линии, запрещено редактирование полей: основной автомобиль, тип работника.
107Основной телефон может быть только один
108Водитель должен иметь основной телефон
109Пароль водителя не соответствует политике паролей

Возвращаемые данные в случае успешного выполнения запроса: нет.

Пример:

Запрос:
POST https://ip:port/common_api/1.0/update_driver_info HTTP/1.1
Signature: <...>
Content-Type: application/json
Content-Length: <...>

{
  "driver_id":10
  "name":"NAME",
  "car_id":140,
  "password":"PASSWORD",
  "birthday":"19930218000000",
  "comment":"COMMENT",
  "order_params":[3,4],
  "name_for_taxophone":"NameForTaxoPhone",
  "phones":[
    {
      "phone":"79999999999",
      "is_default":true,
      “use_for_call”: true
    },
    {
      "phone":"79999999999",
      "is_default":false,
      “use_for_call”: false
    }
  ],
  "attribute_values": [
      {
            "id": 1,
            "bool_value": true
      },
      {
            "id": 2,
            "num_value": 1
      },
      {
            "id": 3,
            "num_value": 10
      },
      {
            "id": 4,
            "str_value": "строка"
      }
  ]
}

Ответ:
{
  "code":0,
  "descr":"OK",
  "data":{}
}

21. Запрос информации об автомобиле

Метод: GET

Название запроса: get_car_info

Параметры:

ПараметрыТипОписание
Обязательные параметры
car_idЦелоеИД автомобиля
Необязательные параметры
need_phototrue или falseНужна ли фотография автомобиля
fields
Строка
Список возвращаемых полей через запятую

Специальные возвращаемые коды:

КодОписание
100Автомобиль не найден

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
car_idЦелоеИД автомобиля
codeСтрокаПозывной автомобиля
nameСтрокаНаименование автомобиля
gos_numberСтрокаГосударственный номер автомобиля
colorСтрокаЦвет автомобиля
markСтрокаМарка автомобиля
modelСтрокаМодель автомобиля
short_nameСтрокаКраткое название автомобиля
production_yearЦелоеГод выпуска автомобиля
is_lockedtrue или falseАвтомобиль заблокирован
fuel_levelДробноеУровень топлива в автомобиле
car_classСтрокаКласс автомобиля (A, B, C, ...)
vinСтрокаVIN
body_numberСтрокаНомер кузова
engine_numberСтрокаНомер двигателя
permitСтрокаРазрешение на перевозку
commentСтрокаОписание
order_paramsМассивМассив параметров автомобиля. Устарело. Рекомендуется использовать параметр attribute_values
ЦелоеИД параметра
car_photoBase64Фото автомобиля (только если need_photo = true или поле driver_photo указано в списке фильтра полей fields)
attribute_values Массив Массив значений атрибутов
• id Целое Идентификатор атрибута
• bool_value true или false Значение, если тип атрибута «Логический»
• num_value Дробное Значение, если тип атрибута:
- «Число» (непосредственное значение)
- «Число (выбор из списка)» (непосредственное значение выбранного элемента списка)
- «Перечисляемый» (значение выбранного элемента перечисления)
- «Дата» и «Дата/время» (Unix-время, всегда целое число)
• str_value Строка Значение, если тип атрибута «Строка»

Пример:

Запрос:

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,
    "is_locked":false,
    "fuel_level":8.15,
    "order_params":[1,2],
    "attribute_values": [
        {
              "id": 1,
              "bool_value": true
        },
        {
              "id": 2,
              "num_value": 1
        },
        {
              "id": 3,
              "num_value": 10
        },
        {
              "id": 4,
              "str_value": "строка"
        }
    ]
  }
}

22. Запрос списка автомобилей

Метод: GET

Название запроса: get_cars_info

Параметры:

ПараметрыТипОписание
Необязательные параметры
locked_carstrue или falseВключить в ответ заблокированных автомобилей (по умолчанию false)
fieldsСтрокаСписок возвращаемых полей через запятую


Специальные возвращаемые коды: нет

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрыТипОписание
crews_infoМассивМассив автомобилей
• car_idЦелоеИД автомобиля
• codeСтрокаПозывной автомобиля
• nameСтрокаНаименование автомобиля
• gos_numberСтрокаГос. номер автомобиля
• colorСтрокаЦвет автомобиля
• markСтрокаМарка автомобиля
• modelСтрокаМодель автомобиля
• short_nameСтрокаКраткое название автомобиля
• production_yearЦелоеГод выпуска автомобиля
• is_lockedtrue или falseАвтомобиль заблокирован
• car_classСтрокаКласс автомобиля (A, B, C, ...)
• vinСтрокаVIN
• body_numberСтрокаНомер кузова
• engine_numberСтрокаНомер двигателя
• permitСтрокаРазрешение на перевозку
• commentСтрокаОписание
• fuel_levelДробноеУровень топлива в автомобиле
• order_paramsМассивМассив параметров автомобиля. Устарело. Рекомендуется использовать параметр attribute_values
• •ЦелоеИД параметра
• attribute_values Массив Массив значений атрибутов
• • id Целое Идентификатор атрибута
• • bool_value true или false Значение, если тип атрибута «Логический»
• • num_value Дробное Значение, если тип атрибута:
- «Число» (непосредственное значение)
- «Число (выбор из списка)» (непосредственное значение выбранного элемента списка)
- «Перечисляемый» (значение выбранного элемента перечисления)
- «Дата» и «Дата/время» (Unix-время, всегда целое число)
• • str_value Строка Значение, если тип атрибута «Строка»

Пример:

Запрос:

GET https://ip:port/common_api/1.0/get_cars_info?locked_cars=true HTTP/1.1
Signature: <...>


Ответ:

{
  "code":0,
  "descr":"OK",
  "data":{
    "crews_info":[
      {
        "car_id":1,
        "code":"111",
        "name":"CAR_1",
        "gos_number":"111111",
        "color":"COLOR_1",
        "mark":"MARK_1",
        "model":"MODEL_1",
        "short_name":"SHORT_NAME_1",
        "production_year":2000,
        "is_locked":false,
        "fuel_level":8.15,
        "order_params":[1,2],
        "attribute_values": [
            {
                  "id": 1,
                  "bool_value": true
            },
            {
                  "id": 2,
                  "num_value": 1
            }
        ]
      },
      {
        "car_id":2,
        "code":"222",
        "name":"CAR_2",
        "gos_number":"222222",
        "color":"COLOR_2",
        "mark":"MARK_2",
        "model":"MODEL_2",
        "short_name":"SHORT_NAME_2",
        "production_year":2000,
        "is_locked":false,
        "fuel_level":null,
        "order_params":[3,4],
        "attribute_values": [
            {
                  "id": 3,
                  "num_value": 10
            },
            {
                  "id": 4,
                  "str_value": "строка"
            }
        ]
      }
    ]
  }
}

23. Создание автомобиля

Метод: POST

Название запроса: create_car

Параметры в формате JSON:

ПараметрыТип Описание
Обязательные параметры
codeСтрокаПозывной
markСтрокаМарка
colorСтрокаЦвет
gos_numberСтрокаГосударственный номер
Необязательные параметры
modelСтрокаМодель
short_nameСтрокаКраткое название
production_yearЦелоеГод выпуска
car_classСтрокаКласс автомобиля (A, B, C, ...)
vinСтрокаVIN
body_numberСтрокаНомер кузова
engine_numberСтрокаНомер двигателя
permitСтрокаРазрешение на перевозку
commentСтрокаОписание
order_paramsМассивМассив параметров автомобиля. Устарело. Рекомендуется использовать параметр attribute_values.
ЦелоеИД параметра
car_photoBase64Фотография автомобиля
attribute_values Массив Массив значений атрибутов
• id Целое Идентификатор атрибута
• bool_value true или false Значение, если тип атрибута «Логический»
• num_value Дробное Значение, если тип атрибута:
- «Число» (непосредственное значение)
- «Число (выбор из списка)» (непосредственное значение выбранного элемента списка)
- «Перечисляемый» (значение выбранного элемента перечисления)
- «Дата» и «Дата/время» (Unix-время, всегда целое число)
• str_value Строка Значение, если тип атрибута «Строка»
crew_group_id
Целое ИД группы экипажей

Специальные возвращаемые коды:

КодОписание
100Автомобиль с ИД=ID имеет такой же позывной=CODE (проверка на дубликат позывного убрана из CommonAPI в ТМ 3.14.101)
104Атрибут с ИД=ID не найден или не может быть привязан к автомобилю
105Группа экипажей не найдена

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
car_idЦелоеИД созданного автомобиля

Пример:

Запрос:
POST https://ip:port/common_api/1.0/create_car HTTP/1.1
Signature: <...>
Content-Type: application/json
Content-Length: <...>

{
  "code":"CODE",
  "mark":"MARK",
  "model":"MODEL",
  "color":"BLACK",
  "gos_number":"NUMBER",
  "production_year":2000,
  "comment":"COMMENT",
  "order_params":[1,2,3,4],
  "attribute_values": [
      {
            "id": 1,
            "bool_value": true
      },
      {
            "id": 2,
            "num_value": 1
      },
      {
            "id": 3,
            "num_value": 10
      },
      {
            "id": 4,
            "str_value": "строка"
      }
  ]
}

Ответ:
{
  "code":0,
  "descr":"OK",
  "data":{
  "car_id":140
 }
}

24. Обновить информацию об автомобиле

Метод: POST

Название запроса: update_car_info

Параметры в формате JSON:

ПараметрыТипОписание
Обязательные параметры
car_idЦелоеИД автомобиля
Необязательные параметры
dont_check_car_on_shift
true или false
Не проверять, что автомобиль уже на линии
code
СтрокаПозывной
markСтрокаМарка
colorСтрокаЦвет
gos_numberСтрокаГосударственный номер
modelСтрокаМодель
short_nameСтрокаКраткое название
production_yearЦелоеГод выпуска
car_classСтрокаКласс автомобиля (A, B, C, ...)
vinСтрокаVIN
body_numberСтрокаНомер кузова
engine_numberСтрокаНомер двигателя
permitСтрокаРазрешение на перевозку
commentСтрокаОписание
order_paramsМассивМассив параметров автомобиля. Устарело. Рекомендуется использовать параметр attribute_values
ЦелоеИД параметра
attribute_values Массив Массив значений атрибутов
• id Целое Идентификатор атрибута
• bool_value true или false Значение, если тип атрибута «Логический»
• num_value Дробное Значение, если тип атрибута:
- «Число» (непосредственное значение)
- «Число (выбор из списка)» (непосредственное значение выбранного элемента списка)
- «Перечисляемый» (значение выбранного элемента перечисления)
- «Дата» и «Дата/время» (Unix-время, всегда целое число)
• str_value Строка Значение, если тип атрибута «Строка»
is_lockedtrue или falseАвтомобиль заблокирован
lock_descriptionСтрокаПричина блокировки
car_photoBase64Фотография автомобиля
crew_group_id
ЦелоеИД группы экипажей

Специальные возвращаемые коды:

КодОписание
102Автомобиль с ИД=ID не найден
103Экипаж на линии, запрещено редактирование полей: марка, модель, краткое наименование, цвет, гос. номер.
104Параметр с ИД=ID не найден или не может быть привязан к автомобилю
105Группа экипажей не найдена

Возвращаемые данные в случае успешного выполнения запроса: нет.

Пример:

Запрос:
POST https://ip:port/common_api/1.0/update_car_info HTTP/1.1
Signature: <...>
Content-Type: application/json
Content-Length: <...>

{
  "car_id":1,
  "code":"CODE",
  "mark":"MARK",
  "model":"MODEL",
  "color":"BLACK",
  "gos_number":"NUMBER",
  "production_year":2000,
  "comment":"COMMENT",
  "order_params":[3,4]
}

Ответ:
{
  "code":0,
  "descr":"OK",
  "data":{}
}

25. Запрос координат экипажей

Метод: GET

Название запроса: get_crews_coords

Параметры:

ПараметрыТипОписание
Необязательные параметры
crew_idЦелоеИД экипажа, по которому нужно вернуть координаты. Если не задано, то будут возвращены координаты всех экипажей на линии

Специальные возвращаемые коды:

КодОписание
100Координаты не найдены

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
crews_coordsМассивСписок координат экипажей
• crew_idЦелоеИД экипажа
• crew_codeСтрокаПозывной экипажа
• coords_timeГГГГММДДччммссВремя получения координат
• latДробноеШирота
• lonДробноеДолгота
• speed
Целое
Скорость движения, км/ч
• direction
Целое
Направление движения (0-Север, 90-Восток, 180-Юг, 270-Запад, -1-не задано)
• 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,
         "speed":67,
         "direction":333,
         "state_kind":"waiting"
      },
      {
         "crew_id":2,
         "crew_code":"222",
         "coords_time":"20120101101010",
         "lat":33.333333,
         "lon":44.444444,
         "speed":0,
         "direction":-1,
         "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"
      }
    ]
  }
}

26. Запрос адресов, содержащих нужную строку

Метод: GET

Название запроса: get_addresses_like

Параметры:

ПараметрыТипОписание
Обязательные параметры
get_streetstrue или falseИскать улицы
get_pointstrue или falseИскать пункты
get_housestrue или falseИскать дома. Не может быть равно true, если get_streets = true или get_points = true.
streetСтрокаЧасть названия улицы или пункта, если идет поиск улиц или пунктов, или полное название улицы, если идет поиск домов
Необязательные параметры
houseСтрокаЧасть номера дома. Нужно только если get_houses = true.
cityСтрокаГород, в котором искать адреса
max_addresses_countЦелоеМаксимальное количество адресов в ответе
search_in_tmtrue или falseИскать адреса в ТМ (по умолчанию = true)
search_in_yandextrue или falseИскать адреса в Яндекс (по умолчанию = false)
search_in_googletrue или falseИскать адреса в Google (по умолчанию = false)
search_in_2gistrue или falseИскать адреса в 2GIS (по умолчанию = false)
search_in_tmgeoservicetrue или falseИскать адреса в TMGeoService (по умолчанию = false)
search_in_mapmd
true или false
Искать адреса в Map.md (по умолчанию = false)

Специальные возвращаемые коды:

КодОписание
100Подходящие адреса не найдены
101Не указано место для поиска адресов

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
addressesМассивСписок подходящих адресов
• address_sourceСтрокаИсточник адреса. Может принимать значения:

•"tm" — ТМ (адрес из базы данных или из карты)

•"yandex" — Яндекс

•"google" — Google

•"2gis" — 2GIS

•"mapmd" - Map.md

• streetСтрокаНазвание улицы или пункта
• houseСтрокаНомер дома
• kindСтрокаТип адреса. Может принимать значения:

• "street" — улица

• "house" — дом

• "point" — пункт

• commentСтрокаКомментарий
• coordsМассивКоординаты дома или пункта
• • latДробноеШирота
• • lonДробноеДолгота

Пример:

Запрос:

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":[
      {
         "address_source":"tm",
         "street":"STREET1",
         "house":"",
         "kind":"street",
         "comment":"",
         "coords":{
             "lat":0,
             "lon":0
         }
      },
      {
         "address_source":"tm",
         "street":"STREET2",
         "house":"",
         "kind":"street",
         "comment":"",
         "coords":{
             "lat":0,
             "lon":0
         }
      },
      {
         "address_source":"tm",
         "street":"POINT_STREET1",
         "house":"",
         "kind":"point",
         "comment":"Point at street STREET1",
         "coords":{
             "lat":11.111111,
             "lon":22.222222
         }
      }
    ]
  }
}

Запрос:

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":[
      {
         "address_source":"tm",
         "street":"STREET1",
         "house":"1",
         "kind":"house",
         "comment":"",
         "coords":{
             "lat":11.111111,
             "lon":22.222222
         }
      },
      {
         "address_source":"tm",
         "street":"STREET1",
         "house":"10",
         "kind":"house",
         "comment":"",
         "coords":{
             "lat":33.333333,
             "lon":44.444444
         }
      }
    ]
  }
}

27. Запрос адресов, содержащих нужную строку 2

Метод: GET

Название запроса: get_addresses_like2

Параметры:

ПараметрыТипОписание
Обязательные параметры
get_streetstrue или falseИскать улицы
get_pointstrue или falseИскать пункты
get_housestrue или falseИскать дома
addressСтрокаСтрока для поиска адреса
Необязательные параметры
cityСтрокаГорода, разделенные запятой, в которых искать адреса
max_addresses_countЦелоеМаксимальное количество адресов в ответе
search_in_tmtrue или falseИскать адреса в ТМ (по умолчанию = true)
search_in_yandextrue или falseИскать адреса в Яндекс (по умолчанию = false)
search_in_googletrue или falseИскать адреса в Google (по умолчанию = false)
search_in_2gistrue или falseИскать адреса в 2GIS (по умолчанию = false)
search_in_tmgeoservicetrue или falseИскать адреса в TMGeoService (по умолчанию = false)
search_in_mapmd
true или false
Искать адреса в Map.md (по умолчанию = false)

Специальные возвращаемые коды:

КодОписание
100Подходящие адреса не найдены
101Не указано место для поиска адресов

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
addressesМассивСписок подходящих адресов
• address_sourceСтрокаИсточник адреса. Может принимать значения:

•"tm" — ТМ (адрес из базы данных или из карты)

•"yandex" — Яндекс

•"google" — Google

•"2gis" — 2GIS

•"mapmd" — Map.md

• cityСтрокаНазвание города
• pointСтрокаНазвание пункта
• streetСтрокаНазвание улицы
• houseСтрокаНомер дома
• kindСтрокаТип адреса. Может принимать значения:

• "street" — улица

• "house" — дом

• "point" — пункт

• commentСтрокаКомментарий
• coordsМассивКоординаты дома или пункта
• • latДробноеШирота
• • lonДробноеДолгота

Пример:

Запрос:

GET https://ip:port/common_api/1.0/get_addresses_like2?get_streets=true&
get_points=true&get_houses=true&address=STR12 HTTP/1.1
Signature: <...>

Ответ:

{
  "code":0,
  "descr":"OK",
  "data":{
    "addresses":[
      {
         "address_source":"tm",
         "kind":"street",
         "city":"CITY ",
         "point":"",
         "street":"STREET",
         "house":"12",        
         "comment":"",
         "coords":{
             "lat":11.11111,
             "lon":22.222222
         }
      },
      {
         "address_source":"tm",
         "kind":"street",
         "city":"CITY ",
         "point":"",
         "street":"STREET",
         "house":"120",        
         "comment":"",
         "coords":{
             "lat":11.11111,
             "lon":22.222222
         }
      }
    ]
  }
}


28. Поиск ближайшего адреса

Метод: GET

Название запроса: find_nearest_address

Параметры:

ПараметрыТипОписание
Обязательные параметры
lattrue или falseИскать улицы
lontrue или falseИскать пункты
Необязательные параметры
radiusЦелоеРадиус в метрах
search_in_tmtrue или falseИскать адреса в ТМ (по умолчанию = true)
search_in_googletrue или falseИскать адреса в Google (по умолчанию = false)
search_in_tmgeoservicetrue или falseИскать адреса в TMGeoService (по умолчанию = false)
search_in_mapmd
true или false
Искать адреса в Map.md (по умолчанию = false)
search_in_2gistrue или falseИскать адреса в 2GIS (по умолчанию = false)

Специальные возвращаемые коды:

КодОписание
100Подходящий адрес не найден
101Не указано место для поиска адресов

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
address_sourceСтрокаИсточник адреса. Может принимать значения:

•"tm" — ТМ (адрес из базы данных или из карты)

•"tmgeoservice" — TMGeoService

•"google" — Google

•"2gis" — 2GIS

•"mapmd" — Map.md

cityСтрокаНазвание города
pointСтрокаНазвание пункта
streetСтрокаНазвание улицы
houseСтрокаНомер дома
kindСтрокаТип адреса. Может принимать значения:

• "street" — улица

• "house" — дом

• "point" — пункт

commentСтрокаКомментарий
coordsМассивКоординаты дома или пункта
• latДробноеШирота
• lonДробноеДолгота

Пример:

Запрос:

GET https://ip:port/common_api/1.0/find_nearest_address?lat=56.850926&lon=53.212706&radius=100&search_in_tm=false&search_in_google=false&search_in_tmgeoservice=true HTTP/1.1
Signature: <...>

Ответ:

{
{
  "code":0,
  "descr":"OK",
  "data":
  {
    "address_source":"tmgeoservice",
    "kind":"house",
    "city":"Ижевск",
    "point":"",
    "street":"Пушкинская ул.",
    "house":"206",
    "comment":"",
    "coords":
    {
      "lat":56.850951,
      "lon":53.212822
    }
  }
}


29. Анализ маршрута

Метод: GET

Название запроса: analyze_route

Параметры:

ПараметрыТипОписание
Обязательные параметры
sourceСтрокаАдрес подачи
destСтрокаАдрес назначения
Необязательные параметры
source_lonДробноеДолгота адреса подачи
source_latДробноеШирота адреса подачи
dest_lonДробноеДолгота адреса назначения
dest_latДробноеШирота адреса назначения


Параметр source не является обязательным к заполнению, если заданы source_lon и source_lat.

Параметр dest не является обязательным к заполнению, если заданы dest_lon и dest_lat.


Специальные возвращаемые коды:

КодОписание
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&
source_lon=53.153044&source_lat=56.893301&dest_lon=53.218103&dest_lat=56.869759 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
  }
}

30. Анализ маршрута 2

Метод: POST

Название запроса: analyze_route2

Параметры в формате JSON:

ПараметрТипОписание
Обязательные параметры
addressesМассивМассив адресов. Первый элемент — адрес подачи, последний — адрес назначения, между ними — остановки.
• addressСтрокаАдрес подачи
• latДробноеШирота адреса
• lonДробноеДолгота адреса
Необязательные параметры
get_full_route_coordstrue или falseВозвращать координаты точек полного маршрута (по умолчанию false)
crew_group_idЦелоеИД группы экипажей

Специальные возвращаемые коды:

КодОписание
100Маршрут не распознан

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрыТипОписание
AddressesМассивМассив адресов. Первый элемент — адрес подачи, последний — адрес назначения, между ними — остановки
• latДробноеШирота адреса
• lonДробноеДолгота адреса
• zone_idЦелоеРайон адреса
• parking_idЦелоеСтоянка адреса
city_distДробноеКилометраж по городу
country_distДробноеКилометраж за городом
source_country_distДробноеКилометраж до адреса подачи, если адрес подачи за городом
full_route_coordsМассивМассив координат точек маршрута
• latДробноеШирота точки
• lonДробноеДолгота точки

Пример:

Запрос:

POST https://ip:port/common_api/1.0/analyze_route2 HTTP/1.1
Content-Type: application/json
Content-Length: <...>
Signature: <...>

{
  "get_full_route_coords":true,
  "addresses":[
    {
      "address":"STREET1, 1",
      "lat":11.111111,
      "lon":22.222222
    },
    {
       "address":"STREET2, 2",
       "lat":33.333333,
       "lon":44.444444
    }
  ]
}



Ответ:
{
  "code":0,
  "descr":"OK",
  "data":{
    "addresses":[
      {
        "lat":11.111111,
        "lon":22.222222,
        "zone_id":1,
        "parking_id":1
      },
      {
        "lat":33.333333,
        "lon":44.444444,
        "zone_id":2,
        "parking_id":2
      }
    ],
    "city_dist":0,
    "country_dist":2.647,
    "source_country_dist":3.412,
    "full_route_coords":[
      {
        "lat":55.833603,
        "lon":37.515537
      },
      {
        "lat":55.832855,
        "lon":37.516315
      },
      {
        "lat":55.833405,
        "lon":37.51799
      },
      ...
    ]
  }
}

31. Запрос информации о состоянии заказа

Метод: GET

Название запроса: get_order_state

Параметры:

ПараметрыТипОписание
Обязательные параметры
order_idЦелоеИД заказа
Необязательные параметры
fieldsСтрокаСписок возвращаемых полей через запятую

Специальные возвращаемые коды:

КодОписание
100Заказ не найден

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
order_idЦелоеИД заказа
state_idЦелоеИД состояния заказа
state_kindСтрокаТип состояния заказа. Может принимать значения:

• "new_order" — новый заказ

• "driver_assigned" — водитель назначен

• "car_at_place" — машина подъехала на место

• "client_inside" — клиент в машине

• "finished" — заказ успешно завершен

• "aborted" — заказ прекращен

crew_idЦелоеИД экипажа
prior_crew_idЦелоеИД предварительного экипажа
driver_idЦелоеИД водителя
car_idЦелоеИД автомобиля
server_time_offsetЦелоеСмещение относительно серверного времени
start_timeГГГГММДДччммссВремя создания заказа
source_timeГГГГММДДччммссВремя подачи
finish_timeГГГГММДДччммссВремя завершения заказа
sourceСтрокаАдрес подачи
source_latСтрокаШирота адреса подачи
source_lonСтрокаДолгота адреса подачи
destinationСтрокаАдрес назначения
destination_latСтрокаШирота адреса назначения
destination_lonСтрокаДолгота адреса назначения
stopsМассивИнформация по остановкам заказа
• addressСтрокаАдрес остановки
• latДробноеШирота адреса остановки
• lonДробноеДолгота адреса остановки
trip_distance
ДробноеФактический километраж
trip_time
ЦелоеФактическое время в пути
customerСтрокаЗаказчик
passengerСтрокаПассажир
phoneСтрокаНомер телефона
phone_to_dial
СтрокаНомер телефона для отзвона
client_idЦелоеИД клиента
client_name
СтрокаИмя клиента
client_group_id
ЦелоеИД группы клиента
client_group_name
СтрокаНазвание группы клиента
client_employee_idЦелоеИД сотрудника клиента
order_crew_group_idЦелоеИД группы экипажей, которая указана в заказе
tariff_idЦелоеИД тарифа
car_markСтрокаМарка автомобиля
car_modelСтрокаМодель автомобиля
car_colorСтрокаЦвет автомобиля
car_numberСтрокаГосударственный номер автомобиля
confirmedСтрокаСостояние подтвержденности заказа водителем или оператором.

Может принимать значения:

• "not_confirmed" — не подтверждено

• "confirmed_by_driver" — заказ принят водителем

• "confirmed_by_oper" — заказ подтвержден оператором

crew_coordsМассивКоординаты экипажа
• latДробноеШирота
• lonДробноеДолгота
order_paramsМассивМассив параметров заказа экипажа. Устарело. Рекомендуется использовать параметр attribute_values
ЦелоеИД параметра заказа
creation_wayСтрокаСпособ создания заказа. Может принимать значения:

• "operator" — заказ создан оператором

• "sms" — заказ создан через смс

• "market" — заказ из биржи

• "common_api" — заказ создан через api

• "t_api" — заказ создан через api

• "taxophone" — заказ создан через таксофон с телефона

• "driver" — заказ создан водителем

• "daily_order" — ежедневный заказ

• "taxophone_web" — заказ создан через таксофон с сайта

• "unknown" — неизвестный

is_priortrue или falseПредварительный заказ
is_really_priortrue или falseПредварительный заказ на вкладке "Предварительные"
emailСтрокаEmail для уведомлений
prior_to_current_before_minutesЦелоеВремя перехода из предварительного в текущие заказы, мин
flight_numberСтрокаНомер рейса
order_bundle_id Целое ИД заявки спецтехники
is_combined
true или false
Признак того, что заказ составной
сombined_order_parts_ids
Массив
Массив ИД заказов-частей, передается только для составного заказа

ЦелоеИД заказа-части
is_part_of_combined
true или false
Признак того, что заказ является частью составного
combined_order_id
ЦелоеИД составного заказа, передается, только если заказ является частью составного
sum Дробное Сумма без скидки
total_sum Дробное Итоговая сумма заказа
cash_sum
Дробное
Сумма наличными
cashless_sum
Дробное
Сумма безналичными
bonus_sum
Дробное
Сумма бонусами
bank_card_sum
Дробное
Сумма банковской картой
attribute_values Массив Массив значений атрибутов
• id Целое Идентификатор атрибута
• bool_value true или false Значение, если тип атрибута «Логический»
• num_value Дробное Значение, если тип атрибута:
- «Число» (непосредственное значение)
- «Число (выбор из списка)» (непосредственное значение выбранного элемента списка)
- «Перечисляемый» (значение выбранного элемента перечисления)
- «Дата» и «Дата/время» (Unix-время, всегда целое число)
• str_value Строка Значение, если тип атрибута «Строка»
bill Массив Чек TMDriver. Данный узел выводится только, если по заказу есть чек
• code Строка Код элемента расчета
• text Строка Наименование элемента расчета
• value Строка Значение элемента расчета (количество)
• sum Строка Стоимость элемента расчета
fact_route Массив Фактический маршрут по заказу, выводится только если поле fact_route передали в списке фильтра полей fields
• lat Дробное Широта точки маршрута
• lon Дробное Долгота точки маршрута
• time ГГГГММДДччммсс Время данной точки
• speed Целое Скорость в данный момент, км/ч
• direction Целое Направление движения, градусы (0 - север, 90 - восток, 180 - юг, 270 - запад)
is_auction true или false Признак заказа-аукциона
payment_pay_system Строка Тип платежной системы ("card", "gpay", "apple_pay", "qr", "sber_pay", "sbp", либо пусто, если не используется)

Пример:

Запрос: 

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,
    "prior_crew_id":0,
    "driver_id":2,
    "car_id":3,
    "server_time_offset:0,
    "start_time":"20130117125641",
    "source_time":"20130117132617",
    "finish_time":"20130117130343",
    "source":"30 Лет Победы ул. \/Ижевск\/, 4Б",
    "source_lat":56.863613,
    "source_lon":53.186539,
    "destination":"Кирова ул. \/Ижевск\/, 56",
    "destination_lat":56.862202,
    "destination_lon":53.187485,
    "stops":[
      {
        "address":"30 Лет Победы ул. \/Ижевск\/, 8",
        "lat":56.863388,
        "lon":53.184269
      }
    ],
    "trip_distance":10.5,
    "trip_time":20,
    "customer":"Слепаков",
    "passenger":"Слепаков",
    "phone":"8800",
    "client_id":1,
    "client_employee_id":1,
    "order_crew_group_id":1,
    "tariff_id":1,
    "car_mark":"Ауди",
    "car_model":"Q7",
    "car_color":"черный",
    "car_number":"А777АА",   
    "confirmed":"confirmed_by_oper",
    "crew_coords": {
        "lat": 56.833981,
        "lon": 53.220249
    },
    "order_params":[
      1,
      2,
      5
    ],
    "creation_way":"operator",
    "is_prior":true,
    "is_really_prior":false,
    "email":"mail@mail.ru",
    "prior_to_current_before_minutes":30,
    "flight_number":"A-0501/123",
    "sum":50.5,
    "total_sum":80,
    "cash_sum":20.1,
    "cashless_sum":10,
    "bonus_sum":5.2,
    "bank_card_sum":15,
    "attribute_values": [
        {
              "id": 1,
              "bool_value": true
        },
        {
              "id": 2,
              "num_value": 1
        },
        {
              "id": 3,
              "num_value": 10
        },
        {
              "id": 4,
              "str_value": "строка"
        }
    ],
    "bill":
    [
      {
        "code":"BOARDING",
        "text":"Посадка",
        "value":"",
        "sum":"20,00"
      },
      {
        "code":"TRIP_TIME",
        "text":"Общее время",
        "value":"0:00:00",
        "sum":""
      },
      {
        "code":"TRIP_DIST",
        "text":"Общее расстояние",
        "value":"0,00 км",
        "sum":""
      },
      {
        "code":"BEFORE_DISC",
        "text":"Сумма без скидки",
        "value":"",
        "sum":"20,00"
      },
      {
        "code":"AFTER_DISC",
        "text":"Сумма со скидкой",
        "value":"",
        "sum":"20,00"
      },
      {
        "code":"MINIMUM",
        "text":"Минималка",
        "value":"",
        "sum":"60,00"
      }
    ],
    "fact_route":
    [
      {
        "lat":11.111111,
        "lon":22.222222,
        "time":"20130117132617",
        "speed":123,
        "direction":0
      }
    ],
    "is_auction":false,
    "payment_pay_system": "qr"
  }
}

32. Создание задачи СМС серверу

Метод: POST

Название запроса: send_sms

Параметры:

ПараметрыТипОписание
Обязательные параметры
phoneСтрока, <= 30 символовНомер телефона
messageСтрокаТекст СМС

Специальные возвращаемые коды: нет

Возвращаемые данные в случае успешного выполнения запроса: нет

Пример:

Запрос:

POST https://ip:port/common_api/1.0/send_sms HTTP/1.1
Content-Type: application/x-www-form-urlencoded
Content-Length: <...>
Signature: <...>

message=SMSText&phone=89050057216

Ответ:

{
  "code":0,
  "descr":"OK",
  "data":{}
}

33. Проверка авторизации

Метод: GET

Название запроса: check_authorization

Параметры:

ПараметрыТипОписание
Обязательные параметры
loginСтрока, <= 60 символовЛогин
passwordСтрока, <= 60 символовПароль

Специальные возвращаемые коды:

КодОписание
100Не найден клиент с логином LOGIN и/или неверный пароль

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
client_idЦелоеИД клиента

Пример:

Запрос:

GET https://ip:port/common_api/1.0/check_authorization?login=LOGIN&password=PASSWORD HTTP/1.1
Signature: <...>

Ответ:

{
  "code":0,
  "descr":"OK",
  "data":{
    "client_id":131
 }
}

34. Регистрация клиента

Метод: POST

Название запроса: register_client

Параметры:

Параметры Тип Описание
Обязательные параметры
name Строка, <= 60 символов ФИО
login Строка, <= 60 символов Логин
password Строка, <= 60 символов Пароль
phones Строка Номера телефонов (через запятую)
Необязательные параметры
client_group Целое ИД группы клиента
parent_id Целое ИД клиента-родителя
address Строка Домашний адрес
birthday ГГГГММДДччммсс Дата рождения
gender Строка Пол. Может принимать значения:

• "male" - мужской

• "female" - женский

email Строка E-mail
use_email_informing true или false Использовать E-mail для отправки уведомлений по заказу
comment Строка Комментарий
use_own_account true или false Использовать собственный счет для оплаты заказов

Специальные возвращаемые коды:

Код Описание
100 Дублирование номера телефона=PHONE в списке
101 Клиент с логином=LOGIN уже существует
102 Группа клиента с ИД=CLIENT_GROUP не найдена
103 Клиент указанный в качестве родителя с ИД=PARENT_ID не найден
109 Пароль клиента не соответствует политике паролей

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
client_idЦелоеИД созданного клиента

Пример:

Запрос:

POST https://ip:port/common_api/1.0/register_clientHTTP/1.1
Signature: <...>
Content-Type: application/x-www-form-urlencoded
Content-Length: <...>

name=NAME&phones=88,99&login=LOGIN&password=PASSWORD&
birthday=19930218115517&gender=male&address=ADDRESS&
client_group=1&parent_id=10&email=mail%40ya.ru&use_email_informing=true&
use_own_account=false

Ответ:

{
  "code":0,
  "descr":"OK",
  "data":{
    "client_id":140
  }
}

35. Регистрация клиента 2

Метод: POST

Название запроса: register_client2

Параметры в формате JSON:

Параметры Тип Описание
Обязательные параметры
name Строка, <= 60 символов ФИО
login Строка, <= 60 символов Логин
password Строка, <= 60 символов Пароль
phones Массив Массив телефонов клиента
phone Строка Номер телефона
is_default true или false Признак основного телефона
Необязательные параметры
client_group_id Целое ИД группы клиента
parent_id Целое ИД клиента-родителя
address Строка Домашний адрес
birthday ГГГГММДДччммсс Дата рождения
gender Строка Пол. Может принимать значения:

• "male" - мужской

• "female" - женский

email Строка E-mail
use_email_informing true или false Использовать E-mail для отправки уведомлений по заказу
comment Строка Комментарий
use_own_account true или false Использовать собственный счет для оплаты заказов
attribute_values Массив Массив значений атрибутов
• id Целое Идентификатор атрибута
• bool_value true или false Значение, если тип атрибута «Логический»
• num_value Дробное Значение, если тип атрибута:
- «Число» (непосредственное значение)
- «Число (выбор из списка)» (непосредственное значение выбранного элемента списка)
- «Перечисляемый» (значение выбранного элемента перечисления)
- «Дата» и «Дата/время» (Unix-время, всегда целое число)
• str_value Строка Значение, если тип атрибута «Строка»

Специальные возвращаемые коды:

Код Описание
100 Дублирование номера телефона=PHONE в списке
101 Клиент с логином=LOGIN уже существует
102 Группа клиента с ИД=CLIENT_GROUP не найдена
103 Клиент указанный в качестве родителя с ИД=PARENT_ID не найден
105 Основной телефон может быть только один
106 Клиент должен иметь основной телефон
107 Атрибут с ИД=ID не найден
108 Атрибут с ИД=ID не может быть привязан к клиенту
109 Пароль клиента не соответствует политике паролей

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
client_idЦелоеИД созданного клиента

Пример:

Запрос:

POST https://ip:port/common_api/1.0/register_client2 HTTP/1.1
Signature: <...>
Content-Type: application/json
Content-Length: <...>

{
  "name":"NAME",
  "login":"LOGIN",
  "password":"PASSWORD",
  "phones":[
    {
      "phone":"88",
      "is_default":true
    },
    {
      "phone":"99",
      "is_default":false
    }
  ],
  "address":"ADDRESS",
  "gender":"male",
  "birthday":"20000101000000",
  "client_group_id":1,
  "parent_id":10,
  "email":"mail@ya.ru",
  "use_email_informing":true,
  "comment":"TEXT",
  "use_own_account":false,
  "attribute_values":[
    {
      "id":5,
      "bool_value":true
    },
    {
      "id":7,
      "num_value":10
    },
    {
      "id":9,
      "str_value":"TEST"
    }
  ]
}

Ответ:

{
  "code":0,
  "descr":"OK",
  "data":{
    "client_id":140
  }
}

36. Запрос информации по клиенту

Метод: GET

Название запроса: get_client_info

Параметры:

Параметры Тип Описание
Обязательные параметры
client_id Целое ИД клиента
Необязательные параметры
fields Строка Список возвращаемых полей через запятую. Для полей списка сотрудников, запрашиваемого клиента, названия начинаются с "employees.", например: "employees.name"

Специальные возвращаемые коды:

Код Описание
100 Не найден клиент ИД=CLIENT_ID

Возвращаемые данные в случае успешного выполнения запроса:

Параметр Тип Описание
client_id Целое ИД клиента
parent_id Целое ИД клиента-родителя
name Строка ФИО
number Строка Номер договора
address Строка Домашний адрес
gender Строка Пол. Может принимать значения:

• "" - не указан

• "male" - мужской

• "female" - женский

birthday ДД.ММ.ГГГГ Дата рождения
phones Массив Массив телефонов клиента
• phone Строка Номер телефона клиента
balance Дробное Баланс
bonus_balance Дробное Бонусный баланс
login Строка Логин
password Строка Пароль
client_group_id Целое ИД группы клиента
tariff_id Целое ИД тарифа клиента или группы клиентов
prize_tariff_id Целое ИД призового тарифа клиента или группы клиентов
tariff_shift_id Целое ИД смены тарифов клиента или группы клиентов
discount_id Целое ИД скидки клиента или группы клиентов
prize_discount_id Целое ИД призовой скидки клиента или группы клиентов
min_balance Дробное Порог, ниже которого не может опускаться баланс
min_balance_for_use_cashless Дробное Минимальный баланс для использования безналичного счета
min_bonus_balance_for_use_bonus Дробное Минимальный баланс для использования бонусного счета
is_locked true или false Клиент заблокирован
lock_description Строка Причина блокировки
use_cashless_account true или false Признак использования безналичного счета
use_cashless true или false Признак использования безналичного расчета по умолчанию. Имеет смысл только при use_cashless_account = true
no_cash_payment true или false Признак запрета использования наличных расчетов. Имеет смысл только при use_cashless_account = true и use_cashless = true
remain_prize Целое Сколько заказов осталось до призового
email Строка E-mail
use_email_informing true или false Использовать E-mail для отправки уведомлений по заказу
default_crew_group Целое Группа экипажей по умолчанию
use_own_account true или false Использовать собственный счет для оплаты заказа
comment Строка Комментарий
employees Массив Массив сотрудников клиента. Поля аналогичны полям основного клиента, только у сотрудников отсутствует поле employees
accounts Массив Массив счетов клиента. Для сотрудников счета возвращаются, только если их явно запросили в фильтре полей "employees.accounts"
• account_kind Целое Тип счета:
- 0 - Основной счет
- 1- Бонусный счет
- Остальные - нестандартные счета
• balance Дробное Баланс счета клиента
• balance_with_children Дробное Баланс счета клиента с учетом вложенных клиентов
attribute_values Массив Массив значений атрибутов. Возвращается, только если явно запросили в фильтре полей "attribute_values" или "employees.attribute_values" для сотрудников
• id Целое Идентификатор атрибута
• bool_value true или false Значение, если тип атрибута «Логический»
• num_value Дробное Значение, если тип атрибута:
- «Число» (непосредственное значение)
- «Число (выбор из списка)» (непосредственное значение выбранного элемента списка)
- «Перечисляемый» (значение выбранного элемента перечисления)
- «Дата» и «Дата/время» (Unix-время, всегда целое число)
• str_value Строка Значение, если тип атрибута «Строка»

Пример:

Запрос:

GET https://ip:port/common_api/1.0/get_client_info?client_id=140 HTTP/1.1
Signature: <...>

Ответ:

{
  "code": 0,
  "descr": "OK",
  "data": {
    "client_id": 20,
    "parent_id": 0,
    "name": "Юр. лицо1",
    "number": "111",
    "address": "Адрес Юр. лицо1",
    "gender": "",
    "birthday": "22.01.2016",
    "phones": [
      "105",
      "123456789",
      "100"
    ],
    "balance": 10,
    "bonus_balance": 333,
    "login": "111",
    "password": "111",
    "client_group_id": 1,
    "tariff_id": 39,
    "prize_tariff_id": 0,
    "tariff_shift_id": 0,
    "discount_id": 2,
    "prize_discount_id": 0,
    "min_balance": 0,
    "min_balance_for_use_cashless": null,
    "min_bonus_balance_for_use_bonus": null,
    "is_locked": false,
    "lock_description": "",
    "use_cashless_account": true,
    "use_cashless": true,
    "remain_prize": 0,
    "email": "Юр. лицо1@ss.ru",
    "use_email_informing": true,
    "default_crew_group": 6,
    "comment": "Сотрудник СВР. Использовать максимальные скидки",
    "employees": [
      {
        "client_id": 323,
        "parent_id": 20,
        "name": "Сотрудник1",
        "number": "111",
        "address": "Адрес Сотрудник1",
        "gender": "",
        "birthday": null,
        "phones": [
          "11221122112211"
        ],
        "balance": 0,
        "bonus_balance": 0,
        "login": "",
        "password": "",
        "client_group_id": 1,
        "tariff_id": 17,
        "prize_tariff_id": 0,
        "tariff_shift_id": 0,
        "discount_id": 2,
        "prize_discount_id": 0,
        "min_balance": 0,
        "min_balance_for_use_cashless": null,
        "min_bonus_balance_for_use_bonus": null,
        "is_locked": false,
        "lock_description": "",
        "use_cashless": true,
        "remain_prize": 0,
        "email": "Сотрудник1@ss.ru",
        "use_email_informing": true,
        "default_crew_group": 6,
        "accounts": [
          {
            "account_kind": 0,
            "balance": 400.00,
            "balance_with_children": 0.00
          },
          {
            "account_kind": 1,
            "balance": 0.00,
            "balance_with_children": 0.00
          },
          {
            "account_kind": 1003,
            "balance": 100.00,
            "balance_with_children": 0.00
          }
        ],
        "attribute_values": [
          {
            "id": 5,
            "bool_value": true
          },
          {
            "id": 4,
            "bool_value": true
          }
        ]
      }
    ],
    "accounts": [
      {
        "account_kind": 0,
        "balance": 2355.00,
        "balance_with_children": 2755.00
      },
      {
        "account_kind": 1,
        "balance": 0.00,
        "balance_with_children": 0.00
      },
      {
        "account_kind": 1003,
        "balance": -20.00,
        "balance_with_children": 80.00
      }
    ],
    "attribute_values": [
      {
        "id": 4,
        "bool_value": true
      }
    ]
  }
}

35. Изменение информации по клиенту

Метод: POST

Название запроса: update_client_info

Параметры:

ПараметрыТипОписание
Обязательные параметры
client_idЦелоеИД клиента
Необязательные параметры
nameСтрока, <= 60 символовФИО
loginСтрока, <= 60 символовЛогин
passwordСтрока, <= 60 символовПароль
phonesСтрокаНомера телефонов (через запятую)
addressСтрокаДомашний адрес
birthdayГГГГММДДччммссДата рождения
genderСтрокаПол. Может принимать значения:

• "male" - мужской

• "female" - женский

parent_idЦелоеИД клиента-родителя
client_group_idЦелоеИД группы клиента
emailСтрокаE-mail
use_email_informingtrue или falseИспользовать E-mail для отправки уведомлений по заказу
comment Строка Комментарий

Специальные возвращаемые коды:

КодОписание
100Клиент с номером телефона=PHONE уже существует
101Клиент с ИД=ID имеет такой же номер телефона=PHONE
102Клиент с логином=LOGIN уже существует
103Группа клиента с ИД=CLIENT_GROUP_ID не найдена
104Клиент указанный в качестве родителя с ИД=PARENT_ID не найден

Возвращаемые данные в случае успешного выполнения запроса: нет

Пример:

Запрос:

POST https://ip:port/common_api/1.0/update_client_info 
Signature: <...>
Content-Type: application/x-www-form-urlencoded
Content-Length: 118

client_id=140&name=NAME&phones=88,99&login=LOGIN&password=PASSWORD&birthday=20140901000000&gender=male&
address=ADDRESS&parent_id=10&client_group_id=3&email=mail%40ya.ru&use_email_informing=true

Ответ:

{
 "code":0,
  "descr":"OK",
  "data":{}
}

36. Запрос текущих заказов

Метод: GET

Название запроса: get_current_orders

Параметры:

ПараметрыТипОписание
Необязательные параметры
client_idЦелоеИД клиента
client_employee_idЦелоеИД сотрудника (только если указан ИД клиента)
phoneСтрока, <= 30 символовТелефон клиента
crew_idЦелоеИД экипажа
driver_idЦелоеИД водителя

Специальные возвращаемые коды:

КодОписание
100Не найден клиент ИД=CLIENT_ID
101Не найден сотрудник клиента ИД=CLIENT_EMPLOYEE_ID

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
idЦелоеИД заказа
state_idЦелоеИД состояния заказа
state_kindСтрокаТип состояния заказа. Может принимать значения:

• "new_order" — новый заказ

• "driver_assigned" — водитель назначен

• "car_at_place" — машина подъехала на место

• "client_inside" — клиент в машине

server_time_offsetЦелоеСмещение относительно серверного времени
start_timeГГГГММДДччммссДата создания заказа
source_timeГГГГММДДччммссВремя подачи
sourceСтрокаАдрес подачи
source_latСтрокаШирота адреса подачи
source_lonСтрокаДолгота адреса подачи
destinationСтрокаАдрес назначения
destination_latСтрокаШирота адреса назначения
destination_lonСтрокаДолгота адреса назначения
stopsМассивИнформация по остановкам заказа
• addressСтрокаАдрес остановки
• latДробноеШирота адреса остановки
• lonДробноеДолгота адреса остановки
customerСтрокаЗаказчик
passengerСтрокаПассажир
crew_idЦелоеИД экипажа
prior_crew_idЦелоеИД предварительного экипажа
driver_idЦелоеИД водителя
car_idЦелоеИД автомобиля
phoneСтрокаНомер телефона
client_idЦелоеИД клиента
tariff_idЦелоеИД тарифа
order_crew_group_idЦелоеИД группы экипажей, которая указана в заказе
creation_wayСтрокаСпособ создания заказа. Может принимать значения:

• "operator" — заказ создан оператором

• "sms" — заказ создан через смс

• "market" — заказ из биржи

• "common_api" — заказ создан через api

• "t_api" — заказ создан через api

• "taxophone" — заказ создан через таксофон с телефона

• "driver" — заказ создан водителем

• "daily_order" — ежедневный заказ

• "taxophone_web" — заказ создан через таксофон с сайта

• "unknown" — неизвестный

client_employee_idЦелоеИД сотрудника клиента
is_priortrue или falseПредварительный заказ
is_really_priortrue или falseПредварительный заказ на вкладке "Предварительные"
emailСтрокаEmail для уведомлений
prior_to_current_before_minutesЦелоеВремя перехода из предварительного в текущие заказы, мин
flight_numberСтрокаНомер рейса

Пример:

Запрос:
GET https://ip:port/common_api/1.0/get_current_orders?client_id=140&phone=18 
Signature: <...>

Ответ:
{
  "code":0,
  "descr":"OK",
  "data":{
    "orders":[
      {
        "id":20648,
        "state_id":44,
        "state_kind":"new_order",
        "server_time_offset:0,
        "start_time":"20130204181111",
        "source_time":"20130204181111",
        "source":"30 Лет Победы ул. \/Ижевск\/, 4Б",
        "source_lat":56.863613,
        "source_lon":53.186539,
        "destination":"Кирова ул. \/Ижевск\/, 56",
        "destination_lat":56.862202,
        "destination_lon":53.187485,
        "stops":[
          {
            "address":"30 Лет Победы ул. \/Ижевск\/, 8",
            "lat":56.863388,
            "lon":53.184269
          }
        ],
        "customer":"Маша",
        "passenger":"Маша",
        "crew_id":0,
        "prior_crew_id":0,
        "driver_id":0,
        "car_id":0,
        "phone":"18",
        "client_id":140,
        "tariff_id":1,
        "order_crew_group_id":1,
        "creation_way":"operator",
        "client_employee_id":1,
        "is_prior":false,
        "is_really_prior":false
        "email":"mail@mail.ru",
        "prior_to_current_before_minutes":30,
        "flight_number":"123/123123-0"
      },
      {
        "id":20670,
        "state_id":45,
        "state_kind":"car_at_place",
        "start_time":"20130207153022",
        "source_time":"20130207153022",
        "source":"11-й мкр,",
        "destination":"1-й пр-т \/Москва\/,",
        "customer":"Саша",
        "passenger":"Саша",
        "crew_id":1,
        "prior_crew_id":1,
        "driver_id":1,
        "car_id":1,
        "phone":"18",
        "client_id":140,
        "tariff_id":2,
        "order_crew_group_id":2,
        "creation_way":"operator",
        "client_employee_id":4,
        "is_prior":false,
        "is_really_prior":false 
        "email":"mail@mail.ru"
        "prior_to_current_before_minutes":30,
        "flight_number":"123/123123"

      }
    ]
  }
}

37. Запрос выполненных заказов

Метод: GET

Название запроса: get_finished_orders

Параметры:

ПараметрыТипОписание
Обязательные параметры
start_timeГГГГММДДччммссНачало периода
finish_timeГГГГММДДччммссКонец периода
Примечание: должен присутствовать хотя бы один параметр из client_id, phone, crew_id, driver_id.
Необязательные параметры
client_idЦелоеИД клиента
client_employee_idЦелоеИД сотрудника (только если указан ИД клиента)
phoneСтрока, <= 30 символовТелефон клиента
crew_idЦелоеИД экипажа
driver_idЦелоеИД водителя
state_typeСтрокаТип состояния заказа. Может принимать значения:

• "all" — все

• "finished" — выполненные

• "aborted" — прекращенные

state_idsСтрокаСписок состояний заказа через точку с запятой, пример: «1;2;3»

Примечание: должен присутствовать хотя бы один параметр из client_id, phone, crew_id, driver_id.

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
idЦелоеИД заказа
state_idЦелоеИД состояния заказа
server_time_offsetЦелоеСмещение относительно серверного времени
start_timeГГГГММДДччммссВремя создания заказа
source_timeГГГГММДДччммссВремя подачи
finish_timeГГГГММДДччммссВремя завершения заказа
sourceСтрокаАдрес подачи
source_latДробноеШирота адреса подачи
source_lonДробноеДолгота адреса подачи
destinationСтрокаАдрес назначения
destination_latДробноеШирота адреса назначения
destination_lonДробноеДолгота адреса назначения
stopsМассивМассив адресов остановок
• addressСтрокаАдрес остановки
• latДробноеШирота адреса остановки
• lonДробноеДолгота адреса остановки
trip_distanceДробноеФактический километраж
trip_timeЦелоеФактическое время в пути
customerСтрокаЗаказчик
passengerСтрокаПассажир
sumДробноеСтоимость заказа без учета скидок (наценок)
total_sumДробноеИтоговая стоимость заказа
cash_sumДробноеЗаплачено наличными
cashless_sumДробноеЗаплачено с безналичного счета клиента
bonus_sumДробноеЗаплачено с бонусного счета клиента
bank_card_sumДробноеЗаплачено банковской картой
crew_idЦелоеИД экипажа
prior_crew_idЦелоеИД предварительного экипажа
driver_idЦелоеИД водителя
car_idЦелоеИД автомобиля
phoneСтрокаНомер телефона
client_idЦелоеИД клиента
tariff_idЦелоеИД тарифа
order_crew_group_idЦелоеИД группы экипажей, которая указана в заказе
creation_wayСтрокаСпособ создания заказа. Может принимать значения:

• "operator" — заказ создан оператором

• "sms" — заказ создан через смс

• "market" — заказ из биржи

• "common_api" — заказ создан через api

• "t_api" — заказ создан через api

• "taxophone" — заказ создан через таксофон с телефона

• "driver" — заказ создан водителем

• "daily_order" — ежедневный заказ

• "taxophone_web" — заказ создан через таксофон с сайта

• "unknown" — неизвестный

client_employee_idЦелоеИД сотрудника клиента
emailСтрокаEmail для уведомлений
flight_numberСтрокаНомер рейса

Пример:

Запрос:
GET https://ip:port/common_api/1.0/get_finished_orders?driver_id=1&start_time=20170314122041&finish_time=20170314122641 
Signature: <...>
Ответ:
{
  "code":0,
  "descr":"OK",
  "data":{
    "orders":[
      {
        "id":20651,
        "state_id":34,
        "server_time_offset:1,
        "start_time":"20130205110812",
        "source_time":"20130205110812",
        "finish_time":"20130205115618",
        "source":"прпроп",
        "source_lat":42.9806060791016,
        "source_lon":47.4614906311035,
        "destination":"рррррр",
        "destination_lat":55.6898765563965,
        "destination_lon":37.6890335083008,
        "stops":[
           {
             "address":"ввввв",
             "lat":55.6792640686035,
             "lon":37.5807800292969
           },
           {
             "address":"ааааа",
             "lat":55.6731262207031,
             "lon":37.6959686279297
           },
           {
             "address":"ппппп",
             "lat":55.678165435791,
             "lon":37.6913642883301
           }
         ],
        "trip_distance":20,
        "trip_time":100,
        "customer":"Вера",
        "passenger":"Вера",
        "sum":908,
        "total_sum":1000,
        "cash_sum":700,
        "cashless_sum":100,
        "bonus_sum":150,
        "bank_card_sum":50,
        "crew_id":6,
        "prior_crew_id":0,
        "driver_id":4,
        "car_id":6,
        "phone":"111111",
        "client_id":140,
        "tariff_id":1,
        "order_crew_group_id":1
        "email":"mail@mail.ru"
        "flight_number":"fln-122"

      },
      {
        "id":20669,
        "state_id":34,
        "source_time":"20130205130500",
        "start_time":"20130205130500",
        "finish_time":"20130205134511",
        "source":"1",
        "destination":"2",
        "customer":"Маша",
        "passenger":"Маша",
        "sum":454,
        "total_sum":500,
        "cash_sum":0,
        "cashless_sum":500,
        "bonus_sum":0,
        "bank_card_sum":0,
        "crew_id":6,
        "prior_crew_id":0,
        "driver_id":4,
        "car_id":6,
        "phone":"222222",
        "client_id":140,
        "tariff_id":2,
        "order_crew_group_id":2
        "creation_way":"operator"
        "client_employee_id":7
        "email":"mail@mail.ru"
        "flight_number":"fln-123"

      }
    ]
  }
}

38. Проведение операции по клиенту

Метод: POST

Название запроса: create_client_operation

Параметры:

ПараметрыТипОписание
Обязательные параметры
client_idЦелоеИД клиента
sumДробноеСумма
oper_typeЦелоеТип операции:

• "receipt" - приход

• "expense" - расход

Необязательные параметры
oper_timeГГГГММДДччммссВремя создания операции (если не указано, текущее)
commentСтрокаКомментарий
pay_typeЦелоеТип оплаты:

• "cash" - наличный

• "nocash" - безналичный

bonus_opertrue или falseОперация по бонусному счёту

Специальные возвращаемые коды:

КодОписание
100Не найден клиент ИД=CLIENT_ID

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
oper_idЦелоеИД операции

Пример:

Запрос:

POST https://ip:port/common_api/1.0/create_client_operation 
Signature: <...>
Content-Type: application/x-www-form-urlencoded
Content-Length: 99

client_id=112&oper_time=20130221100719&oper_sum=300&oper_type=receipt&pay_type=cash&comment=COMMENT&bonus_oper=true

Ответ:

{
  "code":0,
  "descr":"OK",
  "data":{
    "oper_id":31

  }
}

39. Запрос операций по клиенту

Метод: GET

Название запроса: get_client_operations

Параметры:

ПараметрыТипОписание
Обязательные параметры
client_idЦелоеИД клиента
start_timeГГГГММДДччммссНачало периода
finish_timeГГГГММДДччммссКонец периода

Специальные возвращаемые коды:

КодОписание
100Не найден клиент ИД=CLIENT_ID

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
oper_idЦелоеИД операции
oper_timeГГГГММДДччммссВремя создания операции
sumДробноеСумма
order_idЦелоеЗаказ, связанный с операцией
oper_typeЦелоеТип операции:

• "receipt" - приход

• "expense" - расход

pay_typeЦелоеТип оплаты:

• "cash" - наличный

• "nocash" - безналичный

nameСтрокаНаименование
commentСтрокаКомментарий
cancelled_by_oper_idЦелоеИД операции отмены (для отмененной операции)
cancelled_oper_idЦелоеИД отмененной операции (для операции отмены)

Пример:

Запрос:

GET 

GET https://ip:port/common_api/1.0/get_client_operations?
client_id=112&start_time=20130201092112&finish_time=20130221092112 

Signature: <...>

Ответ:

{
  "code":0,
  "descr":"OK",
  "data":{
    "operations":[
      {
        "oper_id":112,
        "oper_time":"20130219091328",
        "sum":"21,8",
        "order_id":11800,
        "oper_type":"receipt",
        "pay_type":"cash",
        "name":"Пополнение счета",
        "comment":"Комментарий"
        "cancelled_by_oper_id":0,
        "cancelled_oper_id":112
      },
      {
        "oper_id":112,
        "oper_time":"20130220112245",
        "sum":"4500",
        "order_id":11801,
        "oper_type":"receipt",
        "pay_type":"cash",
        "name":"Пополнение счета",
        "comment":"Комментарий"
        "cancelled_by_oper_id":111,
        "cancelled_oper_id":0
      }
    ]
  }
}

40. Проведение операции по водителю

Метод: POST

Название запроса: create_driver_operation

Параметры в формате JSON:

ПараметрТипОписание
Обязательные параметры
driver_idЦелоеИД водителя
oper_sumДробноеСумма
oper_typeСтрокаТип операции:

• receipt - приход

• expense - расход

Необязательные параметры
nameСтрокаНаименование операции
oper_timeГГГГММДДччммссВремя создания операции (если не задано, текущее)  !! Не используется с ТМ 3.7
commentСтрокаКомментарий
account_kindЦелоеИД типа счета (0 - основной счет), по умолчанию 0

Специальные возвращаемые коды:

КодОписание
100Водитель не найден ИД=DRIVER_ID

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
oper_idЦелоеИД операции


Пример:

Запрос:

POST https://ip:port/common_api/1.0/create_driver_operation 
Signature: <...>
Content-Type: application/json
Content-Length: 99

{
   "driver_id": 1,
   "oper_sum": 10.00,
   "oper_type": "receipt",
   "name": "Пополнение счета",
   "oper_time": "20141210100719",
   "comment": "Комментарий к операции"
    "account_kind": 1
}

Ответ:

{
   "code":0,
   "descr":"OK",
   "data":{
   "oper_id":31
   }
}

41. Запрос операций по водителю

Метод: GET

Название запроса: get_driver_operations

Параметры:

ПараметрТипОписание
Обязательные параметры
driver_idЦелоеИД водителя
start_timeГГГГММДДччммссНачало периода
finish_timeГГГГММДДччммссКонец периода
Необязательные параметры
account_kindЦелоеИД типа счета (0 - основной счет), по умолчанию 0


Специальные возвращаемые коды:

КодОписание
100Не найден водитель ИД=DRIVER_ID


Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
oper_idЦелоеИД операции
oper_timeГГГГММДДччммссВремя создания операции
sumДробноеСумма
order_idЦелоеЗаказ, связанный с операцией
oper_typeЦелоеТип операции:

•"receipt" - приход

•"expense" - расход

nameСтрокаНаименование
commentСтрокаКомментарий
account_kindЦелоеИД типа счета
cancelled_by_oper_idЦелоеИД операции отмены (для отмененной операции)
cancelled_oper_idЦелоеИД отмененной операции (для операции отмены)

Пример:

Запрос:

GET https://ip:port/common_api/1.0/get_driver_operations?
driver_id=112&start_time=20130201092112&finish_time=20130221092112 
Signature: <...>

Ответ:

{
  "code":0,
  "descr":"OK",
  "data":{
    "operations":[
      {
        "oper_id":111,
        "oper_time":"20130219091328",
        "sum":"21,8",
        "order_id":11800,
        "oper_type":"receipt",
        "name":"DRIVER_OPERATION_1",
        "comment":"DRIVER_OPERATION_COMMENT_1",
        "account_kind":0,
        "cancelled_by_oper_id":0,
        "cancelled_oper_id":112
      },
      {
        "oper_id":112,
        "oper_time":"20130220112245",
        "sum":"4500",
        "order_id":11801,
        "oper_type":"receipt",
        "name":"DRIVER_OPERATION_2",
        "comment":"DRIVER_OPERATION_COMMENT_2",
        "account_kind":0,
        "cancelled_by_oper_id":111,
        "cancelled_oper_id":0
      }
    ]
  }
}

42. Назначение динамического приоритета водителю

Метод: POST

Название запроса: create_driver_dyn_priority

Параметры в формате JSON:

ПараметрТипОписание
Обязательные параметры
driver_idЦелоеИД водителя (должно быть что-то одно: либо driver_id, либо crew_id)
crew_idЦелоеИД экипажа (должно быть что-то одно: либо driver_id, либо crew_id)
priorityЦелоеПриоритет
start_timeГГГГММДДччммссВремя начала действия приоритета
finish_timeГГГГММДДччммссВремя окончания действия приоритета
nameСтрокаНаименование приоритета

Специальные возвращаемые коды:

КодОписание
100Водитель не найден ИД=DRIVER_ID
101Экипаж не найден ИД=CREW_ID
102Время начала действия приоритета должно быть меньше времени окончания
103Время действия приоритета уже истекло

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
dyn_priority_idЦелоеИД созданного динамического приоритета

Пример:

Запрос:
POST https://ip:port/common_api/1.0/create_driver_dyn_priority 
Signature: <...>
Content-Type: application/json
Content-Length: <...>

{
   "driver_id": 1,
   "priority": 10,
   "start_time": "20150101100000",
   "finish_time": "20150101200000",
   "name": "За выполнение заказа в отдаленный район"
}

Ответ:

{
   "code":0,
   "descr":"OK",
   "data":{
   "dyn_priority_id":123
   }
}

43. Задание координат экипажей

Метод: POST

Название запроса: set_crews_coords

Параметры в формате JSON:

ПараметрТипОписание
Обязательные параметры
crew_coordsМассивМассив координат экипажей
• crew_idЦелоеИД экипажа
• gps_idЦелоеGPS идентификатор (если не задан ИД экипажа)
• latДробноеШирота
• lonДробноеДолгота
Необязательные параметры
speedДробноеСкорость


Специальные возвращаемые коды: нет

Возвращаемые данные в случае успешного выполнения запроса: нет


Пример:

Запрос:

POST https://ip:port/common_api/1.0/set_crews_coords 
Signature: <...>
Content-Type: application/json
Content-Length: 109

{"crews_coords":[{"crew_id":1,"lat":11.111111,"lon":22.222222},
{"gps_id":2,"lat":33.333333,"lon":44.444444}]}

Ответ:

{
  "code":0,
  "descr":"OK",
  "data":{}
}

44. Изменение информации по заказу

Метод: POST

Название запроса: update_order

Параметры в формате JSON:

ПараметрТипОписание
Обязательные параметры
order_idЦелоеИД заказа
Необязательные параметры
phoneСтрока, <= 30 символовНомер телефона
source_timeГГГГММДДччммссВремя подачи
is_priortrue или falseПредварительный заказ
customerСтрокаЗаказчик
passengerСтрокаПассажир
commentСтрокаКомментарий
crew_group_idЦелоеИД группы экипажей
client_idЦелоеИД клиента
tariff_idЦелоеИД тариф
addressesМассивМассив адресов. Первый элемент — адрес

подачи(обязательно), последний — адрес назначения, между ними — остановки.

• addressСтрокаАдрес подачи
• latДробноеШирота адреса
• lonДробноеДолгота адреса
order_paramsМассивМассив параметров заказа. Устарело. Рекомендуется использовать параметр attribute_values
ЦелоеИД параметра заказа
attribute_values Массив Массив значений атрибутов
• id Целое Идентификатор атрибута
• bool_value true или false Значение, если тип атрибута «Логический»
• num_value Дробное Значение, если тип атрибута:
- «Число» (непосредственное значение)
- «Число (выбор из списка)» (непосредственное значение выбранного элемента списка)
- «Перечисляемый» (значение выбранного элемента перечисления)
• str_value Строка Значение, если тип атрибута «Строка»
cost_orderДробноеСумма заказа
state_idЦелоеИД состояния заказа
discount_idЦелоеИД скидки
auto_select_discounttrue или falseАвтоматически подобрать скидку, если не указана явно
auto_select_tarifftrue или falseАвтоматически подобрать тариф, если не указан явно
auto_recalc_costtrue или falseАвтоматически пересчитать сумму заказа
auto_update_order_paramstrue или falseАвтоматически обновить параметры заказа по клиенту и группе клиента
emailСтрокаEmail для уведомлений
prior_to_current_before_minutesЦелоеВремя перехода из предварительного в текущие заказы, мин
flight_numberСтрокаНомер рейса
need_custom_validate true или false Использовать специальную проверку перед изменением заказа

Специальные возвращаемые коды:

КодОписание
100Заказ не найден
101Состояние заказа не найдено
102Тариф не найден
103Скидка не найдена
104Группа экипажа не найдена
105Служба не найдена
106Клиент не найден
107Изменение состояния не соответствует необходимым условиям
108Параметр заказа не найден
109Атрибут не может быть привязан к заказу
110 Ошибка специальной проверки заказа перед изменением. В ответе будет возвращаться:
  "data": {
    "message":"Текст ошибки для пользователя."
  }

Возвращаемые данные в случае успешного выполнения запроса: нет.

Пример:

POST https://ip:port/common_api/1.0/update_order 
Signature: <...>
Content-Type: application/json
Content-Length: 208

{
    "order_id": 12105,
    "phone": "555",
    "source_time": "20141216095044",
    "is_prior": true,
    "auto_select_discount": true,
    "auto_select_tariff": true,
    "auto_recalc_cost": true,
    "auto_update_order_params": true,
    "customer": "Заказчик",
    "passenger": "Пассажир",
    "comment": "Комментарий",
    "crew_group_id": 8,
    "client_id": 30,
    "tariff_id": 33,
    "addresses":[
       {"address":"SOURCE","lat":56.896817,"lon":53.147830},       
       {"address":"STOP1","lat":56.845452,"lon":53.226775},
       {"address":"STOP2"},
       {"address":"DESTINATION","lat":56.861230,"lon":53.241870}
    ],
    "cost_order": 200,
    "state_id": 55,
    "discount_id": 1,
    "email" : "mail@mail.ru",
    "prior_to_current_before_minutes":30,
    "flight_number":"Number",
    "need_custom_validate":false,
    "attribute_values": [
      {
            "id": 1,
            "bool_value": true
      },
      {
            "id": 2,
            "num_value": 1
      },
      {
            "id": 3,
            "num_value": 10
      },
      {
            "id": 4,
            "str_value": "строка"
      }
  ]
} Ответ: { "code":0, "descr":"OK", "data":{} }

45. Анализ телефона

Метод: GET

Название запроса: analyze_phone

Параметры:

ПараметрТипОписание
Обязательные параметры
phoneСтрокаНомер телефона
Необязательные параметры
search_in_drivers_mobiletrue или falseИскать среди телефонов водителей
search_in_clientstrue или falseИскать среди телефонов клиентов
search_in_phonestrue или falseИскать в справочнике телефонов


Если параметры search_in_drivers_mobile, search_in_clients, search_in_phones не заданы, то поиск телефона будет происходить во всех справочниках.

Специальные возвращаемые коды:

КодОписание
100Телефон не найден

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
phone_typeСтрокаМожет принимать значения: «driver_mobile», «client», «phone».
idЦелоеИД водителя, клиента, телефона из справочника.
client_employee_idЦелоеИД сотрудника клиента (если телефон найден среди телефонов клиента)


Пример:

Запрос:

GET /common_api/1.0/analyze_phone?
phone=89501234567&search_in_drivers_mobile=true&search_in_drivers_home=true&search_in_clients=true&
search_in_phones=true 

Host: 127.0.0.1:8089
Keep-Alive: 300
Connection: keep-alive
Signature: 4285286a446064353f4a951b721c54f7

Ответ:

{
  "code":0,
  "descr":"OK",
  "data":{
  "phone_type":"client",
  "id":1
  "client_employee_id":2
   }
}

46. Показать сообщение в ТМ

Метод: POST

Название запроса: show_tm_message

Параметры:

ПараметрТипОписание
Обязательные параметры
textСтрокаТекст сообщения
Необязательные параметры
headerСтрокаЗаголовок сообщения
timeoutЦелоеСкрывать сообщение через, сек. (0 — не скрывать)
usersМассивМассив пользователей (если не указаны — отправлять всем)
ЦелоеИД пользователя


Специальные возвращаемые коды:

КодОписание
100Пользователи для отправки сообщения не найдены


Возвращаемые данные в случае успешного выполнения запроса: нет.

Пример:

Запрос:
POST /common_api/1.0/show_tm_message 
Host: 127.0.0.1:8089
Keep-Alive: 300
Connection: keep-alive
Signature: 4285286a446064353f4a951b721c54f7

{
   "text": "Текст сообщения",
   "users": [
       1,
       2,
       3
   ],
   "header": "Заголовок",
   "timeout": 12
}


Ответ:

{
  "code":0,
  "descr":"OK",
  "data":{}
}

47. Запрос списка купленных смен водителей

Метод: GET

Название запроса: get_driver_shifts

Параметры:

ПараметрТипОписание
Обязательные параметры
start_timeГГГГММДДччммссНачало периода
finish_timeГГГГММДДччммссКонец периода
Необязательные параметры
driver_idЦелоеИД водителя
new_shiftstrue или falseВключить в ответ новые смены (по умолчанию true)
in_work_shiftstrue или falseВключить в ответ смены в работе (по умолчанию true)
finished_shiftstrue или falseВключить в ответ выполненные смены (по умолчанию true)
failed_shiftstrue или falseВключить в ответ неуспешно завершенные смены (по умолчанию true)
returned_shiftstrue или falseВключить в ответ возвращенные смены (по умолчанию false)

Специальные возвращаемые коды: нет

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
shiftsМассивМассив купленных смен
• shift_idЦелоеИД купленной смены
• driver_idЦелоеИД водителя
• driver_nameСтрокаФИО водителя
• plan_shift_idСтрокаИД запланированной смены
• plan_shift_nameСтрокаНаименование запланированной смены
• plan_shift_costДробноеЦена смены
• plan_shift_typeСтрокаТип смены («limited» - срочная, «unlimited» - бессрочная)
• plan_shift_start_timeГГГГММДДччммссПлан-начало смены (для срочных)
• plan_shift_finish_timeГГГГММДДччммссПлан-конец смены (для срочных)
• plan_shift_lengthЦелоеПлан продолжительность смены, ч. (для бессрочных)
• plan_shift_crew_group_idЦелоеИД первой группы экипажей, которая может купить смену
• plan_shift_crew_groupsМассивИД групп экипажей, которые могут купить смену
• shift_stateСтрокаСостояние смены («new» - новая, «in_work» - в работе, «finished» - завершена успешно, «failed» - завершена неуспешно)
• buy_timeГГГГММДДччммссВремя продажи смены водителю
• is_returnedtrue или falseПризнак возвращенной смены
• return_timeГГГГММДДччммссВремя возврата смены
• orders_countЦелоеКоличество заказов, выполненных водителем за смену
• orders_sumДробноеСумма заказов, выполненных водителем за смену
• fact_lengthДробноеФактическая продолжительность смены, ч.

Пример:

Запрос:

GET https://ip:port/common_api/1.0/get_driver_shifts?start_time=20140101101010&finish_time=20140101202020 
Signature: <...>


Ответ:

{
  "code":0,
  "descr":"OK",
  "data":{
    "shifts":[
      {
        "shift_id":1,
        "driver_id":1,
        "driver_name":"DRIVER_1",
        "plan_shift_id":1,
        "plan_shift_name":"PLAN_SHIFT_1",
        "plan_shift_cost":100,
        "plan_shift_type":"limited",
        "plan_shift_start_time":"20140101101010",
        "plan_shift_finish_time":"20140101101010",
        "plan_shift_length":null,
        "plan_shift_crew_group_id":1,
        "shift_state":new,
        "buy_time":"20140101101010",
        "is_returned":false,
        "return_time":null,
        "orders_count":10,
        "orders_sum":1000,
        "fact_length":1.2
      },
      {
        "shift_id":2,
        "driver_id":2,
        "driver_name":"DRIVER_2",
        "plan_shift_id":2,
        "plan_shift_name":"PLAN_SHIFT_2",
        "plan_shift_cost":200,
        "plan_shift_type":"unlimited",
        "plan_shift_start_time":null,
        "plan_shift_finish_time":null,
        "plan_shift_length":8,
        "plan_shift_crew_group_id":null,
        "shift_state":new,
        "buy_time":"20140101101010",
        "is_returned":true,
        "return_time":"20140101101010",
        "orders_count":0,
        "orders_sum":0,
        "fact_length":0
      }
    ]
  }
}

48. Запрос списка запланированных смен водителей

Метод: GET

Название запроса: get_driver_plan_shifts

Параметры:

ПараметрТипОписание
Обязательные параметры
start_timeГГГГММДДччммссНачало периода (если включаем в ответ срочные смены)
finish_timeГГГГММДДччммссКонец периода (если включаем в ответ срочные смены)
Необязательные параметры
limited_shiftstrue или falseВключить в ответ срочные смены (по умолчанию true)
unlimited_shiftstrue или falseВключить в ответ бессрочные смены (по умолчанию true)

Специальные возвращаемые коды: нет

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
plan_shiftsМассивМассив запланированных смен
• plan_shift_idЦелоеИД запланированной смены
• plan_shift_nameСтрокаНаименование запланированной смены
• plan_shift_commentСтрокаКомментарий запланированной смены
• plan_shift_costДробноеЦена смены
• plan_shift_typeСтрокаТип смены («limited» - срочная, «unlimited» - бессрочная)
• plan_shift_start_timeГГГГММДДччммссПлан-начало смены (для срочных)
• plan_shift_finish_timeГГГГММДДччммссПлан-конец смены (для срочных)
• plan_shift_lengthЦелоеПлан продолжительность смены, ч. (для бессрочных)
• plan_shift_crew_group_idЦелоеИД первой группы экипажей, которая может купить смену
• plan_shift_crew_groupsМассивИД групп экипажей, которые могут купить смену
• max_sell_countЦелоеМаксимальное количество продаж смены
• sold_countЦелоеКоличество продаж смены

Пример:

Запрос:

GET https://ip:port/common_api/1.0/get_driver_plan_shifts?start_time=20140101101010&finish_time=20140101202020 
Signature: <...>


Ответ:

{
  "code":0,
  "descr":"OK",
  "data":{
    "plan_shifts":[
      {
        "plan_shift_id":1,
        "plan_shift_name":"PLAN_SHIFT_1",
        "plan_shift_comment":"PLAN_SHIFT_COMMENT_1",
        "plan_shift_cost":100,
        "plan_shift_type":"limited",
        "plan_shift_start_time":"20140101101010",
        "plan_shift_finish_time":"20140101101010",
        "plan_shift_length":null,
        "plan_shift_crew_group_id":1,
        "max_sell_count":100,
        "sold_count":10
      },
      {
        "plan_shift_id":2,
        "plan_shift_name":"PLAN_SHIFT_2",
        "plan_shift_comment":"PLAN_SHIFT_COMMENT_2",
        "plan_shift_cost":200,
        "plan_shift_type":"unlimited",
        "plan_shift_start_time":null,
        "plan_shift_finish_time":null,
        "plan_shift_length":8,
        "plan_shift_crew_group_id":2,
        "max_sell_count":200,
        "sold_count":20
      }
    ]
  }
}

49. Продажа смены водителю

Метод: POST

Название запроса: driver_buy_shift

Параметры:

ПараметрТипОписание
Обязательные параметры
crew_idЦелоеИД экипажа
plan_shift_idЦелоеИД запланированной смены

Специальные возвращаемые коды:

КодОписание
100Запланированная смена не найдена
101Экипаж не найден
102Водитель не найден
103Недостаточно денег на счете водителя
104Водитель уволен либо заблокирован
105Запланированная смена устарела
106Не подходит группа экипажа
107Превышено максимальное число покупок смены
108Повторная покупка смены
109Экипажу не назначен атрибут для доступа к смене


Возвращаемые данные в случае успешного выполнения запроса: нет.

Пример:

Запрос:

POST https://ip:port/common_api/1.0/driver_buy_shift 
Signature: <...>
Content-Type: application/x-www-form-urlencoded
Content-Length: 25
crew_id=1&plan_shift_id=1


Ответ:

{
  "code":0,
  "descr":"OK",
  "data":{}
}

50. Сохранение отзыва клиента

Метод: POST

Название запроса: save_client_feed_back

Параметры в формате JSON:

ПараметрТипОписание
Обязательные параметры
phoneСтрокаТелефон
ratingЦелоеРейтинг (от 1 до 5)
textСтрокаТекстовый отзыв
Необязательные параметры
order_idЦелоеИД заказа

Допускается указывать либо параметр rating либо text, либо оба параметра.

Специальные возвращаемые коды: нет.

Возвращаемые данные в случае успешного выполнения запроса: нет.

Пример:

Запрос:
POST /common_api/1.0/save_client_feed_back 
Host: 127.0.0.1:8090
Keep-Alive: 300
Connection: keep-alive
Content-Type: application/json
Content-Length: 72
Signature: <...>

{
  "phone":"89123456789",
  "rating":4,
  "text":"test feedback",
  "order_id":100
}
Ответ:
{
  "code":0,
  "descr":"OK",
  "data":{}
}

51. Поиск экипажей по координатам

Метод: GET

Название запроса: find_crews_by_coords

Параметры:

ПараметрТипОписание
Обязательные параметры
latДробноеШирота точки центра поиска
lonДробноеДолгота точки центра поиска
radiusДробноеРадиус поиска, км или мили
Необязательные параметры
crews_without_coordstrue или falseИскать экипажи без реальных координат по координатам стоянок
crews_release_inЦелоеДопустимое время до освобождения в зоне поиска, если надо возвращать занятые экипажи (если 0, то искать только свободные экипажи), мин
crew_group_idЦелоеИД группы экипажей, заказы из которой должны видеть подходящие экипажи
attributesСтрокаСписок ИД атрибутов заказа, которыми должны обладать подходящие экипажи (через точку с запятой, пример: «1;2;3»). Устарело. Рекомендуется использовать параметр attribute_values
attribute_values Массив Массив значений атрибутов
• id Целое Идентификатор атрибута
• bool_value true или false Значение, если тип атрибута «Логический»
• num_value Дробное Значение, если тип атрибута:
- «Число» (непосредственное значение)
- «Число (выбор из списка)» (непосредственное значение выбранного элемента списка)
- «Перечисляемый» (значение выбранного элемента перечисления)
• str_value Строка Значение, если тип атрибута «Строка»

Специальные возвращаемые коды: нет

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
waiting_countЦелоеКоличество свободных экипажей в зоне поиска
on_order_countЦелоеКоличество занятых экипажей, освобождающихся в зоне поиска

Пример:

Запрос:
GET https://ip:port/common_api/1.0/find_crews_by_coords?
lat=11.111111&lon=22.222222&radius=2&crews_release_in=5 
Signature: <...>
Ответ:
{
  "code":0,
  "descr":"OK",
  "data":{
  "waiting_count":5,
  "on_order_count":2
  }
}

52. Подбор тарифа для заказа

Метод: POST

Название запроса: select_tariff_for_order

Параметры в формате JSON:

ПараметрТипОписание
Необязательные параметры
client_idЦелоеИД клиента
crew_group_idЦелоеИД группы экипажей
source_timeГГГГММДДччммссВремя подачи
is_prizetrue или falseПризовой заказ
addressesМассивМассив координат адресов. Первый элемент — адрес подачи,

последний — адрес назначения, между ними — остановки. Заполняется если определены координаты всех адресов.

• lonДробноеДолгота адреса
• latДробноеШирота адреса

Специальные возвращаемые коды:

КодОписание
100Клиент не найден

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
tariff_idЦелоеТариф

Пример:

Запрос:
POST https://ip:port/common_api/1.0/select_tariff_for_order 
Signature: <...>
Content-Type: application/json
Content-Length: <...>
{
  "client_id":1,
  "crew_group_id":2,
  "source_time":"20160101100000",
  "is_prize":true
 "addresses": [
      {
            "lat": 11.111111,
            "lon": 22.222222
      },
      {
            "lat": 33.333333,
            "lon": 44.444444
 }
}
Ответ:
{
  "code":0,
  "descr":"OK",
  "data":{
  "tariff_id":2
 }
}

53. Импорт марок автомобилей в БД

Метод: POST

Название запроса: import_car_marks

Параметры в формате JSON:

ПараметрТипОписание
Обязательные параметры
marksМассив строкИмпортируемые марки автомобилей

Специальные возвращаемые коды: нет

Возвращаемые данные в случае успешного выполнения запроса: нет

Пример:

Запрос: 

POST https://ip:port/common_api/1.0/import_car_marks 
Signature: <...> 
Content-Type: application/json 
Content-Length: <...> 
{
  "marks": [
    "Mercedes",
    "BMW"
  ]
 } 

Ответ:

 {
  "code":0,
  "descr":"OK",
  "data":{}
 }

54. Импорт цветов автомобилей в БД

Метод: POST

Название запроса: import_car_colors

Параметры в формате JSON:

ПараметрТипОписание
Обязательные параметры
colorsМассив строкИмпортируемые цвета автомобилей

Специальные возвращаемые коды: нет

Возвращаемые данные в случае успешного выполнения запроса: нет

Пример:

Запрос: 

POST https://ip:port/common_api/1.0/import_car_colors 
Signature: <...> 
Content-Type: application/json 
Content-Length: <...>

 {
  "colors": [
    "красный",
    "синий"
  ]
 }

 Ответ:

 {
  "code":0,
  "descr":"OK",
  "data":{}
 }

55. Запрос информации по сотруднику клиента

Метод: GET

Название запроса: get_client_employee_info

Параметры:

ПараметрТипОписание
Обязательные параметры
client_employee_idЦелоеИД сотрудника клиента

Специальные возвращаемые коды:

КодОписание
100Не найден сотрудник клиента ИД=CLIENT_EMPLOYEE_ID

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
client_employee_idЦелоеИД сотрудника
client_idЦелоеИД клиента
nameСтрокаФИО сотрудника
is_deletedtrue или falseПризнак удаленного сотрудника
emailСтрокаE-mail
use_email_informingtrue или falseИспользовать E-mail для отправки уведомлений по заказу
default_crew_groupЦелоеГруппа экипажей по умолчанию
phonesМассивМассив телефонов сотрудника клиента
• phoneСтрокаНомер телефона сотрудника

Пример:

Запрос:

GET https://ip:port/common_api/1.0/get_client_employee_info?client_employee_id=10 
Signature: <...> 

Ответ:

 {
  "code":0,
  "descr":"OK",
  "data":{
     "client_employee_id":5,
    "client_id":1,
    "name":"Иванов Иван",
    "is_deleted":false,
    "email":"mail@mail.ru",
    "use_email_informing":true,
    "default_crew_group":1,
    "phones":[
      {
        "phone":"88"
      },
      {
        "phone":"99"
      }
    ]
  }
 }

56. Создание сотрудника клиента

Метод: POST

Название запроса: create_client_employee

Параметры в формате JSON:

ПараметрТипОписание
Обязательные параметры
client_idЦелоеИД клиента
nameСтрокаФИО сотрудника
Необязательные параметры
emailСтрокаE-mail
use_email_informingtrue или falseИспользовать E-mail для отправки уведомлений по заказу
phonesМассивМассив телефонов сотрудника
• phoneСтрокаНомер телефона

Специальные возвращаемые коды:

КодОписание
100Клиент с ИД=CLIENT_ID не найден
101Клиент с ИД=ID имеет такой же номер телефона=PHONE

Возвращаемые данные в случае успешного выполнения запроса: нет.

Пример:

Запрос: 

POST https://ip:port/common_api/1.0/create_client_employee 
Signature: <...> 
Content-Type: application/json 
Content-Length: 104

{
  "client_id":10
  "name":"Иванов Иван",
  "email":"mail@mail.ru",
  "use_email_informing":true,
  "phones":[
    {
      "phone":"79999999999",
    },
    {
      "phone":"79999999999",
    }
  ]
 }

 Ответ:
 {
  "code":0,
  "descr":"OK",
  "data":{}
 }

57. Обновление информации о сотруднике клиента

Метод: POST

Название запроса: update_client_employee_info

Параметры в формате JSON:

ПараметрТипОписание
Обязательные параметры
client_employee_idЦелоеИД редактируемого сотрудника клиента
Необязательные параметры
nameСтрокаФИО сотрудника
is_deletedtrue или falseПризнак удаленного сотрудника
emailСтрокаE-mail
use_email_informingtrue или falseИспользовать E-mail для отправки уведомлений по заказу
phonesМассивМассив телефонов сотрудника
• phoneСтрокаНомер телефона

Примечание: запрещено редактировать телефоны удаленного сотрудника.


Специальные возвращаемые коды:

КодОписание
100Сотрудник с ИД=CLIENT_EMPLOYEE_ID не найден
101Клиент с ИД=ID имеет такой же номер телефона=PHONE
102Запрещено редактирование телефонов удаленного сотрудника

Возвращаемые данные в случае успешного выполнения запроса: нет.

Пример:

Запрос: 

POST https://ip:port/common_api/1.0/update_client_employee_info 
Signature: <...> 
Content-Type: application/json
Content-Length: 104

{
  "client_employee_id":10
  "name":"Иванов Иван",
  "is_deleted":false,
  "email":"mail@mail.ru",
  "use_email_informing":true,
  "phones":[
    {
      "phone":"79999999999",
    },
    {
      "phone":"79999999999",
    }
  ]
 } 

Ответ:
 {
  "code":0,
  "descr":"OK",
  "data":{}
 }

58. Запрос списка состояний заказа

Метод: GET

Название запроса: get_order_states_list

Параметры: нет

Специальные возвращаемые коды: нет

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
order_paramsМассивСписок параметров заказа
• idЦелоеИД параметра
• nameСтрокаНазвание параметра
• state_typeСтрокаТип состояния. Может принимать значения:

• "accepted" — заказ принят

• "in_work" — заказ в работе

• "finished" — заказ выполнен

• "aborted" — заказ прекращен

Пример:

Запрос:


GET https://ip:port/common_api/1.0/get_order_states_list 

Signature: <...>

Ответ:


{
 "code":0,
 "descr":"OK",
 "data":{
 "order_params":[
     {
      "id":1,
      "name":"Принят",
      "state_type":"accepted"
     },
     {
      "id":2,
      "name":"В работе",
      "state_type":"in_work"
      },
     ...
                ]
        }
}

59. Запрос списка состояний экипажа

Метод: GET

Название запроса: get_crew_states_list

Параметры: нет

Специальные возвращаемые коды: нет

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
order_paramsМассивСписок параметров заказа
• idЦелоеИД параметра
• nameСтрокаНазвание параметра
• state_typeСтрокаТип состояния. Может принимать значения:

• "waiting" — экипаж свободен

• "not_available" — экипаж не на линии

• "on_order" — экипаж на заказе

• "on_break" — экипаж на перерыве

Пример:

Запрос:
GET https://ip:port/common_api/1.0/get_crew_states_list 
Signature: <...>

Ответ:
{
 "code":0,
 "descr":"OK",
 "data":{
 "order_params":[
         {
          "id":1,
          "name":"Свободен",
          "state_type":"waiting"
         },
         {
          "id":2,
          "name":"Не работает",
          "state_type":"not_available"
         },
         ...
               ]
        }
}


60. Запрос информации по клиентам

Метод: GET

Название запроса: get_clients_info

Параметры:

ПараметрТипОписание
Необязательные параметры
textСтрокаТекст для поиска по названию или по номеру договора клиента
max_clients_countЦелоеМаксимальное количество клиентов, которое надо вернуть. Если не указано, то 10.

Специальные возвращаемые коды: Нет

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
client_idЦелоеИД клиента
nameСтрокаНаименование
numberСтрокаНомер договора

Пример:

Запрос:
GET https://ip:port/common_api/1.0/get_clients_info?text=test&max_clients_count=10 
Signature: <...>

Ответ:

{
  "code":0,
  "descr":"OK",
  "data":{
    "clients_info":[
      {
        "client_id":390,
        "name":"tester1",
        "number":"001"
      },
      {
        "client_id":394,
        "name":"tester2",
        "number":"002"
      }
    ]
  }
}

61. Запрос информации о заявке спец. техники

Метод: GET

Название запроса: get_order_bundle_info

Параметры:

Параметр Тип Описание
Обязательные параметры
order_bundle_id Целое ИД заявки спец. техники

Специальные возвращаемые коды:

Код Описание
100 Заявка спец. техники не найдена

Возвращаемые данные в случае успешного выполнения запроса:

Параметр Тип Описание
order_bundle_id Целое ИД заявки спец. техники
start_time ГГГГММДДччммсс Время начала
addresses Массив Массив адресов заявки
• address Строка Адрес подачи
• lat Дробное Широта
• lon Дробное Долгота
client_id Целое ИД клиента
phone Строка Телефон
orders Массив Массив заказов заявки спец. техники
• order_id Целое ИД заказа
duration Целое Длительность заявки спец. техники, в часах

Пример:

Запрос:
GET https://ip:port/common_api/1.0/get_order_bundle_info?order_bundle_id=1 HTTP/1.1
Signature: <...>

Ответ:

{
  "code":0,
  "descr":"OK",
  "data": {
    "order_bundle_id":1,
    "start_time":"20190101100000",
    "addresses": [
      {
        "address":"АДРЕС",
        "lat":11.111111,
        "lon":22.222222
      }
    ],
    "client_id":1,
    "phone":"123",
    "orders": [
      {
        "order_id":111
      },
      {
        "order_id":222
      }
    ],
    "duration":1
  }
}

62. Удаление заявки спец. техники

Метод: POST

Название запроса: delete_order_bundle

Параметры:

Параметр Тип Описание
Обязательные параметры
order_bundle_id Целое ИД заявки спец. техники

Специальные возвращаемые коды:

Код Описание
100 Заявка спец. техники не найдена

Возвращаемые данные в случае успешного выполнения запроса: нет.

Пример:

Запрос:
POST https://ip:port/common_api/1.0/delete_order_bundle HTTP/1.1
Signature: <...>
Content-Type: application/x-www-form-urlencoded
Content-Length: <...>

order_bundle_id=1

Ответ:

{
  "code":0,
  "descr":"OK",
  "data":{}
}

63. Запрос глобальных атрибутов

Метод: GET

Название запроса: get_global_attributes

Параметры: нет.

Специальные возвращаемые коды: нет.

Возвращаемые данные в случае успешного выполнения запроса:

Параметр Тип Описание
global_attributes Массив Массив значений глобальных атрибутов
• id Целое Идентификатор атрибута
• bool_value true или false Значение, если тип атрибута «Логический»
• num_value Дробное Значение, если тип атрибута:
- «Число» (непосредственное значение)
- «Число (выбор из списка)» (непосредственное значение выбранного элемента списка)
- «Перечисляемый» (значение выбранного элемента перечисления)
• str_value Строка Значение, если тип атрибута «Строка»

Пример:

Запрос:
GET https://ip:port/common_api/1.0/get_global_attributes

Ответ:

{
  "code":0,
  "descr":"OK",
  "data":{
    "global_attributes":[
      {
        "id":123,
        "bool_value":true
      },
      {
        "id":124,
        "num_value":314
      },
      {
        "id":125,
        "str_value": "AAA"
      }
    ]
  }
}


Описание протокола 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 

Для получения данных из БД используются запросы типа GET. Для записи данных в БД используются запросы типа POST. В запросе типа GET параметры запроса передаются в URI.

Пример:

GET https://ip:port/tm_tapi/1.0/get_info_by_phone?phone=89058800565&fields=PHONE_TYPE-PHONE_
TO_DIAL&signature=661ce071eeefcb4f7fc8bc1f17bd520b 

В запросе типа POST параметры передаются в теле запроса в формате application/x-www-form- urlencoded.

Пример:

POST https://ip:port/tm_tapi/1.0/change_order_state 
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 

Секретный ключ:
321

Signature = MD5("phone=89058800565&fields=PHONE_TYPE" + "321") = ef17ea682d09e452af544a5758dba396

Формат ответа

TM API всегда возвращает HTTP код 200 ОК. Результат выполнения запроса содержится в теле ответа в формате XML. Общий вид возвращаемого результата:

<response>
<code>Числовой код результата</code>
<descr>Строковое описание результата</descr>
<data>Дополнительная информация</data>
</response>

Существуют общие для всех запросов коды результатов:

КодОписание
0Успешное выполнение запроса
1Неизвестная ошибка
2Неизвестный тип API
3API отключено в настройках модуля TM API в ТМ
4Не совпадает секретный ключ
5Неподдерживаемая версия API
6Неизвестное название запроса
7Неверный тип запроса GET
8Не хватает входного параметра (в доп. информации ответа будет название отсутствующего параметра)
9Некорректный входной параметр (в доп. информации ответа будет название некорректного параметра)
10Внутренняя ошибка обработки запроса

Описание запросов

1. Запрос информации по номеру телефона

Метод: GET

Название запроса: get_info_by_phone

Параметры:

ПараметрТипОписание
Обязательные параметры
PHONEСтрока, <= 16 символовНомер телефона
FIELDSСтрокаСписок полей, которые необходимо вернуть. Поля перечисляются через символ "-"
signatureСтрокаПоле для проверки секретного ключа.

Специальные возвращаемые коды: нет

Возвращаемые данные в случае успешного выполнения запроса: зависит от того какие поля были переданы в поле fields.

ПараметрТипОписание
PHONE_TYPEЦелоеТип телефона звонящего:

1 - если звонит водитель с основного телефона;

2 - если звонит физическое лицо;

3 - если звонит юридическое лицо;

4 - если звонит номер из справочника Телефоны;

5 - если звонит водитель с неосновного телефона;

6 - если звонит ЦОЗ водитель;

0 - неизвестный номер.

PHONE_TO_DIALСтрока, <= 16 символовНомер телефона для отзвона по заказу
CREW_IDЦелоеИД экипажа
IS_PRIOR0 или 1 (false или true)Признак предварительного заказа
IS_PRIZE0 или 1 (false или true)Признак призового заказа
ORDER_CLIENT_IDЦелоеИД клиента из заказа
DRIVER_PHONEСтрока, <= 16 символовНомер телефона водителя
CREW_SYSTEMSTATEЦелоеСостояние экипажа
CLIENT_IDЦелоеИД клиента
CLIENT_TYPEЦелоеТип клиента
CATEGORYIDЦелоеИД категории телефона
PHONE_SYSTEM_CATEGORYЦелоеСистемное значение категории телефона (0 - обычный, 1 - черный, 2 - белый, 3 - серый)
ORDER_IDЦелоеИД заказа
DRIVER_IDЦелоеИД водителя
ORDER_STATEЦелоеСостояние заказа
DRIVER_REMAINDERДробноеБаланс счета водителя
DISCOUNTEDSUMMСтрокаСумма заказа с учетом всех скидок
CREW_GROUP_IDЦелоеИД группы экипажа (если в заказе указан экипаж, то берется ИД группы экипажа, если нет — из карты заказа)
FIRST_CREW_GROUP_IDЦелоеИД первой группы экипажа
CLIENT_BALANCEДробноеБаланс клиента
DRIVER_TIMECOUNTЦелоеВремя пути водителя до адреса подачи в минутах
SOURCE_TIMECOUNTЦелоеВремя оставшееся до подачи в минутах
SOUND_COLORСтрокаЗапись с информацией о цвете
SOUND_MARKСтрокаЗапись с информацией о марке автомобиля
GOSNUMBERСтрокаГосударственный номер автомобиля
CAR_COLORСтрокаЦвет автомобиля
CAR_MARKСтрокаМарка автомобиля
ORDER_COORDSСтрокаКоординаты места подачи. Порядок координат: долгота адреса, широта адреса.
CREW_COORDSСтрокаКоординаты назначенного экипажа. Порядок координат: долгота адреса, широта адреса.
MARKET_TYPEЦелоеТип биржи заказов (2 — Яндекс, 3 — ЦОЗ).
ORDERS_COUNTЦелоеДля телефона клиента — количество текущих и предварительных заказов по телефону; для телефона водителя — количество текущих заказов, на которые назначен данный водитель
CLIENT_GROUP_IDЦелоеИД группы клиента
CLIENT_BONUS_BALANCEДробноеБонусный баланс клиента
AD_LIGHTHOUSEСтрокаПризнак наличия шашек. Пустая строка – номер клиента или водителя без экипажа. 1 – есть шашки, 0 – нет шашек.
CREW_STATEЦелоеСостояние экипажа.
SOURCE_TIMEГГГГММДДччммссДата и время подачи
DRV_SHIFT_START_TIMEГГГГММДДччммссНачало фактической смены водителя
START_USER_SIP_ACCOUNTSСтрокаСписок логинов SIP–аккаунтов пользователя, принявшего заказ
CREATION_WAYСтрокаСпособ создания заказа (operator, sms, market, common_api, t_api, taxophone, driver, daily_order, taxophone_web, unknown)
CREATOR_TAXI_PHONEСтрокаТелефон службы-создателя для заказов, принятых из ЦОЗ
PERFORMER_TAXI_PHONEСтрокаТелефон службы-исполнителя для заказов, отданных в ЦОЗ
CLIENT_IS_LOCKED0 или 1 (false или true)Признак блокировки клиента

Пример:

Запрос:
GET https://ip:port/tm_tapi/1.0/get_info_by_phone?phone=89058800565l&fields=PHONE_TYPE-PHONE_
TO_DIAL-CREW_ID-ORDER_ID&signature=d35ab2765f2968d48c096d5f5327db26 

Ответ:

<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>
    <SOURCE_TIME>20140929134911</SOURCE_TIME>
    <DRV_SHIFT_START_TIME>20141007105050</DRV_SHIFT_START_TIME>
  </data>
</response>

2. Запрос информации по ИД заказа

Метод: GET

Название запроса: get_info_by_order_id

Параметры:

ПараметрТипОписание
Обязательные параметры
ORDER_IDЦелоеИД заказа
FIELDSСтрокаСписок полей, которые необходимо вернуть. Поля перечисляются через символ "-"
signatureСтрокаПоле для проверки секретного ключа

Специальные возвращаемые коды: нет

Возвращаемые данные в случае успешного выполнения запроса: зависит от того какие поля были переданы в поле fields.

ПараметрТипОписание
DRIVER_TIMECOUNTСтрока, <= 16 символовВремя до подачи в минутах, указанное водителем
SOUND_COLORСтрокаЗапись с информацией о цвете
CAR_MARKСтрокаМарка автомобиля
CAR_COLORСтрокаЦвет автомобиля
GOSNUMBERСтрокаГосударственный номер автомобиля
SOUND_MARKСтрокаЗапись с информацией о марке автомобиля
CREW_GROUP_IDЦелоеИД группы экипажа (значение из карты заказа)
FIRST_CREW_GROUP_IDЦелоеИД первой группы экипажа
IS_PRIOR0 или 1 (false или true)Признак предварительного заказа
IS_PRIZE0 или 1 (false или true)Признак призового заказа
DISCOUNTEDSUMMСтрокаСумма заказа с учетом всех скидок
DRIVER_PHONEСтрока, <= 16 символовНомер телефона водителя
CATEGORYIDЦелоеИД категории телефона
SOURCE_TIMECOUNTЦелоеВремя до подачи в минутах
ORDER_COORDSСтрокаКоординаты места подачи. Порядок координат: долгота адреса, широта адреса.
CREW_COORDSСтрокаКоординаты назначенного экипажа. Порядок координат: долгота адреса, широта адреса.
ORDER_STATEЦелоеИД состояния заказа
MARKET_TYPEЦелоеТип биржи заказов (2 — Яндекс, 3 — ЦОЗ).
AD_LIGHTHOUSEСтрокаПризнак наличия шашек (1 – шашки есть, 0 – шашек нет).
CREW_STATEЦелоеСостояние экипажа
SOURCE_TIMEГГГГММДДччммссДата и время подачи
START_USER_SIP_ACCOUNTSСтрокаСписок логинов SIP–аккаунтов пользователя, принявшего заказ
ORDER_PARAMSЦелоеСписок ИД параметров заказа
CREATION_WAYСтрокаСпособ создания заказа (operator, sms, market, common_api, t_api, taxophone, driver, daily_order, taxophone_web, unknown)
CREATOR_TAXI_PHONEСтрокаТелефон службы-создателя для заказов, принятых из ЦОЗ
PERFORMER_TAXI_PHONEСтрокаТелефон службы-исполнителя для заказов, отданных в ЦОЗ

Пример:

Запрос:

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


Ответ:

<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>20140929134911</SOURCE_TIME>
  </data>
</response>

3. Смена состояния заказа

Метод: POST

Название запроса: change_order_state

Параметры:

ПараметрТипОписание
Обязательные параметры
ORDER_IDЦелоеИД заказа
NEED_STATEЦелоеНовое состояние заказа
signatureСтрокаПоле для проверки секретного ключа

Специальные возвращаемые коды:

КодОписание
100Заказ с таким ИД не найден
101Изменение состояния не соответствует необходимым условиям

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТип Описание
ORDER_ID Целое
ИД заказа
NEED_STATEЦелоеНовое состояние заказа

Пример:

Запрос:

POST https://ip:port/tm_tapi/1.0/change_order_state 
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>

4. Запись пути к файлу разговора в базу данных

Метод: POST

Название запроса: create_record_link

Параметры:

ПараметрТипОписание
Обязательные параметры
RECORD_DATEДДММГГГГччммссДата записи
RECORD_LENGTHЦелоеПродолжительность записи (в секундах)
CALL_IDСтрока, <= 60 символовИД звонка (необязателен, если указан PHONE)
PHONEСтрока, <= 16 символовНомер телефона (необязателен, если указан CALL_ID)
FILE_PATHСтрока, <=255 символовПуть к файлу записи
CALL_TYPE0 или 10 — Исходящий, 1 — Входящий
signatureСтрокаПоле для проверки секретного ключа

Специальные возвращаемые коды: нет.

Возвращаемые данные в случае успешного выполнения запроса

ПараметрТипОписание
RECORD_IDЦелоеИД созданной записи

Пример:

Запрос:

POST https://ip:port/tm_tapi/1.0/create_record_link 
Content-Type: application/x-www-form-urlencoded
Content-Length: 185

RECORD_DATE=20130122180949&RECORD_LENGTH=215&CALL_ID=12345&PHONE=8987564&FILE_PATH=d%3A%5Ctemp%5CTM
%5Ctrunk%5CSource%5CDevUtils%5CTMAPITest%5C&CALL_TYPE=1&signature=56851c4e8d2d4bb9ba615615f76ad7f7

Ответ:
<response>
  <code>0</code>
  <descr>OK</descr>
  <data>
    <RECORD_ID>25</RECORD_ID>
  </data>
</response>

5. Создать новый заказ

Метод: POST

Название запроса: make_new_order

Параметры:

ПараметрТипОписание
Обязательные параметры
PHONEСтрока, <= 16 символовНомер телефона
ORDER_STATE_IDЦелоеИД состояния заказа
signatureСтрокаПоле для проверки секретного ключа
Необязательные параметры
CREWGROUPIDЦелоеИД группы экипажа
TARIF_IDЦелоеИД тарифа
DISCOUNTEDSUMMДробноеФиксированная сумма за заказ
CUSTOMERСтрока, <=80 символовЗаказчик
SOURCEСтрока, <=80 символовАдрес подачи
SOURCE_STREETЦелоеИД улицы подачи
SOURCE_HOUSEСтрока, <=10 символовДом подачи
SOURCE_FLATСтрока, <=10 символовКвартира подачи
SOURCE_POINTЦелоеИД пункта подачи
DESTINATIONСтрока, <=80 символовАдрес назначения
DESTINATION_STREETЦелоеИД улицы назначения
DESTINATION_HOUSEСтрока, <=10 символовДом назначения
DESTINATION_FLATСтрока, <=10 символовКвартира назначения
DESTINATION_POINTЦелоеИД пункта назначения
CREWIDЦелоеИД экипажа
SUMMДробноеСтоимость заказа без учета скидок (наценок)
STARTUSERЦелоеПользователь, создавший заказ
STARTTIMEГГГГММДДччммссДата создания заказа
FINISHUSERЦелоеПользователь, завершивший заказ
FINISHTIMEГГГГММДДччммссДата завершения заказа
SOURCE_ZONEЦелоеРайон подачи
DESTINATION_ZONEЦелоеРайон назначения
SOURCE_PARKINGЦелоеСтоянка подачи
DESTINATION_PARKINGЦелоеСтоянка назначения
SOURCE_TIMEГГГГММДДччммссДата подачи
SOURCE_COUNTRY0 или 1 (false или true)Признак междугороднего заказа
IS_PRIOR0 или 1 (false или true)Признак предварительного заказа
PRIZE0 или 1 (false или true)Признак призового заказа
NOTEСтрока, <=80 символовПримечание
BONUSPOINTДробноеБонусные баллы, начисленные водителю за заказ
DISTANCEДробноеКилометраж по городу (в километрах)
HOURLY_LENЦелоеДлительность исполнения почасового заказа (в минутах)
HOURLY_STARTГГГГММДДччммссДата начала отсчета при почасовом заказе
HOURLY_PAY0 или 1 (false или true)Признак почасового заказа
PHONE_TO_DIALСтрока, <=16 символовНомер телефона для отзвона по заказу
FROMBORDER0 или 1 (false или true)Признак заказа "с бордюра"
WAITING_STARTГГГГММДДччммссДата начала ожидания заказчика водителем
WAITING_LENGTHЦелоеОбщая длина периода ожидания заказчика водителем (в минутах)
BACKFREEЦелоеПризнак применения скидки в 50% на обратный путь
INPUTTIMEГГГГММДДччммссДата принятия заказа (от даты создания заказа отличается тем, что может быть задана пользователем)
MONEY_RECEIVE0 или 1 (false или true)Подтверждение принятия денег наличными
NOTIFY_BEFOREЦелоеПериод времени, за который пользователь оповещается о наступлении даты подачи
WANTCREWIDЦелоеИД желаемого экипажа
DISTANCE_COUNTRYДробноеКилометраж за границами города (в километрах)
DISTANCE_CHECK0 или 1 (false или true)Разрешение ручного ввода километража
CLIENTIDЦелоеИД постоянного клиента
INFRA_STATEЦелоеСостояние заявки в исходящей компании колцентра INFRA (1 - заявка передана в исходящую компанию, 2 - отзвон успешно произведен, 3 - занято, 4 - не берут трубку)
INFRA_ORDERЦелоеINFRA-заказ (спец. поле для работы с колцентром компании Инфрател)

Специальные возвращаемые коды: нет

Возвращаемые данные в случае успешного выполнения запроса

ПараметрТипОписание
ORDER_IDЦелоеИД созданного заказа

Пример:

Запрос:

POST https://ip:port/tm_tapi/1.0/make_new_order 
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>

6. Поиск улицы в базе

Метод: POST

Название запроса: street_search

Параметры:

ПараметрТипОписание
Обязательные параметры
PHONEСтрока, <= 16 символовНомер телефона
CALL_IDЦелоеИД звонка
VOICE_STREETСтрока, <= 60 символовНазвание улицы или пункта, полученное через преобразование голоса в текст
signatureСтрокаПоле для проверки секретного ключа

Специальные возвращаемые коды: нет

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
CALL_IDЦелоеИД звонка
PHONEСтрока, <= 16 символовНомер телефона
STREET_FOUND0 или 1 (false или true)Признак того, что улица найдена
STREET_NAMEСтрока, <= 60 символовНаименование улицы или пункта, найденное в базе данных


Пример:

Запрос:
POST https://ip:port/tm_tapi/1.0/street_search 
Content-Type: application/x-www-form-urlencoded
Content-Length: 175

PHONE=89058770593&CALL_ID=56&VOICE_STREET=пушкинск&FIND_STREET=0&API_FIND_STREET=&NUM_HOUSE=&signat
ure=9204a53e0f4842bb623c3a5f7683520a

Ответ:

<response>
  <code>0</code>
  <descr>OK</descr>
  <data>
    <CALL_ID>56</CALL_ID>
    <PHONE>89058770593</PHONE>
    <FIND_STREET>1</FIND_STREET>
    <API_FIND_STREET>Пушкинская</API_FIND_STREET>
  </data>
</response>

7. Смена состояния заказа по результату автодозвона

Метод: POST

Название запроса: set_request_state

Параметры:

ПараметрТипОписание
Обязательные параметры
STATE_IDЦелоеCостояние заказа до отзвона
PHONE_TYPE0 или 1Признак, что звонили клиенту (если 0 - водителю)
ORDER_IDЦелоеИД заказа
STATEЦелое (0, 1, 2, 3, 4, 5)Состояние отзвона (0 – начальное, 1 — в процессе, 2 — успешно, 3 — занято, 4 — нет ответа, 5 — ошибка)
signatureСтрокаПоле для проверки секретного ключа

Специальные возвращаемые коды: нет

Возвращаемые данные в случае успешного выполнения запроса: нет

Настройки смены состояний заказа с использованием автодозвона задаются в карточке состояний заказа.

Пример:

Запрос:
POST https://ip:port/tm_tapi/1.0/set_request_state 
Content-Type: application/x-www-form-urlencoded
Content-Length: 71

state_id=7&phone_type=1&order_id=50&state=4&signature=0eb50db401d3540e038fde68eb260333

Ответ:

<response>
   <code>0</code>
   <descr>OK</descr>
</response>

8. Соединить клиента и водителя

Метод: POST

Название запроса: connect_client_and_driver

Параметры:

ПараметрТипОписание
Обязательные параметры
order_idЦелоеИД заказа
signatureСтрокаПоле для проверки секретного ключа

Специальные возвращаемые коды:

КодОписание
100Не найден заказ с таким ИД
103В заказе нет водителя
104У водителя не определен телефон

Возвращаемые данные в случае успешного выполнения запроса: нет

Пример:

Запрос:

POST https://ip:port/tm_tapi/1.0/connect_client_and_driver 
Content-Type: application/x-www-form-urlencoded
Content-Length: 53

order_id=13&signature=6a4b16da44a495b67eb7af11d51954d4

Ответ:

<response>
   <code>0</code>
   <descr>OK</descr>
</response>

9. Количество свободных экипажей на линии

Метод: GET

Название запроса: get_free_crews_count

Параметры:

ПараметрТипОписание
Обязательные параметры
signatureСтрокаПоле для проверки секретного ключа
Необязательные параметры
crew_group_idЦелоеИД группы экипажа предполагаемого заказа

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
COUNTЦелоеКоличество свободных экипажей на линии

Пример:

Запрос:
GET https://ip:port/tm_tapi/1.0/get_free_crews_count?
crew_group_id=1&uds_id=1&signature=88ca2091061c3e90123275f2c5df55a6 
Content-Type: application/x-www-form-urlencoded
Ответ:
<response>
<code>0</code>
<descr>OK</descr>
<data>
<COUNT>5</COUNT>
</data>
</response>

10. Запрос пользователя по логину софтфона

Метод: GET

Название запроса: get_user_by_sip_login

Параметры:

ПараметрТипОписание
Обязательные параметры
signatureСтрокаПоле для проверки секретного ключа
loginСтрокаЛогин SIP-аккаунта

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
IDЦелоеИД пользователя, который использует указанный логин SIP-аккаунта софтфона в данный момент
NAMEСтрокаИмя пользователя, который использует указанный логин SIP-аккаунта софтфона в данный момент

Пример:

Запрос:
GET https://ip:port/tm_tapi/1.0/get_user_by_sip_login?
login=LOGIN&signature=9b06455cdfe933e7af12a35a70e9b1c6 
Content-Type: application/x-www-form-urlencoded
Ответ:
<response>
<code>0</code>
<descr>OK</descr>
<data>
<ID>1</ID>
<NAME>ADMINISTRATOR</NAME>
</data>
</response>

11. Установить режим «Перерыв» для линий софтфона

Метод: POST

Название запроса: set_sip_account_dnd_mode

Параметры:

ПараметрТипОписание
Обязательные параметры
dndСтрока0 или 1
user_loginСтрокаЛогин пользователя ТМ
linesСтрокаСписок линий, разделенных символом «|»
signatureСтрокаПоле для проверки секретного ключа

Специальные возвращаемые коды:

КодОписание
100Пользователь с таким логином или линиями не найден.

Возвращаемые данные в случае успешного выполнения запроса: нет

Пример:

Запрос:

POST https://ip:port/tm_tapi/1.0/set_sip_account_dnd_mode 
Content-Type: application/x-www-form-urlencoded
Content-Length: 66

dnd=1&user_login=USER&lines=101%7C102&signature=3e8107e0c044e55d983db1fbed82fd8c

Ответ:

<response>
  <code>0</code>
  <descr>OK</descr>
</response>

12. Запрос телефонов водителя по позывному экипажа

Метод: GET

Название запроса: get_driver_phones_by_crew_code

Параметры:

ПараметрТипОписание
Обязательные параметры
crew_codeСтрокаПозывной экипажа


Специальные возвращаемые коды:

КодОписание
100Водитель не найден

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
mobile_phoneСтрокаОсновной телефон водителя
home_phoneСтрокаНеосновной телефон водителя

Пример:

Запрос:

GET https://ip:port/tm_tapi/1.0/get_driver_phones_by_crew_code?
crew_code=CODE&signature=6f03bc45d3aa17f7738672180a3ee5de 
Content-Type: application/x-www-form-urlencoded

Ответ:

<response>
<code>0</code>
<descr>OK</descr>
<data>
<mobile_phone>123456789</mobile_phone>
<home_phone>987654321</home_phone>
</data>
</response>

13. Запрос информации о ключе защиты

Метод: GET

Название запроса: get_key_info

Параметры: нет.

Специальные возвращаемые коды: нет.

Возвращаемые данные в случае успешного выполнения запроса:

ПараметрТипОписание
company_nameСтрокаНаименование организации
company_idЦелоеИД организации
tm_server_license_countЦелоеКоличество лицензий для TMServer
tm_license_countЦелоеКоличество лицензий для TM2
tm_terminal_license_countЦелоеКоличество лицензий для терминала
tm_driver_server_license_countЦелоеКоличество лицензий для TMDriverServer
tm_driver_license_countЦелоеКоличество лицензий для водителей
tm_sms_server_license_countЦелоеКоличество лицензий для TMSMSServer

Пример:

Запрос:
GET https://ip:port/tm_tapi/1.0/get_key_info 
Content-Type: application/x-www-form-urlencoded

signature=6f03bc45d3aa17f7738672180a3ee5de

Ответ:

<response>
<code>0</code>
<descr>OK</descr>
<data>
company_name>ООО БИТ-Мастер</company_name>
<company_id>000</company_id>
<tm_server_license_count>1</tm_server_license_count>
<tm_license_count>10</tm_license_count>
<tm_terminal_license_count>1</tm_terminal_license_count>
<tm_driver_server_license_count>1</tm_driver_server_license_count>
<tm_driver_license_count>30</tm_driver_license_count>
<tm_sms_server_license_count>1</tm_sms_server_license_count>
</data>
</response>

Все настройки в разделе "Настройки и руководство"