<?php
// si maintenance mode activé
if (file_exists('../.maintenance')) {
$canAccess = false;
// Si preview demandé via URL, on set un cookie. Sinon on regarde si un cookie n’existe pas déjà
if (isset($_GET['preview'])) {
$canAccess = boolval($_GET['preview']);
setcookie('preview', boolval($_GET['preview']), time() + 900);
} elseif (isset($_COOKIE['preview'])) {
$canAccess = boolval($_COOKIE['preview']);
}
// sinon on affiche la page de maintenance
if (!$canAccess) {
header('HTTP/1.1 503 Service Temporarily Unavailable');
header('Status: 503 Service Temporarily Unavailable');
die(file_get_contents('./maintenance.html'));
}
}
use App\Kernel;
use Symfony\Component\ErrorHandler\Debug;
use Symfony\Component\HttpFoundation\Request;
use App\Security\NovaSecurity;
require dirname(__DIR__) . '/config/bootstrap.php';
if ($_SERVER['APP_DEBUG']) {
umask(0000);
Debug::enable();
}
Request::setTrustedProxies(['10.0.0.0/8'],
Request::HEADER_X_FORWARDED_FOR |
Request::HEADER_X_FORWARDED_HOST |
Request::HEADER_X_FORWARDED_PORT |
Request::HEADER_X_FORWARDED_PROTO |
Request::HEADER_X_FORWARDED_TRAEFIK
);
if ($_SERVER['APP_ENV'] === 'prod') {
NovaSecurity::novaProcessRequest();
}
$kernel = new Kernel($_SERVER['APP_ENV'], (bool)$_SERVER['APP_DEBUG']);
$request = Request::createFromGlobals();
$response = $kernel->handle($request);
$response->send();
$kernel->terminate($request, $response);