You are here

public function UpdateEntityEncryption::processItem in Field Encryption 3.0.x

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/UpdateEntityEncryption.php, line 69

Class

UpdateEntityEncryption
A Queue Worker that updates an entity's encryption on cron run.

Namespace

Drupal\field_encrypt\Plugin\QueueWorker

Code

public function processItem($data) {
  $entity_type = $this->entityTypeManager
    ->getDefinition($data['entity_type']);
  $storage = $this->entityTypeManager
    ->getStorage($data['entity_type']);
  $is_revisionable = $entity_type
    ->isRevisionable();
  if ($is_revisionable) {
    $entity = $storage
      ->loadRevision($data['entity_id']);
  }
  else {
    $entity = $storage
      ->load($data['entity_id']);
  }

  // If the entity no longer exists then there is nothing to do.
  if (empty($entity)) {
    return;
  }

  // Don't create unnecessary revisions.
  if ($is_revisionable) {
    $entity
      ->setNewRevision(FALSE);
  }
  $entity
    ->save();
}