Добавить файл в чат im.disk.file.commit

Scope: im

Кто может выполнять метод: участник чата

Метод im.disk.file.commit добавляет файл в чат.

Для добавления файла укажите:

  • один из параметров идентификатора чата — CHAT_ID или DIALOG_ID
  • один из параметров идентификатора файла — FILE_ID или UPLOAD_ID

Если передать несколько параметров одновременно, метод обрабатывает только первый.

Получить идентификатор нового файла можно после загрузки методом disk.folder.upload.file. Получить идентификатор существующего файла можно методом:

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

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

Название
тип

Описание

CHAT_ID*
integer

Идентификатор чата.

Обязателен, если не передан DIALOG_ID

DIALOG_ID*
string

Идентификатор диалога в формате:

  • chatXXX — чат
  • sgXXX — чат группы или проекта
  • XXX — идентификатор пользователя личного чата

Обязателен, если не передан CHAT_ID

FILE_ID*
integer

Идентификатор файла на Диске. Можно передать массив.

Обязателен, если не передан UPLOAD_ID

UPLOAD_ID*
integer

Идентификатор файла на Диске. Можно передать массив.

Поддерживает дополнительный параметр AS_FILE, который позволяет отправить изображение без сжатия, в виде файла.

Обязателен, если не передан FILE_ID

MESSAGE
string

Текст сообщения с файлом

SILENT_MODE
string

Параметр для чата Открытых линий

Возможные значения:

  • Y — отправлять уведомление клиенту
  • N — не отправлять уведомление клиенту

AS_FILE
string

Отправить как файл. Только для UPLOAD_ID.

Возможные значения:

  • Y — да
  • N — нет

Примеры кода

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

curl -X POST \
          -H "Content-Type: application/json" \
          -H "Accept: application/json" \
          -d '{"CHAT_ID":1489,"FILE_ID":[5249,5250],"MESSAGE":"Документы по проекту"}' \
          https://**put_your_bitrix24_address**/rest/**put_your_user_id_here**/**put_your_webhook_here**/im.disk.file.commit
        
curl -X POST \
          -H "Content-Type: application/json" \
          -H "Accept: application/json" \
          -d '{"CHAT_ID":1489,"FILE_ID":[5249,5250],"MESSAGE":"Документы по проекту","auth":"**put_access_token_here**"}' \
          https://**put_your_bitrix24_address**/rest/im.disk.file.commit
        
try
        {
            const response = await $b24.callMethod(
                'im.disk.file.commit',
                {
                    CHAT_ID: 1489,
                    FILE_ID: [5249, 5250],
                    MESSAGE: 'Документы по проекту',
                }
            );
        
            console.log(response.getData().result);
        }
        catch (error)
        {
            console.error(error);
        }
        
try {
            $response = $b24Service
                ->core
                ->call(
                    'im.disk.file.commit',
                    [
                        'CHAT_ID' => 1489,
                        'FILE_ID' => [5249, 5250],
                        'MESSAGE' => 'Документы по проекту',
                    ]
                );
        
            $result = $response
                ->getResponseData()
                ->getResult();
        
            echo 'Success: ' . print_r($result, true);
        } catch (Throwable $e) {
            error_log($e->getMessage());
            echo 'Error: ' . $e->getMessage();
        }
        
BX24.callMethod(
            'im.disk.file.commit',
            {
                CHAT_ID: 1489,
                FILE_ID: [5249, 5250],
                MESSAGE: 'Документы по проекту',
            },
            function(result)
            {
                if (result.error())
                {
                    console.error(result.error());
                }
                else
                {
                    console.log(result.data());
                }
            }
        );
        
require_once('crest.php');
        
        $result = CRest::call(
            'im.disk.file.commit',
            [
                'CHAT_ID' => 1489,
                'FILE_ID' => [5249, 5250],
                'MESSAGE' => 'Документы по проекту',
            ]
        );
        
        echo '<PRE>';
        print_r($result);
        echo '</PRE>';
        

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

HTTP-статус: 200

