aboutsummaryrefslogtreecommitdiff
path: root/src/controller/ViewController.php
blob: 9818c6e0db0ad1d9ece8bbb6158bf8b6faee653c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
<?php
// src/view/ViewController.php
//
// génère le HTML avec des Builder

declare(strict_types=1);

use App\Entity\Node;
use Doctrine\ORM\EntityManager;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;

class ViewController extends AbstractBuilder // ViewController est aussi le premier Builder
{
    static public Node $root_node;

    public function __construct(){} // surcharge celui de AbstractBuilder

    public function buildView(EntityManager $entityManager, Request $request): Response
    {
        /* 1/ 1er contrôle des paramètres */

        // mode modification d'une page
        if($_SESSION['admin']
            && $request->query->has('mode') && $request->query->get('mode') === 'page_modif'
            && !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(CURRENT_PAGE === 'article'){
            if($_SESSION['admin']){
                if(!$request->query->has('id')){
                    return new Response($this->html, 302);
                }
                else{
                    // mode création d'article
                    // l'id du bloc et 'from=' sont vérifiés dans ArticleController::editorSubmit
                    if($request->query->get('id')[0] === 'n' && $request->query->has('from') && !empty($request->query->get('from'))){
                        NewBuilder::$new_article_mode = true;
                    }
                }
            }
            elseif($request->query->get('id')[0] === 'n'){ // accès page nouvelle article interdit sans être admin
                return new Response($this->html, 302);
            }
        }
        //else // l'id dans l'adresse n'a pas d'effet sur la suite


        /* 2/ accès au modèle */
        $director = new Director($entityManager, true);
        $director->getWholePageData($request);
        self::$root_node = $director->getNode();


        /* 3/ 2ème contrôle utilisant les données récupérées */

        // article non trouvé en BDD
        if(CURRENT_PAGE === 'article' && !$_SESSION['admin'] && self::$root_node->getNodeByName('main')->getAdoptedChild() === null){
            return new Response($this->html, 302);
        }


        /* 4/ construction de la page avec builders et vues */
        $this->useChildrenBuilder(self::$root_node);

        return new Response($this->html, 200);
    }
}