lapaygroup / start2pay
Start 2 Pay PHP SDK
Requires
- php: >=5.5.9
- guzzlehttp/guzzle: 6.2.*
- symfony/yaml: ~3.2
This package is auto-updated.
Last update: 2024-11-15 22:36:27 UTC
README
PHP SDK для интеграции с сервисом https://start2pay.com
Описание API Start 2 Pay https://wiki.start2pay.com
Установка
Для установки можно использовать менеджер пакетов Composer
composer require lapaygroup/start2pay
Файл конфигурации
Для работы SDK нужно разместить конфигурационный yaml файл. Пример можно посмотреть тут.
Описание параметров:
- auth
- host - адрес API
- username - логин
- password - пароль
- salt - соль для создания контекста
- callback_salt - соль для подписи callbacks
- display_options
- language - язык платежной страницы
- iframe - флаг использования iframe вместо переадресации на платежную страницу Start 2 Pay
- close_additional_tabs: - флаг закрытия всех дополнительных вкладок
- device - тип устройства (desktop, mobile)
- theme - цветовая схема платежной страницы (layout2_white, layout2_black, layout2_dark, layout2_violet)
- message - Сообщение для заказчика. Such rules, limits, etc
- description - Описание отображаемое на платежной странице.
- disable_payment_currency - Данный параметр позволяет при переданом значении true отображать на форме оплаты только одну указанную валюту (currency) которая использовалась при создании платежного контекста
- available_payment_systems - массивы с алиасами платежных направлений ввода и вывода, которые будут доступны для выбора на платежной странице.
Использование SDK
Для получения платежного контекста (ссылки на платежную страницу или iframe) нужно использовтаь метод getContext.
Пример получения ссылки
$payInfo['currency'] = 'RUB'; $payInfo['amount'] = '150.00'; $payInfo['invoice'] = '100'; $payInfo['user_id'] = '123456'; $payInfo['selected_payment_system'] = 'bank_cards'; try { $API = new \LapayGroup\Start2Pay\API('path/to/config.yml'); $context = $API->getContext($payInfo); if (! empty($context['payment_url']) { header('Location: '.$context['payment_url']); } else { // Обработка ошибки получения платежного контекста } } catch(\Exception $e) { // Обработка ошибки обмена с Start 2 Pay }
При получении callback запросов на проверку и проведение оплаты от Start 2 Pay также нужно проверять подпись в параметре signature в JSON массиве данных. Для проверки подписи нужно использовать метод validCallbackSignature. На вход принимает JSON текст из запроса.
Пример проверки подписи
try { $API = new \LapayGroup\Start2Pay\API('path/to/config.yml'); $valid = $API->validCallbackSignature($json); if ($valid) { // Подпись верна - обрабатываем callback } else { // Обрабатываем ошибку подписи } } catch(\Exception $e) { // Обработка ошибки обмена с Start 2 Pay }