1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-09-20 16:31:33 +02:00
invoiceninja/app/PaymentDrivers/PayFastPaymentDriver.php

245 lines
6.9 KiB
PHP
Raw Normal View History

2021-06-24 06:43:14 +02:00
<?php
/**
* Invoice Ninja (https://invoiceninja.com).
*
* @link https://github.com/invoiceninja/invoiceninja source repository
*
* @copyright Copyright (c) 2021. Invoice Ninja LLC (https://invoiceninja.com)
*
* @license https://www.elastic.co/licensing/elastic-license
*/
namespace App\PaymentDrivers;
use App\Models\ClientGatewayToken;
use App\Models\GatewayType;
use App\Models\Payment;
use App\Models\PaymentHash;
use App\Models\SystemLog;
use App\PaymentDrivers\PayFast\CreditCard;
2021-07-06 12:02:47 +02:00
use App\PaymentDrivers\PayFast\Token;
2021-06-24 06:43:14 +02:00
use App\Utils\Traits\MakesHash;
2021-07-05 02:32:26 +02:00
use Illuminate\Http\Request;
2021-07-05 06:07:43 +02:00
use Illuminate\Support\Facades\Cache;
2021-06-24 06:43:14 +02:00
class PayFastPaymentDriver extends BaseDriver
{
use MakesHash;
2021-07-10 10:59:19 +02:00
public $refundable = false; //does this gateway support refunds?
2021-06-24 06:43:14 +02:00
2021-09-29 02:08:57 +02:00
public $token_billing = true; //does this gateway support token billing?
2021-06-24 06:43:14 +02:00
public $can_authorise_credit_card = true; //does this gateway support authorizations?
public $payfast; //initialized gateway
public $payment_method; //initialized payment method
public static $methods = [
2021-07-10 08:26:06 +02:00
GatewayType::CREDIT_CARD => CreditCard::class,
2021-06-24 06:43:14 +02:00
];
2021-07-10 08:26:06 +02:00
const SYSTEM_LOG_TYPE = SystemLog::TYPE_PAYFAST;
2021-07-05 00:59:52 +02:00
//developer resources
//https://sandbox.payfast.co.za/
2021-06-24 07:46:10 +02:00
public function gatewayTypes(): array
{
$types = [];
2022-01-07 03:39:31 +01:00
// if($this->client->currency()->code == 'ZAR' || $this->client->currency()->code == 'USD')
if($this->client->currency()->code == 'ZAR')
2021-06-24 07:46:10 +02:00
$types[] = GatewayType::CREDIT_CARD;
return $types;
}
2021-07-10 08:26:06 +02:00
2021-06-24 07:51:30 +02:00
public function endpointUrl()
{
if($this->company_gateway->getConfigField('testMode'))
return 'https://sandbox.payfast.co.za/eng/process';
return 'https://www.payfast.co.za/eng/process';
}
2021-06-24 06:43:14 +02:00
public function init()
{
2021-06-24 07:46:10 +02:00
try{
2021-07-10 08:11:58 +02:00
2021-07-10 08:26:06 +02:00
$this->payfast = new \PayFast\PayFastPayment(
2021-06-24 07:46:10 +02:00
[
'merchantId' => $this->company_gateway->getConfigField('merchantId'),
'merchantKey' => $this->company_gateway->getConfigField('merchantKey'),
2021-09-29 02:52:09 +02:00
'passPhrase' => $this->company_gateway->getConfigField('passphrase'),
2021-06-24 07:46:10 +02:00
'testMode' => $this->company_gateway->getConfigField('testMode')
]
);
2021-07-10 08:11:58 +02:00
2021-09-23 02:07:29 +02:00
} catch(\Exception $e) {
2021-07-10 08:11:58 +02:00
2021-10-29 23:30:48 +02:00
nlog('##PAYFAST## There was an exception: '.$e->getMessage());
2021-07-10 08:13:20 +02:00
2021-06-24 07:46:10 +02:00
}
2021-06-24 06:43:14 +02:00
return $this;
}
public function setPaymentMethod($payment_method_id)
{
$class = self::$methods[$payment_method_id];
$this->payment_method = new $class($this);
return $this;
}
public function authorizeView(array $data)
{
2021-07-10 08:26:06 +02:00
return $this->payment_method->authorizeView($data);
2021-06-24 06:43:14 +02:00
}
public function authorizeResponse($request)
{
2021-07-10 08:26:06 +02:00
return $this->payment_method->authorizeResponse($request);
2021-06-24 06:43:14 +02:00
}
public function processPaymentView(array $data)
{
return $this->payment_method->paymentView($data); //this is your custom implementation from here
}
public function processPaymentResponse($request)
{
return $this->payment_method->paymentResponse($request); //this is your custom implementation from here
}
public function refund(Payment $payment, $amount, $return_client_response = false)
{
2021-07-10 10:59:19 +02:00
return false;
2021-06-24 06:43:14 +02:00
}
public function tokenBilling(ClientGatewayToken $cgt, PaymentHash $payment_hash)
{
2021-07-06 12:02:47 +02:00
return (new Token($this))->tokenBilling($cgt, $payment_hash);
2021-06-24 06:43:14 +02:00
}
2021-06-24 07:46:10 +02:00
2021-09-29 02:34:02 +02:00
public function generateTokenSignature($data)
{
$fields = [];
$keys = [
'merchant-id',
'version',
'timestamp',
'amount',
'item_name',
'item_description',
'itn',
'm_payment_id',
'cc_css',
'split_payment'
];
foreach($keys as $key)
{
if (!empty($data[$key])) {
$fields[$key] = $data[$key];
}
}
2021-09-29 02:52:09 +02:00
if($this->company_gateway->getConfigField('passphrase'))
$fields['passphrase'] = $this->company_gateway->getConfigField('passphrase');
2021-09-29 02:46:54 +02:00
2021-09-29 02:34:02 +02:00
nlog(http_build_query($fields));
return md5(http_build_query($fields));
}
public function generateSignature($data)
2021-06-24 07:46:10 +02:00
{
2021-07-05 06:07:43 +02:00
$fields = array();
// specific order required by PayFast
// @see https://developers.payfast.co.za/documentation/#checkout-page
foreach (array('merchant_id', 'merchant_key', 'return_url', 'cancel_url', 'notify_url', 'name_first',
'name_last', 'email_address', 'cell_number',
/**
* Transaction Details
*/
2021-09-23 04:09:12 +02:00
'm_payment_id', 'amount', 'item_name', 'item_description',
2021-07-05 06:07:43 +02:00
/**
* Custom return data
*/
'custom_int1', 'custom_int2', 'custom_int3', 'custom_int4', 'custom_int5',
'custom_str1', 'custom_str2', 'custom_str3', 'custom_str4', 'custom_str5',
/**
* Email confirmation
*/
'email_confirmation', 'confirmation_address',
/**
* Payment Method
*/
'payment_method',
/**
* Subscriptions
*/
'subscription_type', 'billing_date', 'recurring_amount', 'frequency', 'cycles',
/**
* Passphrase for md5 signature generation
*/
'passphrase') as $key) {
if (!empty($data[$key])) {
$fields[$key] = $data[$key];
2021-06-24 07:46:10 +02:00
}
}
2021-07-05 06:07:43 +02:00
2021-09-23 07:39:48 +02:00
nlog(http_build_query($fields));
2021-07-05 06:07:43 +02:00
return md5(http_build_query($fields));
2021-06-24 11:45:45 +02:00
}
2021-07-05 06:07:43 +02:00
2021-07-05 02:32:26 +02:00
public function processWebhookRequest(Request $request, Payment $payment = null)
2021-06-24 11:45:45 +02:00
{
2021-07-05 05:36:12 +02:00
$data = $request->all();
2021-11-04 06:00:49 +01:00
// nlog("payfast");
// nlog($data);
2021-07-05 05:56:38 +02:00
2021-07-05 06:07:43 +02:00
if(array_key_exists('m_payment_id', $data))
2021-07-05 05:36:12 +02:00
{
2021-07-05 06:10:09 +02:00
2021-07-05 06:07:43 +02:00
$hash = Cache::get($data['m_payment_id']);
2021-07-10 08:26:06 +02:00
switch ($hash)
2021-07-05 06:07:43 +02:00
{
case 'cc_auth':
$this->setPaymentMethod(GatewayType::CREDIT_CARD)
->authorizeResponse($request);
return response()->json([], 200);
break;
2021-07-10 08:26:06 +02:00
default:
2021-07-10 08:26:06 +02:00
2021-07-05 15:04:17 +02:00
$payment_hash = PaymentHash::whereRaw('BINARY `hash`= ?', [$data['m_payment_id']])->first();
$this->setPaymentMethod(GatewayType::CREDIT_CARD)
->setPaymentHash($payment_hash)
->processPaymentResponse($request);
return response()->json([], 200);
break;
2021-07-05 06:07:43 +02:00
}
2021-07-05 05:36:12 +02:00
}
2021-06-24 11:45:45 +02:00
return response()->json([], 200);
2021-07-10 08:26:06 +02:00
}
2021-06-24 06:43:14 +02:00
}