class EntityRouteProviderSubscriber

Same name and namespace in other branches
  1. 9 core/lib/Drupal/Core/EventSubscriber/EntityRouteProviderSubscriber.php \Drupal\Core\EventSubscriber\EntityRouteProviderSubscriber
  2. 8.9.x core/lib/Drupal/Core/EventSubscriber/EntityRouteProviderSubscriber.php \Drupal\Core\EventSubscriber\EntityRouteProviderSubscriber
  3. 10 core/lib/Drupal/Core/EventSubscriber/EntityRouteProviderSubscriber.php \Drupal\Core\EventSubscriber\EntityRouteProviderSubscriber

Ensures that routes can be provided by entity types.

Hierarchy

Expanded class hierarchy of EntityRouteProviderSubscriber

File

core/lib/Drupal/Core/EventSubscriber/EntityRouteProviderSubscriber.php, line 14

Namespace

Drupal\Core\EventSubscriber
View source
class EntityRouteProviderSubscriber implements EventSubscriberInterface {
    
    /**
     * The entity type manager service.
     *
     * @var \Drupal\Core\Entity\EntityTypeManagerInterface
     */
    protected $entityTypeManager;
    
    /**
     * Constructs a new EntityRouteProviderSubscriber instance.
     *
     * @param \Drupal\Core\Entity\EntityTypeManagerInterface $entity_type_manager
     *   The entity type manager service.
     */
    public function __construct(EntityTypeManagerInterface $entity_type_manager) {
        $this->entityTypeManager = $entity_type_manager;
    }
    
    /**
     * Provides routes on route rebuild time.
     *
     * @param \Drupal\Core\Routing\RouteBuildEvent $event
     *   The route build event.
     */
    public function onDynamicRouteEvent(RouteBuildEvent $event) {
        $route_collection = $event->getRouteCollection();
        foreach ($this->entityTypeManager
            ->getDefinitions() as $entity_type) {
            if ($entity_type->hasRouteProviders()) {
                foreach ($this->entityTypeManager
                    ->getRouteProviders($entity_type->id()) as $route_provider) {
                    // Allow to both return an array of routes or a route collection,
                    // like route_callbacks in the routing.yml file.
                    $routes = $route_provider->getRoutes($entity_type);
                    if ($routes instanceof RouteCollection) {
                        $routes = $routes->all();
                    }
                    foreach ($routes as $route_name => $route) {
                        // Don't override existing routes.
                        if (!$route_collection->get($route_name)) {
                            $route_collection->add($route_name, $route);
                        }
                    }
                }
            }
        }
    }
    
    /**
     * {@inheritdoc}
     */
    public static function getSubscribedEvents() : array {
        $events[RoutingEvents::DYNAMIC][] = [
            'onDynamicRouteEvent',
        ];
        return $events;
    }

}

Members

Title Sort descending Modifiers Object type Summary
EntityRouteProviderSubscriber::$entityTypeManager protected property The entity type manager service.
EntityRouteProviderSubscriber::getSubscribedEvents public static function
EntityRouteProviderSubscriber::onDynamicRouteEvent public function Provides routes on route rebuild time.
EntityRouteProviderSubscriber::__construct public function Constructs a new EntityRouteProviderSubscriber instance.

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