Laravel 5 mobilpay wrapper around omnipay with omnipay-mobilpay driver Edit Add topics
Require the package via composer
composer require adrianbarbos/mobilpayOr add the package to your composer.json file.
{
"require": {
"adrianbarbos/mobilpay": "^1.0"
}
}And run composer update to get the latest version of the package.
Mobilpay comes with a service provider for Laravel. You'll need to add it to your composer.json as mentioned in the above steps, then register the service provider with your application.
From Laravel 5.5, the service provider and facades will automatically get registered.
Open config/app.php and find the providers key. Add MobilpayServiceProvider to the array.
...
Adrianbarbos\Mobilpay\MobilpayServiceProvider::class,
...Add the required aliases to the list of class aliases in the same file.
...
'Omnipay' => Omnipay\Omnipay::class,
'Mobilpay' => Adrianbarbos\Mobilpay\Mobilpay::class,
...Publish config.
php artisan vendor:publish --provider="Adrianbarbos\Mobilpay\MobilpayServiceProvider"
// controller function
Mobilpay::setOrderId(1)
->setAmount('10.00')
->setDetails('Some details')
->purchase();// controller function
$response = Mobilpay::response();
$data = $response->getData(); //array
switch($response->getMessage())
{
case 'confirmed_pending': // transaction is pending review. After this is done, a new IPN request will be sent with either confirmation or cancellation
//update DB, SET status = "pending"
break;
case 'paid_pending': // transaction is pending review. After this is done, a new IPN request will be sent with either confirmation or cancellation
//update DB, SET status = "pending"
break;
case 'paid': // transaction is pending authorization. After this is done, a new IPN request will be sent with either confirmation or cancellation
//update DB, SET status = "open/preauthorized"
break;
case 'confirmed': // transaction is finalized, the money have been captured from the customer's account
//update DB, SET status = "confirmed/captured"
break;
case 'canceled': // transaction is canceled
//update DB, SET status = "canceled"
break;
case 'credit': // transaction has been refunded
//update DB, SET status = "refunded"
break;
} /**
* @param $value string
* @return $this
*/
public function setOrderId($value)/**
* @param $value string
* @return $this
*/
public function setAmount($value)/**
* @param $value string
* @return $this
*/
public function setCurrency($value)/**
* @param $value string
* @return $this
*/
public function setDetails($value)/**
* @param $value string
* @return $this
*/
public function setConfirmUrl($value)/**
* @param $value string
* @return $this
*/
public function setReturnUrl($value)/**
* @param $value boolean
* @return $this
*/
public function setTestMode($value)/**
* @param $value array
* @return $this
*/
public function setAdditionalParams($value)