akhur0286 / yii2-paykeeper
Библиотека для приема платежей через Сбербанк.
Installs: 1 278
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 1
Open Issues: 0
Type:yii2-extension
Requires
- php: >=7.0.0
This package is auto-updated.
Last update: 2025-04-13 19:15:55 UTC
README
Библиотека для приема платежей через интернет для Paykeeper.
Установка с помощью Composer
php composer.phar require akhur0286/yii2-paykeeper "*"
или добавьте в composer.json
"akhur0286/yii2-paykeeper": "*"
Подключение компонента
[ 'components' => [ 'paykeeper' => [ 'class' => 'akhur0286\paykeeper\Merchant', 'merchantLogin' => '', 'merchantPassword' => '', 'serverUrl' => '', 'orderModel' => '', //модель таблицы заказов ], //.. ], ];
Пример работы библиотеки
class PaymentController extends \yii\web\Controller
{
/**
* @inheritdoc
*/
public function actions()
{
return [
'success-payment' => [
'class' => '\akhur0286\paykeeper\actions\BaseAction',
'callback' => [$this, 'successCallback'],
],
'error-payment' => [
'class' => '\akhur0286\paykeeper\actions\BaseAction',
'callback' => [$this, 'failCallback'],
],
];
}
public function successCallback($orderId)
{
/* @var $model PaykeeperInvoice */
$model = PaykeeperInvoice::findOne(['invoice_id' => $orderId]);
if (is_null($model)) {
throw new NotFoundHttpException();
}
$merchant = \Yii::$app->get('paykeeper');
$result = $merchant->checkStatus($orderId);
//Проверяем статус оплаты если всё хорошо обновим инвойс и редерекним
if (isset($result['OrderStatus']) && ($result['OrderStatus'] != $merchant->successStatus)) {
//обработка при успешной оплате $model->related_id номер заказа
echo 'ok';
} else {
$this->redirect($merchant->failUrl.'?orderId=' . $orderId);
}
}
public function failCallback($orderId)
{
/* @var $model PaykeeperInvoice */
$model = PaykeeperInvoice::findOne(['invoice_id' => $orderId]);
if (is_null($model)) {
throw new NotFoundHttpException();
}
//вывод страницы ошибки $model->related_id номер заказа
echo 'error payment';
}
}