Подключения
Общее
Swagger: https://api.radist.online/v2/docs#/Connections
Необходимые права доступа (scopes
) для работы с API: connections
Подключение/connection - сущность, содержащая параметры для соединения с внешним сервисом (telegram/whatsapp/tinkoff/amocrm и т.п.)
Замечания
Через API нельзя удалить подключения. Для удаления необходимо обратиться в поддержку. Имейте в виду, что при удалении также удаляются связанные сущности. Например, при удалении терминала банка, будут удалены все выставленные счета. При удалении мессенджера, будут удалены все чаты и история переписки.
Редактирование параметров доступно не для всех типов подключений. Например, подключения AMOCRM/BITRIX управляются полностью на нашей стороне.
Примеры
Подключение Telegram
Подключение происходит в несколько шагов:
Создание сессии для авторизации
Авторизация
Ввод пароля двухфакторной авторизации (если есть)
Создание подключения
Подключение через сканирование QR-кода
Создаём сессию авторизации https://api.radist.online/v2/docs#/Telegram/TelegramInitializeSession
POST /telegram/init
{"auth_type": "qr"}
Response:
{
"session_id": "fc9132a1-3992-4b57-a9d3-102e17438ae7",
"status": "waiting_for_qr",
"qr_login": {
"url": "tg://login?token=AQLZrYtmQM3kCsDhxpI8zLlKnBvHu8_4sX7d8AaRCI6PGA",
"expires": "2024-07-08T09:14:01Z",
"qr_code": ""
}
}
Отображаем пользователю QR-код для сканирования
Периодически (например, раз в 5 секунд) опрашиваем статус сессии: https://api.radist.online/v2/docs#/Telegram/TelegramSendLoginRequest
POST /telegram/login
{
"session_id": "fc9132a1-3992-4b57-a9d3-102e17438ae7",
"code": null,
"password": null
}
Если в ответ снова получили сессию со
status=waiting_for_qr
и qr-код изменился, показываем новый код пользователю.Если в ответ получили сессию со
status=waiting_for_password
, то показываем пользователю поле ввода пароля для 2FA. Этого шага может не быть, если 2FA отключена.
POST /telegram/login
{
"session_id": "fc9132a1-3992-4b57-a9d3-102e17438ae7",
"code": null,
"password": "radist"
}
Response:
{
"session_id": "fc9132a1-3992-4b57-a9d3-102e17438ae7",
"status": "authenticated",
"qr_login": null
}
После того, как получили сессию со
status=authenticated
, можно создавать подключение: https://api.radist.online/v2/docs#/Connections/ConnectionsCreateConnection
POST /connections/
{
"name": "demo",
"type": "telegram",
"params": {
"session_id": "fc9132a1-3992-4b57-a9d3-102e17438ae7"
}
}
Response:
{
"id": 12345,
"name": "demo",
"radist_token": "4bdb7858-cd5e-4d61-b544-c56b3382ab9b",
"last_status": {
"status_type": "good",
"status_subtype": "normal"
},
"integrations": [],
"subscription_id": 12,
"type": "telegram",
"params": {
"user_id": "12345678",
"username": null,
"phone": "+79001234567",
"group_chats_enabled": false
}
}
Подключение через код в чате Telegram
Создаём сессию авторизации https://api.radist.online/v2/docs#/Telegram/TelegramInitializeSession
POST /telegram/init
{
"auth_type": "code",
"phone": "+79001234567"
}
Response:
{
"session_id": "08661526-6318-4694-bbcd-c9634616ade4",
"status": "waiting_for_code"
}
Показываем пользователю поле для ввода кода
Когда получили код, авторизуемся: https://api.radist.online/v2/docs#/Telegram/TelegramSendLoginRequest
POST /telegram/login
{
"session_id": "08661526-6318-4694-bbcd-c9634616ade4",
"code": 44472
}
Если в ответ получили сессию со
status=waiting_for_password
, то показываем пользователю поле ввода пароля для 2FA. Этого шага может не быть, если 2FA отключена.
POST /telegram/login
{
"session_id": "08661526-6318-4694-bbcd-c9634616ade4",
"code": 44472,
"password": "radist"
}
Response:
{
"session_id": "08661526-6318-4694-bbcd-c9634616ade4",
"status": "authenticated"
}
После того, как получили сессию со
status=authenticated
, можно создавать подключение: https://api.radist.online/v2/docs#/Connections/ConnectionsCreateConnection
POST /connections/
{
"name": "demo",
"type": "telegram",
"params": {
"session_id": "08661526-6318-4694-bbcd-c9634616ade4"
}
}
Response:
{
"id": 12345,
"name": "demo",
"radist_token": "4bdb7858-cd5e-4d61-b544-c56b3382ab9b",
"last_status": {
"status_type": "good",
"status_subtype": "normal"
},
"integrations": [],
"subscription_id": 12,
"type": "telegram",
"params": {
"user_id": "12345678",
"username": null,
"phone": "+79001234567",
"group_chats_enabled": false
}
}
Повторная авторизация
В некоторых случаях может быть необходимо повторить авторизацию. Например, если в приложении Telegram принудительно завершили сессию, которую открыл наш сервис.
Это делается аналогично тому, как происходит первое подключение (см. примеры выше), только при создании сессии для авторизации нужно обязательно передать connection_id
и после успешной авторизации не нужно создавать новое подключение.
POST /telegram/init
{
"auth_type": "qr",
"connection_id": 44378
}
Response:
{
"session_id": "9bc32742-94d5-4ff1-98c8-0239c3ae43f0",
"status": "waiting_for_qr",
"qr_login": {
"url": "tg://login?token=AQJ1s4tmLweHr81U7_dHuP2F71vbNCREIR9mHZb48bABOQ",
"expires": "2024-07-08T09:37:57Z",
"qr_code": ""
}
}
Подключение Telegram Bot
Подключение
Необходимо создать подключение с типом telegram_bot
, передав API ключ от группы: https://api.radist.online/v2/docs#/Connections/ConnectionsCreateItem
{
"name": "demo",
"params": {
"bot_token": "1738456161:AAERS_R5S2cly6u4DkWY0oeTq4zWWu54lxw"
},
"type": "telegram_bot"
}
{
"id": 12345,
"name": "demo",
"radist_token": "12bbecfc-5701-4d60-ba61-d6bf2a346870",
"last_status": null,
"integrations": [],
"subscription_id": 618,
"type": "telegram_bot",
"params": {
"bot_id": "1738456161",
"bot_username": "demo_bot"
}
}
Подключение 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. Сделать это можно двумя способами:
Отдать пользователю ссылку из
params->qr_url
Также код можно получить этим методом: 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