MediaLinkTarget.php

Namespace

Drupal\media\Entity

File

core/modules/media/src/Entity/MediaLinkTarget.php

View source
<?php

declare (strict_types=1);
namespace Drupal\media\Entity;

use Drupal\Core\Cache\Cache;
use Drupal\Core\Entity\EntityInterface;
use Drupal\Core\Entity\EntityLinkTargetInterface;
use Drupal\Core\GeneratedUrl;
use Drupal\media\MediaInterface;
use Drupal\media\MediaSourceInterface;

/**
 * Provides a Media link target handler.
 *
 * Media entities are atypical because by default they do not have their own
 * stand-alone URL, which means only a subset of Media entities is actually
 * linkable.
 *
 * @see media_entity_type_alter()
 * @see \Drupal\media\Routing\MediaRouteProvider::getCanonicalRoute()
 * @see https://www.drupal.org/i/3017935
 *
 * On the other hand, media entities that use the "file" media source plugin can
 * be linked regardless of that setting because the referenced files are still
 * linkable.
 * Every media source plugin is free to implement the base implementation of
 * :getMetadata() because a source plugin is guaranteed to know how the media is
 * stored and linked.
 *
 * @see \Drupal\media\MediaSourceInterface::METADATA_ATTRIBUTE_LINK_TARGET
 * @see \Drupal\media\MediaSourceBase::getMetadata()
 * @see \Drupal\media\Plugin\media\Source\File::getMetadata()
 * @see \Drupal\media\Plugin\media\Source\OEmbed::getMetadata()
 * @see \Drupal\file\Entity\FileLinkTarget
 * @see \Drupal\media\Plugin\EntityReferenceSelection\MediaWithLinkTargetSelection
 */
class MediaLinkTarget implements EntityLinkTargetInterface {
  
  /**
   * {@inheritdoc}
   */
  public function getLinkTarget(EntityInterface $entity) : GeneratedUrl {
    // Below is an example of how to get the generated URL object for a media
    // linked entity which is used in Entity links filter.
    // @see \Drupal\filter\Plugin\Filter\EntityLinks::getUrl().
    // At this point, media entity type is not enabled for entity suggestions in
    // CKEditor.
    // @see \Drupal\ckeditor5\Hook\Ckeditor5Hooks::entityBundleInfoAlter().
    // Technically, media link target handler should not be in the core until
    // core supports media entity by default, consider this is an example on how
    // to build a media link target handler.
    assert($entity instanceof MediaInterface);
    if ($link_target = $entity->getSource()
      ->getMetadata($entity, MediaSourceInterface::METADATA_ATTRIBUTE_LINK_TARGET)) {
      return $link_target;
    }
    // Entities are returned unless standalone URLs are enabled, to avoid
    // meaningless links like this one
    return (new GeneratedUrl())->setGeneratedUrl('')
      ->setCacheMaxAge(Cache::PERMANENT);
  }

}

Classes

Title Deprecated Summary
MediaLinkTarget Provides a Media link target handler.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.