1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-11-18 09:04:35 +01:00
invoiceninja/app/PaymentDrivers/Authorize/AuthorizeCreditCard.php

232 lines
8.3 KiB
PHP
Raw Normal View History

2020-06-16 02:21:40 +02:00
<?php
/**
* Invoice Ninja (https://invoiceninja.com).
2020-06-16 02:21:40 +02:00
*
* @link https://github.com/invoiceninja/invoiceninja source repository
*
* @copyright Copyright (c) 2021. Invoice Ninja LLC (https://invoiceninja.com)
2020-06-16 02:21:40 +02:00
*
* @license https://opensource.org/licenses/AAL
*/
namespace App\PaymentDrivers\Authorize;
use App\Exceptions\PaymentFailed;
2021-01-26 13:09:08 +01:00
use App\Jobs\Mail\PaymentFailureMailer;
use App\Jobs\Util\SystemLogger;
2020-06-16 02:31:05 +02:00
use App\Models\ClientGatewayToken;
use App\Models\GatewayType;
use App\Models\Payment;
2020-09-02 11:36:32 +02:00
use App\Models\PaymentHash;
2020-06-17 00:48:07 +02:00
use App\Models\PaymentType;
use App\Models\SystemLog;
use App\PaymentDrivers\AuthorizePaymentDriver;
use App\Utils\Traits\MakesHash;
2020-06-16 02:21:40 +02:00
/**
* Class AuthorizeCreditCard.
2020-06-16 02:21:40 +02:00
*/
class AuthorizeCreditCard
{
use MakesHash;
2020-06-16 02:21:40 +02:00
public $authorize;
public function __construct(AuthorizePaymentDriver $authorize)
{
$this->authorize = $authorize;
}
public function processPaymentView($data)
{
$tokens = ClientGatewayToken::where('client_id', $this->authorize->client->id)
->where('company_gateway_id', $this->authorize->company_gateway->id)
->where('gateway_type_id', GatewayType::CREDIT_CARD)
->get();
$data['tokens'] = $tokens;
$data['gateway'] = $this->authorize;
$data['public_client_id'] = $this->authorize->init()->getPublicClientKey();
$data['api_login_id'] = $this->authorize->company_gateway->getConfigField('apiLoginId');
2020-06-16 06:01:10 +02:00
return render('gateways.authorize.credit_card.pay', $data);
}
public function processPaymentResponse($request)
{
if ($request->token) {
return $this->processTokenPayment($request);
}
$data = $request->all();
$authorise_create_customer = new AuthorizeCreateCustomer($this->authorize, $this->authorize->client);
$gateway_customer_reference = $authorise_create_customer->create($data);
$authorise_payment_method = new AuthorizePaymentMethod($this->authorize);
$payment_profile = $authorise_payment_method->addPaymentMethodToClient($gateway_customer_reference, $data);
2020-06-17 13:15:24 +02:00
$payment_profile_id = $payment_profile->getPaymentProfile()->getCustomerPaymentProfileId();
2021-01-25 16:12:21 +01:00
if ($request->has('store_card') && $request->input('store_card') === true) {
2020-06-17 11:46:12 +02:00
$authorise_payment_method->payment_method = GatewayType::CREDIT_CARD;
$client_gateway_token = $authorise_payment_method->createClientGatewayToken($payment_profile, $gateway_customer_reference);
2020-06-17 11:46:12 +02:00
}
2021-01-13 15:36:28 +01:00
$data = (new ChargePaymentProfile($this->authorize))->chargeCustomerProfile($gateway_customer_reference, $payment_profile_id, $data['amount_with_fee']);
return $this->handleResponse($data, $request);
}
private function processTokenPayment($request)
{
$client_gateway_token = ClientGatewayToken::query()
->where('id', $this->decodePrimaryKey($request->token))
->where('company_id', auth('contact')->user()->client->company->id)
->first();
if (!$client_gateway_token) {
throw new PaymentFailed(ctrans('texts.payment_token_not_found'), 401);
}
2020-06-17 13:15:24 +02:00
$data = (new ChargePaymentProfile($this->authorize))->chargeCustomerProfile($client_gateway_token->gateway_customer_reference, $client_gateway_token->token, $request->input('amount_with_fee'));
2020-06-17 00:48:07 +02:00
return $this->handleResponse($data, $request);
}
2021-01-26 10:11:29 +01:00
public function tokenBilling($cgt, $payment_hash)
{
$amount = array_sum(array_column($payment_hash->invoices(), 'amount')) + $payment_hash->fee_total;
$data = (new ChargePaymentProfile($this->authorize))->chargeCustomerProfile($cgt->gateway_customer_reference, $cgt->token, $amount);
2020-07-13 06:46:16 +02:00
2020-11-26 05:43:53 +01:00
/*Refactor and push to BaseDriver*/
if ($data['response'] != null && $data['response']->getMessages()->getResultCode() == 'Ok') {
2021-01-26 10:39:52 +01:00
2021-01-26 10:42:55 +01:00
$response = $data['response'];
2021-01-26 10:53:18 +01:00
2020-11-26 12:35:17 +01:00
$this->storePayment($payment_hash, $data);
2020-12-21 12:10:28 +01:00
2020-07-13 06:56:07 +02:00
$vars = [
2021-01-26 10:39:52 +01:00
'invoices' => $payment_hash->invoices(),
'amount' => $amount,
2020-07-13 06:56:07 +02:00
];
$logger_message = [
'server_response' => $response->getTransactionResponse()->getTransId(),
'data' => $this->formatGatewayResponse($data, $vars),
2020-07-13 06:56:07 +02:00
];
SystemLogger::dispatch($logger_message, SystemLog::CATEGORY_GATEWAY_RESPONSE, SystemLog::EVENT_GATEWAY_SUCCESS, SystemLog::TYPE_AUTHORIZE, $this->authorize->client);
return true;
} else {
2021-01-26 10:53:18 +01:00
$vars = [
'invoices' => $payment_hash->invoices(),
'amount' => $amount,
];
$logger_message = [
'server_response' => $response->getTransactionResponse()->getTransId(),
'data' => $this->formatGatewayResponse($data, $vars),
];
2021-01-26 13:09:08 +01:00
PaymentFailureMailer::dispatch($this->authorize->client, $response->getTransactionResponse()->getTransId(), $this->authorize->client->company, $amount);
2021-01-26 10:53:18 +01:00
SystemLogger::dispatch($logger_message, SystemLog::CATEGORY_GATEWAY_RESPONSE, SystemLog::EVENT_GATEWAY_FAILURE, SystemLog::TYPE_AUTHORIZE, $this->authorize->client);
2020-07-14 14:50:16 +02:00
return false;
2020-07-13 06:46:16 +02:00
}
2020-07-08 08:54:16 +02:00
}
2020-11-26 05:43:53 +01:00
2020-07-08 08:54:16 +02:00
private function handleResponse($data, $request)
{
$response = $data['response'];
if ($response != null && $response->getMessages()->getResultCode() == 'Ok') {
return $this->processSuccessfulResponse($data, $request);
}
return $this->processFailedResponse($data, $request);
}
private function storePayment($payment_hash, $data)
{
$amount = array_sum(array_column($payment_hash->invoices(), 'amount')) + $payment_hash->fee_total;
2020-11-26 12:35:17 +01:00
$response = $data['response'];
2020-11-26 12:35:17 +01:00
$payment_record = [];
$payment_record['amount'] = $amount;
2020-11-27 12:08:42 +01:00
$payment_record['payment_type'] = PaymentType::CREDIT_CARD_OTHER;
$payment_record['gateway_type_id'] = GatewayType::CREDIT_CARD;
2020-11-26 12:35:17 +01:00
$payment_record['transaction_reference'] = $response->getTransactionResponse()->getTransId();
2020-11-26 12:35:17 +01:00
$payment = $this->authorize->createPayment($payment_record);
return $payment;
}
2020-07-13 06:46:16 +02:00
private function processSuccessfulResponse($data, $request)
{
$payment_hash = PaymentHash::whereRaw('BINARY `hash`= ?', [$request->input('payment_hash')])->firstOrFail();
$payment = $this->storePayment($payment_hash, $data);
2020-07-13 06:56:07 +02:00
$vars = [
2020-09-03 13:22:49 +02:00
'invoices' => $payment_hash->invoices(),
'amount' => array_sum(array_column($payment_hash->invoices(), 'amount')) + $payment_hash->fee_total,
2020-07-13 06:56:07 +02:00
];
$logger_message = [
2020-08-13 04:33:40 +02:00
'server_response' => $data['response']->getTransactionResponse()->getTransId(),
'data' => $this->formatGatewayResponse($data, $vars),
];
SystemLogger::dispatch(
2021-01-13 15:36:28 +01:00
$logger_message,
SystemLog::CATEGORY_GATEWAY_RESPONSE,
SystemLog::EVENT_GATEWAY_SUCCESS,
SystemLog::TYPE_AUTHORIZE,
$this->authorize->client
);
return redirect()->route('client.payments.show', ['payment' => $this->encodePrimaryKey($payment->id)]);
}
private function processFailedResponse($data, $request)
{
2021-01-26 13:09:08 +01:00
$response = $data['response'];
PaymentFailureMailer::dispatch($this->authorize->client, $response->getTransactionResponse()->getTransId(), $this->authorize->client->company, $data['amount_with_fee']);
throw new \Exception(ctrans('texts.error_title'));
2020-06-16 02:21:40 +02:00
}
2020-07-13 06:56:07 +02:00
private function formatGatewayResponse($data, $vars)
{
$response = $data['response'];
2021-03-30 05:23:29 +02:00
$code = '';
$description = '';
if($response->getTransactionResponse()->getMessages() !== null){
$code = $response->getTransactionResponse()->getMessages()[0]->getCode();
$description = $response->getTransactionResponse()->getMessages()[0]->getDescription();
}
return [
'transaction_reference' => $response->getTransactionResponse()->getTransId(),
2020-07-13 06:56:07 +02:00
'amount' => $vars['amount'],
'auth_code' => $response->getTransactionResponse()->getAuthCode(),
2021-03-30 05:23:29 +02:00
'code' => $code,
'description' => $description,
'invoices' => $vars['invoices'],
];
}
}