class DefaultContentSubscriber

Same name in this branch
  1. 11.x core/modules/media/src/EventSubscriber/DefaultContentSubscriber.php \Drupal\media\EventSubscriber\DefaultContentSubscriber
  2. 11.x core/modules/layout_builder/src/EventSubscriber/DefaultContentSubscriber.php \Drupal\layout_builder\EventSubscriber\DefaultContentSubscriber
  3. 11.x core/modules/content_moderation/src/EventSubscriber/DefaultContentSubscriber.php \Drupal\content_moderation\EventSubscriber\DefaultContentSubscriber
  4. 11.x core/modules/path/src/EventSubscriber/DefaultContentSubscriber.php \Drupal\path\EventSubscriber\DefaultContentSubscriber

Subscribes to default content-related events.

@internal Event subscribers are internal.

Hierarchy

  • class \Drupal\link\EventSubscriber\DefaultContentSubscriber implements \Symfony\Component\EventDispatcher\EventSubscriberInterface

Expanded class hierarchy of DefaultContentSubscriber

File

core/modules/link/src/EventSubscriber/DefaultContentSubscriber.php, line 20

Namespace

Drupal\link\EventSubscriber
View source
class DefaultContentSubscriber implements EventSubscriberInterface {
  public function __construct(protected readonly EntityTypeManagerInterface $entityTypeManager) {
  }
  
  /**
   * {@inheritdoc}
   */
  public static function getSubscribedEvents() : array {
    return [
      PreExportEvent::class => 'preExport',
    ];
  }
  
  /**
   * Reacts before an entity is exported.
   *
   * Adds an export callback for `link` field items to ensure that, if the link
   * points to a content entity, it is marked as a dependency of the entity
   * being exported.
   *
   * @param \Drupal\Core\DefaultContent\PreExportEvent $event
   *   The event object.
   */
  public function preExport(PreExportEvent $event) : void {
    $event->setCallback('field_item:link', function (LinkItemInterface $item, ExportMetadata $metadata) : array {
      $values = $item->getValue();
      $url = $item->getUrl();
      if (!$url->isRouted()) {
        // The URL is not routed, so there's nothing else to do.
        return $values;
      }
      $route_name = explode('.', $url->getRouteName());
      // We can rely on this pattern because routed entity URLs are generated
      // in a consistent way with the `entity` scheme.
      // @see \Drupal\Core\Url::fromUri()
      if (count($route_name) === 3 && $route_name[0] === 'entity' && $route_name[2] === 'canonical') {
        $target_entity_type_id = $route_name[1];
        $route_parameters = $url->getRouteParameters();
        $target_id = $route_parameters[$target_entity_type_id];
        $target = $this->entityTypeManager
          ->getStorage($target_entity_type_id)
          ->load($target_id);
        if ($target instanceof ContentEntityInterface) {
          $values['target_uuid'] = $target->uuid();
          unset($values['uri']);
          $metadata->addDependency($target);
        }
      }
      return $values;
    });
  }

}

Members

Title Sort descending Modifiers Object type Summary
DefaultContentSubscriber::getSubscribedEvents public static function
DefaultContentSubscriber::preExport public function Reacts before an entity is exported.
DefaultContentSubscriber::__construct public function

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