vskut / webmoney-merchant
WebMoney Merchant - PHP Library
This package is not auto-updated.
Last update: 2023-09-02 12:12:33 UTC
README
Эта библиотека должна помочь вам в работе с интерфейсом WebMoney Merchant: https://wiki.webmoney.ru/projects/webmoney/wiki/Web_Merchant_Interface
Навигация
Установка через Composer
-
Устанавливаем Composer:
curl -sS https://getcomposer.org/installer | php
-
Добавляем WebMoney Merchant в зависимость:
php composer.phar require vskut/webmoney-merchant:*@dev
Использование
Генерация формы
Пример: https://github.com/VSKut/WebMoney-Merchant/blob/master/examples/form.php
Подключаем класс любым доступным образом
Native:
require_once('../src/WMMerchantForm.class.php');
Composer:
require_once(__DIR__.'/vendor/autoload.php');
Используем пространство имён
use VSKut\WebMoney_Merchant\WMMerchantForm;
Передаём кошелёк продавца
$merchantForm = new WMMerchantForm('R000000000000');
Устанавливаем сумму для оплаты
$merchantForm->setAmount(123.45);
Устанавливаем описание платежа
$merchantForm->setDescription('Это описание платежа');
Устанавливаем номер платежа
$merchantForm->setPaymentNumber(12);
Устанавливаем дополнительные параметры (не обязательно)
$merchantForm->setDataCustom(array( 'USER_ID' => 15, 'ITEM_ID' => 24, 'CATEGORY_ID' => 1, ));
Передаём RESULT Url посредством формы (не обязательно)
Для использования своих URL через форму не забудьте выставить в настройках кошелька галочку на "Позволять использовать URL, передаваемые в форме"
$merchantForm->setResultUrl('http://vskut.ru/result.php');
Передаём SUCCESS Url и тип вызова посредством формы (не обязательно)
Для использования своих URL через форму не забудьте выставить в настройках кошелька галочку на "Позволять использовать URL, передаваемые в форме"
$merchantForm->setSuccessUrl('http://vskut.ru/success.php', 2); /* * * Типы вызова: * 0 - GET * 1 - POST * 2 - URL * */
Передаём FAIL Url и тип вызова посредством формы (не обязательно)
Для использования своих URL через форму не забудьте выставить в настройках кошелька галочку на "Позволять использовать URL, передаваемые в форме"
$merchantForm->setFailUrl('http://vskut.ru/fail.php', 2); /* * * Типы вызова: * 0 - GET * 1 - POST * 2 - URL * */
В конец формы добавляем JS скрипт с автоматической отправкой формы (не обязательно)
$merchantForm->setAutoSendForm();
Получаем HTML сгенерированной формы
$html = $merchantForm->getHTML();
Just do it :)
echo $html;
RESULT обработчик
Пример: https://github.com/VSKut/WebMoney-Merchant/blob/master/examples/result.php
Подключаем класс любым доступным образом
Native:
require_once('../src/WMMerchantCallback.class.php');
Composer:
require_once(__DIR__.'/vendor/autoload.php');
Используем пространство имён
use VSKut\WebMoney_Merchant\WMMerchantCallback;
Передаём кошелёк продавца, секретный ключ, POST данные
$merchantCallback = new WMMerchantCallback('R000000000000', '000000000000000', $_POST);
Устанавливаем стоимость (не обязательно)
Если не установлено, то стоимость проверяться не будет и скрипт пропустит все платежи вне зависимости от суммы
$merchantCallback->setAmount(123.45);
Проверяем данные запроса на валидность
if ($merchantCallback->isInvalidData()) { echo $merchantCallback->getError(); exit(); }
Проверяем тип запроса (pre-request или finally-request)
if ($merchantCallback->isPreRequest()) { /* * * Пришёл предварительный запрос, деньги от пользователя ещё не переведены * 1) Если нужно, то выполняем любые иные проверки * */ $array = $merchantCallback->getData(); $array = $merchantCallback->getDataCustom(); /* * 2) Возвращаем успешный ответ "YES" и тем самым разрешаем выполнить запрос * */ echo 'YES'; } else { /* * * Пришёл окончательный запрос, деньги уже у нас на кошельке * 1) Если нужно, то выполняем любые иные проверки * */ $array = $merchantCallback->getData(); $array = $merchantCallback->getDataCustom(); /* * 2) Производим выдачу товара * */ }
Настройка WebMoney Merchant
Переходим к настройке кошелька
- Переходим на https://merchant.webmoney.ru
- Проходим авторизацию
- Идём в настройки https://merchant.webmoney.ru/conf/purses.asp
- Напротив нужного кошелька выбираем
настроить
Настройка кошелька
- Указываем
тестовый
либорабочий
режим работы - Указываем торговое имя
- Указываем
Secret Key
- Указываем
Result URL
- Выбираем check-box [x]
Передавать параметры в предварительном запросе
- Указываем
Success URL
и метод его вызова - Указываем
Fail URL
и метод его вызова - При необходимости выбираем check-box [x]
Позволять использовать URL, передаваемые в форме
- Выбираем в
Метод формирования контрольной подписи
-SHA256
- Сохраняем :)