akhur0286 / yii2-paykeeper
此包的最新版本(dev-master)没有可用的许可证信息。
用于通过俄罗斯联邦储蓄银行接收支付的库。
dev-master
2023-09-13 15:41 UTC
Requires
- php: >=7.0.0
This package is auto-updated.
Last update: 2024-09-13 18:03:04 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';
}
}