2017 © Pedro Peláez
 

library currency-php

A small package to facilitate currency conversions in PHP.

image

tomwright/currency-php

A small package to facilitate currency conversions in PHP.

  • Tuesday, October 24, 2017
  • by TomWright
  • Repository
  • 1 Watchers
  • 0 Stars
  • 174 Installations
  • PHP
  • 2 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 5 Versions
  • 0 % Grown

The README.md

CurrencyPHP

Build Status Latest Stable Version Total Downloads Monthly Downloads Daily Downloads License, (*1)

Installation

composer install tomwright/currency-php

Usage

CurrencyPHP is just a basic wrapper. It cannot do conversions out of the box... Saying that... you only need to provide it with the conversion rates., (*2)


$rateFetcher = new MyConversionRateFetcher(); $factory = new CurrencyFactory($rateFetcher); $gbp = $factory->create('GBP'); $usd = $factory->create('USD'); $priceInGBP = 100; $priceInUSD = $gbp->convertTo($usd, $priceInGBP); echo $priceInUSD; // 126

Rate Fetchers

Rate Fetchers are what CurrencyPHP uses to get conversion rates. Any Rate Fetcher you create should implement ConversionRateFetcherInterface., (*3)

Existing Rate Fetchers

If you have created your own Rate Fetcher and want it included here, please submit a pull request., (*4)

Creating Your Own

The following Rate Fetcher gives you some fixed exchange rates: - GBP to USD - USD to GBP - GBP to CAD - CAD to USD, (*5)

class FixedRateFetcher implements ConversionRateFetcherInterface
{

    /**
     * @param Currency $from
     * @param Currency $to
     * @return float
     */
    public function getConversionRate(Currency $from, Currency $to)
    {
        $rates = [
            [
                'from' => 'GBP',
                'to' => 'USD',
                'rate' => 1.2547,
            ],
            [
                'from' => 'USD',
                'to' => 'GBP',
                'rate' => 0.7974,
            ],
            [
                'from' => 'GBP',
                'to' => 'CAD',
                'rate' => 1.6612,
            ],
            [
                'from' => 'CAD',
                'to' => 'USD',
                'rate' => 0.7539,
            ],
        ];

        $result = null;

        foreach ($rates as $rate) {
            if ($rate['from'] === $from->getCurrencyCode() && $rate['to'] === $to->getCurrencyCode()) {
                $result = $rate['rate'];
            }
        }
        return $result;
    }
}

Handling unknown conversion rates

One way conversion rates

The above Rate Fetcher has rates for both GBP to USD, and USD to GBP and this works great... but you'll also notice that it has CAD to USD, but no USD to CAD conversion rates. There is some logic implemented so that you only need to store 1 way conversion rates and it will automatically invert the rate if required., (*6)

Thanks to this logic, you can run a USD to CAD conversion using the above Rate Fetcher with no problems. The full list of conversion that the above can handle is as follows: - GBP to USD - USD to GBP - GBP to CAD - CAD to GBP - CAD to USD - USD to CAD, (*7)

Missing conversion rates

If no conversion rate exists at all between the 2 currencies, an UnhandledConversionRate Exception will be thrown., (*8)

The Versions

24/10 2017

dev-master

9999999-dev

A small package to facilitate currency conversions in PHP.

  Sources   Download

The Requires

 

24/10 2017

0.0.4

0.0.4.0

A small package to facilitate currency conversions in PHP.

  Sources   Download

The Requires

 

13/04 2017

0.0.3

0.0.3.0

A small package to facilitate currency conversions in PHP.

  Sources   Download

The Requires

 

02/02 2017

0.0.2

0.0.2.0

A small package to facilitate currency conversions in PHP.

  Sources   Download

The Requires

 

02/02 2017

0.0.1

0.0.1.0

A small package to facilitate currency conversions in PHP.

  Sources   Download

The Requires