1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-09-21 00:41:34 +02:00
invoiceninja/app/Services/Ledger/LedgerService.php

138 lines
4.1 KiB
PHP
Raw Normal View History

<?php
/**
* Invoice Ninja (https://invoiceninja.com).
*
* @link https://github.com/invoiceninja/invoiceninja source repository
*
* @copyright Copyright (c) 2021. Invoice Ninja LLC (https://invoiceninja.com)
*
2021-06-16 08:58:16 +02:00
* @license https://www.elastic.co/licensing/elastic-license
*/
namespace App\Services\Ledger;
use App\Factory\CompanyLedgerFactory;
2020-06-24 01:39:49 +02:00
use App\Models\Activity;
use App\Models\CompanyLedger;
class LedgerService
{
private $entity;
public function __construct($entity)
{
$this->entity = $entity;
}
public function updateInvoiceBalance($adjustment, $notes = '')
{
$balance = 0;
2021-12-19 02:34:01 +01:00
// \DB::connection(config('database.default'))->beginTransaction();
2021-09-22 10:50:19 +02:00
2021-12-19 03:26:57 +01:00
\DB::connection(config('database.default'))->transaction(function () use($notes, $adjustment, $balance){
2021-12-19 02:34:01 +01:00
$company_ledger = $this->ledger();
2021-12-19 02:34:01 +01:00
if ($company_ledger) {
$balance = $company_ledger->balance;
}
2021-12-19 02:34:01 +01:00
$company_ledger = CompanyLedgerFactory::create($this->entity->company_id, $this->entity->user_id);
$company_ledger->client_id = $this->entity->client_id;
$company_ledger->adjustment = $adjustment;
$company_ledger->notes = $notes;
$company_ledger->balance = $balance + $adjustment;
$company_ledger->activity_id = Activity::UPDATE_INVOICE;
$company_ledger->save();
$this->entity->company_ledger()->save($company_ledger);
}, 5);
2021-12-19 02:34:01 +01:00
// \DB::connection(config('database.default'))->commit();
2021-09-22 10:50:19 +02:00
return $this;
}
2021-01-21 05:05:05 +01:00
public function updatePaymentBalance($adjustment, $notes = '')
{
$balance = 0;
2021-12-19 02:34:01 +01:00
// \DB::connection(config('database.default'))->beginTransaction();
2021-12-19 03:26:57 +01:00
\DB::connection(config('database.default'))->transaction(function () use($notes, $adjustment, $balance){
2021-09-22 10:50:19 +02:00
/* Get the last record for the client and set the current balance*/
$company_ledger = $this->ledger();
if ($company_ledger) {
$balance = $company_ledger->balance;
}
$company_ledger = CompanyLedgerFactory::create($this->entity->company_id, $this->entity->user_id);
$company_ledger->client_id = $this->entity->client_id;
$company_ledger->adjustment = $adjustment;
$company_ledger->balance = $balance + $adjustment;
2020-06-24 01:39:49 +02:00
$company_ledger->activity_id = Activity::UPDATE_PAYMENT;
2021-01-21 05:05:05 +01:00
$company_ledger->notes = $notes;
$company_ledger->save();
$this->entity->company_ledger()->save($company_ledger);
2020-10-08 05:31:02 +02:00
2021-12-19 02:34:01 +01:00
}, 5);
// \DB::connection(config('database.default'))->commit();
2021-09-22 10:50:19 +02:00
2020-10-08 05:31:02 +02:00
return $this;
}
public function updateCreditBalance($adjustment, $notes = '')
{
$balance = 0;
2021-09-22 10:50:19 +02:00
2021-12-19 02:34:01 +01:00
// \DB::connection(config('database.default'))->beginTransaction();
2021-12-19 03:26:57 +01:00
\DB::connection(config('database.default'))->transaction(function () use($notes, $adjustment, $balance){
$company_ledger = $this->ledger();
if ($company_ledger) {
$balance = $company_ledger->balance;
}
$company_ledger = CompanyLedgerFactory::create($this->entity->company_id, $this->entity->user_id);
$company_ledger->client_id = $this->entity->client_id;
$company_ledger->adjustment = $adjustment;
$company_ledger->notes = $notes;
$company_ledger->balance = $balance + $adjustment;
2020-06-24 01:39:49 +02:00
$company_ledger->activity_id = Activity::UPDATE_CREDIT;
$company_ledger->save();
$this->entity->company_ledger()->save($company_ledger);
2021-12-19 02:34:01 +01:00
}, 5);
// \DB::connection(config('database.default'))->commit();
2021-09-22 10:50:19 +02:00
return $this;
}
private function ledger() :?CompanyLedger
{
return CompanyLedger::whereClientId($this->entity->client_id)
->whereCompanyId($this->entity->company_id)
->orderBy('id', 'DESC')
2021-09-22 10:50:19 +02:00
->lockForUpdate()
->first();
}
public function save()
{
$this->entity->save();
return $this->entity;
}
}
2021-09-22 10:50:19 +02:00