diff options
Diffstat (limited to 'src/controller/ViewController.php')
| -rw-r--r-- | src/controller/ViewController.php | 31 |
1 files changed, 18 insertions, 13 deletions
diff --git a/src/controller/ViewController.php b/src/controller/ViewController.php index 9117f0f..9818c6e 100644 --- a/src/controller/ViewController.php +++ b/src/controller/ViewController.php | |||
| @@ -18,22 +18,15 @@ class ViewController extends AbstractBuilder // ViewController est aussi le prem | |||
| 18 | 18 | ||
| 19 | public function buildView(EntityManager $entityManager, Request $request): Response | 19 | public function buildView(EntityManager $entityManager, Request $request): Response |
| 20 | { | 20 | { |
| 21 | /* 1/ accès au modèle */ | 21 | /* 1/ 1er contrôle des paramètres */ |
| 22 | $director = new Director($entityManager, true); | ||
| 23 | $director->makeRootNode(htmlspecialchars($request->query->get('id') ?? '')); | ||
| 24 | self::$root_node = $director->getNode(); | ||
| 25 | |||
| 26 | |||
| 27 | /* 2/ traitement de quelques paramètres */ | ||
| 28 | 22 | ||
| 29 | // mode modification d'une page activé | 23 | // mode modification d'une page |
| 30 | if($_SESSION['admin'] | 24 | if($_SESSION['admin'] |
| 31 | && $request->query->has('mode') && $request->query->get('mode') === 'page_modif' | 25 | && $request->query->has('mode') && $request->query->get('mode') === 'page_modif' |
| 32 | && !in_array(CURRENT_PAGE, ['article', 'nouvelle_page', 'menu_chemins', 'user_edit', 'connection'])) | 26 | && !in_array(CURRENT_PAGE, ['article', 'nouvelle_page', 'menu_chemins', 'user_edit', 'connection'])) |
| 33 | { | 27 | { |
| 34 | MainBuilder::$modif_mode = true; | 28 | MainBuilder::$modif_mode = true; |
| 35 | } | 29 | } |
| 36 | |||
| 37 | // page article: mode création et erreurs d'id | 30 | // page article: mode création et erreurs d'id |
| 38 | if(CURRENT_PAGE === 'article'){ | 31 | if(CURRENT_PAGE === 'article'){ |
| 39 | if($_SESSION['admin']){ | 32 | if($_SESSION['admin']){ |
| @@ -46,18 +39,30 @@ class ViewController extends AbstractBuilder // ViewController est aussi le prem | |||
| 46 | if($request->query->get('id')[0] === 'n' && $request->query->has('from') && !empty($request->query->get('from'))){ | 39 | if($request->query->get('id')[0] === 'n' && $request->query->has('from') && !empty($request->query->get('from'))){ |
| 47 | NewBuilder::$new_article_mode = true; | 40 | NewBuilder::$new_article_mode = true; |
| 48 | } | 41 | } |
| 49 | elseif(self::$root_node->getNodeByName('main')->getAdoptedChild() === null){ // id inconnu | ||
| 50 | return new Response($this->html, 302); | ||
| 51 | } | ||
| 52 | } | 42 | } |
| 53 | } | 43 | } |
| 54 | elseif($request->query->get('id')[0] === 'n'){ // accès page nouvelle article interdit sans être admin | 44 | elseif($request->query->get('id')[0] === 'n'){ // accès page nouvelle article interdit sans être admin |
| 55 | return new Response($this->html, 302); | 45 | return new Response($this->html, 302); |
| 56 | } | 46 | } |
| 57 | } | 47 | } |
| 48 | //else // l'id dans l'adresse n'a pas d'effet sur la suite | ||
| 49 | |||
| 50 | |||
| 51 | /* 2/ accès au modèle */ | ||
| 52 | $director = new Director($entityManager, true); | ||
| 53 | $director->getWholePageData($request); | ||
| 54 | self::$root_node = $director->getNode(); | ||
| 55 | |||
| 56 | |||
| 57 | /* 3/ 2ème contrôle utilisant les données récupérées */ | ||
| 58 | |||
| 59 | // article non trouvé en BDD | ||
| 60 | if(CURRENT_PAGE === 'article' && !$_SESSION['admin'] && self::$root_node->getNodeByName('main')->getAdoptedChild() === null){ | ||
| 61 | return new Response($this->html, 302); | ||
| 62 | } | ||
| 58 | 63 | ||
| 59 | 64 | ||
| 60 | /* 3/ construction de la page avec builders et vues */ | 65 | /* 4/ construction de la page avec builders et vues */ |
| 61 | $this->useChildrenBuilder(self::$root_node); | 66 | $this->useChildrenBuilder(self::$root_node); |
| 62 | 67 | ||
| 63 | return new Response($this->html, 200); | 68 | return new Response($this->html, 200); |
