Отправить сообщение пользователю от имени открытой линии imopenlines.network.message.add

Scope: imopenlines

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

Метод imopenlines.network.message.add отправляет сообщение пользователю от имени открытой линии, подкллюченной в Битрикс24 Network.

Ограничения работы метода:

  1. Метод недоступен при сессионной авторизации. Для сессионной авторизации возвращает ошибку WRONG_AUTH_TYPE
  2. Можно отправлять сообщение не более одного раза для каждого пользователя в течение одной недели. Для аккаунта с лицензией Партнера (NFR) ограничений по лимиту нет
  3. Можно использовать клавиатуру только для форматирования кнопки ссылки на стороннем сайте

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

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

Название
тип

Описание

CODE*
string

Код открытой линии, строка из 32 символов, например ab515f5d85a8b844d484f6ea75a2e494

USER_ID*
integer

Идентификатор получателя сообщения, например 2

MESSAGE*
string

Текст сообщения.

Как форматировать текст — в статье форматирование

ATTACH
object

Вложение.

Формат вложения описан в статье Как использовать вложения

KEYBOARD
object

Клавиатура.

Как создавать клавиатуры — в статье Работа с клавиатурами

URL_PREVIEW
char

Предпросмотр ссылок. Включен Y по умолчанию.

Передайте N, чтобы отключить предпросмотр ссылок

Примеры кода

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

curl -X POST \
          -H "Content-Type: application/json" \
          -H "Accept: application/json" \
          -d '{
            "CODE": "ab515f5d85a8b844d484f6ea75a2e494",
            "USER_ID": 2,
            "MESSAGE": "Подготовили материалы по подключению открытых линий",
            "ATTACH": {
              "ID": 1,
              "COLOR_TOKEN": "primary",
              "BLOCKS": [
                {
                  "MESSAGE": "Во вложении отправили чек-лист и схему подключения"
                },
                {
                  "FILE": [
                    {
                      "NAME": "checklist-openlines.pdf",
                      "LINK": "https://cdn.example.com/docs/checklist-openlines.pdf",
                      "SIZE": 428736
                    }
                  ]
                },
                {
                  "IMAGE": [
                    {
                      "NAME": "Схема подключения",
                      "LINK": "https://cdn.example.com/images/openlines-setup.png",
                      "PREVIEW": "https://cdn.example.com/images/openlines-setup-preview.png",
                      "WIDTH": 1280,
                      "HEIGHT": 720
                    }
                  ]
                }
              ]
            },
            "KEYBOARD": {
              "BUTTONS": [
                {
                  "TEXT": "Открыть инструкцию",
                  "LINK": "https://help.example.com/openlines/setup",
                  "DISPLAY": "LINE",
                  "BG_COLOR_TOKEN": "primary"
                }
              ]
            },
            "URL_PREVIEW": "N"
          }' \
          https://**put_your_bitrix24_address**/rest/**put_your_user_id_here**/**put_your_webhook_here**/imopenlines.network.message.add
        
curl -X POST \
          -H "Content-Type: application/json" \
          -H "Accept: application/json" \
          -d '{
            "CODE": "ab515f5d85a8b844d484f6ea75a2e494",
            "USER_ID": 2,
            "MESSAGE": "Подготовили материалы по подключению открытых линий",
            "ATTACH": {
              "ID": 1,
              "COLOR_TOKEN": "primary",
              "BLOCKS": [
                {
                  "MESSAGE": "Во вложении отправили чек-лист и схему подключения"
                },
                {
                  "FILE": [
                    {
                      "NAME": "checklist-openlines.pdf",
                      "LINK": "https://cdn.example.com/docs/checklist-openlines.pdf",
                      "SIZE": 428736
                    }
                  ]
                },
                {
                  "IMAGE": [
                    {
                      "NAME": "Схема подключения",
                      "LINK": "https://cdn.example.com/images/openlines-setup.png",
                      "PREVIEW": "https://cdn.example.com/images/openlines-setup-preview.png",
                      "WIDTH": 1280,
                      "HEIGHT": 720
                    }
                  ]
                }
              ]
            },
            "KEYBOARD": {
              "BUTTONS": [
                {
                  "TEXT": "Открыть инструкцию",
                  "LINK": "https://help.example.com/openlines/setup",
                  "DISPLAY": "LINE",
                  "BG_COLOR_TOKEN": "primary"
                }
              ]
            },
            "URL_PREVIEW": "N",
            "auth": "**put_access_token_here**"
          }' \
          https://**put_your_bitrix24_address**/rest/imopenlines.network.message.add
        
