Обновить статус «доставлено» imconnector.send.status.delivery

Scope: imopenlines

Кто может выполнять метод: любой пользователь

Метод imconnector.send.status.delivery подтверждает в Битрикс24, что исходящее сообщение открытой линии успешно доставлено во внешнюю систему. Метод не отправляет сообщение повторно, а только фиксирует результат доставки.

В текущей реализации открытых линий при обработке статуса «доставлено» сообщение также помечается как «прочитано».

Метод не применяется для входящих сообщений из внешней системы в открытую линию.

Метод работает только в контексте приложения.

Параметры метода

Обязательные параметры отмечены *

Название
тип

Описание

CONNECTOR*
string

Строковый код коннектора, который задали в параметре ID при вызове imconnector.register

LINE*
integer

Идентификатор открытой линии.

Идентификатор можно получить методами imopenlines.config.get и imopenlines.config.list.get

MESSAGES*
array

Массив статусов доставки. Каждый элемент массива — объект с блоками im, message, chat.

Структура объекта подробно описана ниже

Параметр MESSAGES

Название
тип

Описание

im
object

Внутренние идентификаторы сообщения в Битрикс24 (подробное описание)

message
object

Данные сообщения во внешней системе (подробное описание)

chat
object

Данные чата во внешней системе (подробное описание)

Объект im

Название
тип

Описание

chat_id
integer

Идентификатор чата открытой линии в Битрикс24 для исходящего сообщения

message_id
integer

Идентификатор сообщения в Битрикс24, для которого нужно установить статус доставки

Поля im.chat_id и im.message_id получайте из события OnImConnectorMessageAdd, когда Битрикс24 отправляет сообщение во внешнюю систему.

Обычно эти значения сохраняют при обработке события и потом используют для отправки статуса доставки.

Внешние идентификаторы message.id и chat.id не заменяют im.message_id и im.chat_id.

Объект message

Название
тип

Описание

id
array

Массив внешних идентификаторов сообщений, для которых передается статус доставки. Даже для одного сообщения передавайте массив, например, ["ext-msg-1007"]

date
integer

Время доставки сообщения в Unix Timestamp в секундах

Объект chat

Название
тип

Описание

id
string

Идентификатор чата или канала во внешней системе. Рекомендуется передавать то же значение, что и в chat.id метода imconnector.send.messages

Примеры кода

Как использовать примеры в документации

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
boolean

Возвращает true, если статус доставки успешно принят и обновлен в Битрикс24

DATA
array

Пустой массив при успешной обработке

time
time

Информация о времени выполнения запроса

Обработка ошибок

HTTP-статус: 400, 403

{
            "error": "WRONG_AUTH_TYPE",
            "error_description": "Current authorization type is denied for this method Application context required"
        }
        

Название
тип

Описание

error
string

Строковый код ошибки. Может состоять из цифр, латинских букв и знака подчеркивания

error_description
error_description

Текстовое описание ошибки. Описание не предназначено для показа конечному пользователю в необработанном виде

Возможные коды ошибок

Статус

Код

Описание

Значение

403

WRONG_AUTH_TYPE

Current authorization type is denied for this method Application context required

Метод вызван не в контексте приложения OAuth

400

ERROR_ARGUMENT

Argument 'CONNECTOR' is null or empty

Не передан CONNECTOR

400

ERROR_ARGUMENT

Argument 'LINE' is null or empty

Не передан LINE

400

ERROR_ARGUMENT

Argument 'MESSAGES' is null or empty

Не передан MESSAGES

400

IMCONNECTOR_NO_CORRECT_PROVIDER

Не удалось найти подходящий провайдер для коннектора

Для коннектора не удалось инициализировать провайдер

Статусы и коды системных ошибок

HTTP-статус: 20x, 40x, 50x

Описанные ниже ошибки могут возникнуть при вызове любого метода

Статус

Код
Текст ошибки

Описание

500

INTERNAL_SERVER_ERROR
Internal server error

Возникла внутренняя ошибка сервера, обратитесь к администратору сервера или в техническую поддержку Битрикс24

500

ERROR_UNEXPECTED_ANSWER
Server returned an unexpected response

Возникла внутренняя ошибка сервера, обратитесь к администратору сервера или в техническую поддержку Битрикс24

503

QUERY_LIMIT_EXCEEDED
Too many requests

Превышен лимит на интенсивность запросов

405

ERROR_BATCH_METHOD_NOT_ALLOWED
Method is not allowed for batch usage

Текущий метод не разрешен для вызова с помощью batch

400

ERROR_BATCH_LENGTH_EXCEEDED
Max batch length exceeded

Превышена максимальная длина параметров, переданных в метод batch

401

NO_AUTH_FOUND
Wrong authorization data

Неверный access-токен или код вебхука

400

INVALID_REQUEST
Https required

Для вызовов методов требуется использовать протокол HTTPS

503

OVERLOAD_LIMIT
REST API is blocked due to overload

REST API заблокирован из-за перегрузки. Это ручная индивидуальная блокировка, для снятия необходимо обращаться в техническую поддержку Битрикс24

403

ACCESS_DENIED
REST API is available only on commercial plans

REST API доступен только на коммерческих планах

403

INVALID_CREDENTIALS
Invalid request credentials

У пользователя, с чьим access-токеном или вебхуком был вызван метод, не хватает прав

404

ERROR_MANIFEST_IS_NOT_AVAILABLE
Manifest is not available

Манифест недоступен

403

insufficient_scope
The request requires higher privileges than provided by the webhook token

Запрос требует более высоких привилегий, чем предоставляет токен вебхука

401

expired_token
The access token provided has expired

Предоставленный access-токен доступа истек

403

user_access_error
The user does not have access to the application

Пользователь не имеет доступа к приложению. Это означает, что приложение установлено, но администратор портала разрешил доступ к этому приложению только конкретным пользователям

500

PORTAL_DELETED
Portal was deleted

Публичная часть сайта закрыта. Чтобы открыть публичную часть сайта на коробочной установке отключите опцию «Временное закрытие публичной части сайта». Путь к настройке: Рабочий стол > Настройки > Настройки продукта > Настройки модулей > Главный модуль > Временное закрытие публичной части сайта

Продолжите изучение