setBasePath($altorouterPath); $router->map('GET', '/', 'FrontController'); $router->map('GET|POST', '/admin/[i:id]/[a:action]?', 'Admin'); $router->map('GET|POST', '/teacher/[i:id]/[a:action]?', 'Teacher'); $router->map('GET|POST', '/student/[i:id]/[a:action]?', 'Student'); $router->map('GET|POST', '/abs/[a:action]?', 'Abs'); $twig->addGlobal('base', $altorouterPath); $match = $router->match(); if (!$match) { throw new Exception("Erreur 404 page not found"); } if ($match) { $target = $match['target'] ?? null; $action = Validation::val_action($match['params']['action'] ?? null); $id = $match['params']['id'] ?? null; switch ($action) { case null: $this->home(); break; default : if ($id != null && !$this->checkIdExist($id)) throw new Exception("identifiant invalide"); if ($target == null) throw new Exception("pas de target"); if (isset($_SESSION['login']) && isset($_SESSION['roles'])) { $_SESSION['login'] = strip_tags($_SESSION['login']); for ($i=0 ; $igetId() != $id) throw new Exception("erreur 403 permission denied"); } $controller = '\\controller\\' . $target . 'Controller'; $controller = new $controller; if (is_callable(array($controller, $action))) call_user_func_array(array($controller, $action), array($match['params'])); break; } else (new AbsController())->login(); } } } catch (Exception $e) { $dVueEreur[] = $e->getMessage(); echo $twig->render('erreur.html', ['dVueEreur' => $dVueEreur]); } } public function home(): void { global $twig; echo $twig->render('home.html'); var_dump($_SESSION['roles']); } }