public function EntityUsageRegenerateTrackingInfoWorker::processItem in Entity Usage 8.2
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/ EntityUsageRegenerateTrackingInfoWorker.php, line 74
Class
- EntityUsageRegenerateTrackingInfoWorker
- RegenerateTrackingInfoWorker class.
Namespace
Drupal\entity_usage\Plugin\QueueWorkerCode
public function processItem($data) {
// $data here is expected to contain
// - 'entity_type': always present;
// - 'entity_id': present when the entity isn't revisionable;
// - 'entity_revision_id': present when the entity is revisionable;
if (empty($data['entity_type']) || empty($data['entity_id']) && empty($data['entity_revision_id'])) {
// Just skip this item.
return;
}
$storage = $this->entityTypeManager
->getStorage($data['entity_type']);
if ($storage
->getEntityType()
->isRevisionable() && !empty($data['entity_revision_id'])) {
$entity = $storage
->loadRevision($data['entity_revision_id']);
}
elseif (!empty($data['entity_id'])) {
$entity = $storage
->load($data['entity_id']);
}
if ($entity) {
try {
$this->entityUsageUpdateManager
->trackUpdateOnCreation($entity);
} catch (\Exception $e) {
$this->logger
->warning("An error occurred when tracking usage info for entity with data: @data. Error message: {$e->getMessage()}", [
'@data' => json_encode($data),
]);
}
}
}