try
        {
            const response = await $b24.callMethod(
                'imopenlines.network.message.add',
                {
                    CODE: 'ab515f5d85a8b844d484f6ea75a2e494',
                    USER_ID: 2,
                    MESSAGE: 'Подготовили материалы по подключению открытых линий',
                    ATTACH: {
                        ID: 1,
                        COLOR_TOKEN: 'primary',
                        BLOCKS: [
                            {
                                MESSAGE: 'Во вложении отправили чек-лист и схему подключения'
                            },
                            {
                                FILE: [
                                    {
                                        NAME: 'checklist-openlines.pdf',
                                        LINK: 'https://cdn.example.com/docs/checklist-openlines.pdf',
                                        SIZE: 428736
                                    }
                                ]
                            },
                            {
                                IMAGE: [
                                    {
                                        NAME: 'Схема подключения',
                                        LINK: 'https://cdn.example.com/images/openlines-setup.png',
                                        PREVIEW: 'https://cdn.example.com/images/openlines-setup-preview.png',
                                        WIDTH: 1280,
                                        HEIGHT: 720
                                    }
                                ]
                            }
                        ]
                    },
                    KEYBOARD: {
                        BUTTONS: [
                            {
                                TEXT: 'Открыть инструкцию',
                                LINK: 'https://help.example.com/openlines/setup',
                                DISPLAY: 'LINE',
                                BG_COLOR_TOKEN: 'primary'
                            }
                        ]
                    },
                    URL_PREVIEW: 'N'
                }
            );
        
            const result = response.getData().result;
            console.log(result);
        }
        catch (error)
        {
            console.error(error);
        }
        
try {
            $response = $b24Service
                ->core
                ->call(
                    'imopenlines.network.message.add',
                    [
                        'CODE' => 'ab515f5d85a8b844d484f6ea75a2e494',
                        'USER_ID' => 2,
                        'MESSAGE' => 'Подготовили материалы по подключению открытых линий',
                        'ATTACH' => [
                            'ID' => 1,
                            'COLOR_TOKEN' => 'primary',
                            'BLOCKS' => [
                                [
                                    'MESSAGE' => 'Во вложении отправили чек-лист и схему подключения'
                                ],
                                [
                                    'FILE' => [
                                        [
                                            'NAME' => 'checklist-openlines.pdf',
                                            'LINK' => 'https://cdn.example.com/docs/checklist-openlines.pdf',
                                            'SIZE' => 428736
                                        ]
                                    ]
                                ],
                                [
                                    'IMAGE' => [
                                        [
                                            'NAME' => 'Схема подключения',
                                            'LINK' => 'https://cdn.example.com/images/openlines-setup.png',
                                            'PREVIEW' => 'https://cdn.example.com/images/openlines-setup-preview.png',
                                            'WIDTH' => 1280,
                                            'HEIGHT' => 720
                                        ]
                                    ]
                                ]
                            ]
                        ],
                        'KEYBOARD' => [
                            'BUTTONS' => [
                                [
                                    'TEXT' => 'Открыть инструкцию',
                                    'LINK' => 'https://help.example.com/openlines/setup',
                                    'DISPLAY' => 'LINE',
                                    'BG_COLOR_TOKEN' => 'primary'
                                ]
                            ]
                        ],
                        'URL_PREVIEW' => 'N',
                    ]
                );
        
            $result = $response
                ->getResponseData()
                ->getResult();
        
            print_r($result);
        } catch (Throwable $e) {
            echo $e->getMessage();
        }
        
