承接 tetthys/currency 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

tetthys/currency

最新稳定版本:0.0.1

Composer 安装命令:

composer require tetthys/currency

包简介

Lightweight, framework-agnostic currency converter (fixed-scale decimal, PHP 8.3+).

README 文档

README

Lightweight, framework-agnostic currency converter for PHP 8.3+.
Uses fixed-scale decimal math (bcmath) and pluggable exchange-rate providers.

📦 Installation

composer require tetthys/currency

Requires PHP 8.3+ and the bcmath extension.

🚀 Quick Example

use Tetthys\Currency\Providers\CallableExchangeRateProvider;
use Tetthys\Currency\Services\CurrencyConverter;

$provider = new CallableExchangeRateProvider(
    fn(string $code) => match ($code) {
        'USD' => '1',
        'KRW' => '1380.00',
        'JPY' => '152.00',
        default => throw new RuntimeException("Unknown currency: {$code}"),
    }
);

$converter = new CurrencyConverter($provider);

echo $converter->amount('100')->from('USD')->to('KRW')->convert(); // "138000.00"
echo $converter->amount('138000')->from('KRW')->to('USD')->convert(); // "100.00"

🧩 Core Concepts

ExchangeRateProviderInterface

An interface that returns the per-USD rate for a given currency:

public function getPerUsd(string $currency): string;

Example: getPerUsd('KRW')"1380.00" means 1 USD = 1380 KRW.

CallableExchangeRateProvider

A tiny adapter that wraps a closure:

$provider = new CallableExchangeRateProvider(
    fn(string $currency) => match (strtoupper($currency)) {
        'USD' => '1',
        'EUR' => '0.91',
        'GBP' => '0.78',
        default => throw new RuntimeException('Unknown currency'),
    }
);

CurrencyConverter

Performs fixed-scale conversions using bcmath:

$converter = new CurrencyConverter($provider);

$result = $converter
    ->amount('250.50')
    ->from('USD')
    ->to('EUR')
    ->scale(4)
    ->convert(); // e.g. "227.9550"

⚙️ Creating Your Own Provider

Implement Tetthys\Currency\Contracts\ExchangeRateProviderInterface:

use Tetthys\Currency\Contracts\ExchangeRateProviderInterface;
use Tetthys\Currency\Exceptions\CurrencyApiException;

final class MyApiProvider implements ExchangeRateProviderInterface
{
    public function getPerUsd(string $currency): string
    {
        $response = file_get_contents("https://example.com/api/latest/USD");
        $data = json_decode($response, true);

        return (string)($data['rates'][strtoupper($currency)]
            ?? throw new CurrencyApiException('Missing rate'));
    }
}

🧮 Notes

  • All arithmetic uses BCMath for precision and consistency.
  • Scale (decimal places) defaults to 2, configurable via ->scale(n).
  • Same-currency conversions simply return the normalized value.

🪪 License

MIT © Tetthys Labs

统计信息

  • 总下载量: 28
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-10-19