Package Data | |
---|---|
Maintainer Username: | SaeedPooyanfar |
Maintainer Contact: | saeedp47@gmail.com (Saeed Pooyanfar) |
Package Create Date: | 2017-08-10 |
Package Last Update: | 2023-07-23 |
Home Page: | |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2024-12-23 03:01:59 |
Package Statistics | |
---|---|
Total Downloads: | 10,433 |
Monthly Downloads: | 85 |
Daily Downloads: | 4 |
Total Stars: | 47 |
Total Watchers: | 3 |
Total Forks: | 5 |
Total Open Issues: | 6 |
Use this lib with other frameworks Other available methods Other available configs
install it:
composer require saeedpooyanfar/zarinpal
add it to providers in "config/app.php" file:
<?php
...
'providers' => [
...
Zarinpal\ZarinpalServiceProvider::class,
...
],
...
set 36 chars "ZARINPAL_MERCHANTID" in .env
file:
...
ZARINPAL_MERCHANTID=XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX
...
request new payment:
<?php
...
use Zarinpal\Zarinpal;
...
...
public function request(Zarinpal $zarinpal) {
$payment = [
'CallbackURL' => route('payment.verify'), // Required
'Amount' => 5000, // Required
'Description' => 'a short description', // Required
'Email' => 'saeedp47@gmail.com', // Optional
'Mobile' => '0933xxx7694' // Optional
];
$response = $zarinpal->request($payment);
if($response['Status'] === 100) {
$authority = $response['Authority'];
return $zarinpal->redirect($authority);
}
return 'Error,
Status: '.$response['Status'].',
Message: '.$response['Message'];
}
...
If you have other redirection methods you can use:
...
$url = $zarinpal->getRedirectUrl($authority);
...
to get the redirect url as a string.
verify the payment:
<?php
...
use Illuminate\Support\Facades\Input;
use Zarinpal\Zarinpal;
...
...
public function verify(Zarinpal $zarinpal) {
$payment = [
'Authority' => Input::get('Authority'), // $_GET['Authority']
'Status' => Input::get('Status'), // $_GET['Status']
'Amount' => 5000
];
$response = $zarinpal->verify($payment);
if($response['Status'] === 100) {
return 'Payment was successful,
RefID: '.$response['RefID'].',
Message: '.$response['Message'];
}
return 'Error,
Status: '.$response['Status'].',
Message: '.$response['Message'];
}
...
<?php
...
use Zarinpal\Zarinpal;
use Zarinpal\Clients\GuzzleClient; // OR SoapClient
...
...
$merchantID = 'XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX';
$sandbox = false; // OR true
$client = new GuzzleClient($sandbox);
$lang = 'fa'; // OR en
$zarinpal = new Zarinpal($merchantID, $client, $lang, $sandbox);
// object is ready, call methods now!
...
1- requestWithExtra
:
dividing money in different zarinpal wallets
...
// same as request method,
// but this needs AdditionalData in payment array
$amount = 10000;
$divider = [];
// 8000 in zp.1.1 wallet and
// 2000 in zp.2.5 wallet
$divider['Wages'] = [
'zp.1.1' => [
'Amount' => $amount * (80/100), // 80%
'Description' => 'a short description'
],
'zp.2.5' => [
'Amount' => $amount * (20/100), // 20%
'Description' => 'a short description'
]
];
$payment = [
...
'Amount' => $amount, // Required
'AdditionalData' => json_encode($divider), // Required
...
];
$response = $zarinpal->requestWithExtra($payment);
...
2- verifyWithExtra
:
if you used requestWithExtra method for payment then you must verify it with this one
...
// exactly same as verify method
$response = $zarinpal->verifyWithExtra($payment);
...
3- refreshAuthority
:
extends authority token lifetime
...
$detail = [
'Authority' => $authority, // Required
'ExpireIn' => 7200 // Required (in secodns)
];
$response = $zarinpal->refreshAuthority($detail);
...
4- unverifiedTransactions
:
get successful payments which you didn't call verify method on them
...
$response = $zarinpal->unverifiedTransactions();
$payments = json_decode($response['Authorities']);
foreach($payments as $payment) {
$authority = $payment->Authority;
$amount = $payment->Amount;
$channel = $payment->Channel;
$date = $payment->Date;
...
}
...
This lib and its methods written based on official zarinpal documents, so reading the docs might be helpful