steffenbrand / curr-curr
Delivers current exchange rates for EUR provided by the ECB as PHP objects.
Installs: 6 114
Dependents: 1
Suggesters: 0
Security: 0
Stars: 8
Watchers: 2
Forks: 1
Open Issues: 0
Requires
- php: ^7.3 || ^8.0
- guzzlehttp/guzzle: ^6.3
- psr/simple-cache: ^1.0
Requires (Dev)
- odan/cache: ^0.1.5
- phpunit/phpunit: ^9.5
This package is auto-updated.
Last update: 2025-01-04 20:42:02 UTC
README
Delivers current exchange rates for EUR provided by the ECB under https://www.ecb.europa.eu/stats/eurofxref/eurofxref-daily.xml as PHP objects.
How to install
composer require steffenbrand/curr-curr
How to use
Request exchange rate for specific currency
try { $cc = new CurrCurr(); $exchangeRate = $cc->getExchangeRateByCurrency(Currency::USD); $exchangeRate->getDate(); $exchangeRate->getCurrency(); $exchangeRate->getRate(); } catch (ExchangeRatesRequestFailedException $e) { // webservice might not be present } catch (ExchangeRatesMappingFailedException $e) { // webservice might not deliver what we expect } catch (CurrencyNotSupportedException $e) { // requested currency might not be provided }
Request all available exchange rates
try { $cc = new CurrCurr(); $exchangeRates = $cc->getExchangeRates(); $exchangeRates[Currency::USD]->getDate(); $exchangeRates[Currency::USD]->getCurrency(); $exchangeRates[Currency::USD]->getRate(); foreach ($exchangeRates as $exchangeRate) { $exchangeRate->getDate(); $exchangeRate->getCurrency(); $exchangeRate->getRate(); } } catch (ExchangeRatesRequestFailedException $e) { // webservice might not be present } catch (ExchangeRatesMappingFailedException $e) { // webservice might not deliver what we expect }
Using PSR-16 SimpleCache
CurrCurr does not provide its own SimpleCache implementation, however it does give you the possibility to inject any PSR-16 compliant implementation into the EcbClient. You just have to wrap it with a CacheConfig instance.
$cc = new CurrCurr( new EcbClient( EcbClient::DEFAULT_EXCHANGE_RATES_URL, new CacheConfig( new OpCache(sys_get_temp_dir() . '/cache') // Any PSR-16 compliant implementation // This example uses odan/cache ) ) );
You can provide your own key and time to live.
new CacheConfig( new OpCache(sys_get_temp_dir() . '/cache') CacheConfig::CACHE_UNTIL_MIDNIGHT, // time to live in seconds CacheConfig::DEFAULT_CACHE_KEY // key used for caching );
Mocking webservice response for Unit Testing your own project
CurrCurr allows you to inject your own implementation of the EcbClientInterface. But you can also use the provided EcbClientMock, which allows you to simulate 3 different responses.
$cc1 = new CurrCurr(new EcbClientMock(EcbClientMock::VALID_RESPONSE)); $cc2 = new CurrCurr(new EcbClientMock(EcbClientMock::USD_MISSING_RESPONSE)); $cc3 = new CurrCurr(new EcbClientMock(EcbClientMock::DATE_MISSING_RESPONSE));