mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2025-05-24 02:14:21 -04:00
Create driver template
This commit is contained in:
parent
137231c95e
commit
b2c005a1aa
@ -11,15 +11,24 @@
|
|||||||
|
|
||||||
namespace App\PaymentDrivers;
|
namespace App\PaymentDrivers;
|
||||||
|
|
||||||
|
use App\Models\ClientGatewayToken;
|
||||||
use App\Models\Payment;
|
use App\Models\Payment;
|
||||||
|
use App\Models\PaymentHash;
|
||||||
|
use Illuminate\Http\Request;
|
||||||
|
|
||||||
abstract class AbstractPaymentDriver
|
abstract class AbstractPaymentDriver
|
||||||
{
|
{
|
||||||
abstract public function authorize($payment_method);
|
abstract public function authorizeView(array $data);
|
||||||
|
|
||||||
abstract public function purchase($amount, $return_client_response = false);
|
abstract public function authorizeResponse(Request $request);
|
||||||
|
|
||||||
|
abstract public function processPaymentView(array $data);
|
||||||
|
|
||||||
|
abstract public function processPaymentResponse(Request $request);
|
||||||
|
|
||||||
abstract public function refund(Payment $payment, $refund_amount, $return_client_response = false);
|
abstract public function refund(Payment $payment, $refund_amount, $return_client_response = false);
|
||||||
|
|
||||||
|
abstract public function tokenBilling(ClientGatewayToken $cgt, PaymentHash $payment_hash);
|
||||||
|
|
||||||
abstract public function setPaymentMethod($payment_method_id);
|
abstract public function setPaymentMethod($payment_method_id);
|
||||||
}
|
}
|
||||||
|
@ -60,22 +60,19 @@ class BaseDriver extends AbstractPaymentDriver
|
|||||||
/* The client */
|
/* The client */
|
||||||
public $client;
|
public $client;
|
||||||
|
|
||||||
/* The initiated gateway driver class*/
|
/* The initialized gateway driver class*/
|
||||||
public $payment_method;
|
public $payment_method;
|
||||||
|
|
||||||
/**
|
/* PaymentHash */
|
||||||
* @var PaymentHash
|
|
||||||
*/
|
|
||||||
public $payment_hash;
|
public $payment_hash;
|
||||||
|
|
||||||
|
/* Array of payment methods */
|
||||||
public static $methods = [];
|
public static $methods = [];
|
||||||
|
|
||||||
public function __construct(CompanyGateway $company_gateway, Client $client = null, $invitation = false)
|
public function __construct(CompanyGateway $company_gateway, Client $client = null, $invitation = false)
|
||||||
{
|
{
|
||||||
$this->company_gateway = $company_gateway;
|
$this->company_gateway = $company_gateway;
|
||||||
|
|
||||||
$this->invitation = $invitation;
|
$this->invitation = $invitation;
|
||||||
|
|
||||||
$this->client = $client;
|
$this->client = $client;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -83,23 +80,35 @@ class BaseDriver extends AbstractPaymentDriver
|
|||||||
* Authorize a payment method.
|
* Authorize a payment method.
|
||||||
*
|
*
|
||||||
* Returns a reusable token for storage for future payments
|
* Returns a reusable token for storage for future payments
|
||||||
* @param const $payment_method The GatewayType::constant
|
*
|
||||||
* @return void Return a view for collecting payment method information
|
* @param array $data
|
||||||
|
* @return mixed Return a view for collecting payment method information
|
||||||
*/
|
*/
|
||||||
public function authorize($payment_method)
|
public function authorizeView(array $data) {}
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Executes purchase attempt for a given amount.
|
* The payment authorization response
|
||||||
*
|
*
|
||||||
* @param float $amount The amount to be collected
|
* @param Request $request
|
||||||
* @param bool $return_client_response Whether the method needs to return a response (otherwise we assume an unattended payment)
|
* @return mixed Return a response for collecting payment method information
|
||||||
* @return mixed
|
|
||||||
*/
|
*/
|
||||||
public function purchase($amount, $return_client_response = false)
|
public function authorizeResponse(Request $request) {}
|
||||||
{
|
|
||||||
}
|
/**
|
||||||
|
* Process a payment
|
||||||
|
*
|
||||||
|
* @param array $data
|
||||||
|
* @return mixed Return a view for the payment
|
||||||
|
*/
|
||||||
|
public function processPaymentView(array $data) {}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Process payment response
|
||||||
|
*
|
||||||
|
* @param Request $request
|
||||||
|
* @return mixed Return a response for the payment
|
||||||
|
*/
|
||||||
|
public function processPaymentResponse(Request $request) {}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Executes a refund attempt for a given amount with a transaction_reference.
|
* Executes a refund attempt for a given amount with a transaction_reference.
|
||||||
@ -109,23 +118,30 @@ class BaseDriver extends AbstractPaymentDriver
|
|||||||
* @param bool $return_client_response Whether the method needs to return a response (otherwise we assume an unattended payment)
|
* @param bool $return_client_response Whether the method needs to return a response (otherwise we assume an unattended payment)
|
||||||
* @return mixed
|
* @return mixed
|
||||||
*/
|
*/
|
||||||
public function refund(Payment $payment, $amount, $return_client_response = false)
|
public function refund(Payment $payment, $amount, $return_client_response = false) {}
|
||||||
{
|
|
||||||
}
|
/**
|
||||||
|
* Process an unattended payment.
|
||||||
|
*
|
||||||
|
* @param ClientGatewayToken $cgt The client gateway token object
|
||||||
|
* @param PaymentHash $payment_hash The Payment hash containing the payment meta data
|
||||||
|
* @return void The payment response
|
||||||
|
*/
|
||||||
|
public function tokenBilling(ClientGatewayToken $cgt, PaymentHash $payment_hash){}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set the inbound request payment method type for access.
|
* Set the inbound request payment method type for access.
|
||||||
*
|
*
|
||||||
* @param int $payment_method_id The Payment Method ID
|
* @param int $payment_method_id The Payment Method ID
|
||||||
*/
|
*/
|
||||||
public function setPaymentMethod($payment_method_id)
|
public function setPaymentMethod($payment_method_id){}
|
||||||
{
|
|
||||||
}
|
|
||||||
|
/************************** Helper methods *************************************/
|
||||||
|
|
||||||
public function setPaymentHash(PaymentHash $payment_hash)
|
public function setPaymentHash(PaymentHash $payment_hash)
|
||||||
{
|
{
|
||||||
$this->payment_hash = $payment_hash;
|
$this->payment_hash = $payment_hash;
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -186,17 +202,6 @@ class BaseDriver extends AbstractPaymentDriver
|
|||||||
return $payment->service()->applyNumber()->save();
|
return $payment->service()->applyNumber()->save();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Process an unattended payment.
|
|
||||||
*
|
|
||||||
* @param ClientGatewayToken $cgt The client gateway token object
|
|
||||||
* @param PaymentHash $payment_hash The Payment hash containing the payment meta data
|
|
||||||
* @return void The payment response
|
|
||||||
*/
|
|
||||||
public function tokenBilling(ClientGatewayToken $cgt, PaymentHash $payment_hash)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* When a successful payment is made, we need to append the gateway fee
|
* When a successful payment is made, we need to append the gateway fee
|
||||||
* to an invoice.
|
* to an invoice.
|
||||||
@ -212,7 +217,7 @@ class BaseDriver extends AbstractPaymentDriver
|
|||||||
/*Payment invoices*/
|
/*Payment invoices*/
|
||||||
$payment_invoices = $payment_hash->invoices();
|
$payment_invoices = $payment_hash->invoices();
|
||||||
|
|
||||||
// /*Fee charged at gateway*/
|
/*Fee charged at gateway*/
|
||||||
$fee_total = $payment_hash->fee_total;
|
$fee_total = $payment_hash->fee_total;
|
||||||
|
|
||||||
// Sum of invoice amounts
|
// Sum of invoice amounts
|
||||||
@ -262,7 +267,6 @@ class BaseDriver extends AbstractPaymentDriver
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Store payment method as company gateway token.
|
* Store payment method as company gateway token.
|
||||||
*
|
*
|
||||||
|
101
app/PaymentDrivers/DriverTemplate.php
Normal file
101
app/PaymentDrivers/DriverTemplate.php
Normal file
@ -0,0 +1,101 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Invoice Ninja (https://invoiceninja.com).
|
||||||
|
*
|
||||||
|
* @link https://github.com/invoiceninja/invoiceninja source repository
|
||||||
|
*
|
||||||
|
* @copyright Copyright (c) 2020. Invoice Ninja LLC (https://invoiceninja.com)
|
||||||
|
*
|
||||||
|
* @license https://opensource.org/licenses/AAL
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace App\PaymentDrivers;
|
||||||
|
|
||||||
|
use App\Utils\Traits\MakesHash;
|
||||||
|
|
||||||
|
|
||||||
|
class YourGatewayPaymentDriver extends BaseDriver
|
||||||
|
{
|
||||||
|
use MakesHash;
|
||||||
|
|
||||||
|
public $refundable = true; //does this gateway support refunds?
|
||||||
|
|
||||||
|
public $token_billing = true; //does this gateway support token billing?
|
||||||
|
|
||||||
|
public $can_authorise_credit_card = true; //does this gateway support authorizations?
|
||||||
|
|
||||||
|
public $gateway; //initialized gateway
|
||||||
|
|
||||||
|
public $payment_method; //initialized payment method
|
||||||
|
|
||||||
|
public static $methods = [
|
||||||
|
GatewayType::CREDIT_CARD => CreditCard::class, //maps GatewayType => Implementation class
|
||||||
|
];
|
||||||
|
|
||||||
|
const SYSTEM_LOG_TYPE = SystemLog::TYPE_STRIPE;
|
||||||
|
|
||||||
|
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();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function tokenBilling(ClientGatewayToken $cgt, PaymentHash $payment_hash)
|
||||||
|
{
|
||||||
|
return $this->payment_method->yourTokenBillingImplmentation();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a payment record for the given
|
||||||
|
* data array.
|
||||||
|
*
|
||||||
|
* @param array $data An array of payment attributes
|
||||||
|
* @param float $amount The amount of the payment
|
||||||
|
* @return Payment The payment object
|
||||||
|
*/
|
||||||
|
public function createPaymentRecord($data, $amount): ?Payment
|
||||||
|
{
|
||||||
|
$payment = PaymentFactory::create($this->client->company_id, $this->client->user_id);
|
||||||
|
$payment->client_id = $this->client->id;
|
||||||
|
$payment->company_gateway_id = $this->company_gateway->id;
|
||||||
|
$payment->status_id = Payment::STATUS_COMPLETED;
|
||||||
|
$payment->gateway_type_id = $data['gateway_type_id'];
|
||||||
|
$payment->type_id = $data['type_id'];
|
||||||
|
$payment->currency_id = $this->client->getSetting('currency_id');
|
||||||
|
$payment->date = Carbon::now();
|
||||||
|
$payment->transaction_reference = $data['transaction_reference'];
|
||||||
|
$payment->amount = $amount;
|
||||||
|
$payment->save();
|
||||||
|
|
||||||
|
return $payment->service()->applyNumber()->save();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user