akaunting/app/Console/Commands/RecurringCheck.php

185 lines
5.2 KiB
PHP
Raw Normal View History

2018-04-27 19:02:42 +03:00
<?php
namespace App\Console\Commands;
use App\Models\Company\Company;
use App\Models\Common\Recurring;
use App\Models\Expense\Bill;
use App\Models\Expense\BillHistory;
use App\Models\Expense\Payment;
use App\Models\Income\Invoice;
use App\Models\Income\InvoiceHistory;
use App\Models\Income\Revenue;
use App\Notifications\Expense\Bill as BillNotification;
use App\Notifications\Income\Invoice as InvoiceNotification;
use App\Traits\Incomes;
use App\Utilities\Overrider;
use Date;
use Illuminate\Console\Command;
use Recurr\Rule;
use Recurr\Transformer\ArrayTransformer;
use Recurr\Transformer\ArrayTransformerConfig;
class RecurringCheck extends Command
{
use Incomes;
/**
* The name and signature of the console command.
*
* @var string
*/
protected $signature = 'recurring:check';
/**
* The console command description.
*
* @var string
*/
protected $description = 'Check for recurring';
/**
* Create a new command instance.
*/
public function __construct()
{
parent::__construct();
}
/**
* Execute the console command.
*
* @return mixed
*/
public function handle()
{
2018-04-27 22:16:35 +03:00
$this->today = Date::today();
2018-04-27 19:02:42 +03:00
// Get all companies
$companies = Company::all();
foreach ($companies as $company) {
// Set company id
session(['company_id' => $company->id]);
// Override settings and currencies
Overrider::load('settings');
Overrider::load('currencies');
$company->setSettings();
$recurring = $company->recurring();
foreach ($recurring as $recur) {
2018-04-28 11:56:11 +03:00
$current = Date::parse($recur->schedule()->current()->getStart()->format('Y-m-d'));
2018-04-27 19:02:42 +03:00
// Check if should recur today
2018-04-27 22:16:35 +03:00
if ($this->today->ne($current)) {
2018-04-27 19:02:42 +03:00
continue;
}
$type = end(explode('\\', $recur->recurable_type));
$model = $type::find($recur->recurable_id);
if (!$model) {
continue;
}
switch ($type) {
case 'Bill':
$this->recurBill($company, $model);
break;
case 'Invoice':
$this->recurInvoice($company, $model);
break;
case 'Payment':
case 'Revenue':
2018-04-27 22:16:35 +03:00
// Create new record
$clone = $model->duplicate();
// Update date
$clone->paid_at = $this->today->format('Y-m-d');
$clone->save();
2018-04-27 19:02:42 +03:00
break;
}
}
}
// Unset company_id
session()->forget('company_id');
}
protected function recurInvoice($company, $model)
{
2018-04-27 22:16:35 +03:00
// Create new record
2018-04-27 19:02:42 +03:00
$clone = $model->duplicate();
2018-04-27 22:16:35 +03:00
// Days between invoiced and due date
$diff_days = Date::parse($clone->due_at)->diffInDays(Date::parse($clone->invoiced_at));
// Update dates
$clone->invoiced_at = $this->today->format('Y-m-d');
$clone->due_at = $this->today->addDays($diff_days)->format('Y-m-d');
$clone->save();
2018-04-27 19:02:42 +03:00
// Add invoice history
InvoiceHistory::create([
'company_id' => session('company_id'),
'invoice_id' => $clone->id,
'status_code' => 'draft',
'notify' => 0,
'description' => trans('messages.success.added', ['type' => $clone->invoice_number]),
]);
// Notify the customer
if ($clone->customer && !empty($clone->customer_email)) {
$clone->customer->notify(new InvoiceNotification($clone));
}
// Notify all users assigned to this company
foreach ($company->users as $user) {
if (!$user->can('read-notifications')) {
continue;
}
$user->notify(new InvoiceNotification($clone));
}
// Update next invoice number
$this->increaseNextInvoiceNumber();
}
protected function recurBill($company, $model)
{
2018-04-27 22:16:35 +03:00
// Create new record
2018-04-27 19:02:42 +03:00
$clone = $model->duplicate();
2018-04-27 22:16:35 +03:00
// Days between invoiced and due date
$diff_days = Date::parse($clone->due_at)->diffInDays(Date::parse($clone->invoiced_at));
// Update dates
$clone->billed_at = $this->today->format('Y-m-d');
$clone->due_at = $this->today->addDays($diff_days)->format('Y-m-d');
$clone->save();
2018-04-27 19:02:42 +03:00
// Add bill history
BillHistory::create([
'company_id' => session('company_id'),
'bill_id' => $clone->id,
'status_code' => 'draft',
'notify' => 0,
'description' => trans('messages.success.added', ['type' => $clone->bill_number]),
]);
// Notify all users assigned to this company
foreach ($company->users as $user) {
if (!$user->can('read-notifications')) {
continue;
}
$user->notify(new BillNotification($clone));
}
}
}