public function JobUpload::processItem in TMGMT Extension Suite 8.2
Same name and namespace in other branches
- 8 src/Plugin/QueueWorker/JobUpload.php \Drupal\tmgmt_extension_suit\Plugin\QueueWorker\JobUpload::processItem()
Works on a single queue item.
Parameters
mixed $data: The data that was passed to \Drupal\Core\Queue\QueueInterface::createItem() when the item was queued.
Throws
\Drupal\Core\Queue\RequeueException Processing is not yet finished. This will allow another process to claim the item immediately.
\Exception A QueueWorker plugin may throw an exception to indicate there was a problem. The cron process will log the exception, and leave the item in the queue to be processed again later.
\Drupal\Core\Queue\SuspendQueueException More specifically, a SuspendQueueException should be thrown when a QueueWorker plugin is aware that the problem will affect all subsequent workers of its queue. For example, a callback that makes HTTP requests may find that the remote server is not responding. The cron process will behave as with a normal Exception, and in addition will not attempt to process further items from the current item's queue during the current cron run.
Overrides QueueWorkerInterface::processItem
See also
\Drupal\Core\Cron::processQueues()
File
- src/
Plugin/ QueueWorker/ JobUpload.php, line 65
Class
- JobUpload
- Executes interface translation queue tasks.
Namespace
Drupal\tmgmt_extension_suit\Plugin\QueueWorkerCode
public function processItem($data) {
$id = $data['id'];
try {
$job = Job::load($id);
if (empty($job)) {
$this->logger
->error(t('Requesting translation for a job :job_id is failed: non-existent job. This job has been deleted from admin UI but queue item is still in the queue.', [
':job_id' => $id,
])
->render());
return;
}
$plugin = $job
->getTranslator()
->getPlugin();
if ($plugin instanceof ExtendedTranslatorPluginInterface) {
$plugin
->requestTranslationExtended($job, $data);
}
} catch (\Exception $e) {
$this->logger
->error($e
->getMessage());
}
}