You are here

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\QueueWorker

Code

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),
      ]);
    }
  }
}