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;
|
||||
|
||||
use App\Models\ClientGatewayToken;
|
||||
use App\Models\Payment;
|
||||
use App\Models\PaymentHash;
|
||||
use Illuminate\Http\Request;
|
||||
|
||||
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 tokenBilling(ClientGatewayToken $cgt, PaymentHash $payment_hash);
|
||||
|
||||
abstract public function setPaymentMethod($payment_method_id);
|
||||
}
|
||||
|
@ -60,22 +60,19 @@ class BaseDriver extends AbstractPaymentDriver
|
||||
/* The client */
|
||||
public $client;
|
||||
|
||||
/* The initiated gateway driver class*/
|
||||
/* The initialized gateway driver class*/
|
||||
public $payment_method;
|
||||
|
||||
/**
|
||||
* @var PaymentHash
|
||||
*/
|
||||
/* PaymentHash */
|
||||
public $payment_hash;
|
||||
|
||||
/* Array of payment methods */
|
||||
public static $methods = [];
|
||||
|
||||
public function __construct(CompanyGateway $company_gateway, Client $client = null, $invitation = false)
|
||||
{
|
||||
$this->company_gateway = $company_gateway;
|
||||
|
||||
$this->invitation = $invitation;
|
||||
|
||||
$this->client = $client;
|
||||
}
|
||||
|
||||
@ -83,23 +80,35 @@ class BaseDriver extends AbstractPaymentDriver
|
||||
* Authorize a payment method.
|
||||
*
|
||||
* 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.
|
||||
*
|
||||
* @param float $amount The amount to be collected
|
||||
* @param bool $return_client_response Whether the method needs to return a response (otherwise we assume an unattended payment)
|
||||
* @return mixed
|
||||
* The payment authorization response
|
||||
*
|
||||
* @param Request $request
|
||||
* @return mixed Return a response for collecting payment method information
|
||||
*/
|
||||
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.
|
||||
@ -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)
|
||||
* @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.
|
||||
*
|
||||
* @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)
|
||||
{
|
||||
$this->payment_hash = $payment_hash;
|
||||
|
||||
return $this;
|
||||
}
|
||||
|
||||
@ -186,17 +202,6 @@ class BaseDriver extends AbstractPaymentDriver
|
||||
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
|
||||
* to an invoice.
|
||||
@ -212,7 +217,7 @@ class BaseDriver extends AbstractPaymentDriver
|
||||
/*Payment invoices*/
|
||||
$payment_invoices = $payment_hash->invoices();
|
||||
|
||||
// /*Fee charged at gateway*/
|
||||
/*Fee charged at gateway*/
|
||||
$fee_total = $payment_hash->fee_total;
|
||||
|
||||
// Sum of invoice amounts
|
||||
@ -262,7 +267,6 @@ class BaseDriver extends AbstractPaymentDriver
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* 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