aminkt / yii2-payment-module
Online payment module for yii2
Installs: 114
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 2
Forks: 2
Open Issues: 0
Type:yii2-extension
Requires
- php: >=7.1
- ext-openssl: *
- ext-soap: *
- aminkt/exceptions: v1.0.0.x-dev
- yiisoft/yii2: ~2.0.11
- yiisoft/yii2-httpclient: ~2.0.0
This package is auto-updated.
Last update: 2025-01-03 21:56:47 UTC
README
If you want i will happy to use your help to improve this project. For contributing please refer to this link.
How to install this module:
Step1: Add flowing line to require part of composer.json
:
"aminkt/yii2-payment-module": "*",
Or run bellow command :
composer require aminkt/yii2-payment-module
Step2: Add flowing lines in your application config:
'payment' => [ 'class' => aminkt\yii2\payment\Payment::class, 'minAmount' => 100, // Min availbale money that can pay by gates. // If you want, same as minAmount you can set maxAmount. 'maxAmount' => 1000000, // In Development you can uncomment below line to enable by pass mode.This config will pass the gates. // 'enableByPass' => true, 'orderClass' => \common\models\Order::class, Your order model class name. // Add this part to add your own gates. 'components' => [ 'payment' => [ 'class' => aminkt\yii2\payment\components\Payment::class, // Uncomment below line if you wnat change you default callback address. // 'callback' => ['/v1/payment/verify'], 'bankTimeout' => 60 * 30, // Max time user can be in bank site. 'encryptKey' => 'wumBOOH04e', // This key will used to generate security token 'blockTime' => 10, // How many times system allow to a user have risky actions. 'gates' => [ 'Parsian' => [ 'class' => \aminkt\yii2\payment\gates\Parsian::class, 'identityData' => [ 'pin' => 'x8Xd1tR4So8kL50d3EV1', 'terminal' => '92133477' ] ], 'BehPardakht' => [ 'class' => \aminkt\yii2\payment\gates\MellatGate::class, 'identityData' => [ 'terminalId' => '****', 'userName' => '****', 'password' => '****', 'payerId' => 0, 'webService' => 'https://bpm.shaparak.ir/pgwchannel/services/pgw?wsdl', 'bankGatewayAddress' => 'https://bpm.shaparak.ir/pgwchannel/startpay.mellat', ] ], ] ] ] ]
All time please add Mellat Bank gate in down of gates list because it may make issue in automatic gate selector. Mellat gate throw an exception when it's not available that system can not catch it so the processes may become failed. If you can fix this please contribute.
Step3: Create your own order model and implement aminkt\yii2\payment\interfaces\OrderInterface
in your order model.
Using order model in this module is required.
Note: Using a table as order model is an standard pattern to keep track of every thing you try to sale. refer this link to read more: http://www.databaseanswers.org/data_models/customers_and_orders/index.htm
Database Migrations
Before usage this extension, we'll also need to prepare the database.
php yii migrate --migrationPath=@vendor/aminkt/yii2-payment-module/migrations
Usage:
In your code when you want create a payment request use below code:
$payment = \aminkt\payment\Payment::getInstance()->payment; $data = $payment->payRequest($orderModel);
Use
$orderModel
to make a connection between your order table and payment data. by defining this you can access to your orders later from payment logs.
When users paid money, they will redirect in a page in you site that you defined.
By default user will redirect to /payment/default/verify
route.
For changing default call back page use below code:
$payment = \aminkt\payment\Payment::getInstance()->payment; $payment->callback = ['/your-controller/your-action']; // callBack give an array defined a route.
Also you can set callback address globally in module configuration.
In your verify page use below code to verify payment:
$verify = Payment::getInstance() ->getPayment() ->verify(); if($verify) { // Payment was successfull. } else { // Paymen verify become failed. }
$verify
is false
if verify action become failed and otherwise return an true.
Security
Module will check security issues and log them in yii2 log system. You can also define below attribute in payment component config to change default behavior of security system.
Gate configuration
Every gate has some configuration. In this module prepared some default gates that you can use.
If you want create your own gate please refer to Create gate class section.
You can contribute your gates to this report and help me to improve productivity.
List of gates:
Create gate class
To create gate class you should create a new class in your application and extend it from \aminkt\yii2\payment\gates\AbstractGate
.
Implement uncompleted methods and then use below rule to read identity data and configurations from module configuration:
As you know every gate has some configuration that user will prepare that as array. you can access this config from your gate by calling
getIdentity
methods.
For example if user use below configuration:
[ 'class' => \name\space\of\your\CustomGate::class, 'password' => 'some password', 'verifyUrl' => 'http://your/verify.url' ]
Then in CustomGate
you can access below methods:
getIdentityPassword(); getIdentityVerifyUrl();
Implement your gate. see examples and if you like contribute it in this repo.
Gate configurations
Sep
"Sep" => [ 'class' => \aminkt\payment\lib\Sep::className(), 'identityData' => [ 'MID' => '******', 'password' => '******', 'bankGatewayAddress' => 'https://sep.shaparak.ir/payment.aspx', 'webService' => "https://sep.shaparak.ir/payments/referencepayment.asmx?WSDL", ] ],
MellatGate
'BehPardakht' => [ 'class' => \aminkt\yii2\payment\gates\MellatGate::class, 'identityData' => [ 'terminalId' => '****', 'userName' => '****', 'password' => '****', 'payerId' => 0, 'webService' => 'https://bpm.shaparak.ir/pgwchannel/services/pgw?wsdl', 'bankGatewayAddress' => 'https://bpm.shaparak.ir/pgwchannel/startpay.mellat', ] ],
Parsian
'Parsian' => [ 'class' => \aminkt\yii2\payment\gates\Parsian::class, 'identityData' => [ 'payRequestUrl' => 'https://pec.shaparak.ir/NewIPGServices/Sale/SaleService.asmx?WSDL', 'verifyUrl' => 'https://pec.shaparak.ir/NewIPGServices/Confirm/ConfirmService.asmx?WSDL', 'gateAddress' => 'https://pec.shaparak.ir/NewIPG/', 'pin' => '**********', 'terminal' => '********' ] ]
IranKish
'IranKish' => [ 'class' => \aminkt\yii2\payment\gates\IranKish::class, 'payRequestUrl' => 'https://ikc.shaparak.ir/XToken/Tokens.xml', 'verifyUrl' => 'https://ikc.shaparak.ir/XVerify/Verify.xml', 'gateAddress' => 'https://ikc.shaparak.ir/TPayment/Payment/index', 'merchantId' => '******' ]
ZarinPal
"Zarinpal" => [ 'class' => \aminkt\payment\lib\ZarinPal::className(), 'identityData' => [ 'merchantCode' => '******', 'redirectUrl' => 'https://zarinpal.com/pg/StartPay/%u', 'payRequestUrl' => 'https://www.zarinpal.com/pg/rest/WebGate/PaymentRequest.json', 'verifyRequestUrl' => 'https://www.zarinpal.com/pg/rest/WebGate/PaymentVerification.json', 'isZarin' => false, 'enableSandbox' => false ] ],
Reports:
In older versions you can use some routes to see some views in your backend panel for logs but in this current
we improve our module to use in rest modules so you still have a route to read logs but as RESTAPI
.
This part documents not complete yet.