1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-11-16 16:13:20 +01:00
invoiceninja/app/Services/Payment/PaymentService.php

182 lines
5.3 KiB
PHP
Raw Normal View History

<?php
/**
* payment Ninja (https://paymentninja.com).
*
* @link https://github.com/invoiceninja/invoiceninja source repository
*
2022-04-27 05:20:41 +02:00
* @copyright Copyright (c) 2022. payment Ninja LLC (https://paymentninja.com)
*
2021-06-16 08:58:16 +02:00
* @license https://www.elastic.co/licensing/elastic-license
*/
namespace App\Services\Payment;
use App\Factory\PaymentFactory;
use App\Models\Invoice;
use App\Models\Payment;
2020-09-19 03:20:14 +02:00
use App\Models\PaymentHash;
2021-01-06 06:54:04 +01:00
use App\Utils\Traits\MakesHash;
class PaymentService
{
2021-01-06 06:54:04 +01:00
use MakesHash;
private $payment;
public function __construct($payment)
{
$this->payment = $payment;
}
public function manualPayment($invoice) :?Payment
{
/* Create Payment */
$payment = PaymentFactory::create($invoice->company_id, $invoice->user_id);
$payment->amount = $invoice->balance;
$payment->status_id = Payment::STATUS_COMPLETED;
$payment->client_id = $invoice->client_id;
$payment->transaction_reference = ctrans('texts.manual_entry');
$payment->currency_id = $invoice->client->getSetting('currency_id');
/* Create a payment relationship to the invoice entity */
2021-10-15 09:47:41 +02:00
$payment->saveQuietly();
$payment->invoices()->attach($invoice->id, [
'amount' => $payment->amount,
]);
2021-10-15 09:47:41 +02:00
event('eloquent.created: App\Models\Payment', $payment);
return $payment;
}
public function sendEmail($contact = null)
{
return (new SendEmail($this->payment, $contact))->run();
}
public function reversePayment()
{
$invoices = $this->payment->invoices()->get();
$client = $this->payment->client;
$invoices->each(function ($invoice) {
if ($invoice->pivot->amount > 0) {
$invoice->service()
->updateBalance($invoice->pivot->amount)
->updatePaidToDate($invoice->pivot->amount * -1)
->setStatus(Invoice::STATUS_SENT)
->save();
}
});
2020-10-10 12:57:28 +02:00
$this->payment
->ledger()
->updatePaymentBalance($this->payment->amount);
$client->service()
->updateBalance($this->payment->amount)
->updatePaidToDate($this->payment->amount * -1)
->save();
2020-10-10 12:57:28 +02:00
return $this;
}
2020-05-29 00:21:47 +02:00
public function refundPayment(array $data) :?Payment
{
return ((new RefundPayment($this->payment, $data)))->run();
}
public function deletePayment($update_client_paid_to_date = true) :?Payment
2020-06-28 00:24:08 +02:00
{
return (new DeletePayment($this->payment, $update_client_paid_to_date))->run();
2020-06-28 00:24:08 +02:00
}
2020-09-19 03:20:14 +02:00
public function updateInvoicePayment(PaymentHash $payment_hash) :?Payment
{
return ((new UpdateInvoicePayment($this->payment, $payment_hash)))->run();
}
public function applyNumber()
{
$this->payment = (new ApplyNumber($this->payment))->run();
return $this;
}
2021-01-06 06:54:04 +01:00
public function applyCredits($payment_hash)
{
/* Iterate through the invoices and apply credits to them */
collect($payment_hash->invoices())->each(function ($payable_invoice) use ($payment_hash) {
2021-11-07 07:12:51 +01:00
$invoice = Invoice::withTrashed()->find($this->decodePrimaryKey($payable_invoice->invoice_id));
2021-01-06 06:54:04 +01:00
$amount = $payable_invoice->amount;
$credits = $payment_hash->fee_invoice
->client
->service()
->getCredits();
foreach ($credits as $credit) {
//starting invoice balance
$invoice_balance = $invoice->balance;
//credit payment applied
$credit->service()->applyPayment($invoice, $amount, $this->payment);
//amount paid from invoice calculated
$remaining_balance = ($invoice_balance - $invoice->fresh()->balance);
//reduce the amount to be paid on the invoice from the NEXT credit
$amount -= $remaining_balance;
//break if the invoice is no longer PAYABLE OR there is no more amount to be applied
if (! $invoice->isPayable() || (int) $amount == 0) {
2021-01-06 06:54:04 +01:00
break;
}
}
});
return $this;
2021-01-06 06:54:04 +01:00
}
public function applyCreditsToInvoice($invoice)
{
2023-02-16 02:36:09 +01:00
$amount = $invoice->amount;
2023-02-16 02:36:09 +01:00
$credits = $invoice->client
->service()
->getCredits();
2023-02-16 02:36:09 +01:00
foreach ($credits as $credit) {
//starting invoice balance
$invoice_balance = $invoice->balance;
2023-02-16 02:36:09 +01:00
//credit payment applied
$credit->service()->applyPayment($invoice, $amount, $this->payment);
2023-02-16 02:36:09 +01:00
//amount paid from invoice calculated
$remaining_balance = ($invoice_balance - $invoice->fresh()->balance);
2023-02-16 02:36:09 +01:00
//reduce the amount to be paid on the invoice from the NEXT credit
$amount -= $remaining_balance;
2023-02-16 02:36:09 +01:00
//break if the invoice is no longer PAYABLE OR there is no more amount to be applied
if (! $invoice->isPayable() || (int) $amount == 0) {
break;
}
2023-02-16 02:36:09 +01:00
}
return $this;
}
2020-08-13 04:30:45 +02:00
public function save()
{
2021-10-15 09:47:41 +02:00
$this->payment->saveQuietly();
2020-08-13 04:30:45 +02:00
return $this->payment->fresh();
}
}