RoutePreloader::onRequest

public RoutePreloader::onRequest(KernelEvent $event)

Loads all non-admin routes right before the actual page is rendered.

Parameters

\Symfony\Component\HttpKernel\Event\KernelEvent $event: The event to process.

File

core/lib/Drupal/Core/Routing/RoutePreloader.php, line 71

Class

RoutePreloader
Defines a class which preloads non-admin routes.

Namespace

Drupal\Core\Routing

Code

public function onRequest(KernelEvent $event) {
  // Only preload on normal HTML pages, as they will display menu links.
  if ($this->routeProvider instanceof PreloadableRouteProviderInterface && $event->getRequest()->getRequestFormat() == 'html') {

    // Ensure that the state query is cached to skip the database query, if
    // possible.
    $key = 'routing.non_admin_routes';
    if ($cache = $this->cache->get($key)) {
      $routes = $cache->data;
    }
    else {
      $routes = $this->state->get($key, []);
      $this->cache->set($key, $routes, Cache::PERMANENT, ['routes']);
    }

    if ($routes) {
      // Preload all the non-admin routes at once.
      $this->routeProvider->preLoadRoutes($routes);
    }
  }
}
doc_Drupal
2016-10-29 09:39:11
Comments
Leave a Comment

Please login to continue.