{
            "result": {
                "FILES": {
                    "upload5249": {
                        "id": 5249,
                        "chatId": 1489,
                        "date": {},
                        "type": "file",
                        "name": "image.png",
                        "extension": "png",
                        "size": 2144,
                        "image": {
                            "height": 61,
                            "width": 72
                        },
                        "status": "done",
                        "progress": 100,
                        "authorId": 503,
                        "authorName": "Иван Иванов",
                        "urlPreview": "https://mysite.ru/bitrix/services/main/ajax.php?action=disk.api.file.download&SITE_ID=s1&humanRE=1&fileId=5249&exact=N&_esd=hpbccd%2FZFlCVMvT8%2FoXYU%2FfMrCjiXqxIAf6V4Sv1rR0euQRiW7%2BsdhF7n1QGRL8ZBBmpuiVaX9sY2NbsyigTzBiykXGbFEbXUAmoPO8IvcdVkdoD5n6CJHZG9DZ0DRpH6i5goVbMdjo%3D&fileName=image.png",
                        "urlShow": "https://mysite.ru/bitrix/services/main/ajax.php?action=disk.api.file.showImage&SITE_ID=s1&humanRE=1&fileId=5249&width=1280&height=1280&signature=9f56cfa3412e55679012a6c3bef9ff391f1fc7becf6dc42bea2b8d68656934ce&exact=N&_esd=hpbccd%2FZFlCVMvT8%2FoXYU%2FfMrCjiXqxIAf6V4Sv1rR0euQRiW7%2BsdhF7n1QGRL8ZBBmpuiVaX9sY2NbsyigTzBiykXGbFEbXUAmoPO8IvcdVkdoD5n6CJHZG9DZ0DRpH6i5goVbMdjo%3D&fileName=image.png",
                        "urlDownload": "https://mysite.ru/bitrix/services/main/ajax.php?action=disk.api.file.download&SITE_ID=s1&humanRE=1&fileId=5249&exact=N&_esd=hpbccd%2FZFlCVMvT8%2FoXYU%2FfMrCjiXqxIAf6V4Sv1rR0euQRiW7%2BsdhF7n1QGRL8ZBBmpuiVaX9sY2NbsyigTzBiykXGbFEbXUAmoPO8IvcdVkdoD5n6CJHZG9DZ0DRpH6i5goVbMdjo%3D&fileName=image.png",
                        "viewerAttrs": {
                            "viewer": "",
                            "viewerType": "image",
                            "src": "https://mysite.ru/bitrix/services/main/ajax.php?action=disk.api.file.download&SITE_ID=s1&humanRE=1&fileId=5249&exact=N&_esd=hpbccd%2FZFlCVMvT8%2FoXYU%2FfMrCjiXqxIAf6V4Sv1rR0euQRiW7%2BsdhF7n1QGRL8ZBBmpuiVaX9sY2NbsyigTzBiykXGbFEbXUAmoPO8IvcdVkdoD5n6CJHZG9DZ0DRpH6i5goVbMdjo%3D&fileName=image.png",
                            "viewerResized": "",
                            "objectId": "5249",
                            "viewerGroupBy": "1489",
                            "imChatId": 1489,
                            "title": "image.png",
                            "actions": "[{\"type\":\"download\"},{\"type\":\"copyToMe\",\"text\":\"Сохранить на Диск\",\"action\":\"BXIM.disk.saveToDiskAction\",\"params\":{\"fileId\":\"5249\"},\"extension\":\"disk.viewer.actions\",\"buttonIconClass\":\"ui-btn-icon-cloud\"}]"
                        },
                        "mediaUrl": {
                            "preview": {
                                "250": "https://mysite.ru/bitrix/services/main/ajax.php?action=disk.api.file.download&SITE_ID=s1&humanRE=1&fileId=5249&exact=N&_esd=hpbccd%2FZFlCVMvT8%2FoXYU%2FfMrCjiXqxIAf6V4Sv1rR0euQRiW7%2BsdhF7n1QGRL8ZBBmpuiVaX9sY2NbsyigTzBiykXGbFEbXUAmoPO8IvcdVkdoD5n6CJHZG9DZ0DRpH6i5goVbMdjo%3D&fileName=image.png"
                            }
                        },
                        "isTranscribable": false,
                        "isVideoNote": false,
                        "isVoiceNote": false
                    }
                },
                "DISK_ID": [
                    "5249"
                ],
                "FILE_MODELS": {
                    "upload5249": {
                        "id": 5249,
                        "name": "image.png",
                        "createTime": {},
                        "updateTime": {},
                        "deleteTime": null,
                        "code": "media_original",
                        "xmlId": null,
                        "storageId": 663,
                        "realObjectId": 5249,
                        "parentId": 4821,
                        "deletedType": 0,
                        "createdBy": "503",
                        "updatedBy": "503",
                        "deletedBy": "0",
                        "uniqueCode": "k7lj3sQxTRWSi6K93Vyh",
                        "typeFile": 2,
                        "globalContentVersion": 2,
                        "fileId": 57077,
                        "size": 2144,
                        "etag": "73c045036a9e96943fa57316371655c2",
                        "links": {
                            "download": "/bitrix/services/main/ajax.php?action=disk.file.download&SITE_ID=s1&fileId=5249",
                            "showInGrid": "/bitrix/tools/disk/focus.php?objectId=5249&action=showObjectInGrid&ncc=1",
                            "preview": "/bitrix/services/main/ajax.php?action=disk.api.file.showImage&SITE_ID=s1&humanRE=1&width=640&height=640&signature=8e152b3f4820b07a3f8ea79a6de60b0ae5a82a57467d08d1e8a8a399afb0330f&fileId=5249"
                        }
                    }
                },
                "MESSAGE_ID": 84779
            },
            "time": {
                "start": 1772451339,
                "finish": 1772451339.658828,
                "duration": 0.6588280200958252,
                "processing": 0,
                "date_start": "2026-03-02T14:35:39+03:00",
                "date_finish": "2026-03-02T14:35:39+03:00",
                "operating_reset_at": 1772451939,
                "operating": 0
            }
        }
        

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

