Получить валюту по id crm.currency.get
Выберите инструмент для разработки с AI-агентом:
- используйте Битрикс24 Вайбкод, чтобы создать приложение для Битрикс24 по описанию задачи без знания языков программирования. Агент напишет код и разместит приложение на сервере без ручной настройки хостинга
- используйте MCP-сервер, чтобы разрабатывать интеграцию через REST API в своем проекте. Агент будет обращаться к официальной REST-документации
Scope:
crmКто может выполнять метод: любой пользователь с доступом к настройкам CRM
Метод получает данные валюты по её символьному идентификатору id по ISO 4217.
Примечание
Параметры локализации (настройки, зависящие от языка) будут возвращены для текущего языка портала.
Параметры метода
Обязательные параметры отмечены *
|
Название |
Описание |
|
Символьный идентификатор валюты. Соответствует стандарту ISO 4217. Можно получить методом crm.currency.list |
Примеры кода
Как использовать примеры в документации
curl -X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{"id":"RUB"}' \
https://**put_your_bitrix24_address**/rest/**put_your_user_id_here**/**put_your_webhook_here**/crm.currency.get
curl -X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{"id":"RUB","auth":"**put_access_token_here**"}' \
https://**put_your_bitrix24_address**/rest/crm.currency.get
// 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, ISODate } from '@bitrix24/b24jssdk'
declare const $b24: B24Frame
// Shape of the payload returned in result (match the "response handling" section of the page)
type CrmCurrencyResult = {
CURRENCY: string
AMOUNT_CNT: string
AMOUNT: string
SORT: string
BASE: string
FULL_NAME: string
LID: string
FORMAT_STRING: string
DEC_POINT: string
THOUSANDS_SEP: string | null
DECIMALS: string
DATE_UPDATE: ISODate | null
LANG: Record<string, CrmCurrencyLang>
}
type CrmCurrencyLang = {
FORMAT_STRING: string
FULL_NAME: string
DEC_POINT: string
THOUSANDS_SEP: string | null
DECIMALS: string
THOUSANDS_VARIANT: string
HIDE_ZERO: string
}
try {
const response = await $b24.actions.v2.call.make<CrmCurrencyResult>({
method: 'crm.currency.get',
params: {
id: 'RUB',
},
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:', result.CURRENCY, result.FULL_NAME)
}
} 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 getCurrency() {
try {
// Initialize the SDK inside a Bitrix24 frame
const $b24 = await B24Js.initializeB24Frame()
const response = await $b24.actions.v2.call.make({
method: 'crm.currency.get',
params: {
id: 'RUB',
},
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:', result.CURRENCY, result.FULL_NAME)
} catch (error) {
// Thrown on transport or SDK failures (AjaxError, SdkError, etc.)
console.error(error)
}
}
document.addEventListener('DOMContentLoaded', getCurrency)
</script>
try {
$response = $b24Service
->core
->call(
'crm.currency.get',
[
'id' => 'RUB',
]
);
$result = $response
->getResponseData()
->getResult();
if ($result->error()) {
error_log($result->error());
echo 'Error: ' . $result->error();
} else {
echo 'Success: ' . print_r($result->data(), true);
}
} catch (Throwable $e) {
error_log($e->getMessage());
echo 'Error calling crm.currency.get: ' . $e->getMessage();
}
from b24pysdk.client import BaseClient
from b24pysdk.errors import BitrixAPIError, BitrixSDKException
client: BaseClient
try:
bitrix_response = client.crm.currency.get(bitrix_id="RUB").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}")
BX24.callMethod(
"crm.currency.get",
{
id: "RUB"
},
)
.then(
function(result)
{
if (result.error())
{
console.error(result.error());
}
else
{
console.log(result.data());
}
},
function(error)
{
console.info(error);
}
);
require_once('crest.php');
$result = CRest::call(
'crm.currency.get',
[
'id' => 'RUB'
]
);
echo '<PRE>';
print_r($result);
echo '</PRE>';
Обработка ответа
HTTP-статус: 200
{
"result": {
"CURRENCY": "RUB",
"AMOUNT_CNT": "1",
"AMOUNT": "1.0000",
"SORT": "100",
"BASE": "Y",
"FULL_NAME": "Российский рубль",
"LID": "ru",
"FORMAT_STRING": "# ₽",
"DEC_POINT": ".",
"THOUSANDS_SEP": " ",
"DECIMALS": "2",
"DATE_UPDATE": "2024-01-29T12:28:40+02:00",
"LANG": {
"en": {
"FORMAT_STRING": "₽#",
"FULL_NAME": "Russian Ruble",
"DEC_POINT": ".",
"THOUSANDS_SEP": null,
"DECIMALS": "2",
"THOUSANDS_VARIANT": "C",
"HIDE_ZERO": "Y"
},
"ru": {
"FORMAT_STRING": "# ₽",
"FULL_NAME": "Российский рубль",
"DEC_POINT": ".",
"THOUSANDS_SEP": " ",
"DECIMALS": "2",
"THOUSANDS_VARIANT": "B",
"HIDE_ZERO": "Y"
}
}
},
"time": {
"start": 1718357792.091095,
"finish": 1718357792.889212,
"duration": 0.79811692237854,
"processing": 0.10800814628601074,
"date_start": "2024-06-14T11:36:32+02:00",
"date_finish": "2024-06-14T11:36:32+02:00",
"operating": 0
}
}
Возвращаемые данные
|
Название |
Описание |
|
result |
Объект с данными валюты |
|
time |
Информация о времени выполнения запроса |
Обработка ошибок
HTTP-статус: 400
{
"error": "",
"error_description": "Not found"
}
|
Название |
Описание |
|
error |
Строковый код ошибки. Может состоять из цифр, латинских букв и знака подчеркивания |
|
error_description |
Текстовое описание ошибки. Описание не предназначено для показа конечному пользователю в необработанном виде |
Возможные коды ошибок
|
Код |
Описание |
Значение |
|
Пустая строка |
Access denied. |
Недостаточно прав доступа |
|
Пустая строка |
Not found |
Валюта с указанным кодом не найдена |
Статусы и коды системных ошибок
HTTP-статус: 20x, 40x, 50x
Описанные ниже ошибки могут возникнуть при вызове любого метода
|
Статус |
Код |
Описание |
|
|
|
Возникла внутренняя ошибка сервера, обратитесь к администратору сервера или в техническую поддержку Битрикс24 |
|
|
|
Возникла внутренняя ошибка сервера, обратитесь к администратору сервера или в техническую поддержку Битрикс24 |
|
|
|
Превышен лимит на интенсивность запросов |
|
|
|
Метод заблокирован из-за превышения лимита на ресурсоемкость запросов. Блокировка снимается автоматически через 10 минут |
|
|
|
Текущий метод не разрешен для вызова с помощью batch |
|
|
|
Превышена максимальная длина параметров, переданных в метод batch |
|
|
|
Неверный access-токен или код вебхука |
|
|
|
Для вызовов методов требуется использовать протокол HTTPS |
|
|
|
REST API заблокирован из-за перегрузки. Это ручная индивидуальная блокировка, для снятия необходимо обращаться в техническую поддержку Битрикс24 |
|
|
|
REST API доступен только на коммерческих планах |
|
|
|
У пользователя, с чьим access-токеном или вебхуком был вызван метод, не хватает прав |
|
|
|
Манифест недоступен |
|
|
|
Запрос требует более высоких привилегий, чем предоставляет токен вебхука |
|
|
|
Предоставленный access-токен доступа истек |
|
|
|
Пользователь не имеет доступа к приложению. Это означает, что приложение установлено, но администратор портала разрешил доступ к этому приложению только конкретным пользователям |
|
|
|
Публичная часть сайта закрыта. Чтобы открыть публичную часть сайта на коробочной установке отключите опцию «Временное закрытие публичной части сайта». Путь к настройке: Рабочий стол > Настройки > Настройки продукта > Настройки модулей > Главный модуль > Временное закрытие публичной части сайта |