#Ответить на команду
POST /v1/bots/:botId/commands/:commandId/answer
Отправляет ответ на вызов slash-команды. Вызывайте из обработчика события ONIMBOTV2COMMANDADD.
#Поля запроса (body)
| Параметр | Тип | Обяз. | Описание |
|---|---|---|---|
messageId |
number | да | ID сообщения с вызовом команды (из события) |
message |
string | да | Текст ответа. Поддерживает BB-коды |
keyboard |
array | нет | Интерактивная клавиатура |
attach |
array/object | нет | ATTACH-блоки |
#Примеры
#curl — личный ключ
curl -X POST https://vibecode.bitrix24.tech/v1/bots/42/commands/7/answer \
-H "X-Api-Key: YOUR_API_KEY" \
-H "Content-Type: application/json" \
-d '{
"messageId": 1510,
"message": "[b]Справка по задачам[/b]\n\nДоступные действия:\n[SEND=/status]Проверить статус[/SEND]\n[SEND=/create]Создать задачу[/SEND]"
}'
#curl — OAuth-приложение
curl -X POST https://vibecode.bitrix24.tech/v1/bots/42/commands/7/answer \
-H "X-Api-Key: YOUR_APP_KEY" \
-H "Authorization: Bearer USER_SESSION_TOKEN" \
-H "Content-Type: application/json" \
-d '{
"messageId": 1510,
"message": "[b]Справка по задачам[/b]\n\nДоступные действия:\n[SEND=/status]Проверить статус[/SEND]\n[SEND=/create]Создать задачу[/SEND]"
}'
#JavaScript — личный ключ
const res = await fetch('https://vibecode.bitrix24.tech/v1/bots/42/commands/7/answer', {
method: 'POST',
headers: {
'X-Api-Key': 'YOUR_API_KEY',
'Content-Type': 'application/json',
},
body: JSON.stringify({
messageId: 1510,
message: '[b]Справка по задачам[/b]\n\nДоступные действия:\n[SEND=/status]Проверить статус[/SEND]',
}),
})
const { success, data } = await res.json()
#JavaScript — OAuth-приложение
const res = await fetch('https://vibecode.bitrix24.tech/v1/bots/42/commands/7/answer', {
method: 'POST',
headers: {
'X-Api-Key': 'YOUR_APP_KEY',
'Authorization': 'Bearer USER_SESSION_TOKEN',
'Content-Type': 'application/json',
},
body: JSON.stringify({
messageId: 1510,
message: '[b]Справка по задачам[/b]\n\nДоступные действия:\n[SEND=/status]Проверить статус[/SEND]',
}),
})
const { success, data } = await res.json()
#Поля ответа
| Поле | Тип | Описание |
|---|---|---|
data |
boolean | true при успешной отправке ответа |
#Пример ответа
{
"success": true,
"data": true
}
#Пример ответа при ошибке
404 — бот не найден:
{
"success": false,
"error": {
"code": "BOT_NOT_FOUND",
"message": "Bot 999 not found. Register it first via POST /v1/bots."
}
}
#Ошибки
| HTTP | Код | Описание |
|---|---|---|
| 400 | INVALID_BOT_ID |
botId не является числом |
| 404 | BOT_NOT_FOUND |
Бот с таким ID не найден |
| 403 | BOT_ACCESS_DENIED |
Бот принадлежит другому API-ключу |
| 502 | BITRIX_ERROR |
Ошибка Bitrix24 (текст ошибки в message) |
| 403 | SCOPE_DENIED |
API-ключ не имеет скоупа imbot |
| 401 | TOKEN_MISSING |
API-ключ не имеет настроенных токенов |
Полный список общих ошибок API — Ошибки.
#Известные особенности
Не требует членства в чате: бот может ответить на команду даже если не является участником чата. Доступ предоставляется временно через связку messageId + commandId. Если бот не участник — ответ отправляется как системное сообщение с именем бота.
#Смотрите также
- Зарегистрировать команду — создание команды
- События — получение события
ONIMBOTV2COMMANDADD - Форматирование текста — BB-коды для ответа
- Клавиатура — кнопки в ответе
- Бот-платформа — обзор, быстрый старт
- Лимиты и оптимизация — rate limits платформы