CreditCard::class, ]; const SYSTEM_LOG_TYPE = SystemLog::TYPE_PAYFAST; //developer resources //https://sandbox.payfast.co.za/ public function gatewayTypes(): array { $types = []; $types[] = GatewayType::CREDIT_CARD; return $types; } 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'; } public function init() { try{ $this->payfast = new PayFastPayment( [ 'merchantId' => $this->company_gateway->getConfigField('merchantId'), 'merchantKey' => $this->company_gateway->getConfigField('merchantKey'), 'passPhrase' => $this->company_gateway->getConfigField('passPhrase'), 'testMode' => $this->company_gateway->getConfigField('testMode') ] ); } catch(Exception $e) { echo '##PAYFAST## There was an exception: '.$e->getMessage(); } 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) { return $this->payment_method->authorizeView($data); //this is your custom implementation from here } public function authorizeResponse($request) { return $this->payment_method->authorizeResponse($request); //this is your custom implementation from here } 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) { return $this->payment_method->yourRefundImplementationHere(); //this is your custom implementation from here } public function tokenBilling(ClientGatewayToken $cgt, PaymentHash $payment_hash) { return $this->payment_method->yourTokenBillingImplmentation(); //this is your custom implementation from here } public function generateSignature($data, $passPhrase = null) { // Create parameter string $pfOutput = ''; foreach( $data as $key => $val ) { if($val !== '') { $pfOutput .= $key .'='. urlencode( trim( $val ) ) .'&'; } } // Remove last ampersand $getString = substr( $pfOutput, 0, -1 ); if( $passPhrase !== null ) { $getString .= '&passphrase='. urlencode( trim( $passPhrase ) ); } return md5( $getString ); } public function processWebhookRequest(Request $request, Payment $payment = null) { $this->init(); nlog($request->all()); $data = $request->all(); if(array_key_exists('m_payment_id', $data) && $data['m_payment_id'] == 'pre-auth') { return $this->setPaymentMethod(GatewayType::CREDIT_CARD) ->authorizeResponse($request); } return response()->json([], 200); } }