You are here

public function MessageSubscribe::processItem in Message Subscribe 8

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/MessageSubscribe.php, line 53

Class

MessageSubscribe
Queue worker to process sending of message subscriptions.

Namespace

Drupal\message_subscribe\Plugin\QueueWorker

Code

public function processItem($data) {
  $message = $data['message'];
  $entity = $data['entity'];
  $notify_options = $data['notify_options'];
  $subscribe_options = $data['subscribe_options'];
  $context = $data['context'];

  // Reload message and entity.
  $message = $message
    ->load($message
    ->id());
  $entity = $entity
    ->load($entity
    ->id());
  if (!$entity || !$message) {
    return;
  }

  // Denotes this is being processed from a queue worker.
  $subscribe_options['queue'] = TRUE;
  $this->subscribers
    ->sendMessage($entity, $message, $notify_options, $subscribe_options, $context);
}