Обновить статус «доставлено» imconnector.send.status.delivery
Scope:
imopenlinesКто может выполнять метод: любой пользователь
Метод imconnector.send.status.delivery подтверждает в Битрикс24, что исходящее сообщение открытой линии успешно доставлено во внешнюю систему. Метод не отправляет сообщение повторно, а только фиксирует результат доставки.
В текущей реализации открытых линий при обработке статуса «доставлено» сообщение также помечается как «прочитано».
Метод не применяется для входящих сообщений из внешней системы в открытую линию.
Метод работает только в контексте приложения.
Параметры метода
Обязательные параметры отмечены *
|
Название |
Описание |
|
CONNECTOR* |
Строковый код коннектора, который задали в параметре |
|
LINE* |
Идентификатор открытой линии. Идентификатор можно получить методами imopenlines.config.get и imopenlines.config.list.get |
|
MESSAGES* |
Массив статусов доставки. Каждый элемент массива — объект с блоками Структура объекта подробно описана ниже |
Параметр MESSAGES
|
Название |
Описание |
|
im |
Внутренние идентификаторы сообщения в Битрикс24 (подробное описание) |
|
message |
Данные сообщения во внешней системе (подробное описание) |
|
chat |
Данные чата во внешней системе (подробное описание) |
Объект im
|
Название |
Описание |
|
chat_id |
Идентификатор чата открытой линии в Битрикс24 для исходящего сообщения |
|
message_id |
Идентификатор сообщения в Битрикс24, для которого нужно установить статус доставки |
Поля im.chat_id и im.message_id получайте из события OnImConnectorMessageAdd, когда Битрикс24 отправляет сообщение во внешнюю систему.
Обычно эти значения сохраняют при обработке события и потом используют для отправки статуса доставки.
Внешние идентификаторы message.id и chat.id не заменяют im.message_id и im.chat_id.
Объект message
|
Название |
Описание |
|
id |
Массив внешних идентификаторов сообщений, для которых передается статус доставки. Даже для одного сообщения передавайте массив, например, |
|
date |
Время доставки сообщения в Unix Timestamp в секундах |
Объект chat
|
Название |
Описание |
|
id |
Идентификатор чата или канала во внешней системе. Рекомендуется передавать то же значение, что и в |
Примеры кода
Как использовать примеры в документации
curl -X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{
"CONNECTOR": "myconnector",
"LINE": 107,
"MESSAGES": [
{
"im": {
"chat_id": 323,
"message_id": 85911
},
"message": {
"id": ["ext-msg-1007"],
"date": 1738065600
},
"chat": {
"id": "channel-123"
}
}
],
"auth": "**put_access_token_here**"
}' \
https://**put_your_bitrix24_address**/rest/imconnector.send.status.delivery
const payload = {
CONNECTOR: 'myconnector',
LINE: 107,
MESSAGES: [
{
im: { chat_id: 323, message_id: 85911 },
message: { id: ['ext-msg-1007'], date: 1738065600 },
chat: { id: 'channel-123' },
},
],
};
const response = await $b24.callMethod('imconnector.send.status.delivery', payload);
console.log(response.getData());
$result = $b24Service->core->call(
'imconnector.send.status.delivery',
[
'CONNECTOR' => 'myconnector',
'LINE' => 107,
'MESSAGES' => [
[
'im' => ['chat_id' => 323, 'message_id' => 85911],
'message' => ['id' => ['ext-msg-1007'], 'date' => 1738065600],
'chat' => ['id' => 'channel-123'],
],
],
]
);
BX24.callMethod(
'imconnector.send.status.delivery',
{
CONNECTOR: 'myconnector',
LINE: 107,
MESSAGES: [
{
im: { chat_id: 323, message_id: 85911 },
message: { id: ['ext-msg-1007'], date: 1738065600 },
chat: { id: 'channel-123' },
},
],
},
function(result) {
console.log(result.data());
}
);
$result = CRest::call(
'imconnector.send.status.delivery',
[
'CONNECTOR' => 'myconnector',
'LINE' => 107,
'MESSAGES' => [
[
'im' => ['chat_id' => 323, 'message_id' => 85911],
'message' => ['id' => ['ext-msg-1007'], 'date' => 1738065600],
'chat' => ['id' => 'channel-123'],
],
],
]
);
Обработка ответа
HTTP-статус: 200
{
"result": {
"SUCCESS": true,
"DATA": []
},
"time": {
"start": 1738065600.11,
"finish": 1738065600.21,
"duration": 0.10,
"processing": 0.04,
"date_start": "2025-01-28T12:00:00+00:00",
"date_finish": "2025-01-28T12:00:00+00:00"
}
}
Возвращаемые данные
|
Название |
Описание |
|
SUCCESS |
Возвращает |
|
DATA |
Пустой массив при успешной обработке |
|
time |
Информация о времени выполнения запроса |
Обработка ошибок
HTTP-статус: 400, 403
{
"error": "WRONG_AUTH_TYPE",
"error_description": "Current authorization type is denied for this method Application context required"
}
|
Название |
Описание |
|
error |
Строковый код ошибки. Может состоять из цифр, латинских букв и знака подчеркивания |
|
error_description |
Текстовое описание ошибки. Описание не предназначено для показа конечному пользователю в необработанном виде |
Возможные коды ошибок
|
Статус |
Код |
Описание |
Значение |
|
|
|
Current authorization type is denied for this method Application context required |
Метод вызван не в контексте приложения OAuth |
|
|
|
Argument 'CONNECTOR' is null or empty |
Не передан |
|
|
|
Argument 'LINE' is null or empty |
Не передан |
|
|
|
Argument 'MESSAGES' is null or empty |
Не передан |
|
|
|
Не удалось найти подходящий провайдер для коннектора |
Для коннектора не удалось инициализировать провайдер |
Статусы и коды системных ошибок
HTTP-статус: 20x, 40x, 50x
Описанные ниже ошибки могут возникнуть при вызове любого метода
|
Статус |
Код |
Описание |
|
|
|
Возникла внутренняя ошибка сервера, обратитесь к администратору сервера или в техническую поддержку Битрикс24 |
|
|
|
Возникла внутренняя ошибка сервера, обратитесь к администратору сервера или в техническую поддержку Битрикс24 |
|
|
|
Превышен лимит на интенсивность запросов |
|
|
|
Текущий метод не разрешен для вызова с помощью batch |
|
|
|
Превышена максимальная длина параметров, переданных в метод batch |
|
|
|
Неверный access-токен или код вебхука |
|
|
|
Для вызовов методов требуется использовать протокол HTTPS |
|
|
|
REST API заблокирован из-за перегрузки. Это ручная индивидуальная блокировка, для снятия необходимо обращаться в техническую поддержку Битрикс24 |
|
|
|
REST API доступен только на коммерческих планах |
|
|
|
У пользователя, с чьим access-токеном или вебхуком был вызван метод, не хватает прав |
|
|
|
Манифест недоступен |
|
|
|
Запрос требует более высоких привилегий, чем предоставляет токен вебхука |
|
|
|
Предоставленный access-токен доступа истек |
|
|
|
Пользователь не имеет доступа к приложению. Это означает, что приложение установлено, но администратор портала разрешил доступ к этому приложению только конкретным пользователям |
|
|
|
Публичная часть сайта закрыта. Чтобы открыть публичную часть сайта на коробочной установке отключите опцию «Временное закрытие публичной части сайта». Путь к настройке: Рабочий стол > Настройки > Настройки продукта > Настройки модулей > Главный модуль > Временное закрытие публичной части сайта |
Продолжите изучение
- Зарегистрировать коннектор imconnector.register
- Активировать коннектор imconnector.activate
- Получить статус коннектора imconnector.status
- Установить настройки коннектора imconnector.connector.data.set
- Получить список коннекторов imconnector.list
- Отменить регистрацию коннектора imconnector.unregister
- Отправить сообщения в Битрикс24 imconnector.send.messages
- Изменить отправленные сообщения imconnector.update.messages
- Удалить отправленные сообщения imconnector.delete.messages
- Установить новое имя чата imconnector.chat.name.set
- Как создать коннектор открытых линий для чата на сайте