From 5fc838a518a1f95873eb0b744c71c0c9af0066a6 Mon Sep 17 00:00:00 2001 From: Sean Kegel Date: Fri, 20 Sep 2024 18:23:42 -0400 Subject: [PATCH] Support multiple batch IDs when retrying failed batch jobs --- .../Queue/Console/RetryBatchCommand.php | 48 +++++++++++++------ 1 file changed, 34 insertions(+), 14 deletions(-) diff --git a/src/Illuminate/Queue/Console/RetryBatchCommand.php b/src/Illuminate/Queue/Console/RetryBatchCommand.php index f4af6c3a47bd..28f2b2767f3b 100644 --- a/src/Illuminate/Queue/Console/RetryBatchCommand.php +++ b/src/Illuminate/Queue/Console/RetryBatchCommand.php @@ -15,7 +15,8 @@ class RetryBatchCommand extends Command implements Isolatable * * @var string */ - protected $signature = 'queue:retry-batch {id : The ID of the batch whose failed jobs should be retried}'; + protected $signature = 'queue:retry-batch + {id?* : The ID of the batch whose failed jobs should be retried}'; /** * The console command description. @@ -31,25 +32,32 @@ class RetryBatchCommand extends Command implements Isolatable */ public function handle() { - $batch = $this->laravel[BatchRepository::class]->find($id = $this->argument('id')); + $batchesFound = count($ids = $this->getBatchJobIds()) > 0; - if (! $batch) { - $this->components->error("Unable to find a batch with ID [{$id}]."); + if ($batchesFound) { + $this->components->info('Pushing failed batch jobs back onto the queue.'); + } - return 1; - } elseif (empty($batch->failedJobIds)) { - $this->components->error('The given batch does not contain any failed jobs.'); + foreach ($ids as $batchId) { + $batch = $this->laravel[BatchRepository::class]->find($batchId); - return 1; - } + if (! $batch) { + $this->components->error("Unable to find a batch with ID [{$batchId}]."); + } elseif (empty($batch->failedJobIds)) { + $this->components->error('The given batch does not contain any failed jobs.'); + } - $this->components->info("Pushing failed queue jobs of the batch [$id] back onto the queue."); + $this->components->info("Pushing failed queue jobs of the batch [$batchId] back onto the queue."); - foreach ($batch->failedJobIds as $failedJobId) { - $this->components->task($failedJobId, fn () => $this->callSilent('queue:retry', ['id' => $failedJobId]) == 0); - } + foreach ($batch->failedJobIds as $failedJobId) { + $this->components->task( + $failedJobId, + fn () => $this->callSilent('queue:retry', ['id' => $failedJobId]) == 0 + ); + } - $this->newLine(); + $this->newLine(); + } } /** @@ -61,4 +69,16 @@ public function isolatableId() { return $this->argument('id'); } + + /** + * Get the batch IDs to be retried. + * + * @return array + */ + protected function getBatchJobIds() + { + $ids = (array) $this->argument('id'); + + return array_values(array_filter(array_unique($ids))); + } }