Найти сообщение в чате im.dialog.messages.search
Scope:
imКто может выполнять метод: участник чата
Метод im.dialog.messages.search выполняет поиск сообщений в чате.
Параметры метода
Обязательные параметры отмечены *
|
Название |
Описание |
|
CHAT_ID* |
Идентификатор чата, в котором выполняется поиск |
|
SEARCH_MESSAGE |
Строка поиска по тексту сообщения. Поиск по этому параметру выполняется для строк длиной более 2 символов |
|
DATE_FROM |
Начало периода поиска в формате ISO 8601 (RFC3339) |
|
DATE_TO |
Конец периода поиска в формате ISO 8601 (RFC3339) |
|
DATE |
Поиск сообщений за конкретную дату в формате ISO 8601 (RFC3339). Если параметр передан, поиск выполняется в пределах суток от указанной даты |
|
ORDER |
Параметры сортировки. Поддерживаемое поле:
По умолчанию: |
|
LIMIT |
Количество возвращаемых сообщений. Значение по умолчанию: |
|
LAST_ID |
Идентификатор последнего сообщения из предыдущей выборки для пагинации |
Примеры кода
Как использовать примеры в документации
curl -X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{"CHAT_ID":3,"SEARCH_MESSAGE":"test","ORDER":{"ID":"DESC"},"LIMIT":20}' \
https://**put_your_bitrix24_address**/rest/**put_your_user_id_here**/**put_your_webhook_here**/im.dialog.messages.search
curl -X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{"CHAT_ID":3,"SEARCH_MESSAGE":"test","ORDER":{"ID":"DESC"},"LIMIT":20,"auth":"**put_access_token_here**"}' \
https://**put_your_bitrix24_address**/rest/im.dialog.messages.search
try
{
const response = await $b24.callMethod(
'im.dialog.messages.search',
{
CHAT_ID: 3,
SEARCH_MESSAGE: 'test',
ORDER: { ID: 'DESC' },
LIMIT: 20
}
);
const result = response.getData().result;
console.log('Search result:', result);
}
catch (error)
{
console.error('Error:', error);
}
try {
$response = $b24Service
->core
->call(
'im.dialog.messages.search',
[
'CHAT_ID' => 3,
'SEARCH_MESSAGE' => 'test',
'ORDER' => ['ID' => 'DESC'],
'LIMIT' => 20,
]
);
$result = $response
->getResponseData()
->getResult();
echo 'Success: ' . print_r($result, true);
} catch (Throwable $e) {
error_log($e->getMessage());
echo 'Error: ' . $e->getMessage();
}
BX24.callMethod(
'im.dialog.messages.search',
{
CHAT_ID: 3,
SEARCH_MESSAGE: 'test',
ORDER: { ID: 'DESC' },
LIMIT: 20
},
function(result)
{
if (result.error())
{
console.error(result.error());
}
else
{
console.log(result.data());
}
}
);
require_once('crest.php');
$result = CRest::call(
'im.dialog.messages.search',
[
'CHAT_ID' => 3,
'SEARCH_MESSAGE' => 'test',
'ORDER' => ['ID' => 'DESC'],
'LIMIT' => 20,
]
);
echo '<PRE>';
print_r($result);
echo '</PRE>';
Обработка ответа
HTTP-статус: 200
{
"result": {
"users": [
{
"id": 1,
"active": true,
"name": "Алекс",
"firstName": "Алекс",
"lastName": "",
"workPosition": "",
"color": "#df532d",
"avatar": "https://cdn-ru.bitrix24.ru/path/avatar.jpg",
"avatarHr": "https://cdn-ru.bitrix24.ru/path/avatar.jpg",
"gender": "F",
"birthday": "",
"extranet": false,
"network": false,
"bot": false,
"connector": false,
"externalAuthId": "socservices",
"status": "online",
"idle": false,
"lastActivityDate": "2026-02-13T14:27:33+03:00",
"mobileLastDate": false,
"desktopLastDate": false,
"absent": false,
"departments": [1, 107, 47, 3],
"phones": {
"personal_mobile": "79998887766",
"inner_phone": "111"
},
"botData": null,
"type": "user",
"website": "",
"email": "user@example.com"
}
],
"files": [],
"additionalMessages": [],
"copilot": null,
"stickers": [],
"reactions": [],
"tariffRestrictions": {
"isHistoryLimitExceeded": false
},
"usersShort": [],
"messages": [
{
"id": 33653,
"chat_id": 2421,
"author_id": 1,
"date": "2026-02-13T14:28:00+03:00",
"text": "test message",
"isSystem": false,
"uuid": "18533186-232b-4423-8438-64501da182f5",
"forward": null,
"params": [],
"viewedByOthers": false,
"unread": false,
"viewed": true
}
]
},
"time": {
"start": 1770982150,
"finish": 1770982150.503861,
"duration": 0.5038609504699707,
"processing": 0,
"date_start": "2026-02-13T14:29:10+03:00",
"date_finish": "2026-02-13T14:29:10+03:00",
"operating_reset_at": 1770982750,
"operating": 0
}
}
Возвращаемые данные
|
Название |
Описание |
|
result |
Корневой элемент ответа |
|
result.messages |
Массив найденных сообщений (подробное описание) |
|
result.users |
Пользователи, связанные с найденными сообщениями (подробное описание) |
|
result.files |
Файлы из найденных сообщений |
|
result.additionalMessages |
Дополнительные сообщения, связанные с найденными, например пересылаемые или цитируемые (подробное описание) |
|
result.copilot |
Данные BitrixGPT, если присутствуют в ответе. Может быть |
|
result.stickers |
Стикеры, связанные с найденными сообщениями |
|
result.reactions |
Реакции на найденные сообщения (подробное описание) |
|
result.tariffRestrictions |
Информация о тарифных ограничениях истории. Содержит флаг |
|
result.usersShort |
Краткая информация о пользователях, поставивших реакции. Используется как дополняющий справочник к |
|
time |
Информация о времени выполнения запроса |
Сообщение
|
Название |
Описание |
|
id |
Идентификатор сообщения |
|
chat_id |
Идентификатор чата |
|
author_id |
Идентификатор автора сообщения |
|
date |
Дата и время создания сообщения |
|
text |
Текст сообщения |
|
isSystem |
Признак системного сообщения |
|
uuid |
Внешний UUID сообщения. Может быть |
|
forward |
Информация о пересылке. Может быть |
|
params |
Параметры сообщения |
|
viewedByOthers |
Признак, что сообщение просмотрено другими участниками |
|
unread |
Признак непрочитанного сообщения для текущего пользователя |
|
viewed |
Признак, что сообщение просмотрено текущим пользователем |
Пользователь
|
Название |
Описание |
|
id |
Идентификатор пользователя |
|
active |
Пользователь активен |
|
name |
Полное имя |
|
firstName |
Имя |
|
lastName |
Фамилия |
|
workPosition |
Должность |
|
color |
Цвет профиля в формате hex |
|
avatar |
URL аватара |
|
avatarHr |
URL аватара в высоком разрешении |
|
gender |
Пол |
|
birthday |
День рождения |
|
extranet |
Признак экстранет-пользователя |
|
network |
Признак пользователя Bitrix24 Network |
|
bot |
Признак бота |
|
connector |
Признак пользователя-коннектора |
|
externalAuthId |
Код внешней авторизации |
|
status |
Статус пользователя |
|
idle |
Признак неактивности |
|
lastActivityDate |
Дата и время последней активности |
|
mobileLastDate |
Последняя активность в мобильном приложении. Может быть |
|
desktopLastDate |
Последняя активность в десктоп-приложении. Может быть |
|
absent |
Признак отсутствия |
|
departments |
Массив идентификаторов подразделений |
|
phones |
Телефоны пользователя |
|
botData |
Дополнительные данные бота. Для обычного пользователя |
|
type |
Тип пользователя |
|
website |
Веб-сайт пользователя |
|
email |
E-mail пользователя |
Реакции
|
Название |
Описание |
|
messageId |
Идентификатор сообщения |
|
reactionCounters |
Количество реакций по каждому типу |
|
reactionUsers |
Пользователи по типам реакций |
|
ownReactions |
Реакции текущего пользователя |
Обработка ошибок
HTTP-статус: 400, 403
{
"error": "CHAT_ID_EMPTY",
"error_description": "CHAT_ID can`t be empty"
}
|
Название |
Описание |
|
error |
Строковый код ошибки. Может состоять из цифр, латинских букв и знака подчеркивания |
|
error_description |
Текстовое описание ошибки. Описание не предназначено для показа конечному пользователю в необработанном виде |
Возможные коды ошибок
|
Код |
Описание |
Значение |
|
|
CHAT_ID cant be empty |
Не передан обязательный параметр |
|
|
You do not have access to this chat |
Нет доступа к указанному чату |
Статусы и коды системных ошибок
HTTP-статус: 20x, 40x, 50x
Описанные ниже ошибки могут возникнуть при вызове любого метода
|
Статус |
Код |
Описание |
|
|
|
Возникла внутренняя ошибка сервера, обратитесь к администратору сервера или в техническую поддержку Битрикс24 |
|
|
|
Возникла внутренняя ошибка сервера, обратитесь к администратору сервера или в техническую поддержку Битрикс24 |
|
|
|
Превышен лимит на интенсивность запросов |
|
|
|
Текущий метод не разрешен для вызова с помощью batch |
|
|
|
Превышена максимальная длина параметров, переданных в метод batch |
|
|
|
Неверный access-токен или код вебхука |
|
|
|
Для вызовов методов требуется использовать протокол HTTPS |
|
|
|
REST API заблокирован из-за перегрузки. Это ручная индивидуальная блокировка, для снятия необходимо обращаться в техническую поддержку Битрикс24 |
|
|
|
REST API доступен только на коммерческих планах |
|
|
|
У пользователя, с чьим access-токеном или вебхуком был вызван метод, не хватает прав |
|
|
|
Манифест недоступен |
|
|
|
Запрос требует более высоких привилегий, чем предоставляет токен вебхука |
|
|
|
Предоставленный access-токен доступа истек |
|
|
|
Пользователь не имеет доступа к приложению. Это означает, что приложение установлено, но администратор портала разрешил доступ к этому приложению только конкретным пользователям |
|
|
|
Публичная часть сайта закрыта. Чтобы открыть публичную часть сайта на коробочной установке отключите опцию «Временное закрытие публичной части сайта». Путь к настройке: Рабочий стол > Настройки > Настройки продукта > Настройки модулей > Главный модуль > Временное закрытие публичной части сайта |
Продолжите изучение
- Получить список последних сообщений im.dialog.messages.get
- Установить признак «прочитано» у сообщений im.dialog.read
- Установить признак «не прочитано» у сообщений im.dialog.unread
- Отправить признак «Пользователь пишет» im.dialog.writing
- Отправить сообщение im.message.add
- Изменить сообщение im.message.update
- Удалить сообщение im.message.delete