Determine whether the page is configured to be offline.
\Symfony\Component\HttpKernel\Event\GetResponseEvent $event: The event to process.
public function onKernelRequestMaintenance(GetResponseEvent $event) {
$request = $event
->getRequest();
$site_status = $request->attributes
->get('_maintenance');
$path = $request->attributes
->get('system_path');
if ($site_status == MENU_SITE_OFFLINE) {
// If the site is offline, log out unprivileged users.
if (user_is_logged_in() && !user_access('access site in maintenance mode')) {
user_logout();
// Redirect to homepage.
$event
->setResponse(new RedirectResponse(url('<front>', array(
'absolute' => TRUE,
))));
return;
}
if (user_is_anonymous()) {
switch ($path) {
case 'user':
// Forward anonymous user to login page.
$event
->setResponse(new RedirectResponse(url('user/login', array(
'absolute' => TRUE,
))));
return;
case 'user/login':
case 'user/password':
// Disable offline mode.
$request->attributes
->set('_maintenance', MENU_SITE_ONLINE);
break;
default:
if (strpos($path, 'user/reset/') === 0) {
// Disable offline mode.
$request->attributes
->set('_maintenance', MENU_SITE_ONLINE);
}
break;
}
}
}
if (user_is_logged_in()) {
if ($path == 'user/login') {
// If user is logged in, redirect to 'user' instead of giving 403.
$event
->setResponse(new RedirectResponse(url('user', array(
'absolute' => TRUE,
))));
return;
}
if ($path == 'user/register') {
// Authenticated user should be redirected to user edit page.
$event
->setResponse(new RedirectResponse(url('user/' . $GLOBALS['user']->uid . '/edit', array(
'absolute' => TRUE,
))));
return;
}
}
}