Добавить валюту crm.currency.add
Выберите инструмент для разработки с AI-агентом:
- используйте Битрикс24 Вайбкод, чтобы создать приложение для Битрикс24 по описанию задачи без знания языков программирования. Агент напишет код и разместит приложение на сервере без ручной настройки хостинга
- используйте MCP-сервер, чтобы разрабатывать интеграцию через REST API в своем проекте. Агент будет обращаться к официальной REST-документации
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)JS (TS)JS (UMD)PHPPythoncurl -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.add// This snippet is an ES module: top-level await requires type="module" or a bundler. // $b24 is an already-initialized SDK instance (see the SDK "Get started" guide). import { Text } from '@bitrix24/b24jssdk' import type { B24Frame } from '@bitrix24/b24jssdk' declare const $b24: B24Frame try { const response = await $b24.actions.v2.call.make<string>({ method: 'crm.currency.add', params: { fields: { CURRENCY: 'CNY', BASE: 'N', AMOUNT: 12.2251, AMOUNT_CNT: 1, SORT: 9000, LANG: { ru: { DECIMALS: 2, DEC_POINT: '.', FORMAT_STRING: '# CNY', FULL_NAME: 'Yuan', HIDE_ZERO: 'Y', THOUSANDS_VARIANT: 'S', }, en: { DECIMALS: 2, DEC_POINT: ',', FORMAT_STRING: '# CNY', FULL_NAME: 'Yuan', HIDE_ZERO: 'Y', THOUSANDS_SEP: '.', }, }, }, }, requestId: Text.getUuidRfc4122() }) // The payload is available only on a successful response if (!response.isSuccess) { console.error(response.getErrorMessages().join('; ')) } else { const result = response.getData()!.result console.info('Created currency id:', result) } } catch (error) { // Thrown on transport or SDK failures (AjaxError, SdkError, etc.) console.error(error) }<!-- Load the SDK (UMD build); it is exposed as the global B24Js --> <script src="https://unpkg.com/@bitrix24/b24jssdk@1/dist/umd/index.min.js"></script> <script> async function addCurrency() { try { // Initialize the SDK inside a Bitrix24 frame const $b24 = await B24Js.initializeB24Frame() const response = await $b24.actions.v2.call.make({ method: 'crm.currency.add', params: { fields: { CURRENCY: 'CNY', BASE: 'N', AMOUNT: 12.2251, AMOUNT_CNT: 1, SORT: 9000, LANG: { ru: { DECIMALS: 2, DEC_POINT: '.', FORMAT_STRING: '# CNY', FULL_NAME: 'Yuan', HIDE_ZERO: 'Y', THOUSANDS_VARIANT: 'S', }, en: { DECIMALS: 2, DEC_POINT: ',', FORMAT_STRING: '# CNY', FULL_NAME: 'Yuan', HIDE_ZERO: 'Y', THOUSANDS_SEP: '.', }, }, }, }, requestId: B24Js.Text.getUuidRfc4122() }) // The payload is available only on a successful response if (!response.isSuccess) { console.error(response.getErrorMessages().join('; ')) return } const result = response.getData().result console.info('Created currency id:', result) } catch (error) { // Thrown on transport or SDK failures (AjaxError, SdkError, etc.) console.error(error) } } document.addEventListener('DOMContentLoaded', addCurrency) </script>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>';from b24pysdk.client import BaseClient from b24pysdk.errors import BitrixAPIError, BitrixSDKException client: BaseClient try: bitrix_response = client.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": ".", }, }, }, ).response result = bitrix_response.result print(result) except BitrixAPIError as error: print( "Ошибка Bitrix API", f"error: {error.error}", f"error_description: {error.error_description}", sep="\n", ) except BitrixSDKException as error: print(f"Ошибка Bitrix SDK: {error.message}") except Exception as error: print(f"Непредвиденная ошибка: {error}") -
Создание индонезийской рупии
Предполагаем, что базовая валюта — рубль. Валюта имеет очень низкий курс — 1 рупия эквивалентна 0,00548 рубля. В этом случае номинал (AMOUNT_CNT) увеличиваем, чтобы задавать курс с требуемой точностью.
Как использовать примеры в документации
cURL (Webhook)cURL (OAuth)JS (TS)JS (UMD)PHPPythoncurl -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":"Rp#","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":"Rp#","FULL_NAME":"rupee","HIDE_ZERO":"Y","THOUSANDS_VARIANT":"C"}}},"auth":"**put_access_token_here**"}' \ https://**put_your_bitrix24_address**/rest/crm.currency.add// This snippet is an ES module: top-level await requires type="module" or a bundler. // $b24 is an already-initialized SDK instance (see the SDK "Get started" guide). import { Text } from '@bitrix24/b24jssdk' import type { B24Frame } from '@bitrix24/b24jssdk' declare const $b24: B24Frame try { const response = await $b24.actions.v2.call.make<string>({ method: 'crm.currency.add', params: { fields: { CURRENCY: 'IDR', AMOUNT: 54.8738, AMOUNT_CNT: 10000, SORT: 8000, LANG: { ru: { DECIMALS: 2, DEC_POINT: '.', FORMAT_STRING: 'Rp#', FULL_NAME: 'Rupee', HIDE_ZERO: 'Y', THOUSANDS_VARIANT: 'C', }, en: { DECIMALS: 2, DEC_POINT: '.', FORMAT_STRING: 'Rp#', FULL_NAME: 'Rupee', HIDE_ZERO: 'Y', THOUSANDS_VARIANT: 'C', }, }, }, }, requestId: Text.getUuidRfc4122() }) // The payload is available only on a successful response if (!response.isSuccess) { console.error(response.getErrorMessages().join('; ')) } else { const result = response.getData()!.result console.info('Created currency id:', result) } } catch (error) { // Thrown on transport or SDK failures (AjaxError, SdkError, etc.) console.error(error) }<!-- Load the SDK (UMD build); it is exposed as the global B24Js --> <script src="https://unpkg.com/@bitrix24/b24jssdk@1/dist/umd/index.min.js"></script> <script> async function addCurrency() { try { // Initialize the SDK inside a Bitrix24 frame const $b24 = await B24Js.initializeB24Frame() const response = await $b24.actions.v2.call.make({ method: 'crm.currency.add', params: { fields: { CURRENCY: 'IDR', AMOUNT: 54.8738, AMOUNT_CNT: 10000, SORT: 8000, LANG: { ru: { DECIMALS: 2, DEC_POINT: '.', FORMAT_STRING: 'Rp#', FULL_NAME: 'Rupee', HIDE_ZERO: 'Y', THOUSANDS_VARIANT: 'C', }, en: { DECIMALS: 2, DEC_POINT: '.', FORMAT_STRING: 'Rp#', FULL_NAME: 'Rupee', HIDE_ZERO: 'Y', THOUSANDS_VARIANT: 'C', }, }, }, }, requestId: B24Js.Text.getUuidRfc4122() }) // The payload is available only on a successful response if (!response.isSuccess) { console.error(response.getErrorMessages().join('; ')) return } const result = response.getData().result console.info('Created currency id:', result) } catch (error) { // Thrown on transport or SDK failures (AjaxError, SdkError, etc.) console.error(error) } } document.addEventListener('DOMContentLoaded', addCurrency) </script>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' => 'Rp#', 'FULL_NAME' => 'rupee', 'HIDE_ZERO' => 'Y', 'THOUSANDS_VARIANT' => 'C', ] ] ] ] ); echo '<PRE>'; print_r($result); echo '</PRE>';from b24pysdk.client import BaseClient from b24pysdk.errors import BitrixAPIError, BitrixSDKException client: BaseClient try: bitrix_response = client.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", }, }, }, ).response result = bitrix_response.result print(result) except BitrixAPIError as error: print( "Ошибка Bitrix API", f"error: {error.error}", f"error_description: {error.error_description}", sep="\n", ) except BitrixSDKException as error: print(f"Ошибка Bitrix SDK: {error.message}") except Exception as error: print(f"Непредвиденная ошибка: {error}")
Обработка ответа
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 |
|
|
|
Превышен лимит на интенсивность запросов |
|
|
|
Метод заблокирован из-за превышения лимита на ресурсоемкость запросов. Блокировка снимается автоматически через 10 минут |
|
|
|
Текущий метод не разрешен для вызова с помощью batch |
|
|
|
Превышена максимальная длина параметров, переданных в метод batch |
|
|
|
Неверный access-токен или код вебхука |
|
|
|
Для вызовов методов требуется использовать протокол HTTPS |
|
|
|
REST API заблокирован из-за перегрузки. Это ручная индивидуальная блокировка, для снятия необходимо обращаться в техническую поддержку Битрикс24 |
|
|
|
REST API доступен только на коммерческих планах |
|
|
|
У пользователя, с чьим access-токеном или вебхуком был вызван метод, не хватает прав |
|
|
|
Манифест недоступен |
|
|
|
Запрос требует более высоких привилегий, чем предоставляет токен вебхука |
|
|
|
Предоставленный access-токен доступа истек |
|
|
|
Пользователь не имеет доступа к приложению. Это означает, что приложение установлено, но администратор портала разрешил доступ к этому приложению только конкретным пользователям |
|
|
|
Публичная часть сайта закрыта. Чтобы открыть публичную часть сайта на коробочной установке отключите опцию «Временное закрытие публичной части сайта». Путь к настройке: Рабочий стол > Настройки > Настройки продукта > Настройки модулей > Главный модуль > Временное закрытие публичной части сайта |