2019-06-11 12:36:58 +10:00
|
|
|
<?php
|
|
|
|
|
2024-07-07 10:21:27 +10:00
|
|
|
namespace App\Console\Commands\Ezypay;
|
2019-06-11 12:36:58 +10:00
|
|
|
|
2021-07-29 13:11:14 +10:00
|
|
|
use Carbon\Carbon;
|
2019-06-11 12:36:58 +10:00
|
|
|
use Illuminate\Console\Command;
|
|
|
|
|
2020-02-01 22:12:31 +11:00
|
|
|
use App\Classes\External\Payments\Ezypay;
|
2019-06-11 12:36:58 +10:00
|
|
|
use App\Models\Account;
|
|
|
|
|
2024-07-07 10:21:27 +10:00
|
|
|
class PaymentNext extends Command
|
2019-06-11 12:36:58 +10:00
|
|
|
{
|
|
|
|
/**
|
|
|
|
* The name and signature of the console command.
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
2024-07-07 10:21:27 +10:00
|
|
|
protected $signature = 'ezypay:payment:next';
|
2019-06-11 12:36:58 +10:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The console command description.
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $description = 'Load next payments, and ensure they cover the next invoice';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Execute the console command.
|
|
|
|
*
|
|
|
|
* @return mixed
|
|
|
|
*/
|
|
|
|
public function handle()
|
|
|
|
{
|
2021-07-29 13:11:14 +10:00
|
|
|
$poo = new Ezypay;
|
2019-06-11 12:36:58 +10:00
|
|
|
|
2021-07-29 13:11:14 +10:00
|
|
|
foreach ($poo->getCustomers() as $c) {
|
|
|
|
if ($c->BillingStatus == 'Inactive') {
|
2024-07-07 10:21:27 +10:00
|
|
|
$this->comment(sprintf('Ignoring INACTIVE: [%s] %s %s',$c->EzypayReferenceNumber,$c->Firstname,$c->Surname));
|
2019-06-11 12:36:58 +10:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Load Account Details from ReferenceId
|
2024-07-07 10:21:27 +10:00
|
|
|
$ao = Account::find((int)substr($c->ReferenceId,2,4));
|
2019-06-11 12:36:58 +10:00
|
|
|
|
2021-07-29 13:11:14 +10:00
|
|
|
if (! $ao) {
|
2019-06-11 12:36:58 +10:00
|
|
|
$this->warn(sprintf('Missing: [%s] %s %s (%s)',$c->EzypayReferenceNumber,$c->Firstname,$c->Surname,$c->ReferenceId));
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Get Due Invoices
|
2024-07-07 10:21:27 +10:00
|
|
|
$invoice_due = $ao->invoiceSummaryDue()->get();
|
|
|
|
|
|
|
|
$this->info(sprintf('Account [%s] (%s) has [%d] invoices due, totalling [%3.2f]',
|
|
|
|
$ao->lid,
|
|
|
|
$ao->name,
|
|
|
|
$invoice_due->count(),
|
|
|
|
($due=$invoice_due->sum('_balance')),
|
|
|
|
));
|
2019-06-11 12:36:58 +10:00
|
|
|
|
|
|
|
$next_pay = $poo->getDebits([
|
|
|
|
'customerId'=>$c->Id,
|
|
|
|
'dateFrom'=>now()->format('Y-m-d'),
|
|
|
|
'dateTo'=>now()->addQuarter()->format('Y-m-d'),
|
|
|
|
])->reverse()->first();
|
|
|
|
|
2021-07-29 13:11:14 +10:00
|
|
|
if ($next_pay->Status !== 'Pending') {
|
2024-07-07 10:21:27 +10:00
|
|
|
$this->warn(sprintf('- Next payment is not pending for (%s)',$ao->name));
|
2021-07-29 13:11:14 +10:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
$next_paydate = Carbon::createFromTimeString($next_pay->Date);
|
|
|
|
|
2024-07-07 10:21:27 +10:00
|
|
|
if ($next_pay->Amount < $due)
|
|
|
|
$this->error(sprintf('- Next payment on [%s] for (%s) [%s] not sufficient for outstanding balance [%s]',
|
2021-07-29 13:11:14 +10:00
|
|
|
$next_paydate->format('Y-m-d'),
|
|
|
|
$ao->name,
|
|
|
|
number_format($next_pay->Amount,2),
|
2024-07-07 10:21:27 +10:00
|
|
|
number_format($due,2)));
|
2021-07-29 13:11:14 +10:00
|
|
|
|
2024-07-07 10:21:27 +10:00
|
|
|
elseif ($next_pay->Amount > $due)
|
|
|
|
$this->warn(sprintf('- Next payment on [%s] for (%s) [%s] is too much for outstanding balance [%s]',
|
2021-07-29 13:11:14 +10:00
|
|
|
$next_paydate->format('Y-m-d'),
|
|
|
|
$ao->name,
|
|
|
|
number_format($next_pay->Amount,2),
|
2024-07-07 10:21:27 +10:00
|
|
|
number_format($due,2)));
|
2021-07-29 13:11:14 +10:00
|
|
|
|
2019-06-11 12:36:58 +10:00
|
|
|
else
|
2024-07-07 10:21:27 +10:00
|
|
|
$this->info(sprintf('- Next payment on [%s] for (%s) [%s] will cover outstanding balance [%s]',
|
2021-07-29 13:11:14 +10:00
|
|
|
$next_paydate->format('Y-m-d'),
|
|
|
|
$ao->name,
|
|
|
|
number_format($next_pay->Amount,2),
|
2024-07-07 10:21:27 +10:00
|
|
|
number_format($due,2)));
|
2019-06-11 12:36:58 +10:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|