Подключения

Общее

Подключение/connection - сущность, содержащая параметры для соединения с внешним сервисом (telegram/whatsapp/tinkoff/amocrm и т.п.)

Методы для управления подключениями описаны здесь: https://api.radist.online/v2/docs#/Connections

Замечания

  • Через API нельзя удалить подключения. Для удаления необходимо обратиться в поддержку. Имейте в виду, что при удалении также удаляются связанные сущности. Например, при удалении терминала банка, будут удалены все выставленные счета. При удалении мессенджера, будут удалены все чаты и история переписки.

  • Редактирование параметров доступно не для всех типов подключений. Например, подключения AMOCRM/BITRIX управляются полностью на нашей стороне.

Примеры

Подключение Telegram

Авторизация и первое подключение

Сначала необходимо запросить код для авторизации в Telegram. Для этого необходимо отправить запрос, указав номер телефона : https://api.radist.online/v2/docs#/Telegram/TelegramSendCodeRequest

Пример ответа
{
  "session_id": "string",
  "phone_code_hash": "string"
}

❗Сохраните полученные в ответ session_id & phone_code_hash.

После получения кода от пользователя необходимо создать подключение: https://api.radist.online/v2/docs#/Connections/ConnectionsCreateItem

Пример запроса
{
  "name": "ЛЮБОЕ НАЗВАНИЕ",
  "type": "telegram",
  "params": {
    "phone": "+79000000000", // телефон клиента
    "phone_code_hash": "значение с предыдущего шага",
    "session_id": "значение с предыдущего шага",
    "code": 12345, // код, который пришёл в SMS или в приложении
}

При получении ответа с кодом ошибки 17003 (необходима двухфакторная авторизация) необходимо запросить у пользователя пароль и снова отправить запрос на создание подключения, но добавив в параметры поле password.

Повторная авторизация

В некоторых случаях может быть необходимо повторить авторизацию. Например, если в приложении Telegram принудительно завершили сессию, которую открыл наш сервис.

Необходимо запросить код, передав в параметрах id подключения: https://api.radist.online/v2/docs#/Telegram/TelegramSendCodeRequest

В ответ так же придут session_id и phone_code_hash.

Затем необходимо отправить запрос на авторизацию: https://api.radist.online/v2/docs#/Telegram/TelegramSendLoginRequest

{
  "connection_id": 12345,
  "code": 123456, // код, пришедший в SMS или в приложении
  "phone_code_hash": "string" // значение с предыдущего шага
}

Если на номере включена двухфакторная авторизация, то в ответ будет получена ошибка с кодом 17003 (необходима двухфакторная авторизация). Нужно будет повторить запрос, добавив пароль в поле password:

{
  "connection_id": 12345,
  "code": 123456, // код, пришедший в SMS или в приложении
  "phone_code_hash": "string", // значение с предыдущего шага
  "password": "string" // пароль от 2FA
}

Подключение WhatsApp

Авторизация и первое подключение

Необходимо создать подключение с типом whatsapp: https://api.radist.online/v2/docs#/Connections/ConnectionsCreateItem

Пример запроса
{
  "name": "some name",
  "type": "whatsapp"
}
Пример ответа
{
  "id": 6271,
  "name": "some name",
  "radist_token": "a091b49b-055b-4e62-a913-19544b829c64",
  "last_status": {
    "status_type": "bad",
    "status_subtype": "whatsapp_qr_not_scanned"
  },
  "integrations": null,
  "subscription_id": 616,
  "type": "whatsapp",
  "params": {
    "phone": null,
    "qr_url": "https://services.radist.online/whatsapp/qr/Vw9WE5XjWyK3"
  }
}

После этого необходимо отобразить пользователю QR-код, чтобы он отсканировал его в мобильном приложении WhatsApp. Сделать это можно двумя способами:

  1. Отдать пользователю ссылку из params->qr_url

  2. Также код можно получить этим методом: https://api.radist.online/v2/docs#/Connections/ConnectionsGetWhatsappInstanceStatus

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

{
  "status": "qr",
  "qr_code": ""
}

Повторная авторизация

Для переподключения достаточно запросить новый QR-код и отсканировать его.

Подключение группы Одноклассников

Первое подключение

Необходимо создать подключение с типом odnoklassniki, передав API ключ от группы: https://api.radist.online/v2/docs#/Connections/ConnectionsCreateItem

Пример запроса
{
  "name": "ok demo",
  "type": "odnoklassniki",
  "params": {
    "ok_api_key": "tkn1YMi1UuraOrb5DpqmD9TYEFAabPg3mlaRHK4hfusrud5oVIee0LlAxNJ7jJA33FQR1:CLEQNMJGDIHBABABA"
  }
}
Пример ответа
{
  "id": 6272,
  "name": "ok demo",
  "radist_token": "73def00f-22fa-4541-a5c1-a15eb347a959",
  "last_status": {
    "status_type": "good",
    "status_subtype": "normal"
  },
  "integrations": null,
  "subscription_id": 617,
  "type": "odnoklassniki",
  "params": {
    "group_id": "group:59129296584917"
  }
}

Изменение API-ключа

Необходимость изменить API-ключ может возникнуть по разным причинам:

  • В настройках группы сбросили ключ

  • Ключ давно не использовался и стал неактивен

Для его обновления можно использовать метод: https://api.radist.online/v2/docs#/Connections/ConnectionsUpdateItem

Last updated