hamraa / lumen-payment
A Lumen package for connecting to payment gateways
Requires
- ext-curl: *
- ext-json: *
- ext-libxml: *
- ext-simplexml: *
- ext-soap: *
- ext-xml: *
- nesbot/carbon: *
- paypal/rest-api-sdk-php: *
This package is auto-updated.
Last update: 2025-01-17 19:01:48 UTC
README
A Lumen package for connecting to payment gateways.
By this package we are able to connect to all Iranian bank with one unique API.
Please inform us once you've encountered bug or issue.
Available Banks:
- MELLAT
- SADAD (MELLI)
- SAMAN
- PARSIAN
- PASARGAD
- ZARINPAL
- PAYPAL (New)
- ASAN PARDAKHT (New)
- PAY.IR (New) (to use : new \Payir())
Installation
First, install the package via Composer:
composer require hamraa/lumen-payment
Copy the required files:
mkdir -p config cp vendor/hamraa/lumen-payment/config/payment.php config/payment.php cp vendor/hamraa/lumen-payment/database/migrations/create_payment_transactions_table.php.stub database/migrations/2016_01_01_000000_create_payment_transactions_table.php cp vendor/hamraa/lumen-payment/database/migrations/create_payment_transactions_status_logs_table.php.stub database/migrations/2016_01_01_000000_create_payment_transactions_status_logs_table.php cp vendor/hamraa/lumen-payment/resources/views resources/views
Then, in bootstrap/app.php
:
- register the alias:
$app->withFacades(true, [ 'Hamraa\Payment\Gateway' => 'Gateway', ]);
- register the config file:
$app->configure('payment');
- register the service provider:
$app->register(\Hamraa\Payment\PaymentServiceProvider::class);
Now, run your migrations:
php artisan migrate
Done!
Usage
You can make connection to bank in several ways (Facade , Service container):
try { $gateway = \Gateway::make(new \Mellat()); // $gateway->setCallback(url('/path/to/callback/route')); You can also change the callback $gateway ->price(1000) // setShipmentPrice(10) // optional - just for paypal // setProductName("My Product") // optional - just for paypal ->ready(); $refId = $gateway->refId(); // شماره ارجاع بانک $transID = $gateway->transactionId(); // شماره تراکنش // در اینجا // شماره تراکنش بانک را با توجه به نوع ساختار دیتابیس تان // در جداول مورد نیاز و بسته به نیاز سیستم تان // ذخیره کنید . return $gateway->redirect(); } catch (\Exception $e) { // نمایش خطای تراکنش echo $e->getMessage(); }
You can call the gateway by these ways :
- Gateway::make(new Mellat());
- Gateway::mellat()
- app('gateway')->make(new Mellat());
- app('gateway')->mellat();
Instead of MELLAT you can enter other banks Name as we introduced above .
In price
method you should enter the price in IRR (RIAL)
and in your callback :
try { $gateway = \Gateway::verify(); $trackingCode = $gateway->trackingCode(); $refId = $gateway->refId(); $cardNumber = $gateway->cardNumber(); // تراکنش با موفقیت سمت بانک تایید گردید // در این مرحله عملیات خرید کاربر را تکمیل میکنیم } catch (\Hamraa\Payment\Exceptions\RetryException $e) { // تراکنش قبلا سمت بانک تاییده شده است و // کاربر احتمالا صفحه را مجددا رفرش کرده است // لذا تنها فاکتور خرید قبل را مجدد به کاربر نمایش میدهیم echo $e->getMessage() . "<br>"; } catch (\Exception $e) { // نمایش خطای بانک echo $e->getMessage(); }
Credits
This package is based on larabook/gateway (payment package for laravel) with some major change to compatible with Lumen framework and some code improvments.
Thanks
Special thanks to larabook team.