Зарегистрировать нового робота bizproc.robot.add
Scope:
bizprocКто может выполнять метод: администратор
Метод bizproc.robot.add регистрирует нового робота.
Работает только в контексте приложения.
Параметры метода
Обязательные параметры отмечены *
|
Название |
Описание |
|
CODE* |
Внутренний идентификатор робота. Является уникальным в рамках приложения. Допустимые символы — |
|
HANDLER* |
URL, на который робот будет отправлять данные через сервер очередей bitrix24. В ссылке должен быть тот же домен, на котором установлено приложение |
|
AUTH_USER_ID |
Идентификатор пользователя, токен которого будет передан приложению |
|
USE_SUBSCRIPTION |
Должен ли робот ожидать ответа от приложения. Возможные значения:
|
|
NAME* |
Название робота. Может быть строкой или ассоциативным массивом локализированных строк вида:
|
|
DESCRIPTION |
Описание робота. Может быть строкой или ассоциативным массивом локализированных строк вида:
|
|
PROPERTIES |
Объект с параметрами робота. Содержит объекты, каждый из которых описывает параметр робота. Системное название параметра должно начинаться с буквы и может содержать символы |
|
RETURN_PROPERTIES |
Объект с дополнительными результатами робота. Содержит объекты, каждый из которых описывает параметр робота. Параметр управляет возможностью робота ожидать ответа приложения и работать с данными, которые придут в ответе. Системное название параметра должно начинаться с буквы и может содержать символы |
|
DOCUMENT_TYPE |
Тип документа, который будет определять типы данных для параметров
Возможные варианты значений:
|
|
FILTER |
Объект с правилами ограничения робота по типу документа и редакции. Может содержать ключи:
Каждое правило в массиве может быть строкой или массивом типа документа в полном или частичном варианте. Чтобы ограничить роботов по редакции Битрикс24 укажите:
Примеры:
|
|
USE_PLACEMENT |
Дает возможность открывать дополнительные настройки робота в слайдере приложения. Возможные значения:
|
|
PLACEMENT_HANDLER* |
URL обработчика встройки на стороне приложения. Обязательное, если |
Объект PROPERTY
|
Название |
Описание |
|
Name |
Наименование параметра |
|
Description |
Описание параметра |
|
Type |
Тип параметра. Базовые значения:
|
|
Options |
Массив значений параметра типа список
|
|
Required |
Обязательность параметра. Возможные значения:
|
|
Multiple |
Множественность параметра. Возможные значения:
|
|
Default |
Значение параметра по умолчанию. Для |
Примеры объектов
// пример для типа select
'docType': {
'Name': {
'ru': 'Тип документа',
'en': 'Document type'
},
'Required': 'Y',
'Multiple': 'N',
'Default': 'pdf',
'Type': 'select',
'Options': {
'pdf': 'PDF',
'docx': 'DOCX'
}
}
// пример для типа bool
'saveDoc': {
'Name': {
'ru': 'Сохранить документ',
'en': 'Save document'
},
'Description': {
'ru': 'Присвоить порядковый номер',
'en': 'Assign a sequential number'
},
'Type': 'bool',
'Required': 'Y',
'Multiple': 'N',
'Default': 'Y'
}
// пример для типа string
'Parameters': {
'Name': {
'ru': 'Параметры шаблона',
'en': 'Template\'s parameters'
},
'Description': {
'ru': 'ParamID={=ParamValue}',
'en': 'ParamID={=ParamValue}'
},
'Type': 'string',
'Required': 'N',
'Multiple': 'Y'
}
Примеры кода
Как использовать примеры в документации
curl -X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{"CODE":"test_robot","HANDLER":"https://your_domain/robot.php","AUTH_USER_ID":1,"USE_SUBSCRIPTION":"Y","NAME":"Отправить сообщение","PROPERTIES":{"datetime":{"Name":"Во сколько","Type":"datetime"},"text":{"Name":"Текст","Type":"text"},"user":{"Name":"Кому","Type":"user","Default":"Автор;"}},"FILTER":{"INCLUDE":[["crm","CCrmDocumentDeal"],["crm","CCrmDocumentLead"]]},"auth":"**put_access_token_here**"}' \
https://**put_your_bitrix24_address**/rest/bizproc.robot.add
try
{
const response = await $b24.callMethod(
'bizproc.robot.add',
{
'CODE': 'test_robot',
'HANDLER': 'https://your_domain/robot.php',
'AUTH_USER_ID': 1,
'USE_SUBSCRIPTION': 'Y',
'NAME': 'Отправить сообщение',
'PROPERTIES': {
'datetime': {
'Name': 'Во сколько',
'Type': 'datetime'
},
'text': {
'Name': 'Текст',
'Type': 'text'
},
'user': {
'Name': 'Кому',
'Type': 'user',
'Default': 'Автор;'
}
},
'FILTER': {
INCLUDE: [
['crm', 'CCrmDocumentDeal'],
['crm', 'CCrmDocumentLead']
]
}
}
);
const result = response.getData().result;
alert("Успешно: " + result);
}
catch( error )
{
alert("Error: " + error);
}
try {
$result = $serviceBuilder
->getBizProcScope()
->robot()
->add(
'robot_code', // string $code
'https://example.com/handler', // string $handlerUrl
1, // int $b24AuthUserId
['en' => 'Robot Name'], // array $localizedRobotName
true, // bool $isUseSubscription
[], // array $properties
false, // bool $isUsePlacement
[] // array $returnProperties
);
if ($result->isSuccess()) {
print_r($result->getCoreResponse()->getResponseData()->getResult());
} else {
print("Failed to add robot.");
}
} catch (Throwable $e) {
print("Error: " . $e->getMessage());
}
BX24.callMethod(
'bizproc.robot.add',
{
'CODE': 'test_robot',
'HANDLER': 'https://your_domain/robot.php',
'AUTH_USER_ID': 1,
'USE_SUBSCRIPTION': 'Y',
'NAME': 'Отправить сообщение',
'PROPERTIES': {
'datetime': {
'Name': 'Во сколько',
'Type': 'datetime'
},
'text': {
'Name': 'Текст',
'Type': 'text'
},
'user': {
'Name': 'Кому',
'Type': 'user',
'Default': 'Автор;'
}
},
'FILTER': {
INCLUDE: [
['crm', 'CCrmDocumentDeal'],
['crm', 'CCrmDocumentLead']
]
}
},
function(result)
{
if(result.error())
alert("Error: " + result.error());
else
alert("Успешно: " + result.data());
}
);
require_once('crest.php');
$result = CRest::call(
'bizproc.robot.add',
[
'CODE' => 'test_robot',
'HANDLER' => 'https://your_domain/robot.php',
'AUTH_USER_ID' => 1,
'USE_SUBSCRIPTION' => 'Y',
'NAME' => 'Отправить сообщение',
'PROPERTIES' => [
'datetime' => [
'Name' => 'Во сколько',
'Type' => 'datetime'
],
'text' => [
'Name' => 'Текст',
'Type' => 'text'
],
'user' => [
'Name' => 'Кому',
'Type' => 'user',
'Default' => 'Автор;'
]
],
'FILTER' => [
'INCLUDE' => [
['crm', 'CCrmDocumentDeal'],
['crm', 'CCrmDocumentLead']
]
]
]
);
echo '<PRE>';
print_r($result);
echo '</PRE>';
Обработка ответа
HTTP-статус: 200
{
"result": true,
"time": {
"start": 1738148752.692647,
"finish": 1738148752.749058,
"duration": 0.056411027908325195,
"processing": 0.018677949905395508,
"date_start": "2025-01-29T14:05:52+03:00",
"date_finish": "2025-01-29T14:05:52+03:00",
"operating_reset_at": 1738149352,
"operating": 0
}
}
Возвращаемые данные
|
Название |
Описание |
|
result |
Возвращает |
|
time |
Информация о времени выполнения запроса |
Обработка ошибок
HTTP-статус: 400
{
"error": "ERROR_ACTIVITY_VALIDATION_FAILURE",
"error_description": "Empty activity code!"
}
|
Название |
Описание |
|
error |
Строковый код ошибки. Может состоять из цифр, латинских букв и знака подчеркивания |
|
error_description |
Текстовое описание ошибки. Описание не предназначено для показа конечному пользователю в необработанном виде |
Возможные коды ошибок
|
Код |
Сообщение об ошибке |
Описание |
|
|
Application context required |
Необходим контекст приложения |
|
|
Access denied! |
Метод выполнил не администратор |
|
|
Empty data! |
Не указаны поля с информацией |
|
|
Empty activity code! |
Не указан код робота |
|
|
Wrong activity code! |
Некорректный код робота |
|
|
Unsupported handler protocol |
Некорректный протокол хендлера http, https |
|
|
Wrong handler URL |
Невалидный урл хендлера |
|
|
Empty activity NAME! |
Не указано название робота |
|
|
Wrong properties array! |
Некорректно заполнены параметры |
|
|
Wrong property key <ключ>! |
Некорректный идентификатор свойства |
|
|
Empty property NAME <ключ>! |
Не указано название свойства |
|
|
Wrong activity FILTER! |
Некорректный фильтр |
|
|
Wrong activity DOCUMENT_TYPE! |
Некорректный |
|
|
Activity or Robot already installed! |
Робот с таким кодом уже установлен |
|
|
Activity or Robot already added! |
Робот уже был добавлен |
|
|
Activity save error! |
Не удалось сохранить робота, системная ошибка |
Статусы и коды системных ошибок
HTTP-статус: 20x, 40x, 50x
Описанные ниже ошибки могут возникнуть при вызове любого метода
|
Статус |
Код |
Описание |
|
|
|
Возникла внутренняя ошибка сервера, обратитесь к администратору сервера или в техническую поддержку Битрикс24 |
|
|
|
Возникла внутренняя ошибка сервера, обратитесь к администратору сервера или в техническую поддержку Битрикс24 |
|
|
|
Превышен лимит на интенсивность запросов |
|
|
|
Текущий метод не разрешен для вызова с помощью batch |
|
|
|
Превышена максимальная длина параметров, переданных в метод batch |
|
|
|
Неверный access-токен или код вебхука |
|
|
|
Для вызовов методов требуется использовать протокол HTTPS |
|
|
|
REST API заблокирован из-за перегрузки. Это ручная индивидуальная блокировка, для снятия необходимо обращаться в техническую поддержку Битрикс24 |
|
|
|
REST API доступен только на коммерческих планах |
|
|
|
У пользователя, с чьим access-токеном или вебхуком был вызван метод, не хватает прав |
|
|
|
Манифест недоступен |
|
|
|
Запрос требует более высоких привилегий, чем предоставляет токен вебхука |
|
|
|
Предоставленный access-токен доступа истек |
|
|
|
Пользователь не имеет доступа к приложению. Это означает, что приложение установлено, но администратор портала разрешил доступ к этому приложению только конкретным пользователям |
|
|
|
Публичная часть сайта закрыта. Чтобы открыть публичную часть сайта на коробочной установке отключите опцию «Временное закрытие публичной части сайта». Путь к настройке: Рабочий стол > Настройки > Настройки продукта > Настройки модулей > Главный модуль > Временное закрытие публичной части сайта |
Продолжите изучение
- Роботы приложений
- Обновить поля робота bizproc.robot.update
- Получить список зарегистрированных приложением роботов bizproc.robot.list
- Удалить зарегистрированного робота bizproc.robot.delete
- Вернуть параметры действию или роботу bizproc.event.send