You are here

public function BrightcoveSubscriptionsQueueWorker::processItem in Brightcove Video Connect 8

Same name and namespace in other branches
  1. 8.2 src/Plugin/QueueWorker/BrightcoveSubscriptionsQueueWorker.php \Drupal\brightcove\Plugin\QueueWorker\BrightcoveSubscriptionsQueueWorker::processItem()
  2. 3.x src/Plugin/QueueWorker/BrightcoveSubscriptionsQueueWorker.php \Drupal\brightcove\Plugin\QueueWorker\BrightcoveSubscriptionsQueueWorker::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/BrightcoveSubscriptionsQueueWorker.php, line 74

Class

BrightcoveSubscriptionsQueueWorker
Gathers the subscriptions for creation and delete check.

Namespace

Drupal\brightcove\Plugin\QueueWorker

Code

public function processItem($data) {
  $cms = BrightcoveUtil::getCmsApi($data);
  try {
    $subscriptions = $cms
      ->getSubscriptions();
    foreach (!empty($subscriptions) ? $subscriptions : [] as $subscription) {
      if ($subscription instanceof Subscription) {
        $this->subscriptionQueue
          ->createItem([
          'api_client_id' => $data,
          'subscription' => $subscription,
        ]);
      }
    }
  } catch (APIException $e) {
    if ($e
      ->getCode() == 401) {
      watchdog_exception('brightcove', $e, 'Access denied for Notifications.', [], RfcLogLevel::WARNING);
    }
    else {
      throw $e;
    }
  }
}