2019-09-05 09:00:12 +02:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Invoice Ninja (https://invoiceninja.com)
|
|
|
|
*
|
|
|
|
* @link https://github.com/invoiceninja/invoiceninja source repository
|
|
|
|
*
|
|
|
|
* @copyright Copyright (c) 2019. Invoice Ninja LLC (https://invoiceninja.com)
|
|
|
|
*
|
|
|
|
* @license https://opensource.org/licenses/AAL
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace App\PaymentDrivers;
|
|
|
|
|
2019-09-08 14:13:55 +02:00
|
|
|
use App\Models\GatewayType;
|
2019-09-13 00:33:48 +02:00
|
|
|
use Stripe\PaymentIntent;
|
2019-09-14 14:34:05 +02:00
|
|
|
use Stripe\SetupIntent;
|
2019-09-05 14:42:26 +02:00
|
|
|
use Stripe\Stripe;
|
|
|
|
|
2019-09-05 09:00:12 +02:00
|
|
|
class StripePaymentDriver extends BasePaymentDriver
|
|
|
|
{
|
2019-09-06 07:22:05 +02:00
|
|
|
protected $refundable = true;
|
2019-09-05 09:00:12 +02:00
|
|
|
|
2019-09-06 07:22:05 +02:00
|
|
|
protected $token_billing = true;
|
|
|
|
|
2019-09-15 13:40:46 +02:00
|
|
|
protected $can_authorise_credit_card = true;
|
|
|
|
|
2019-09-06 07:22:05 +02:00
|
|
|
protected $customer_reference = 'customerReferenceParam';
|
|
|
|
|
2019-09-08 14:13:55 +02:00
|
|
|
|
2019-09-05 14:42:26 +02:00
|
|
|
/**
|
|
|
|
* Methods in this class are divided into
|
|
|
|
* two separate streams
|
|
|
|
*
|
|
|
|
* 1. Omnipay Specific
|
|
|
|
* 2. Stripe Specific
|
|
|
|
*
|
|
|
|
* Our Stripe integration is deeper than
|
|
|
|
* other gateways and therefore
|
|
|
|
* relies on direct calls to the API
|
|
|
|
*/
|
2019-09-08 14:13:55 +02:00
|
|
|
/************************************** Stripe API methods **********************************************************/
|
2019-09-05 14:42:26 +02:00
|
|
|
|
2019-09-16 06:59:59 +02:00
|
|
|
public function init()
|
2019-09-08 14:13:55 +02:00
|
|
|
{
|
2019-09-16 06:59:59 +02:00
|
|
|
Stripe::setApiKey($this->company_gateway->getConfigField('23_apiKey'));
|
2019-09-08 14:13:55 +02:00
|
|
|
}
|
|
|
|
/**
|
|
|
|
* Returns the gateway types
|
|
|
|
*/
|
|
|
|
public function gatewayTypes() :array
|
|
|
|
{
|
|
|
|
$types = [
|
|
|
|
GatewayType::CREDIT_CARD,
|
|
|
|
GatewayType::TOKEN,
|
|
|
|
];
|
|
|
|
|
|
|
|
if($this->company_gateway->getSofortEnabled() && $this->invitation && $this->client() && isset($this->client()->country) && in_array($this->client()->country, ['AUT', 'BEL', 'DEU', 'ITA', 'NLD', 'ESP']))
|
|
|
|
$types[] = GatewayType::SOFORT;
|
|
|
|
|
|
|
|
if($this->company_gateway->getAchEnabled())
|
|
|
|
$types[] = GatewayType::BANK_TRANSFER;
|
|
|
|
|
|
|
|
if ($this->company_gateway->getSepaEnabled())
|
|
|
|
$types[] = GatewayType::SEPA;
|
|
|
|
|
|
|
|
if ($this->company_gateway->getBitcoinEnabled())
|
|
|
|
$types[] = GatewayType::BITCOIN;
|
|
|
|
|
|
|
|
if ($this->company_gateway->getAlipayEnabled())
|
|
|
|
$types[] = GatewayType::ALIPAY;
|
|
|
|
|
|
|
|
if ($this->company_gateway->getApplePayEnabled())
|
|
|
|
$types[] = GatewayType::APPLE_PAY;
|
|
|
|
|
|
|
|
|
|
|
|
return $types;
|
|
|
|
|
2019-09-12 13:46:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public function viewForType($payment_type)
|
|
|
|
{
|
|
|
|
switch ($payment_type) {
|
|
|
|
case GatewayType::CREDIT_CARD:
|
2019-09-14 14:34:05 +02:00
|
|
|
return 'portal.default.gateways.stripe.credit_card';
|
2019-09-12 13:46:09 +02:00
|
|
|
break;
|
|
|
|
case GatewayType::TOKEN:
|
2019-09-14 14:34:05 +02:00
|
|
|
return 'portal.default.gateways.stripe.credit_card';
|
2019-09-12 13:46:09 +02:00
|
|
|
break;
|
|
|
|
case GatewayType::SOFORT:
|
2019-09-14 14:34:05 +02:00
|
|
|
return 'portal.default.gateways.stripe.sofort';
|
2019-09-12 13:46:09 +02:00
|
|
|
break;
|
|
|
|
case GatewayType::BANK_TRANSFER:
|
2019-09-14 14:34:05 +02:00
|
|
|
return 'portal.default.gateways.stripe.ach';
|
2019-09-12 13:46:09 +02:00
|
|
|
break;
|
|
|
|
case GatewayType::SEPA:
|
2019-09-14 14:34:05 +02:00
|
|
|
return 'portal.default.gateways.stripe.sepa';
|
2019-09-12 13:46:09 +02:00
|
|
|
break;
|
|
|
|
case GatewayType::BITCOIN:
|
2019-09-14 14:34:05 +02:00
|
|
|
return 'portal.default.gateways.stripe.other';
|
2019-09-12 13:46:09 +02:00
|
|
|
break;
|
|
|
|
case GatewayType::ALIPAY:
|
2019-09-14 14:34:05 +02:00
|
|
|
return 'portal.default.gateways.stripe.other';
|
2019-09-12 13:46:09 +02:00
|
|
|
break;
|
|
|
|
case GatewayType::APPLE_PAY:
|
2019-09-14 14:34:05 +02:00
|
|
|
return 'portal.default.gateways.stripe.other';
|
2019-09-12 13:46:09 +02:00
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
# code...
|
|
|
|
break;
|
|
|
|
}
|
2019-09-08 14:13:55 +02:00
|
|
|
}
|
2019-09-13 00:33:48 +02:00
|
|
|
|
2019-09-14 14:34:05 +02:00
|
|
|
public function authorizeCreditCardView($data)
|
|
|
|
{
|
2019-09-16 04:05:30 +02:00
|
|
|
$intent['intent'] = $this->getSetupIntent();
|
2019-09-14 14:34:05 +02:00
|
|
|
|
2019-09-16 13:03:25 +02:00
|
|
|
return view('portal.default.gateways.stripe.create_customer', array_merge($data, $intent));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
public function authorizeCreditCardResponse($request)
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* {
|
|
|
|
"id": "seti_1FJHmuKmol8YQE9DdhDgFXhT",
|
|
|
|
"object": "setup_intent",
|
|
|
|
"cancellation_reason": null,
|
|
|
|
"client_secret": "seti_1FJHmuKmol8YQE9DdhDgFXhT_secret_FoveetSB7RewVngU7H6IcrH9dlM1BXd",
|
|
|
|
"created": 1568631032,
|
|
|
|
"description": null,
|
|
|
|
"last_setup_error": null,
|
|
|
|
"livemode": false,
|
|
|
|
"next_action": null,
|
|
|
|
"payment_method": "pm_1FJHvQKmol8YQE9DV19fPXXk",
|
|
|
|
"payment_method_types": [
|
|
|
|
"card"
|
|
|
|
],
|
|
|
|
"status": "succeeded",
|
|
|
|
"usage": "off_session"
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
\Stripe\Stripe::setApiKey('sk_test_faU9gVB7Hx19fCTo0e5ggZ0x');
|
|
|
|
|
|
|
|
\Stripe\PaymentMethod::retrieve('pm_1EUmzw2xToAoV8choYUtciXR');
|
|
|
|
|
|
|
|
|
|
|
|
{
|
|
|
|
"id": "pm_1EUmzw2xToAoV8choYUtciXR",
|
|
|
|
"object": "payment_method",
|
|
|
|
"card": {
|
|
|
|
"brand": "visa",
|
|
|
|
"checks": {
|
|
|
|
"address_line1_check": null,
|
|
|
|
"address_postal_code_check": null,
|
|
|
|
"cvc_check": null
|
|
|
|
},
|
|
|
|
"country": "US",
|
|
|
|
"exp_month": 8,
|
|
|
|
"exp_year": 2020,
|
|
|
|
"fingerprint": "sStRRZt3Xlw0Ec6B",
|
|
|
|
"funding": "credit",
|
|
|
|
"generated_from": null,
|
|
|
|
"last4": "4242",
|
|
|
|
"three_d_secure_usage": {
|
|
|
|
"supported": true
|
|
|
|
},
|
|
|
|
"wallet": null
|
|
|
|
},
|
|
|
|
"created": 1556596276,
|
|
|
|
"customer": "cus_3fAHf0I56s1QFx",
|
|
|
|
"livemode": false,
|
|
|
|
"metadata": {},
|
|
|
|
"type": "card"
|
|
|
|
}
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
//get the customer or create a new one.
|
|
|
|
//get the payment method
|
|
|
|
//attached payment method to customer
|
|
|
|
//store meta data
|
2019-09-16 04:05:30 +02:00
|
|
|
|
|
|
|
|
2019-09-14 14:34:05 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2019-09-13 00:33:48 +02:00
|
|
|
/**
|
|
|
|
* Creates a new String Payment Intent
|
|
|
|
* @param array $data The data array to be passed to Stripe
|
|
|
|
* @return PaymentIntent The Stripe payment intent object
|
|
|
|
*/
|
|
|
|
public function createIntent($data)
|
|
|
|
{
|
2019-09-16 06:59:59 +02:00
|
|
|
$this->init();
|
2019-09-13 00:33:48 +02:00
|
|
|
return PaymentIntent::create($data);
|
|
|
|
}
|
2019-09-14 14:34:05 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a setup intent that allows the user to enter card details without initiating a transaction.
|
|
|
|
*
|
|
|
|
* @return \Stripe\SetupIntent
|
|
|
|
*/
|
|
|
|
public function getSetupIntent()
|
|
|
|
{
|
2019-09-16 06:59:59 +02:00
|
|
|
$this->init();
|
2019-09-14 14:34:05 +02:00
|
|
|
return SetupIntent::create();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getPublishableKey()
|
|
|
|
{
|
|
|
|
return $this->company_gateway->getPublishableKey();
|
|
|
|
}
|
2019-09-16 06:59:59 +02:00
|
|
|
|
|
|
|
public function findOrCreateCustomer() :?\Stripe\Customer
|
|
|
|
{
|
|
|
|
|
|
|
|
$customer = null;
|
|
|
|
|
|
|
|
$this->init();
|
|
|
|
|
|
|
|
$client_gateway_token = $this->client->gateway_tokens->whereGatewayId($this->company_gateway->gateway_id)->first();
|
|
|
|
|
|
|
|
if($client_gateway_token->gateway_customer_reference)
|
|
|
|
$customer = \Stripe\Customer::retrieve($client_gateway_token->gateway_customer_reference);
|
|
|
|
else{
|
|
|
|
$customer = \Stripe\Customer::create([
|
|
|
|
"email" => $this->client->present()->email(),
|
|
|
|
"name" => $this->client->present()->name(),
|
|
|
|
"phone" => $this->client->present()->phone(),
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
return $customer;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-09-05 14:42:26 +02:00
|
|
|
/************************************** Omnipay API methods **********************************************************/
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2019-09-05 09:00:12 +02:00
|
|
|
}
|