Добавить валюту crm.currency.add
Scope:
crmКто может выполнять метод: любой пользователь с доступом к изменению настроек CRM
Метод добавляет новую валюту.
Для языков, используемых на портале, необходимо указать параметры локализации. Если этого не сделать, будут использованы параметры по умолчанию. Для конкретного языка можно задать параметры локализации методом crm.currency.localizations.set.
Параметры метода
Обязательные параметры отмечены *
|
Название |
Описание |
|
fields* |
Значения полей (подробное описание приведено ниже) для добавления новой валюты в виде структуры:
|
Параметр fields
Обязательные параметры отмечены *
|
Название |
Описание |
|
CURRENCY* |
Идентификатор валюты. Соответствует стандарту ISO 4217 |
|
BASE |
Признак, является ли валюта базовой. Возможные значения:
Значение по умолчанию — Важно Не рекомендуется менять базовую валюту через REST. Иначе потребуется изменить курсы всех валют |
|
AMOUNT_CNT* |
Номинал. В качестве номинала чаще всего используется |
|
AMOUNT* |
Курс обмена по отношению к базовой валюте |
|
SORT |
Положение в списке валют. Значение по умолчанию — |
|
LANG |
Параметры локализации валюты. Объект в формате Если указать не все языки, для оставшихся будут использоваться параметры локализации по умолчанию |
Параметр LANG
|
Название |
Описание |
|
DECIMALS* |
Число десятичных знаков дробной части |
|
DEC_POINT |
Десятичная точка при выводе |
|
FORMAT_STRING |
Шаблон формата |
|
FULL_NAME |
Название валюты на языке, для которого добавляется локализация |
|
HIDE_ZERO |
Признак, скрывать незначащие нули или нет |
|
THOUSANDS_SEP |
Разделитель триад |
|
THOUSANDS_VARIANT |
Код разделителя триад. Допустимые значения описаны в справочнике |
Примеры кода
-
Создание юаня с параметрами локализации (русский и английский языки)
Базовая валюта — рубль. Курс юаня — 12.2251 руб за 1 юань.
Как использовать примеры в документации
cURL (Webhook)cURL (OAuth)JSPHPcurl -X POST \ -H "Content-Type: application/json" \ -H "Accept: application/json" \ -d '{"fields":{"CURRENCY":"CNY","BASE":"N","AMOUNT":12.2251,"AMOUNT_CNT":1,"SORT":9000,"LANG":{"ru":{"DECIMALS":2,"DEC_POINT":".","FORMAT_STRING":"# CNY","FULL_NAME":"юань","HIDE_ZERO":"Y","THOUSANDS_VARIANT":"S"},"en":{"DECIMALS":2,"DEC_POINT":",","FORMAT_STRING":"# CNY","FULL_NAME":"yuan","HIDE_ZERO":"Y","THOUSANDS_SEP":"."}}}}' \ https://**put_your_bitrix24_address**/rest/**put_your_user_id_here**/**put_your_webhook_here**/crm.currency.addcurl -X POST \ -H "Content-Type: application/json" \ -H "Accept: application/json" \ -d '{"fields":{"CURRENCY":"CNY","BASE":"N","AMOUNT":12.2251,"AMOUNT_CNT":1,"SORT":9000,"LANG":{"ru":{"DECIMALS":2,"DEC_POINT":".","FORMAT_STRING":"# CNY","FULL_NAME":"юань","HIDE_ZERO":"Y","THOUSANDS_VARIANT":"S"},"en":{"DECIMALS":2,"DEC_POINT":",","FORMAT_STRING":"# CNY","FULL_NAME":"yuan","HIDE_ZERO":"Y","THOUSANDS_SEP":"."}}},"auth":"**put_access_token_here**"}' \ https://**put_your_bitrix24_address**/rest/crm.currency.addBX24.callMethod( "crm.currency.add", { fields: { CURRENCY: 'CNY', BASE: 'N', AMOUNT: 12.2251, AMOUNT_CNT: 1, SORT: 9000, LANG: { ru: { DECIMALS: 2, DEC_POINT: '.', FORMAT_STRING: '# CNY', FULL_NAME: 'юань', HIDE_ZERO: 'Y', THOUSANDS_VARIANT: 'S', }, en: { DECIMALS: 2, DEC_POINT: ',', FORMAT_STRING: '# CNY', FULL_NAME: 'yuan', HIDE_ZERO: 'Y', THOUSANDS_SEP: '.', }, }, } }, ) .then( function(result) { if (result.error()) { console.error(result.error()); } else { console.log(result); } }, function(error) { console.info(error); } );require_once('crest.php'); $result = CRest::call( 'crm.currency.add', [ 'fields' => [ 'CURRENCY' => 'CNY', 'BASE' => 'N', 'AMOUNT' => 12.2251, 'AMOUNT_CNT' => 1, 'SORT' => 9000, 'LANG' => [ 'ru' => [ 'DECIMALS' => 2, 'DEC_POINT' => '.', 'FORMAT_STRING' => '# CNY', 'FULL_NAME' => 'юань', 'HIDE_ZERO' => 'Y', 'THOUSANDS_VARIANT' => 'S', ], 'en' => [ 'DECIMALS' => 2, 'DEC_POINT' => ',', 'FORMAT_STRING' => '# CNY', 'FULL_NAME' => 'yuan', 'HIDE_ZERO' => 'Y', 'THOUSANDS_SEP' => '.', ], ], ] ] ); echo '<PRE>'; print_r($result); echo '</PRE>'; -
Создание индонезийской рупии
Предполагаем, что базовая валюта — рубль. Валюта имеет очень низкий курс — 1 рупия эквивалентна 0,00548 рубля. В этом случае номинал (AMOUNT_CNT) увеличиваем, чтобы задавать курс с требуемой точностью.
Как использовать примеры в документации
cURL (Webhook)cURL (OAuth)JSPHPcurl -X POST \ -H "Content-Type: application/json" \ -H "Accept: application/json" \ -d '{"fields":{"CURRENCY":"IDR","AMOUNT":54.8738,"AMOUNT_CNT":10000,"SORT":8000,"LANG":{"ru":{"DECIMALS":2,"DEC_POINT":".","FORMAT_STRING":"Rp#","FULL_NAME":"рупия","HIDE_ZERO":"Y","THOUSANDS_VARIANT":"C"},"en":{"DECIMALS":2,"DEC_POINT":".","FORMAT_STRING":"# CNY","FULL_NAME":"rupee","HIDE_ZERO":"Y","THOUSANDS_VARIANT":"C"}}}}' \ https://**put_your_bitrix24_address**/rest/**put_your_user_id_here**/**put_your_webhook_here**/crm.currency.addcurl -X POST \ -H "Content-Type: application/json" \ -H "Accept: application/json" \ -d '{"fields":{"CURRENCY":"IDR","AMOUNT":54.8738,"AMOUNT_CNT":10000,"SORT":8000,"LANG":{"ru":{"DECIMALS":2,"DEC_POINT":".","FORMAT_STRING":"Rp#","FULL_NAME":"рупия","HIDE_ZERO":"Y","THOUSANDS_VARIANT":"C"},"en":{"DECIMALS":2,"DEC_POINT":".","FORMAT_STRING":"# CNY","FULL_NAME":"rupee","HIDE_ZERO":"Y","THOUSANDS_VARIANT":"C"}}},"auth":"**put_access_token_here**"}' \ https://**put_your_bitrix24_address**/rest/crm.currency.addBX24.callMethod( "crm.currency.add", { fields: { CURRENCY: 'IDR', AMOUNT: 54.8738, AMOUNT_CNT: 10000, SORT: 8000, LANG: { ru: { DECIMALS: 2, DEC_POINT: '.', FORMAT_STRING: 'Rp#', FULL_NAME: 'рупия', HIDE_ZERO: 'Y', THOUSANDS_VARIANT: 'C' }, en: { DECIMALS: 2, DEC_POINT: '.', FORMAT_STRING: '# CNY', FULL_NAME: 'rupee', HIDE_ZERO: 'Y', THOUSANDS_VARIANT: 'C' } } } }, ) .then( function(result) { if (result.error()) { console.error(result.error()); } else { console.log(result); } }, function(error) { console.info(error); } );require_once('crest.php'); $result = CRest::call( 'crm.currency.add', [ 'fields' => [ 'CURRENCY' => 'IDR', 'AMOUNT' => 54.8738, 'AMOUNT_CNT' => 10000, 'SORT' => 8000, 'LANG' => [ 'ru' => [ 'DECIMALS' => 2, 'DEC_POINT' => '.', 'FORMAT_STRING' => 'Rp#', 'FULL_NAME' => 'рупия', 'HIDE_ZERO' => 'Y', 'THOUSANDS_VARIANT' => 'C', ], 'en' => [ 'DECIMALS' => 2, 'DEC_POINT' => '.', 'FORMAT_STRING' => '# CNY', 'FULL_NAME' => 'rupee', 'HIDE_ZERO' => 'Y', 'THOUSANDS_VARIANT' => 'C', ] ] ] ] ); echo '<PRE>'; print_r($result); echo '</PRE>';
Обработка ответа
HTTP-статус: 200
{
"result": "CNY",
"time": {
"start": 1717684463.467685,
"finish": 1717684465.282238,
"duration": 1.8145530223846436,
"processing": 0.12580394744873047,
"date_start": "2024-06-06T16:34:23+02:00",
"date_finish": "2024-06-06T16:34:25+02:00",
"operating": 0
}
}
Возвращаемые данные
|
Название |
Описание |
|
result |
Идентификатор созданной валюты |
|
time |
Информация о времени выполнения запроса |
Обработка ошибок
HTTP-статус: 400
{
"error": "",
"error_description": "Access denied."
}
|
Название |
Описание |
|
error |
Строковый код ошибки. Может состоять из цифр, латинских букв и знака подчеркивания |
|
error_description |
Текстовое описание ошибки. Описание не предназначено для показа конечному пользователю в необработанном виде |
Возможные коды ошибок
|
Код |
Описание |
Значение |
|
Пустая строка |
Access denied. |
Недостаточно прав доступа |
|
Пустая строка |
Модуль "Валюты" не найден! Пожалуйста, установите модуль "Валюты". |
|
|
|
Undefined array key "#FIELD#" |
Не указано обязательное поле #FIELD# (вместо #FIELD# будет подставлен код отсутствующего поля) |
|
|
Другие ошибки в данных для создания валюты |
Статусы и коды системных ошибок
HTTP-статус: 20x, 40x, 50x
Описанные ниже ошибки могут возникнуть при вызове любого метода
|
Статус |
Код |
Описание |
|
|
|
Возникла внутренняя ошибка сервера, обратитесь к администратору сервера или в техническую поддержку Битрикс24 |
|
|
|
Возникла внутренняя ошибка сервера, обратитесь к администратору сервера или в техническую поддержку Битрикс24 |
|
|
|
Превышен лимит на интенсивность запросов |
|
|
|
Текущий метод не разрешен для вызова с помощью batch |
|
|
|
Превышена максимальная длина параметров, переданных в метод batch |
|
|
|
Неверный access-токен или код вебхука |
|
|
|
Для вызовов методов требуется использовать протокол HTTPS |
|
|
|
REST API заблокирован из-за перегрузки. Это ручная индивидуальная блокировка, для снятия необходимо обращаться в техническую поддержку Битрикс24 |
|
|
|
REST API доступен только на коммерческих планах |
|
|
|
У пользователя, с чьим access-токеном или вебхуком был вызван метод, не хватает прав |
|
|
|
Манифест недоступен |
|
|
|
Запрос требует более высоких привилегий, чем предоставляет токен вебхука |
|
|
|
Предоставленный access-токен доступа истек |
|
|
|
Пользователь не имеет доступа к приложению. Это означает, что приложение установлено, но администратор портала разрешил доступ к этому приложению только конкретным пользователям |
|
|
|
Публичная часть сайта закрыта. Чтобы открыть публичную часть сайта на коробочной установке отключите опцию «Временное закрытие публичной части сайта». Путь к настройке: Рабочий стол > Настройки > Настройки продукта > Настройки модулей > Главный модуль > Временное закрытие публичной части сайта |
Продолжите изучение
- Обновить валюту crm.currency.update
- Получить валюту по id crm.currency.get
- Получить список валют crm.currency.list
- Удалить валюту crm.currency.delete
- Получить поля валюты crm.currency.fields