Название
тип

Описание

result
object

Корневой объект результата (подробное описание)

time
time

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

Объект result-item

Название
тип

Описание

FILES
object

Данные добавленных файлов (подробное описание)

DISK_ID
array

Массив идентификаторов файлов на Диске

FILE_MODELS
object

Модели добавленных файлов на Диске (подробное описание)

MESSAGE_ID
integer

Идентификатор сообщения с файлами

Объект FILES

Название
тип

Описание

upload{id}
object

Объект файла, где id — идентификатор файла загрузки (подробное описание)

Объект FILES.upload

Название
тип

Описание

id
integer

Идентификатор файла на Диске

chatId
integer

Идентификатор чата

date
object

Дата создания файла

type
string

Тип элемента

name
string

Имя файла

extension
string

Расширение файла

size
integer

Размер файла в байтах

image
object

Параметры изображения (подробное описание)

status
string

Статус обработки файла

progress
integer

Прогресс обработки файла в процентах

authorId
integer

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

authorName
string

Имя автора файла

urlPreview
string

Ссылка на превью файла

urlShow
string

Ссылка на просмотр файла

urlDownload
string

Ссылка на скачивание файла

viewerAttrs
object

Параметры просмотрщика файла (подробное описание)

mediaUrl
object

Ссылки на медиафайл (подробное описание)

isTranscribable
boolean

Доступна ли расшифровка файла

isVideoNote
boolean

Является ли файл видеосообщением

isVoiceNote
boolean

Является ли файл голосовым сообщением

Объект image

Название
тип

Описание

height
integer

Высота изображения

width
integer

Ширина изображения

Объект viewerAttrs

Название
тип

Описание

viewer
string

Идентификатор просмотрщика

viewerType
string

Тип просмотрщика

src
string

Источник файла для просмотрщика

viewerResized
string

Источник уменьшенной версии файла

objectId
string

Идентификатор объекта в просмотрщике

viewerGroupBy
string

Идентификатор группы просмотра

imChatId
integer

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

title
string

Заголовок в просмотрщике

actions
string

Список действий в просмотрщике в формате JSON-строки

Объект mediaUrl

Название
тип

Описание

preview
object

Набор ссылок на превью файла по размерам (подробное описание)

Объект mediaUrl.preview

Название
тип

Описание

250
string

Ссылка на превью шириной 250 px

Объект FILE_MODELS

Название
тип

Описание

upload{id}
object

Объект модели файла, где id — идентификатор файла загрузки (подробное описание)

Объект FILE_MODELS.upload

Название
тип

Описание

id
integer

Идентификатор файла на Диске

name
string

Имя файла

createTime
object

Дата создания файла

updateTime
object

Дата обновления файла

deleteTime
string

Дата удаления файла, может быть null

code
string

Код типа файла

xmlId
string

Внешний идентификатор, может быть null

storageId
integer

Идентификатор хранилища

realObjectId
integer

Идентификатор реального объекта

parentId
integer

Идентификатор родительской папки

deletedType
integer

Тип удаления

createdBy
string

Идентификатор автора создания

updatedBy
string

Идентификатор автора обновления

deletedBy
string

Идентификатор автора удаления

uniqueCode
string

Уникальный код файла

typeFile
integer

Числовой код типа файла

globalContentVersion
integer

Глобальная версия контента

fileId
integer

Идентификатор связанного файла

size
integer

Размер файла в байтах

etag
string

ETag файла

links
object

Ссылки для работы с файлом (подробное описание)

Название
тип

Описание

download
string

Ссылка на скачивание файла

showInGrid
string

Ссылка на показ файла в сетке

preview
string

Ссылка на превью файла

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

HTTP-статус: 400

{
            "error": "CHAT_ID_EMPTY",
            "error_description": "Chat ID can't be empty"
        }
        

Название
тип

Описание

error
string

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

error_description
error_description

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

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

Статус

Код

Описание

Значение

400

CHAT_ID_EMPTY

Chat ID can't be empty

Возможные причины:

  • не передан один из обязательных параметров CHAT_ID или DIALOG_ID
  • передан пустой CHAT_ID

400

DIALOG_ID_EMPTY

Dialog ID can't be empty

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

400

FILES_ERROR

List of files in not specified

Не передан один из обязательных параметров FILE_ID или UPLOAD_ID

400

SAVE_ERROR

Error during saving file to chat

Возможные причины:

  • передан пустым FILE_ID или UPLOAD_ID
  • переданы несуществующие идентификаторы файлов

403

ACCESS_ERROR

You do not have access to the specified dialog

Недостаточно прав на просмотр диалога или передан несуществующий диалог

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

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

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

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