Обновить валюту crm.currency.update
Выберите инструмент для разработки с AI-агентом:
- используйте Битрикс24 Вайбкод, чтобы создать приложение для Битрикс24 по описанию задачи без знания языков программирования. Агент напишет код и разместит приложение на сервере без ручной настройки хостинга
- используйте MCP-сервер, чтобы разрабатывать интеграцию через REST API в своем проекте. Агент будет обращаться к официальной REST-документации
Scope:
crmКто может выполнять метод: любой пользователь с доступом к изменению настроек CRM
Метод обновляет существующую валюту.
Параметры
|
Название |
Описание |
|
ID |
Идентификатор валюты. Соответствует стандарту ISO 4217. Идентификатор можно получить методом crm.currency.list |
|
fields |
Значения полей (подробное описание приведено ниже) для обновления валюты в виде структуры:
|
Параметр fields
Обязательные параметры отмечены *
|
Название |
Описание |
|
SORT |
Положение в списке валют. Значение по умолчанию — |
|
AMOUNT_CNT* |
Номинал. В качестве номинала чаще всего используется |
|
AMOUNT* |
Курс обмена по отношению к базовой валюте |
|
BASE |
Признак, является ли валюта базовой. Возможные значения:
Значение по умолчанию — Важно Не рекомендуется менять базовую валюту через REST. Иначе необходимо будет изменить курсы всех валют |
|
LANG |
Параметры локализации валюты. Объект в формате Если указать не все языки, для оставшихся будут использоваться параметры локализации по умолчанию |
Параметр LANG
|
Название |
Описание |
|
DECIMALS* |
Число десятичных знаков дробной части |
|
DEC_POINT |
Десятичная точка при выводе |
|
FORMAT_STRING |
Шаблон формата |
|
FULL_NAME |
Название валюты на языке, для которого добавляется локализация |
|
HIDE_ZERO |
Признак, скрывать незначащие нули или нет |
|
THOUSANDS_SEP |
Разделитель триад |
|
THOUSANDS_VARIANT |
Код разделителя триад. Допустимые значения смотрите в справочнике crm_currency_localization |
Примеры
-
Изменение курса юаня по отношению к базовой валюте
Как использовать примеры в документации
cURL (Webhook)cURL (OAuth)JS (TS)JS (UMD)PHPPythoncurl -X POST \ -H "Content-Type: application/json" \ -H "Accept: application/json" \ -d '{"ID":"CNY","fields":{"AMOUNT":15.3449}}' \ https://**put_your_bitrix24_address**/rest/**put_your_user_id_here**/**put_your_webhook_here**/crm.currency.updatecurl -X POST \ -H "Content-Type: application/json" \ -H "Accept: application/json" \ -d '{"ID":"CNY","fields":{"AMOUNT":15.3449},"auth":"**put_access_token_here**"}' \ https://**put_your_bitrix24_address**/rest/crm.currency.update// 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<boolean>({ method: 'crm.currency.update', params: { ID: 'CNY', fields: { AMOUNT: 15.3449, }, }, 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('Currency updated:', 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 updateCurrency() { try { // Initialize the SDK inside a Bitrix24 frame const $b24 = await B24Js.initializeB24Frame() const response = await $b24.actions.v2.call.make({ method: 'crm.currency.update', params: { ID: 'CNY', fields: { AMOUNT: 15.3449, }, }, 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('Currency updated:', result) } catch (error) { // Thrown on transport or SDK failures (AjaxError, SdkError, etc.) console.error(error) } } document.addEventListener('DOMContentLoaded', updateCurrency) </script>require_once('crest.php'); $result = CRest::call( 'crm.currency.update', [ 'ID' => 'CNY', 'fields' => [ 'AMOUNT' => 15.3449, ] ] ); 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.update( bitrix_id="CNY", fields={ "AMOUNT": 15.3449, }, ).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}") -
Изменение локализаций валюты (на примере доллара США)
После выполнения этого примера для валюты USD будут изменены (либо добавлены) локализации только для английского и немецкого языков. Локализации для остальных языков, если они были, не изменятся.
Данный пример аналогичен работе метода crm.currency.localizations.set
Как использовать примеры в документации
cURL (Webhook)cURL (OAuth)JS (TS)JS (UMD)PHPPythoncurl -X POST \ -H "Content-Type: application/json" \ -H "Accept: application/json" \ -d '{"ID":"USD","fields":{"LANG":{"en":{"DECIMALS":2,"DEC_POINT":".","FORMAT_STRING":"$#","FULL_NAME":"доллар США","HIDE_ZERO":"Y","THOUSANDS_VARIANT":"S"},"de":{"DECIMALS":2,"DEC_POINT":".","FORMAT_STRING":"# $","FULL_NAME":"US-Dollar","HIDE_ZERO":"Y","THOUSANDS_VARIANT":"C"}}}}' \ https://**put_your_bitrix24_address**/rest/**put_your_user_id_here**/**put_your_webhook_here**/crm.currency.updatecurl -X POST \ -H "Content-Type: application/json" \ -H "Accept: application/json" \ -d '{"ID":"USD","fields":{"LANG":{"en":{"DECIMALS":2,"DEC_POINT":".","FORMAT_STRING":"$#","FULL_NAME":"доллар США","HIDE_ZERO":"Y","THOUSANDS_VARIANT":"S"},"de":{"DECIMALS":2,"DEC_POINT":".","FORMAT_STRING":"# $","FULL_NAME":"US-Dollar","HIDE_ZERO":"Y","THOUSANDS_VARIANT":"C"}}},"auth":"**put_access_token_here**"}' \ https://**put_your_bitrix24_address**/rest/crm.currency.update// 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<boolean>({ method: 'crm.currency.update', params: { ID: 'USD', fields: { LANG: { en: { DECIMALS: 2, DEC_POINT: '.', FORMAT_STRING: '$#', FULL_NAME: 'US Dollar', HIDE_ZERO: 'Y', THOUSANDS_VARIANT: 'S', }, de: { DECIMALS: 2, DEC_POINT: '.', FORMAT_STRING: '# $', FULL_NAME: 'US-Dollar', 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('Currency updated:', 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 updateCurrency() { try { // Initialize the SDK inside a Bitrix24 frame const $b24 = await B24Js.initializeB24Frame() const response = await $b24.actions.v2.call.make({ method: 'crm.currency.update', params: { ID: 'USD', fields: { LANG: { en: { DECIMALS: 2, DEC_POINT: '.', FORMAT_STRING: '$#', FULL_NAME: 'US Dollar', HIDE_ZERO: 'Y', THOUSANDS_VARIANT: 'S', }, de: { DECIMALS: 2, DEC_POINT: '.', FORMAT_STRING: '# $', FULL_NAME: 'US-Dollar', 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('Currency updated:', result) } catch (error) { // Thrown on transport or SDK failures (AjaxError, SdkError, etc.) console.error(error) } } document.addEventListener('DOMContentLoaded', updateCurrency) </script>require_once('crest.php'); $result = CRest::call( 'crm.currency.update', [ 'ID' => 'USD', 'fields' => [ 'LANG' => [ 'en' => [ 'DECIMALS' => 2, 'DEC_POINT' => '.', 'FORMAT_STRING' => '$#', 'FULL_NAME' => 'доллар США', 'HIDE_ZERO' => 'Y', 'THOUSANDS_VARIANT' => 'S', ], 'de' => [ 'DECIMALS' => 2, 'DEC_POINT' => '.', 'FORMAT_STRING' => '# $', 'FULL_NAME' => 'US-Dollar', '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.update( bitrix_id="USD", fields={ "LANG": { "en": { "DECIMALS": 2, "DEC_POINT": ".", "FORMAT_STRING": "$#", "FULL_NAME": "доллар США", "HIDE_ZERO": "Y", "THOUSANDS_VARIANT": "S", }, "de": { "DECIMALS": 2, "DEC_POINT": ".", "FORMAT_STRING": "# $", "FULL_NAME": "US-Dollar", "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": true,
"time": {
"start": 1717764521.938284,
"finish": 1717764522.516576,
"duration": 0.5782921314239502,
"processing": 0.07656002044677734,
"date_start": "2024-06-07T14:48:41+02:00",
"date_finish": "2024-06-07T14:48:42+02:00",
"operating": 0
}
}
Возвращаемые данные
|
Название |
Описание |
|
result |
Результат обновления валюты |
|
time |
Информация о времени выполнения запроса |
Обработка ошибок
HTTP-статус: 400
{
"error": "",
"error_description": "Access denied."
}
|
Название |
Описание |
|
error |
Строковый код ошибки. Может состоять из цифр, латинских букв и знака подчеркивания |
|
error_description |
Текстовое описание ошибки. Описание не предназначено для показа конечному пользователю в необработанном виде |
Возможные коды ошибок
|
Код |
Описание |
Значение |
|
Пустая строка |
Access denied. |
Недостаточно прав доступа |
|
Пустая строка |
Модуль "Валюты" не найден! Пожалуйста, установите модуль "Валюты". |
|
|
|
Другие ошибки в данных для изменения валюты |
Статусы и коды системных ошибок
HTTP-статус: 20x, 40x, 50x
Описанные ниже ошибки могут возникнуть при вызове любого метода
|
Статус |
Код |
Описание |
|
|
|
Возникла внутренняя ошибка сервера, обратитесь к администратору сервера или в техническую поддержку Битрикс24 |
|
|
|
Возникла внутренняя ошибка сервера, обратитесь к администратору сервера или в техническую поддержку Битрикс24 |
|
|
|
Превышен лимит на интенсивность запросов |
|
|
|
Метод заблокирован из-за превышения лимита на ресурсоемкость запросов. Блокировка снимается автоматически через 10 минут |
|
|
|
Текущий метод не разрешен для вызова с помощью batch |
|
|
|
Превышена максимальная длина параметров, переданных в метод batch |
|
|
|
Неверный access-токен или код вебхука |
|
|
|
Для вызовов методов требуется использовать протокол HTTPS |
|
|
|
REST API заблокирован из-за перегрузки. Это ручная индивидуальная блокировка, для снятия необходимо обращаться в техническую поддержку Битрикс24 |
|
|
|
REST API доступен только на коммерческих планах |
|
|
|
У пользователя, с чьим access-токеном или вебхуком был вызван метод, не хватает прав |
|
|
|
Манифест недоступен |
|
|
|
Запрос требует более высоких привилегий, чем предоставляет токен вебхука |
|
|
|
Предоставленный access-токен доступа истек |
|
|
|
Пользователь не имеет доступа к приложению. Это означает, что приложение установлено, но администратор портала разрешил доступ к этому приложению только конкретным пользователям |
|
|
|
Публичная часть сайта закрыта. Чтобы открыть публичную часть сайта на коробочной установке отключите опцию «Временное закрытие публичной части сайта». Путь к настройке: Рабочий стол > Настройки > Настройки продукта > Настройки модулей > Главный модуль > Временное закрытие публичной части сайта |