kosmosafive / kosmosafive.cbrrates
Курсы валют ЦБ РФ
Installs: 0
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
Type:bitrix-d7-module
pkg:composer/kosmosafive/kosmosafive.cbrrates
Requires
- php: >=8.3
- kosmosafive/bitrix-diag: ^1.1
- kosmosafive/bitrix-ds: ^1.4
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.89
- lendable/composer-license-checker: ^1.2
- monolog/monolog: ^3.9
- phpstan/phpstan: ^2.1
- rector/rector: ^2.2
- roave/security-advisories: dev-latest
- shipmonk/composer-dependency-analyser: ^1.8
This package is auto-updated.
Last update: 2025-11-14 12:12:49 UTC
README
Получение котировок валют Центрального банка Российской Федерации.
Установка
В composer.json (пример для директории local) проекта добавьте
{
"require": {
"wikimedia/composer-merge-plugin": "dev-master"
},
"config": {
"allow-plugins": {
"wikimedia/composer-merge-plugin": true
}
},
"extra": {
"merge-plugin": {
"require": [
"../bitrix/composer-bx.json",
"modules/*/composer.json"
],
"recurse": true,
"replace": true,
"ignore-duplicates": false,
"merge-dev": true,
"merge-extra": false,
"merge-extra-deep": false,
"merge-scripts": false
},
"installer-paths": {
"modules/{$name}/": [
"type:bitrix-d7-module"
]
}
}
}
- установить модуль
Конфигурация модуля
Конфигурацию рекомендуется указывать в файле /bitrix/.settings_extra.php.
- adapter — настройки адаптера
return [ 'kosmosafive.cbrrates' => [ 'value' => [ 'adapter' => [ 'bitrix' => [ 'http_client_options' => [ 'redirect' => true, ], ], ], ] ] ];
Использование
Отправлять запросы можно как напрямую (сервис Kosmosafive\CBRRates\CBRApiInterface::class), так и с помощью сервиса-обертки (сервис Kosmosafive\CBRRates\Service\ApiServiceInterface::class).
Использование напрямую
- Получить клиент
use Bitrix\Main\Loader; use Bitrix\Main\DI\ServiceLocator; use Kosmosafive\CBRRates\CBRApiInterface; $api = ServiceLocator::getInstance()->get(CBRApiInterface::class); $client = $api->getClient();
- Выполнить запрос
$rateCollection = (new Route\Scripts\XmlDaily($client))->get();
Использование сервиса-обертки
Реализованы методы:
- получение котировок на заданный на день | getDailyRates(?Type\Date $date = null)
- справочник по кодам валют | getCurrencies()
- обновление котировок на заданный день | updateDailyRates(Type\Date $date)
- Получить сервис
use Bitrix\Main\Loader; use Bitrix\Main\DI\ServiceLocator; use Kosmosafive\CBRRates\Service\ApiServiceInterface; $apiService = ServiceLocator::getInstance()->get(ApiServiceInterface::class);
- Выполнить запрос
$rateCollection = $apiService->getDailyRates();
Клиент
Поддерживается множество клиентов. Клиент идентифицируется по ключу. По умолчанию создается клиент с ключом default. Добавить собственный клиент можно программно.
use Kosmosafive\CBRRates\Options; $clientKey = 'custom'; $options = new Options(); $client = new Client($options); $addClientResult = $apiService->addClient($clientKey, $client); $client = $apiService->getClient($clientKey);
События
onGetClient
Вызывается при вызове метода $apiService->getClient, когда клиент не был найден. В параметрах передается key — идентификатор запрошенного клиента. Обратно необходимо вернуть Клиент в параметре client.
Маршруты
- Scripts
-
- XmlDaily: get
-
- XmlValFul: get
Логирование
Реализована поддержка логгера, реализующего интерфейс PSR-3, указанного в конфигурации системы (Разработчик Bitrix Framework: Логгеры).
Расширенный логгер доступен при реализации интерфейса Kosmosafive\CBRRates\Diag\Logger\HttpLoggerInterface:
namespace Kosmosafive\CBRRates\Diag\Logger; use Kosmosafive\CBRRates\Http\RequestInterface; use Kosmosafive\CBRRates\Http\ResponseInterface; interface HttpLoggerInterface { public function logRequest(string $level, RequestInterface $request): void; public function logResponse(string $level, ResponseInterface $response): void; }
Модуль содержит расширенную файловую реализацию логгера — Kosmosafive\CBRRates\Diag\Logger\FileHttpLogger
Поиск логгера будет осуществлен по ключам kosmosafive.cbrrates и default.
Исключения
- Kosmosafive\CBRRates\Exception\Exception
- Kosmosafive\CBRRates\Http\Exception\RequestException
Интерфейс командной строки
Обновление котировок за указанный день \ период
kosmosafive.cbrrates:update-daily-rates <from> [<to>]
- from — Дата \ Дата начала периода (YYYY-MM-DD)
- to — (опционально) Дата конца периода (YYYY-MM-DD)