You are here

public function BrightcoveVideoQueueWorker::processItem in Brightcove Video Connect 3.x

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

Class

BrightcoveVideoQueueWorker
Processes Entity Update Tasks for Video.

Namespace

Drupal\brightcove\Plugin\QueueWorker

Code

public function processItem($data) {

  /** @var \Brightcove\Item\Video\Video $video */
  $video = $data['video'];

  /** @var \Drupal\brightcove\Entity\BrightcoveVideo $video_entity */
  $video_entity = BrightcoveVideo::createOrUpdate($video, $this->storage, $data['api_client_id']);
  if (!empty($video_entity)) {

    // Get existing text tracks.
    $existing_text_tracks = [];
    foreach ($video_entity
      ->getTextTracks() as $text_track) {

      /** @var \Drupal\brightcove\Entity\BrightcoveTextTrack $text_track_entity */
      $text_track_entity = BrightcoveTextTrack::load($text_track['target_id']);
      if (!is_null($text_track_entity)) {
        $existing_text_tracks[$text_track_entity
          ->getTextTrackId()] = TRUE;
      }
    }

    // Save Video text tracks.
    $text_tracks = $video
      ->getTextTracks();
    foreach ($text_tracks as $text_track) {

      // Remove existing text tracks from the list which are still existing on
      // Brightcove.
      if (isset($existing_text_tracks[$text_track
        ->getId()])) {
        unset($existing_text_tracks[$text_track
          ->getId()]);
      }

      // Create new queue item for text track.
      $this->textTrackQueue
        ->createItem([
        'text_track' => $text_track,
        'video_entity_id' => $video_entity
          ->id(),
      ]);
    }

    // Remove existing text tracks which are no longer available on
    // Brightcove.
    foreach (array_keys($existing_text_tracks) as $text_track_id) {

      // Create new delete queue item for text track.
      $this->textTrackDeleteQueue
        ->createItem($text_track_id);
    }
  }
}