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

dev-master 2025-11-14 12:06 UTC

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).

Использование напрямую

  1. Получить клиент
use Bitrix\Main\Loader;
use Bitrix\Main\DI\ServiceLocator;
use Kosmosafive\CBRRates\CBRApiInterface;

$api = ServiceLocator::getInstance()->get(CBRApiInterface::class);
$client = $api->getClient();
  1. Выполнить запрос
$rateCollection = (new Route\Scripts\XmlDaily($client))->get();

Использование сервиса-обертки

Реализованы методы:

  • получение котировок на заданный на день | getDailyRates(?Type\Date $date = null)
  • справочник по кодам валют | getCurrencies()
  • обновление котировок на заданный день | updateDailyRates(Type\Date $date)
  1. Получить сервис
use Bitrix\Main\Loader;
use Bitrix\Main\DI\ServiceLocator;
use Kosmosafive\CBRRates\Service\ApiServiceInterface;

$apiService = ServiceLocator::getInstance()->get(ApiServiceInterface::class);
  1. Выполнить запрос
$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)