<?php/**
* @file
* Contains Drupal\Core\EventSubscriber\AccessSubscriber.
*/namespaceDrupal\Core\EventSubscriber;
useSymfony\Component\HttpKernel\KernelEvents;
useSymfony\Component\HttpKernel\Event\GetResponseEvent;
useSymfony\Component\EventDispatcher\EventSubscriberInterface;
useDrupal\Core\Routing\RoutingEvents;
useDrupal\Core\Access\AccessManager;
useDrupal\Core\Routing\RouteBuildEvent;
/**
* Access subscriber for controller requests.
*/class AccessSubscriberimplements EventSubscriberInterface {
/**
* Constructs a new AccessSubscriber.
*
* @param \Drupal\Core\Access\AccessManager $access_manager
* The access check manager that will be responsible for applying
* AccessCheckers against routes.
*/
public function__construct(AccessManager $access_manager) {
$this->accessManager = $access_manager;
}
/**
* Verifies that the current user can access the requested path.
*
* @param \Symfony\Component\HttpKernel\Event\GetResponseEvent $event
* The Event to process.
*/
public functiononKernelRequestAccessCheck(GetResponseEvent $event) {
$request = $event
->getRequest();
if (!$request->attributes
->has('_route')) {
// If no Route is available it is likely a static resource and access is
// handled elsewhere.return;
}
$this->accessManager
->check($request->attributes
->get('_route'));
}
/**
* Apply access checks to routes.
*
* @param \Drupal\Core\Routing\RouteBuildEvent $event
* The event to process.
*/
public functiononRoutingRouteAlterSetAccessCheck(RouteBuildEvent $event) {
$this->accessManager
->setChecks($event
->getRouteCollection());
}
/**
* Registers the methods in this class that should be listeners.
*
* @return array
* An array of event listener definitions.
*/
static functiongetSubscribedEvents() {
$events[KernelEvents::REQUEST][] = array(
'onKernelRequestAccessCheck',
30,
);
// Setting very low priority to ensure access checks are run after alters.$events[RoutingEvents::ALTER][] = array(
'onRoutingRouteAlterSetAccessCheck',
0,
);
return$events;
}
}