public function BrightcoveVideoPageQueueWorker::processItem in Brightcove Video Connect 8
Same name and namespace in other branches
- 8.2 src/Plugin/QueueWorker/BrightcoveVideoPageQueueWorker.php \Drupal\brightcove\Plugin\QueueWorker\BrightcoveVideoPageQueueWorker::processItem()
- 3.x src/Plugin/QueueWorker/BrightcoveVideoPageQueueWorker.php \Drupal\brightcove\Plugin\QueueWorker\BrightcoveVideoPageQueueWorker::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/ BrightcoveVideoPageQueueWorker.php, line 61
Class
- BrightcoveVideoPageQueueWorker
- Processes Entity Update Tasks for Video.
Namespace
Drupal\brightcove\Plugin\QueueWorkerCode
public function processItem($data) {
$cms = BrightcoveUtil::getCmsApi($data['api_client_id']);
// Get videos.
$videos = $cms
->listVideos(NULL, 'created_at', $data['items_per_page'], $data['page'] * $data['items_per_page']);
foreach ($videos as $video) {
$this->videoQueue
->createItem([
'api_client_id' => $data['api_client_id'],
'video' => $video,
]);
}
}