rarus/bonus-server-php-sdk

Bonus server PHP SDK

Installs: 301

Dependents: 0

Suggesters: 0

Security: 0

Stars: 2

Watchers: 6

Forks: 1

Open Issues: 3

pkg:composer/rarus/bonus-server-php-sdk


README

Установка

composer require rarus/bonus-server-php-sdk^2.0

Зависимости

  • PHP >= 8.2+
  • ext-bcmath
  • ext-curl
  • ext-json

Быстрый старт

$client = RarusLMS::client('API_URL','API_TOKEN');

$card = $client->cards()->getById(1); // Возвращает Cards\DTO\CardDto
$user = $client->users()->getById(1); // Возвращает Users\DTO\UserDto

// Сериализация в массив
$payload = $card->toArray();

Расширенный пример использования

use GuzzleHttp\HandlerStack;
use GuzzleHttp\MessageFormatter;
use GuzzleHttp\Middleware;
use Money\Currency;
use Monolog\Handler\StreamHandler;
use Monolog\Logger;
use Rarus\LMS\SDK\RarusLMS;
use Rarus\LMS\SDK\Users\DTO\Fabric;
use Rarus\LMS\SDK\Users\DTO\Factory;
use Symfony\Component\Cache\Adapter\FilesystemAdapter;
use Symfony\Component\Cache\Psr16Cache;

$logger = new Logger('rarus-bonus-service');
$logger->pushHandler(
    new StreamHandler(
        getenv('LOG_FILE'), 
        getenv('LOG_LEVEL'), 
    )
);

$guzzleHandlerStack = HandlerStack::create();
$guzzleHandlerStack->push(
    Middleware::log(
        $logger,
        new MessageFormatter(MessageFormatter::DEBUG)
    )
);

$httpClient = new GuzzleHttp\Client([
    'base_uri' => getenv('API_URL'),
    'connect_timeout' => 10,
    'headers' => [
        'Accept' => 'application/json',
    ],
    'handler' => $guzzleHandlerStack,  
]);

$psr6Cache = new FilesystemAdapter(); 
$psr16Cache = new Psr16Cache($psr6Cache);

$client = RarusLMS::factory()
    ->setApiKey(getenv('API_TOKEN'))
    ->setHttpClient($httpClient)
    ->setLogger($logger)
    ->setCurrency(new Currency('RUB'))
    ->setDateTimeZone(new DateTimeZone('Europe/Moscow'))
    ->setCache($psr16Cache)
    ->build();

$userDto = Factory::create()
    ->withName('Иванов Иван')
    ->withPhone('+7(900)000-00-00')
    ->withShopId(1)
    ->withEmail('test@example.com')
    ->build();
    
$newUser = $client->users()->createUser($userDto); // Возвращает Users\DTO\UserDto

$user = $client->users(300)->getUserById(1); // кеширует ответ на 5 мин
$card = $client->cards()->getCardById(1);

$card = $client->cards()->getById(1); // Возвращает Cards\DTO\CardDto
$user = $client->users()->getById(1); // Возвращает Users\DTO\UserDto

// Сериализация в массив
$payload = $card->toArray();

Денежные суммы (moneyphp/money)

Все денежные поля представлены типом Money (minor units). Пример в CardDto:

use Money\Money;
use Money\Currency;

// В fromArray:
$balance = MoneyParser::parse($data['balance'] ?? 0.0, $currency);

// В toArray (для JSON):
'balance'  => MoneyParser::toString($this->balance),

Примеры

Получить карту и вывести баланс

use Money\Currency;
$card = $client->cards()->getById(1);
$balanceMoney = $card->balance->getAmount();
echo MoneyParser::convertMoneyToString($balanceMoney, new Currency('RUB')); // 509,7050

Сериализация в массив (например, для кэша)

$cached = $card->toArray();
$again = Cards\DTO\CardDto::fromArray($cached);

Ошибки

Все HTTP/протокольные ошибки приводятся к исключениям пространства имён RarusBonus\Exceptions:

  • BaseException — базовое исключение SDK, от которого наследуются все остальные типы ошибок.
  • ApiException — ошибка, возвращённая сервером API (статус 4xx/5xx).
  • NetworkException — ошибка сетевого уровня (таймаут, DNS, SSL и т. п.).
  • InvalidArgumentException — ошибка, возникающая при передаче некорректных аргументов в методы SDK.
  • RuntimeException — ошибка, возникающая во время выполнения программы (например, ошибки парсинга или логики).
  • UnknownException — непредусмотренная ошибка, не попавшая в другие категории.
try {
    $user = $this->client->users()->getUserById($userId);
} catch (NetworkException $e) {
    // ошибка сетевого уровня
} catch (ApiClientException $e) {
    // ошибка, возвращённая сервером API
} catch (UnknownException $e) {
    // непредусмотренная ошибка
}