mirror of
https://github.com/invoiceninja/invoiceninja.git
synced 2025-07-09 03:14:30 -04:00
getParent() ref to utilities
This commit is contained in:
parent
fdafc068bb
commit
7818afddf8
@ -29,6 +29,11 @@ trait Utilities
|
|||||||
return $this->company_gateway->getConfigField('publicApiKey');
|
return $this->company_gateway->getConfigField('publicApiKey');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getParent()
|
||||||
|
{
|
||||||
|
return static::class == 'App\PaymentDrivers\CheckoutComPaymentDriver' ? $this : $this->checkout;
|
||||||
|
}
|
||||||
|
|
||||||
public function convertToCheckoutAmount($amount, $currency)
|
public function convertToCheckoutAmount($amount, $currency)
|
||||||
{
|
{
|
||||||
$cases = [
|
$cases = [
|
||||||
@ -52,42 +57,42 @@ trait Utilities
|
|||||||
|
|
||||||
private function processSuccessfulPayment(Payment $_payment)
|
private function processSuccessfulPayment(Payment $_payment)
|
||||||
{
|
{
|
||||||
if ($this->checkout->payment_hash->data->store_card) {
|
if ($this->getParent()->payment_hash->data->store_card) {
|
||||||
$this->storePaymentMethod($_payment);
|
$this->storePaymentMethod($_payment);
|
||||||
}
|
}
|
||||||
|
|
||||||
$data = [
|
$data = [
|
||||||
'payment_method' => $_payment->source['id'],
|
'payment_method' => $_payment->source['id'],
|
||||||
'payment_type' => PaymentType::parseCardType(strtolower($_payment->source['scheme'])),
|
'payment_type' => PaymentType::parseCardType(strtolower($_payment->source['scheme'])),
|
||||||
'amount' => $this->checkout->payment_hash->data->raw_value,
|
'amount' => $this->getParent()->payment_hash->data->raw_value,
|
||||||
'transaction_reference' => $_payment->id,
|
'transaction_reference' => $_payment->id,
|
||||||
];
|
];
|
||||||
|
|
||||||
$payment = $this->checkout->createPayment($data, \App\Models\Payment::STATUS_COMPLETED);
|
$payment = $this->getParent()->createPayment($data, \App\Models\Payment::STATUS_COMPLETED);
|
||||||
|
|
||||||
SystemLogger::dispatch(
|
SystemLogger::dispatch(
|
||||||
['response' => $_payment, 'data' => $data],
|
['response' => $_payment, 'data' => $data],
|
||||||
SystemLog::CATEGORY_GATEWAY_RESPONSE,
|
SystemLog::CATEGORY_GATEWAY_RESPONSE,
|
||||||
SystemLog::EVENT_GATEWAY_SUCCESS,
|
SystemLog::EVENT_GATEWAY_SUCCESS,
|
||||||
SystemLog::TYPE_CHECKOUT,
|
SystemLog::TYPE_CHECKOUT,
|
||||||
$this->checkout->client
|
$this->getParent()->client
|
||||||
);
|
);
|
||||||
|
|
||||||
return redirect()->route('client.payments.show', ['payment' => $this->checkout->encodePrimaryKey($payment->id)]);
|
return redirect()->route('client.payments.show', ['payment' => $this->getParent()->encodePrimaryKey($payment->id)]);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function processUnsuccessfulPayment(Payment $_payment)
|
public function processUnsuccessfulPayment(Payment $_payment)
|
||||||
{
|
{
|
||||||
PaymentFailureMailer::dispatch(
|
PaymentFailureMailer::dispatch(
|
||||||
$this->checkout->client,
|
$this->getParent()->client,
|
||||||
$_payment,
|
$_payment,
|
||||||
$this->checkout->client->company,
|
$this->getParent()->client->company,
|
||||||
$this->checkout->payment_hash->data->value
|
$this->getParent()->payment_hash->data->value
|
||||||
);
|
);
|
||||||
|
|
||||||
$message = [
|
$message = [
|
||||||
'server_response' => $_payment,
|
'server_response' => $_payment,
|
||||||
'data' => $this->checkout->payment_hash->data,
|
'data' => $this->getParent()->payment_hash->data,
|
||||||
];
|
];
|
||||||
|
|
||||||
SystemLogger::dispatch(
|
SystemLogger::dispatch(
|
||||||
@ -95,7 +100,7 @@ trait Utilities
|
|||||||
SystemLog::CATEGORY_GATEWAY_RESPONSE,
|
SystemLog::CATEGORY_GATEWAY_RESPONSE,
|
||||||
SystemLog::EVENT_GATEWAY_FAILURE,
|
SystemLog::EVENT_GATEWAY_FAILURE,
|
||||||
SystemLog::TYPE_CHECKOUT,
|
SystemLog::TYPE_CHECKOUT,
|
||||||
$this->checkout->client
|
$this->getParent()->client
|
||||||
);
|
);
|
||||||
|
|
||||||
throw new PaymentFailed($_payment->status, $_payment->http_code);
|
throw new PaymentFailed($_payment->status, $_payment->http_code);
|
||||||
@ -103,27 +108,10 @@ trait Utilities
|
|||||||
|
|
||||||
private function processPendingPayment(Payment $_payment)
|
private function processPendingPayment(Payment $_payment)
|
||||||
{
|
{
|
||||||
$data = [
|
|
||||||
'payment_method' => $_payment->source->id,
|
|
||||||
'payment_type' => PaymentType::CREDIT_CARD_OTHER,
|
|
||||||
'amount' => $this->checkout->payment_hash->data->value,
|
|
||||||
'transaction_reference' => $_payment->id,
|
|
||||||
];
|
|
||||||
|
|
||||||
$payment = $this->checkout->createPayment($data, \App\Models\Payment::STATUS_PENDING);
|
|
||||||
|
|
||||||
SystemLogger::dispatch(
|
|
||||||
['response' => $_payment, 'data' => $data],
|
|
||||||
SystemLog::CATEGORY_GATEWAY_RESPONSE,
|
|
||||||
SystemLog::EVENT_GATEWAY_SUCCESS,
|
|
||||||
SystemLog::TYPE_CHECKOUT,
|
|
||||||
$this->checkout->client
|
|
||||||
);
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
return redirect($_payment->_links['redirect']['href']);
|
return redirect($_payment->_links['redirect']['href']);
|
||||||
} catch (Exception $e) {
|
} catch (Exception $e) {
|
||||||
return $this->processInternallyFailedPayment($this->checkout, $e);
|
return $this->processInternallyFailedPayment($this->getParent(), $e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -140,10 +128,10 @@ trait Utilities
|
|||||||
$data = [
|
$data = [
|
||||||
'payment_meta' => $payment_meta,
|
'payment_meta' => $payment_meta,
|
||||||
'token' => $response->source['id'],
|
'token' => $response->source['id'],
|
||||||
'payment_method_id' => $this->checkout->payment_hash->data->payment_method_id,
|
'payment_method_id' => $this->getParent()->payment_hash->data->payment_method_id,
|
||||||
];
|
];
|
||||||
|
|
||||||
return $this->checkout->storePaymentMethod($data);
|
return $this->getParent()->storePaymentMethod($data);
|
||||||
} catch (Exception $e) {
|
} catch (Exception $e) {
|
||||||
session()->flash('message', ctrans('texts.payment_method_saving_failed'));
|
session()->flash('message', ctrans('texts.payment_method_saving_failed'));
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user