2023-07-26 19:44:07 +10:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Console\Commands;
|
|
|
|
|
|
|
|
use Illuminate\Console\Command;
|
|
|
|
|
|
|
|
use App\Models\Job;
|
|
|
|
|
|
|
|
class JobList extends Command
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* The name and signature of the console command.
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $signature = 'job:list';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The console command description.
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $description = 'Detail list of items in the queue';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Execute the console command.
|
|
|
|
*/
|
|
|
|
public function handle()
|
|
|
|
{
|
|
|
|
$lastq = NULL;
|
|
|
|
|
|
|
|
foreach (Job::orderBy('queue')->orderBy('created_at')->cursor() as $o) {
|
|
|
|
if ($o->queue !== $lastq) {
|
|
|
|
$this->alert(sprintf('Queue: %s',$o->queue));
|
|
|
|
$lastq = $o->queue;
|
|
|
|
}
|
|
|
|
|
2023-11-26 11:32:21 +11:00
|
|
|
$this->info(sprintf('%s-%d: %s[%s] - %d/%d tries [Next:%s]%s',
|
2023-07-26 19:44:07 +10:00
|
|
|
$o->uuid,
|
|
|
|
$o->id,
|
|
|
|
$o->display_name,
|
|
|
|
$o->command->subject,
|
2023-11-26 11:32:21 +11:00
|
|
|
$o->attempts,$o->maxTries,
|
|
|
|
$o->available_at ?: '-',
|
|
|
|
$o->attempts ? sprintf(' (Created:%s)',$o->created_at) : ''
|
2023-07-26 19:44:07 +10:00
|
|
|
));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|