BX24.callMethod(
            'imopenlines.network.message.add',
            {
                CODE: 'ab515f5d85a8b844d484f6ea75a2e494',
                USER_ID: 2,
                MESSAGE: 'Подготовили материалы по подключению открытых линий',
                ATTACH: {
                    ID: 1,
                    COLOR_TOKEN: 'primary',
                    BLOCKS: [
                        {
                            MESSAGE: 'Во вложении отправили чек-лист и схему подключения'
                        },
                        {
                            FILE: [
                                {
                                    NAME: 'checklist-openlines.pdf',
                                    LINK: 'https://cdn.example.com/docs/checklist-openlines.pdf',
                                    SIZE: 428736
                                }
                            ]
                        },
                        {
                            IMAGE: [
                                {
                                    NAME: 'Схема подключения',
                                    LINK: 'https://cdn.example.com/images/openlines-setup.png',
                                    PREVIEW: 'https://cdn.example.com/images/openlines-setup-preview.png',
                                    WIDTH: 1280,
                                    HEIGHT: 720
                                }
                            ]
                        }
                    ]
                },
                KEYBOARD: {
                    BUTTONS: [
                        {
                            TEXT: 'Открыть инструкцию',
                            LINK: 'https://help.example.com/openlines/setup',
                            DISPLAY: 'LINE',
                            BG_COLOR_TOKEN: 'primary'
                        }
                    ]
                },
                URL_PREVIEW: 'N'
            },
            function(result)
            {
                if (result.error())
                {
                    console.error(result.error());
                }
                else
                {
                    console.log(result.data());
                }
            }
        );
        
require_once('crest.php');
        
        $result = CRest::call(
            'imopenlines.network.message.add',
            [
                'CODE' => 'ab515f5d85a8b844d484f6ea75a2e494',
                'USER_ID' => 2,
                'MESSAGE' => 'Подготовили материалы по подключению открытых линий',
                'ATTACH' => [
                    'ID' => 1,
                    'COLOR_TOKEN' => 'primary',
                    'BLOCKS' => [
                        [
                            'MESSAGE' => 'Во вложении отправили чек-лист и схему подключения'
                        ],
                        [
                            'FILE' => [
                                [
                                    'NAME' => 'checklist-openlines.pdf',
                                    'LINK' => 'https://cdn.example.com/docs/checklist-openlines.pdf',
                                    'SIZE' => 428736
                                ]
                            ]
                        ],
                        [
                            'IMAGE' => [
                                [
                                    'NAME' => 'Схема подключения',
                                    'LINK' => 'https://cdn.example.com/images/openlines-setup.png',
                                    'PREVIEW' => 'https://cdn.example.com/images/openlines-setup-preview.png',
                                    'WIDTH' => 1280,
                                    'HEIGHT' => 720
                                ]
                            ]
                        ]
                    ]
                ],
                'KEYBOARD' => [
                    'BUTTONS' => [
                        [
                            'TEXT' => 'Открыть инструкцию',
                            'LINK' => 'https://help.example.com/openlines/setup',
                            'DISPLAY' => 'LINE',
                            'BG_COLOR_TOKEN' => 'primary'
                        ]
                    ]
                ],
                'URL_PREVIEW' => 'N',
            ]
        );
        
        print_r($result);
        

Обработка ответа

HTTP-статус: 200

{
            "result": true,
            "time": {
                "start": 1773740787,
                "finish": 1773740787.828814,
                "duration": 0.8288140296936035,
                "processing": 0,
                "date_start": "2026-03-17T12:46:27+03:00",
                "date_finish": "2026-03-17T12:46:27+03:00",
                "operating_reset_at": 1773741387,
                "operating": 0.17312097549438477
            }
        }
        

Возвращаемые данные

Название
тип

Описание

result
boolean

Возвращает true, если сообщение отправлено

time
time

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

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

HTTP-статус: 400

{
            "error": "CODE",
            "error_description": "You entered an invalid code"
        }
        

Название
тип

Описание

error
string

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

error_description
error_description

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

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

Статус

Код

Описание

Значение

403

WRONG_AUTH_TYPE

Access for this method not allowed by session authorization

Метод вызван с сессионной авторизацией

400

CODE

You entered an invalid code

Некорректный код в параметре CODE, ожидается строка из 32 символов

400

IMBOT_ERROR

Module IMBOT is not installed

Не установлен модуль imbot

400

NOT_FOUND

Line not found

Открытая линия не найдена

400

USER_ID_EMPTY

User ID can't be empty

Не указан идентификатор пользователя

400

USER_MESSAGE_LIMIT

You cant send more than one message per week to each user

Превышен лимит сообщений для конкретного пользователя

400

MESSAGE_EMPTY

Message can't be empty

Не указан текст сообщения

400

ATTACH_OVERSIZE

You have exceeded the maximum allowable size of attach

Превышен максимально допустимый размер вложения 30 Кб

400

ATTACH_ERROR

Incorrect attach params

Объект вложения не прошел проверку

400

KEYBOARD_ERROR

Incorrect keyboard params

Объект клавиатуры не прошел проверку

400

WRONG_REQUEST

Message isn't added

Сообщение не отправлено

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

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

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

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