You are here

class RouteSubscriber in Scheduled Updates 8

Subscriber for Field UI routes.

Hierarchy

  • class \Drupal\Core\Routing\RouteSubscriberBase implements \Symfony\Component\EventDispatcher\EventSubscriberInterface

Expanded class hierarchy of RouteSubscriber

1 string reference to 'RouteSubscriber'
scheduled_updates.services.yml in ./scheduled_updates.services.yml
scheduled_updates.services.yml
1 service uses RouteSubscriber
scheduled_updates.routing.subscriber in ./scheduled_updates.services.yml
Drupal\scheduled_updates\Routing\RouteSubscriber

File

src/Routing/RouteSubscriber.php, line 19
Contains \Drupal\scheduled_updates\Routing\RouteSubscriber.

Namespace

Drupal\scheduled_updates\Routing
View source
class RouteSubscriber extends RouteSubscriberBase {

  /**
   * The entity type manager
   *
   * @var \Drupal\Core\Entity\EntityManagerInterface
   */
  protected $manager;

  /**
   * Constructs a RouteSubscriber object.
   *
   * @param \Drupal\Core\Entity\EntityManagerInterface $manager
   *   The entity type manager.
   */
  public function __construct(EntityManagerInterface $manager) {
    $this->manager = $manager;
  }

  /**
   * {@inheritdoc}
   */
  protected function alterRoutes(RouteCollection $collection) {
    foreach ($this->manager
      ->getDefinitions() as $entity_type_id => $entity_type) {
      if ($route_name = $entity_type
        ->get('field_ui_base_route')) {

        // Try to get the route from the current collection.
        if (!($entity_route = $collection
          ->get($route_name))) {
          continue;
        }
        $path = $entity_route
          ->getPath();
        $options = $entity_route
          ->getOptions();
        if ($bundle_entity_type = $entity_type
          ->getBundleEntityType()) {
          $options['parameters'][$bundle_entity_type] = array(
            'type' => 'entity:' . $bundle_entity_type,
          );
        }

        // Special parameter used to easily recognize all Field UI routes.
        $options['_scheduled_updates'] = TRUE;
        $defaults = array(
          'entity_type_id' => $entity_type_id,
        );

        // If the entity type has no bundles and it doesn't use {bundle} in its
        // admin path, use the entity type.
        if (strpos($path, '{bundle}') === FALSE) {
          $defaults['bundle'] = !$entity_type
            ->hasKey('bundle') ? $entity_type_id : '';
        }
        $route = new Route("{$path}/fields/add-scheduled-update", array(
          '_entity_form' => 'scheduled_update_type.add-as-field',
          '_title' => 'Add an Update Field',
        ) + $defaults, array(
          '_permission' => 'administer ' . $entity_type_id . ' fields',
        ), $options);
        $collection
          ->add("entity.scheduled_update_type.add_form.field.{$entity_type_id}", $route);
      }
    }
  }

  /**
   * {@inheritdoc}
   */
  public static function getSubscribedEvents() {
    $events = parent::getSubscribedEvents();
    $events[RoutingEvents::ALTER] = array(
      'onAlterRoutes',
      -110,
    );
    return $events;
  }

}

Members

Namesort descending Modifiers Type Description Overrides
RouteSubscriber::$manager protected property The entity type manager
RouteSubscriber::alterRoutes protected function Alters existing routes for a specific collection. Overrides RouteSubscriberBase::alterRoutes
RouteSubscriber::getSubscribedEvents public static function Returns an array of event names this subscriber wants to listen to. Overrides RouteSubscriberBase::getSubscribedEvents
RouteSubscriber::__construct public function Constructs a RouteSubscriber object.
RouteSubscriberBase::onAlterRoutes public function Delegates the route altering to self::alterRoutes(). 1