From a28479d0fcb41955fe5381371261e9109f339d89 Mon Sep 17 00:00:00 2001 From: polo Date: Wed, 1 Oct 2025 10:24:31 +0200 Subject: =?UTF-8?q?visibilit=C3=A9=20bouton=20Modifier=20la=20page,=20s?= =?UTF-8?q?=C3=A9curit=C3=A9=20si=20&mode=3Dpage=5Fmodif=20est=20utilis?= =?UTF-8?q?=C3=A9=20de=20mani=C3=A8re=20non=20attendue?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/controller/ViewController.php | 17 ++++++++++------- 1 file changed, 10 insertions(+), 7 deletions(-) (limited to 'src/controller') diff --git a/src/controller/ViewController.php b/src/controller/ViewController.php index f66baff..9117f0f 100644 --- a/src/controller/ViewController.php +++ b/src/controller/ViewController.php @@ -5,7 +5,6 @@ declare(strict_types=1); -use App\Entity\Article; use App\Entity\Node; use Doctrine\ORM\EntityManager; use Symfony\Component\HttpFoundation\Request; @@ -19,21 +18,24 @@ class ViewController extends AbstractBuilder // ViewController est aussi le prem public function buildView(EntityManager $entityManager, Request $request): Response { - // accès au modèle + /* 1/ accès au modèle */ $director = new Director($entityManager, true); $director->makeRootNode(htmlspecialchars($request->query->get('id') ?? '')); self::$root_node = $director->getNode(); + + /* 2/ traitement de quelques paramètres */ + // mode modification d'une page activé - if($_SESSION['admin'] && $request->query->has('page') + if($_SESSION['admin'] && $request->query->has('mode') && $request->query->get('mode') === 'page_modif' - && $request->query->get('page') !== 'connexion' && $request->query->get('page') !== 'article' && $request->query->get('page') !== 'nouvelle_page' && $request->query->get('page') !== 'menu_chemins'){ - // les contrôles de la 2è ligne devraient utiliser un tableau + && !in_array(CURRENT_PAGE, ['article', 'nouvelle_page', 'menu_chemins', 'user_edit', 'connection'])) + { MainBuilder::$modif_mode = true; } // page article: mode création et erreurs d'id - if($request->query->has('page') && $request->query->get('page') === 'article'){ + if(CURRENT_PAGE === 'article'){ if($_SESSION['admin']){ if(!$request->query->has('id')){ return new Response($this->html, 302); @@ -54,7 +56,8 @@ class ViewController extends AbstractBuilder // ViewController est aussi le prem } } - //début de la construction de la page + + /* 3/ construction de la page avec builders et vues */ $this->useChildrenBuilder(self::$root_node); return new Response($this->html, 200); -- cgit v1.2.3