1
0
mirror of https://github.com/invoiceninja/invoiceninja.git synced 2024-11-10 21:22:58 +01:00
invoiceninja/app/Services/Scheduler/SchedulerService.php

89 lines
2.8 KiB
PHP
Raw Normal View History

2023-01-08 06:15:33 +01:00
<?php
/**
* Invoice Ninja (https://invoiceninja.com).
*
* @link https://github.com/invoiceninja/invoiceninja source repository
*
* @copyright Copyright (c) 2022. Invoice Ninja LLC (https://invoiceninja.com)
*
* @license https://www.elastic.co/licensing/elastic-license
*/
2023-01-13 02:43:38 +01:00
namespace App\Services\Scheduler;
2023-01-08 06:15:33 +01:00
2023-01-13 23:46:17 +01:00
use App\Models\Client;
2023-01-13 02:43:38 +01:00
use App\Models\Scheduler;
2023-01-13 23:46:17 +01:00
use App\Utils\Traits\MakesHash;
use Illuminate\Support\Str;
2023-01-13 02:43:38 +01:00
2023-01-13 12:24:23 +01:00
class SchedulerService
2023-01-08 06:15:33 +01:00
{
2023-01-13 23:46:17 +01:00
use MakesHash;
private string $method;
2023-01-08 06:15:33 +01:00
public function __construct(public Scheduler $scheduler) {}
2023-01-13 23:46:17 +01:00
/**
* Called from the TaskScheduler Cron
*
* @return void
*/
public function runTask(): void
2023-01-08 06:15:33 +01:00
{
2023-01-13 23:46:17 +01:00
$this->{$this->scheduler->template}();
}
private function client_statement()
{
$query = Client::query()
->where('company_id', $this->scheduler->company_id);
//Email only the selected clients
if(count($this->scheduler->parameters['clients']) >= 1)
$query->where('id', $this->transformKeys($this->scheduler->parameters['clients']));
2023-01-14 08:47:14 +01:00
$statement_properties = $this->calculateStatementProperties();
2023-01-13 23:46:17 +01:00
$query->cursor()
2023-01-14 08:47:14 +01:00
->each(function ($client) use($statement_properties){
2023-01-13 23:46:17 +01:00
//work out the date range
2023-01-14 08:47:14 +01:00
$pdf = $client->service()->statement($statement_properties);
2023-01-13 23:46:17 +01:00
});
2023-01-14 08:47:14 +01:00
}
private function calculateStatementProperties()
{
$start_end = $this->calculateStartAndEndDates();
return [
'start_date' =>$start_end[0],
'end_date' =>$start_end[1],
'show_payments_table' => $this->scheduler->parameters['show_payments_table'],
'show_aging_table' => $this->scheduler->parameters['show_aging_table'],
'status' => $this->scheduler->status
];
}
private function calculateStartAndEndDates()
{
return match ($this->scheduler->parameters['date_range']) {
'this_month' => [now()->firstOfMonth()->format('Y-m-d'), now()->lastOfMonth()->format('Y-m-d')],
'this_quarter' => [now()->firstOfQuarter()->format('Y-m-d'), now()->lastOfQuarter()->format('Y-m-d')],
'this_year' => [now()->firstOfYear()->format('Y-m-d'), now()->format('Y-m-d')],
'previous_month' => [now()->subMonth()->firstOfMonth()->format('Y-m-d'), now()->subMonth()->lastOfMonth()->format('Y-m-d')],
'previous_quarter' => [now()->subQuarter()->firstOfQuarter()->format('Y-m-d'), now()->subQuarter()->lastOfQuarter()->format('Y-m-d')],
'previous_year' => [now()->subYear()->firstOfYear()->format('Y-m-d'), now()->subYear()->format('Y-m-d')],
'custom_range' => [$this->scheduler->parameters['start_date'], $this->scheduler->parameters['end_date']]
};
2023-01-13 23:46:17 +01:00
}
2023-01-14 08:47:14 +01:00
private function thisMonth()
{
2023-01-08 06:15:33 +01:00
2023-01-14 08:47:14 +01:00
}
2023-01-08 06:15:33 +01:00
}