Добавить обработчик кассы sale.cashbox.handler.add
Scope:
sale, cashboxКто может выполнять метод: администратор CRM (право «Разрешить изменять настройки»)
Метод добавляет REST-обработчик кассы.
Параметры метода
Обязательные параметры отмечены *
|
Название |
Описание |
|
CODE* |
Код REST-обработчика. Должен быть уникальным среди всех обработчиков |
|
NAME* |
Название REST-обработчика |
|
SORT |
Сортировка. Значение по умолчанию: |
|
SUPPORTS_FFD105 |
Поддерживает ли касса формат фискальных данных версии 1.05. Возможные значения:
Значение по умолчанию: |
|
SETTINGS* |
Настройки обработчика (подробное описание приведено ниже) |
Параметр SETTINGS
Обязательные параметры отмечены *
|
Название |
Описание |
|
PRINT_URL* |
Адрес, на который отправляются данные для печати чека |
|
CHECK_URL* |
Адрес, по которому происходит проверка статуса чека |
|
HTTP_VERSION |
Версия протокола HTTP, используемая для запросов. Возможные значения: Если параметр не заполнен, то для запросов используется HTTP |
|
CONFIG* |
Структура настроек (подробное описание приведено ниже), которые пользователь сможет устанавливать и изменять на странице редактирования кассы, а также при добавлении или обновлении кассы через REST. Каждый ключ в этом параметре задает один раздел на странице настроек, ключ является кодом раздела. Значения объекта описывают раздел и содержащиеся в нем настройки |
Параметр SETTINGS[CONFIG]
Обязательные параметры отмечены *
|
Название |
Описание |
|
LABEL* |
Заголовок раздела |
|
ITEMS* |
Список настроек раздела (подробное описание приведено ниже). Ключ является кодом настройки, значение — описанием настройки |
Параметр SETTINGS[CONFIG][код раздела][ITEMS]
Обязательные параметры отмечены *
|
Название |
Описание |
|
TYPE* |
Тип настройки. Возможные значения:
|
|
LABEL* |
Название настройки |
|
REQUIRED* |
Является ли настройка обязательной. Возможные значения:
|
|
DISABLED |
Отключена ли возможность редактирования настройки. Возможные значения:
Значение по умолчанию: |
|
MULTIPLE |
Является ли настройка множественной. Возможные значения:
Значение по умолчанию: |
|
MULTILINE |
Является ли поле многострочным. Используется для типа
Значение по умолчанию: |
|
OPTIONS* |
Список возможных значений свойства. Используется для типа Ключ объекта — значение свойства, значение ключа — название значения, отображаемое в интерфейсе |
|
TIME |
Есть ли возможность выбрать время. Используется для типа
Значение по умолчанию: |
Примеры кода
Как использовать примеры в документации
-X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{"CODE":"restcashbox01","NAME":"REST-касса 01","SORT":100,"SUPPORTS_FFD105":"Y","SETTINGS":{"PRINT_URL":"http://example.com/rest_print.php","CHECK_URL":"http://example.com/rest_check.php","HTTP_VERSION":"1.1","CONFIG":{"AUTH":{"LABEL":"Авторизация","ITEMS":{"KEYWORD":{"TYPE":"STRING","LABEL":"Кодовое слово"},"PREFERENCE":{"TYPE":"ENUM","LABEL":"Множественный выбор","REQUIRED":"Y","OPTIONS":{"FIRST":"Первый","SECOND":"Второй","THIRD":"Третий"}}}},"INTERACTION":{"LABEL":"Настройки взаимодействия с кассой","ITEMS":{"MODE":{"TYPE":"ENUM","LABEL":"Режим работы с кассой","OPTIONS":{"ACTIVE":"боевой","TEST":"тестовый"}}}}}}}' \
https://**put_your_bitrix24_address**/rest/**put_your_user_id_here**/**put_your_webhook_here**/sale.cashbox.handler.add
-X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{"CODE":"restcashbox01","NAME":"REST-касса 01","SORT":100,"SUPPORTS_FFD105":"Y","SETTINGS":{"PRINT_URL":"http://example.com/rest_print.php","CHECK_URL":"http://example.com/rest_check.php","HTTP_VERSION":"1.1","CONFIG":{"AUTH":{"LABEL":"Авторизация","ITEMS":{"KEYWORD":{"TYPE":"STRING","LABEL":"Кодовое слово"},"PREFERENCE":{"TYPE":"ENUM","LABEL":"Множественный выбор","REQUIRED":"Y","OPTIONS":{"FIRST":"Первый","SECOND":"Второй","THIRD":"Третий"}}}},"INTERACTION":{"LABEL":"Настройки взаимодействия с кассой","ITEMS":{"MODE":{"TYPE":"ENUM","LABEL":"Режим работы с кассой","OPTIONS":{"ACTIVE":"боевой","TEST":"тестовый"}}}}}},"auth":"**put_access_token_here**"}' \
https://**put_your_bitrix24_address**/rest/sale.cashbox.handler.add
try
{
const response = await $b24.callMethod(
"sale.cashbox.handler.add",
{
"CODE": "restcashbox01",
"NAME": "REST-касса 01",
"SORT": 100,
"SUPPORTS_FFD105": "Y",
"SETTINGS":
{
"PRINT_URL": "http://example.com/rest_print.php",
"CHECK_URL": "http://example.com/rest_check.php",
"HTTP_VERSION": "1.1",
"CONFIG":
{
"AUTH": {
"LABEL": "Авторизация",
"ITEMS": {
"KEYWORD": {
"TYPE": "STRING",
"LABEL": "Кодовое слово"
},
"PREFERENCE": {
"TYPE": "ENUM",
"LABEL": "Множественный выбор",
"REQUIRED": "Y",
"OPTIONS": {
"FIRST": "Первый",
"SECOND": "Второй",
"THIRD": "Третий",
}
}
}
},
"INTERACTION": {
"LABEL": "Настройки взаимодействия с кассой",
"ITEMS": {
"MODE": {
"TYPE": "ENUM",
"LABEL": "Режим работы с кассой",
"OPTIONS": {
"ACTIVE": "боевой",
"TEST": "тестовый"
}
}
}
}
}
}
}
);
const result = response.getData().result;
console.dir(result);
}
catch(error)
{
console.error(error);
}
try {
$response = $b24Service
->core
->call(
'sale.cashbox.handler.add',
[
'CODE' => 'restcashbox01',
'NAME' => 'REST-касса 01',
'SORT' => 100,
'SUPPORTS_FFD105' => 'Y',
'SETTINGS' => [
'PRINT_URL' => 'http://example.com/rest_print.php',
'CHECK_URL' => 'http://example.com/rest_check.php',
'HTTP_VERSION' => '1.1',
'CONFIG' => [
'AUTH' => [
'LABEL' => 'Авторизация',
'ITEMS' => [
'KEYWORD' => [
'TYPE' => 'STRING',
'LABEL' => 'Кодовое слово',
],
'PREFERENCE' => [
'TYPE' => 'ENUM',
'LABEL' => 'Множественный выбор',
'REQUIRED' => 'Y',
'OPTIONS' => [
'FIRST' => 'Первый',
'SECOND' => 'Второй',
'THIRD' => 'Третий',
],
],
],
],
'INTERACTION' => [
'LABEL' => 'Настройки взаимодействия с кассой',
'ITEMS' => [
'MODE' => [
'TYPE' => 'ENUM',
'LABEL' => 'Режим работы с кассой',
'OPTIONS' => [
'ACTIVE' => 'боевой',
'TEST' => 'тестовый',
],
],
],
],
],
],
]
);
$result = $response
->getResponseData()
->getResult();
echo 'Success: ' . print_r($result, true);
console.dir($result);
} catch (Throwable $e) {
error_log($e->getMessage());
echo 'Error adding cashbox handler: ' . $e->getMessage();
}
BX24.callMethod(
"sale.cashbox.handler.add",
{
"CODE": "restcashbox01",
"NAME": "REST-касса 01",
"SORT": 100,
"SUPPORTS_FFD105": "Y",
"SETTINGS":
{
"PRINT_URL": "http://example.com/rest_print.php",
"CHECK_URL": "http://example.com/rest_check.php",
"HTTP_VERSION": "1.1",
"CONFIG":
{
"AUTH": {
"LABEL": "Авторизация",
"ITEMS": {
"KEYWORD": {
"TYPE": "STRING",
"LABEL": "Кодовое слово"
},
"PREFERENCE": {
"TYPE": "ENUM",
"LABEL": "Множественный выбор",
"REQUIRED": "Y",
"OPTIONS": {
"FIRST": "Первый",
"SECOND": "Второй",
"THIRD": "Третий",
}
}
}
},
"INTERACTION": {
"LABEL": "Настройки взаимодействия с кассой",
"ITEMS": {
"MODE": {
"TYPE": "ENUM",
"LABEL": "Режим работы с кассой",
"OPTIONS": {
"ACTIVE": "боевой",
"TEST": "тестовый"
}
}
}
}
}
}
},
function(result)
{
if(result.error())
console.error(result.error());
else
console.dir(result.data());
}
);
require_once('crest.php');
$result = CRest::call(
'sale.cashbox.handler.add',
[
'CODE' => 'restcashbox01',
'NAME' => 'REST-касса 01',
'SORT' => 100,
'SUPPORTS_FFD105' => 'Y',
'SETTINGS' =>
[
'PRINT_URL' => 'http://example.com/rest_print.php',
'CHECK_URL' => 'http://example.com/rest_check.php',
'HTTP_VERSION' => '1.1',
'CONFIG' =>
[
'AUTH' =>
[
'LABEL' => 'Авторизация',
'ITEMS' =>
[
'KEYWORD' =>
[
'TYPE' => 'STRING',
'LABEL' => 'Кодовое слово'
],
'PREFERENCE' =>
[
'TYPE' => 'ENUM',
'LABEL' => 'Множественный выбор',
'REQUIRED' => 'Y',
'OPTIONS' =>
[
'FIRST' => 'Первый',
'SECOND' => 'Второй',
'THIRD' => 'Третий',
]
]
]
],
'INTERACTION' =>
[
'LABEL' => 'Настройки взаимодействия с кассой',
'ITEMS' =>
[
'MODE' =>
[
'TYPE' => 'ENUM',
'LABEL' => 'Режим работы с кассой',
'OPTIONS' =>
[
'ACTIVE' => 'боевой',
'TEST' => 'тестовый'
]
]
]
]
]
]
]
);
echo '<PRE>';
print_r($result);
echo '</PRE>';
Частые кейсы и сценарии
Обработка ответа
HTTP-статус: 200
{
"result": 5,
"time": {
"start": 1712132792.910734,
"finish": 1712132793.530359,
"duration": 0.6196250915527344,
"processing": 0.032338857650756836,
"date_start": "2024-04-03T10:26:32+02:00",
"date_finish": "2024-04-03T10:26:33+02:00",
"operating_reset_at": 1705765533,
"operating": 3.3076241016387939
}
}
Возвращаемые данные
|
Название |
Описание |
|
result |
Идентификатор созданного обработчика |
|
time |
Информация о времени выполнения запроса |
Обработка ошибок
HTTP-статус: 400, 403
{
"error": "ERROR_HANDLER_ALREADY_EXIST",
"error_description": "Handler already exists!"
}
|
Название |
Описание |
|
error |
Строковый код ошибки. Может состоять из цифр, латинских букв и знака подчеркивания |
|
error_description |
Текстовое описание ошибки. Описание не предназначено для показа конечному пользователю в необработанном виде |
Возможные коды ошибок
|
Код |
Описание |
Статус |
|
|
Недостаточно прав для добавления обработчика |
403 |
|
|
Не указано значение обязательного поля либо значение одного из полей указано неверно |
400 |
|
|
Обработчик с кодом, указанным в параметре |
400 |
|
|
Прочие ошибки. Более подробную информацию об ошибке можно найти в |
400 |
Статусы и коды системных ошибок
HTTP-статус: 20x, 40x, 50x
Описанные ниже ошибки могут возникнуть при вызове любого метода
|
Статус |
Код |
Описание |
|
|
|
Возникла внутренняя ошибка сервера, обратитесь к администратору сервера или в техническую поддержку Битрикс24 |
|
|
|
Возникла внутренняя ошибка сервера, обратитесь к администратору сервера или в техническую поддержку Битрикс24 |
|
|
|
Превышен лимит на интенсивность запросов |
|
|
|
Текущий метод не разрешен для вызова с помощью batch |
|
|
|
Превышена максимальная длина параметров, переданных в метод batch |
|
|
|
Неверный access-токен или код вебхука |
|
|
|
Для вызовов методов требуется использовать протокол HTTPS |
|
|
|
REST API заблокирован из-за перегрузки. Это ручная индивидуальная блокировка, для снятия необходимо обращаться в техническую поддержку Битрикс24 |
|
|
|
REST API доступен только на коммерческих планах |
|
|
|
У пользователя, с чьим access-токеном или вебхуком был вызван метод, не хватает прав |
|
|
|
Манифест недоступен |
|
|
|
Запрос требует более высоких привилегий, чем предоставляет токен вебхука |
|
|
|
Предоставленный access-токен доступа истек |
|
|
|
Пользователь не имеет доступа к приложению. Это означает, что приложение установлено, но администратор портала разрешил доступ к этому приложению только конкретным пользователям |
|
|
|
Публичная часть сайта закрыта. Чтобы открыть публичную часть сайта на коробочной установке отключите опцию «Временное закрытие публичной части сайта». Путь к настройке: Рабочий стол > Настройки > Настройки продукта > Настройки модулей > Главный модуль > Временное закрытие публичной части сайта |
Страница PRINT_URL
Страница PRINT_URL — адрес, на который отправляются данные для печати чека.
Пример данных, отправляемых на PRINT_URL
{
"type": "sell",
"calculated_sign": "income",
"unique_id": 85,
"items": [
{
"name": "Товар",
"base_price": 12000.0,
"price": 9600.0,
"sum": 9600.0,
"currency": "RUB",
"quantity": 1,
"measure_code": "796",
"vat": 3,
"vat_sum": 1600.0,
"payment_object": "commodity_marking",
"nomenclature_code": "DM �Yߠ�Q:4H7/3f^7fZ1",
"marking_code": "011390002199781321Q:4H7/3f^7fZ1",
"barcode": "1234567890",
"discount": {
"discount": 2400.0
},
"payment_method": "full_payment"
}
],
"date_create": 1712235417,
"payments": [
{
"type": "cash",
"is_cash": "Y",
"sum": 1000,
"currency": "RUB"
}
],
"client_email": "client@example.com",
"client_phone": "+123456789",
"total_sum": 9600.0,
"uuid": "check|example.com|85",
"operation": "income",
"number_kkm": "",
"service_email": "admin@example.com",
"cashbox_params": {
"AUTH": {
"LOGIN": "user123",
"PASSWORD": "top_secret!"
},
"COMPANY": {
"INN": "123"
},
"INTERACTION": {
"MODE": "ACTIVE"
}
}
}
Структура POST-параметров, отправляемых на PRINT_URL
|
Название |
Описание |
|
type |
Тип чека. Значения:
|
|
operation |
Признак прихода/расхода. Значения:
|
|
calculated |
Аналогично |
|
unique_id |
ID чека в базе данных портала |
|
items |
Массив товаров в чеке (подробное описание приведено ниже) |
|
date_create |
Дата создания чека ( |
|
payments |
Массив оплат (подробное описание приведено ниже) |
|
client_email |
E-mail клиента (при наличии) |
|
client_phone |
Номер телефона клиента (при наличии) |
|
total_sum |
Общая сумма по чеку |
|
uuid |
Идентификатор документа во внешней системе (портал Битрикс24) |
|
service_email |
Email (из настроек кассы) |
Параметр items
|
Название |
Описание |
|
name |
Название товара |
|
base_price |
Цена товара без учета скидок и наценок |
|
price |
Цена продажи |
|
sum |
Сумма позиции |
|
quantity |
Количество товара |
|
vat |
Идентификатор налога. Он может быть использован в методе catalog.vat.get для получения информации по налогу |
|
vat_sum |
Cумма налога |
|
barcode |
Штрихкод. Используется при включенном складском учете и передаче товара с уникальным штрихкодом |
|
nomenclature_code |
Код товарной номенклатуры в двоичном представлении (при наличии) |
|
marking_code |
Код товарной номенклатуры (при наличии) |
|
payment_object |
Признак предмета расчета. Стандартные значения:
|
|
payment_method |
Признак способа расчета. Значения:
|
|
supplier_info |
Агентские реквизиты при использовании агентских схем (подробное описание приведено ниже) |
|
discount |
Скидка на товар. Ключ является устаревшим и больше не используется. |
Параметр supplier_info
|
Название |
Описание |
|
phones |
Номера телефонов |
|
name |
Название поставщика |
|
inn |
ИНН поставщика |
Параметр payments
|
Название |
Описание |
|
type |
Тип оплаты. Значения:
|
|
is_cash |
Производится ли оплата наличными ( |
|
sum |
Сумма оплаты |
|
currency |
Валюта оплаты |
Страница CHECK_URL
Страница CHECK_URL — адрес, по которому проверяется успешность печати чека.
Запрос по адресу CHECK_URL производится либо по обращению менеджера, либо автоматически спустя некоторое время после успешной печати чека.
Пример данных, отправляемых на CHECK_URL
{
"uuid": "00112233-4455-6677-8899-aabbccddeeff"
}
Структура POST-параметров, отправляемых на CHECK_URL
|
Название |
Описание |
|
uuid |
Идентификатор чека |
Продолжите изучение
- Обновить данные обработчика кассы sale.cashbox.handler.update
- Получить список доступных обработчиков касс sale.cashbox.handler.list
- Удалить обработчик кассы sale.cashbox.handler.delete
- Добавить кассу sale.cashbox.add
- Обновить существующую кассу sale.cashbox.update
- Получить список настроенных касс sale.cashbox.list
- Удалить кассу sale.cashbox.delete
- Сохранить результат печати чека sale.cashbox.check.apply
- Как подключить кассу к Битрикс24