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
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.*
- dev-master
- 2.0.1
- 2.0.0
- 1.4.1
- 1.4.0
- 1.3.4
- 1.3.3
- 1.3.2
- 1.3.1
- 1.3.0
- v1.2.1
- v1.2.0
- v1.1.0
- v1.0.2-beta
- v1.0.1
- v1.0.1-beta2
- v1.0.1-beta
- v1.0.0.x-dev
- v1.0.0-beta.2
- v1.0.0-beta
- v0.8.2
- v0.8.1.1
- v0.8.1
- v0.8.0
- 0.7.2
- 0.7.1
- 0.7.0
- 0.6.0
- 0.5.9
- 0.5.8
- 0.5.7
- 0.5.6
- 0.5.5
- 0.5.4
- 0.5.3
- 0.5.2
- 0.5.1
- 0.5.0
- 0.3.5
- 0.3.4
- 0.3.3
- 0.3.1
- 0.3.0
- 0.1.2
- dev-fix/payment
- dev-release/1.x
- dev-dependabot/github_actions/actions/checkout-6
- dev-dependabot/github_actions/actions/cache-5
- dev-version/2.0
- dev-task+78061-user-additional-fields
- dev-task+67375-fix-money-currency
- dev-task+73910-fix-get-by-coupon-id
- dev-task+73910-coupon-hold
- dev-task+72895
- dev-task+69061
- dev-task+69981
- dev-task+69230
- dev-dev
- dev-task+67
- dev-task+64
- dev-task+61
- dev-task+58
- dev-task+55
- dev-task+53
- dev-old-api
This package is not auto-updated.
Last update: 2026-01-09 08:45:43 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) { // непредусмотренная ошибка }