Отправить сообщения в Битрикс24 imconnector.send.messages
Если вы разрабатываете интеграции для Битрикс24 с помощью AI-инструментов (Codex, Claude Code, Cursor), подключите MCP-сервер, чтобы ассистент использовал официальную REST-документацию.
Scope:
imopenlinesКто может выполнять метод: любой пользователь
Метод imconnector.send.messages принимает сообщения из внешней системы и передает их в открытую линию Битрикс24 через пользовательский коннектор.
В параметрах метода используются значения внешней системы: идентификатор пользователя, идентификатор чата, ссылка на чат и его название в приложении, которое зарегистрировало коннектор.
В результате выполнения метода возвращаются созданные в Битрикс24 идентификатор чата и идентификатор диалога открытой линии.
Метод работает только в контексте приложения.
Параметры метода
Обязательные параметры отмечены *
|
Название |
Описание |
|
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. Допустимое значение — |
Поля name и last_name могут содержать буквы, пробелы, дефисы и апострофы. Цифры и другие специальные символы использовать нельзя. Максимальная длина для name и last_name — 25 символов. Язык и регистр могут быть любыми.
Параметр skip_phone_validate рекомендуется использовать только в редких случаях, когда номер не проходит встроенную проверку. Это вынужденная мера, чтобы обойти ограничения валидатора телефона. В обычном сценарии передавайте телефон без этого параметра.
Объект 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",
"skip_phone_validate": "Y"
},
"message": {
"id": "ext-msg-1001",
"date": 1773265993,
"text": "Добрый день",
"files": [
{"url": "https://example.ru/files/spec.pdf", "name": "spec.pdf"}
],
"disable_crm": "Y"
},
"chat": {
"id": "channel-123",
"name": "Канал поддержки",
"url": "https://example.ru/chats/123"
}
}
],
"auth": "**put_access_token_here**"
}' \
https://**put_your_bitrix24_address**/rest/imconnector.send.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',
skip_phone_validate: 'Y',
},
message: {
id: 'ext-msg-1001',
date: 1773265993,
text: 'Добрый день',
files: [{ url: 'https://example.ru/files/spec.pdf', name: 'spec.pdf' }],
disable_crm: 'Y',
},
chat: {
id: 'channel-123',
name: 'Канал поддержки',
url: 'https://example.ru/chats/123',
},
},
],
};
const response = await $b24.callMethod('imconnector.send.messages', payload);
console.log(response.getData());
$result = $b24Service->core->call(
'imconnector.send.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',
'skip_phone_validate' => 'Y',
],
'message' => [
'id' => 'ext-msg-1001',
'date' => 1773265993,
'text' => 'Добрый день',
'files' => [
['url' => 'https://example.ru/files/spec.pdf', 'name' => 'spec.pdf'],
],
'disable_crm' => 'Y',
],
'chat' => [
'id' => 'channel-123',
'name' => 'Канал поддержки',
'url' => 'https://example.ru/chats/123',
],
],
],
]
);
BX24.callMethod(
'imconnector.send.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',
skip_phone_validate: 'Y',
},
message: {
id: 'ext-msg-1001',
date: 1773265993,
text: 'Добрый день',
files: [{ url: 'https://example.ru/files/spec.pdf', name: 'spec.pdf' }],
disable_crm: 'Y',
},
chat: {
id: 'channel-123',
name: 'Канал поддержки',
url: 'https://example.ru/chats/123',
},
},
],
},
function(result) {
console.log(result.data());
}
);
$result = CRest::call(
'imconnector.send.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',
'skip_phone_validate' => 'Y',
],
'message' => [
'id' => 'ext-msg-1001',
'date' => 1773265993,
'text' => 'Добрый день',
'files' => [
['url' => 'https://example.ru/files/spec.pdf', 'name' => 'spec.pdf'],
],
'disable_crm' => 'Y',
],
'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": "Добрый день",
"files": []
},
"chat": {
"id": "channel-123",
"name": "Канал поддержки",
"description": "Ссылка на исходный пост: https://example.ru/chats/123"
},
"extra": {
"skip_phone_validate": "Y",
"disable_tracker": "Y"
},
"SUCCESS": true,
"session": {
"ID": "323",
"CHAT_ID": "1767"
}
}
]
}
},
"time": {
"start": 1773265993,
"finish": 1773265994.487149,
"duration": 1.4871490001678467,
"processing": 1,
"date_start": "2026-03-11T13:53:13+03:00",
"date_finish": "2026-03-11T13:53:14+03:00",
"operating_reset_at": 1773266593,
"operating": 1.1916680335998535
}
}
Возвращаемые данные
|
Название |
Описание |
|
SUCCESS |
Возвращает |
|
DATA |
Данные c информацией об отправленных сообщениях. Структура объекта подробно описана ниже |
|
time |
Информация о времени выполнения запроса |
Объект DATA
|
Название |
Описание |
|
RESULT |
Массив результатов по каждому элементу Структура элемента подробно описана ниже |
Объект RESULT[]
|
Название |
Описание |
|
user |
Внутренний идентификатор пользователя Битрикс24 |
|
message |
Данные сообщения после обработки (подробное описание) |
|
chat |
Данные чата после обработки (подробное описание) |
|
extra |
Дополнительные флаги обработки сообщения (подробное описание) |
|
SUCCESS |
Признак успешной обработки текущего элемента массива |
|
ERRORS |
Массив текстов ошибок по текущему элементу, возвращается при |
|
session |
Информация о сессии открытой линии, возвращается, если доступна (подробное описание) |
Объект message
|
Название |
Описание |
|
id |
Внешний идентификатор сообщения |
|
date |
Дата сообщения после обработки |
|
text |
Текст сообщения |
|
files |
Массив файлов сообщения |
Объект chat
|
Название |
Описание |
|
id |
Идентификатор чата или канала |
|
name |
Название чата или канала |
|
description |
Описание чата, например ссылка на исходный пост |
Объект extra
|
Название |
Описание |
|
skip_phone_validate |
Признак отключения проверки телефона, возвращается при значении |
|
disable_tracker |
Признак отключения CRM трекера, возвращается при значении |
Объект session
|
Название |
Описание |
|
ID |
Идентификатор сессии открытой линии |
|
CHAT_ID |
Идентификатор чата в Битрикс24 |
Обработка ошибок
HTTP-статус: 400, 403
{
"error": "ERROR_ARGUMENT",
"error_description": "Argument 'MESSAGES' 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 |
Не передан |
|
|
|
The value of an argument 'MESSAGES' must be of type array |
|
|
|
|
The MESSAGES parameter must be an array of messages (arrays) |
Элементы |
|
|
|
The incorrect structure of a message inside MESSAGES parameter |
В элементе |
|
|
|
Линия 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
- Изменить отправленные сообщения imconnector.update.messages
- Удалить отправленные сообщения imconnector.delete.messages
- Обновить статус «доставлено» imconnector.send.status.delivery
- Установить новое имя чата imconnector.chat.name.set
- Как создать коннектор открытых линий для чата на сайте