Изменить отправленные сообщения imconnector.update.messages
Scope:
imopenlinesКто может выполнять метод: любой пользователь
Метод imconnector.update.messages обновляет данные ранее переданных сообщений внешней системы в открытой линии.
Метод работает только в контексте приложения.
В параметрах метода используются значения внешней системы: идентификатор пользователя, идентификатор чата, ссылка на чат и его название в приложении, которое зарегистрировало коннектор.
Для обновления передавайте те же message.id и chat.id, которые использовали при отправке сообщений методом imconnector.send.messages.
Параметры метода
Обязательные параметры отмечены *
|
Название |
Описание |
|
CONNECTOR* |
Строковый код коннектора, который задали в параметре |
|
LINE* |
Идентификатор открытой линии. Идентификатор можно получить методами imopenlines.config.get и imopenlines.config.list.get |
|
MESSAGES* |
Массив сообщений для обновления. Каждый элемент массива — одно сообщение в формате объекта с тремя обязательными блоками: Структура объекта подробно описана ниже |
Параметр MESSAGES
|
Название |
Описание |
|
user |
Данные пользователя внешней системы. Структура объекта подробно описана ниже |
|
message |
Данные сообщения внешней системы. Структура объекта подробно описана ниже |
|
chat |
Данные чата внешней системы. Структура объекта подробно описана ниже |
Объект user
|
Название |
Описание |
|
id* |
Идентификатор пользователя во внешней системе |
|
last_name |
Фамилия пользователя |
|
name |
Имя пользователя |
|
picture |
Аватар пользователя в формате объекта с полем |
|
url |
Ссылка на профиль пользователя во внешней системе |
|
gender |
Пол пользователя. Поддерживаются значения |
|
email |
Email пользователя |
|
phone |
Телефон пользователя |
|
skip_phone_validate |
Отключает проверку телефона перед сохранением в CRM. Допустимое значение — |
Объект message
|
Название |
Описание |
|
id |
Идентификатор сообщения во внешней системе, которое нужно обновить |
|
date |
Время сообщения в Unix Timestamp в секундах |
|
text |
Новый текст сообщения. Передавайте О допустимом форматировании читайте в статье Форматирование |
|
files |
Массив файлов. Каждый файл передается как массив вида |
|
disable_crm |
Отключает CRM трекер для сообщения. Допустимое значение — |
|
user_id |
Идентификатор менеджера в Битрикс24. Если передать |
Объект chat
|
Название |
Описание |
|
id* |
Идентификатор чата или канала во внешней системе. Рекомендуется передавать то же значение, что и в |
|
name |
Название чата или канала. Рекомендуется использовать значение из |
|
url |
Ссылка на чат или канал во внешней системе. Рекомендуется использовать значение из |
Примеры кода
Как использовать примеры в документации
curl -X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{
"CONNECTOR": "myconnector",
"LINE": 107,
"MESSAGES": [
{
"user": {
"id": "ext-user-42",
"last_name": "Иванов",
"name": "Иван",
"picture": {"url": "https://example.ru/u42.png"},
"url": "https://example.ru/users/42",
"gender": "male",
"email": "ivan@example.ru",
"phone": "+79990000000"
},
"message": {
"id": "ext-msg-1001",
"date": 1773266050,
"text": "Добрый день, уточнили детали"
},
"chat": {
"id": "channel-123",
"name": "Канал поддержки",
"url": "https://example.ru/chats/123"
}
}
],
"auth": "**put_access_token_here**"
}' \
https://**put_your_bitrix24_address**/rest/imconnector.update.messages
const payload = {
CONNECTOR: 'myconnector',
LINE: 107,
MESSAGES: [
{
user: {
id: 'ext-user-42',
last_name: 'Иванов',
name: 'Иван',
picture: { url: 'https://example.ru/u42.png' },
url: 'https://example.ru/users/42',
gender: 'male',
email: 'ivan@example.ru',
phone: '+79990000000',
},
message: {
id: 'ext-msg-1001',
date: 1773266050,
text: 'Добрый день, уточнили детали',
},
chat: {
id: 'channel-123',
name: 'Канал поддержки',
url: 'https://example.ru/chats/123',
},
},
],
};
const response = await $b24.callMethod('imconnector.update.messages', payload);
console.log(response.getData());
$result = $b24Service->core->call(
'imconnector.update.messages',
[
'CONNECTOR' => 'myconnector',
'LINE' => 107,
'MESSAGES' => [
[
'user' => [
'id' => 'ext-user-42',
'last_name' => 'Иванов',
'name' => 'Иван',
'picture' => ['url' => 'https://example.ru/u42.png'],
'url' => 'https://example.ru/users/42',
'gender' => 'male',
'email' => 'ivan@example.ru',
'phone' => '+79990000000',
],
'message' => [
'id' => 'ext-msg-1001',
'date' => 1773266050,
'text' => 'Добрый день, уточнили детали',
],
'chat' => [
'id' => 'channel-123',
'name' => 'Канал поддержки',
'url' => 'https://example.ru/chats/123',
],
],
],
]
);
BX24.callMethod(
'imconnector.update.messages',
{
CONNECTOR: 'myconnector',
LINE: 107,
MESSAGES: [
{
user: {
id: 'ext-user-42',
last_name: 'Иванов',
name: 'Иван',
picture: { url: 'https://example.ru/u42.png' },
url: 'https://example.ru/users/42',
gender: 'male',
email: 'ivan@example.ru',
phone: '+79990000000',
},
message: {
id: 'ext-msg-1001',
date: 1773266050,
text: 'Добрый день, уточнили детали',
},
chat: {
id: 'channel-123',
name: 'Канал поддержки',
url: 'https://example.ru/chats/123',
},
},
],
},
function(result) {
console.log(result.data());
}
);
$result = CRest::call(
'imconnector.update.messages',
[
'CONNECTOR' => 'myconnector',
'LINE' => 107,
'MESSAGES' => [
[
'user' => [
'id' => 'ext-user-42',
'last_name' => 'Иванов',
'name' => 'Иван',
'picture' => ['url' => 'https://example.ru/u42.png'],
'url' => 'https://example.ru/users/42',
'gender' => 'male',
'email' => 'ivan@example.ru',
'phone' => '+79990000000',
],
'message' => [
'id' => 'ext-msg-1001',
'date' => 1773266050,
'text' => 'Добрый день, уточнили детали',
],
'chat' => [
'id' => 'channel-123',
'name' => 'Канал поддержки',
'url' => 'https://example.ru/chats/123',
],
],
],
]
);
Обработка ответа
HTTP-статус: 200
{
"result": {
"SUCCESS": true,
"DATA": {
"RESULT": [
{
"user": "585",
"message": {
"id": "ext-msg-1001",
"date": {},
"text": "Добрый день, уточнили детали"
},
"chat": {
"id": "channel-123",
"name": "Канал поддержки",
"description": "Ссылка на исходный пост: https://example.ru/chats/123"
},
"SUCCESS": true
}
]
}
},
"time": {
"start": 1773322669,
"finish": 1773322669.300999,
"duration": 0.3009989261627197,
"processing": 0,
"date_start": "2026-03-12T16:37:49+03:00",
"date_finish": "2026-03-12T16:37:49+03:00",
"operating_reset_at": 1773323269,
"operating": 0
}
}
Возвращаемые данные
|
Название |
Описание |
|
SUCCESS |
Возвращает |
|
DATA |
Данные обработки сообщений. Структура объекта подробно описана ниже |
|
time |
Информация о времени выполнения запроса |
Объект DATA
|
Название |
Описание |
|
RESULT |
Массив результатов по каждому элементу Структура элемента подробно описана ниже |
Объект RESULT[]
|
Название |
Описание |
|
user |
Внутренний идентификатор пользователя Битрикс24 |
|
message |
Данные сообщения после обработки (подробное описание) |
|
chat |
Данные чата после обработки (подробное описание) |
|
extra |
Дополнительные флаги обработки сообщения (подробное описание) |
|
SUCCESS |
Признак успешной обработки текущего элемента массива |
|
ERRORS |
Массив текстов ошибок по текущему элементу, возвращается при |
Объект message
|
Название |
Описание |
|
id |
Внешний идентификатор сообщения |
|
date |
Дата сообщения после обработки |
|
text |
Текст сообщения |
|
files |
Массив файлов сообщения |
Объект chat
|
Название |
Описание |
|
id |
Идентификатор чата или канала |
|
name |
Название чата или канала |
|
description |
Описание чата, например ссылка на исходный пост |
Объект extra
|
Название |
Описание |
|
skip_phone_validate |
Признак отключения проверки телефона, возвращается при значении |
|
disable_tracker |
Признак отключения CRM трекера, возвращается при значении |
Обработка ошибок
HTTP-статус: 400, 403
{
"error": "ERROR_ARGUMENT",
"error_description": "Argument 'LINE' is null or empty"
}
|
Название |
Описание |
|
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 |
Не передан |
|
|
|
Линия c таким ID неактивна или не существует |
Передан неактивный |
|
|
|
Не удалось найти подходящий провайдер для коннектора |
Для коннектора не удалось инициализировать провайдер |
Статусы и коды системных ошибок
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.delete.messages
- Обновить статус «доставлено» imconnector.send.status.delivery
- Установить новое имя чата imconnector.chat.name.set