74 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			74 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
namespace App\Console\Commands\Schedule;
 | 
						|
 | 
						|
use Illuminate\Console\Command;
 | 
						|
use App\Models\Schedule;
 | 
						|
use Illuminate\Database\Eloquent\Builder;
 | 
						|
use App\Services\Schedules\ProcessScheduleService;
 | 
						|
use Carbon\Carbon;
 | 
						|
 | 
						|
class ProcessRunnableCommand extends Command
 | 
						|
{
 | 
						|
    protected $signature = 'p:schedule:process';
 | 
						|
 | 
						|
    protected $description = 'Process schedules in the database and determine which are ready to run.';
 | 
						|
 | 
						|
    /**
 | 
						|
     * Handle command execution.
 | 
						|
     */
 | 
						|
    public function handle(): int
 | 
						|
    {
 | 
						|
        $schedules = Schedule::query()
 | 
						|
            ->with('tasks')
 | 
						|
            ->whereRelation('server', fn (Builder $builder) => $builder->whereNull('status'))
 | 
						|
            ->where('is_active', true)
 | 
						|
            ->where('is_processing', false)
 | 
						|
            ->whereDate('next_run_at', '<=', Carbon::now()->toDateString())
 | 
						|
            ->get();
 | 
						|
 | 
						|
        if ($schedules->count() < 1) {
 | 
						|
            $this->line(__('commands.schedule.process.no_tasks'));
 | 
						|
 | 
						|
            return 0;
 | 
						|
        }
 | 
						|
 | 
						|
        $bar = $this->output->createProgressBar(count($schedules));
 | 
						|
        foreach ($schedules as $schedule) {
 | 
						|
            $bar->clear();
 | 
						|
            $this->processSchedule($schedule);
 | 
						|
            $bar->advance();
 | 
						|
            $bar->display();
 | 
						|
        }
 | 
						|
 | 
						|
        $this->line('');
 | 
						|
 | 
						|
        return 0;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Processes a given schedule and logs and errors encountered the console output. This should
 | 
						|
     * never throw an exception out, otherwise you'll end up killing the entire run group causing
 | 
						|
     * any other schedules to not process correctly.
 | 
						|
     */
 | 
						|
    protected function processSchedule(Schedule $schedule)
 | 
						|
    {
 | 
						|
        if ($schedule->tasks->isEmpty()) {
 | 
						|
            return;
 | 
						|
        }
 | 
						|
 | 
						|
        try {
 | 
						|
            $this->getLaravel()->make(ProcessScheduleService::class)->handle($schedule);
 | 
						|
 | 
						|
            $this->line(trans('command/messages.schedule.output_line', [
 | 
						|
                'schedule' => $schedule->name,
 | 
						|
                'hash' => $schedule->hashid,
 | 
						|
            ]));
 | 
						|
        } catch (\Throwable|\Exception $exception) {
 | 
						|
            logger()->error($exception, ['schedule_id' => $schedule->id]);
 | 
						|
 | 
						|
            $this->error(__('commands.schedule.process.no_tasks') . " #$schedule->id: " . $exception->getMessage());
 | 
						|
        }
 | 
						|
    }
 | 
						|
}
 |