rarus / bonus-server-php-sdk
Bonus server PHP SDK
2.0.4
2026-03-30 13:33 UTC
Requires
- php: ~8.2.0 || ~8.3.0 || ~8.4.0
- ext-curl: *
- ext-json: *
- fig/http-message-util: 1.*
- guzzlehttp/guzzle: ^7.9.3
- moneyphp/money: ^v4.7.1
- monolog/monolog: 3.9.0
- php-http/discovery: ^1.20
- psr/log: ^3.0.2
- psr/simple-cache: ^3.0
Requires (Dev)
- ext-intl: *
- laravel/pint: ^1.24.0
- phpstan/phpstan: 2.*
- phpunit/phpunit: *
- rector/rector: ^2.1
- symfony/cache: ^7.3
- symfony/dotenv: 7.*
This package is not auto-updated.
Last update: 2026-06-22 14:37:31 UTC
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) { // непредусмотренная ошибка }