Subversion Repositories Applications.framework

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
5 aurelien 1
<?php
2
/**
3
 * Fichier contenant la classe controleur
4
 *
5
* @category  PHP
6
* @package   Framework
7
* @author    aurelien <aurelien@tela-botanica.org>
8
* @copyright 2009 Tela-Botanica
9
* @license   http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
10
* @version   SVN: <svn_id>
11
* @link      /doc/framework/
12
 */
13
 
14
/**
15
* classe Controlleur, coeur d'une application, c'est normalement la seule classe d'une application
16
* qui devrait être appelée de l'extérieur.
17
* Elle est abstraite donc doit obligatoirement être étendue
18
*
19
* PHP Version 5
20
*
21
* @category  Class
22
* @package   Framework
23
* @author    aurelien <aurelien@tela-botanica.org>
24
* @copyright 2009 Tela-Botanica
25
* @license   http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
26
* @version   SVN: <svn_id>
27
* @link      /doc/framework/
28
*
29
*/
30
abstract class Controleur
31
{
32
    /**
33
     * Registre global, normalement accessible partout
34
     */
35
    private $_registre;
36
    /**
37
     * Gestionnaire d'exceptions php
38
     */
39
    private $__gestionnaire_exception;
40
    /**
41
     * Gestionnaire d'erreurs php
42
     */
43
    private $_gestionnaire_erreur;
44
 
45
    /**
46
     * Constructeur par défaut
47
     */
48
    final public function __construct()
49
    {
50
        $this->registre = Registre::getInstance();
51
        $this->registre->set('chemin_config', CHEMIN_APPLI.'configuration'.DIRECTORY_SEPARATOR);
52
        $this->registre->set('base_chemin_modele', DOSSIER_MODELES.DIRECTORY_SEPARATOR);
53
        $this->registre->set('base_chemin_squelette', DOSSIER_SQUELETTES.DIRECTORY_SEPARATOR);
54
        $this->registre->set('base_chemin_controleur', DOSSIER_CONTROLEURS.DIRECTORY_SEPARATOR);
55
        $this->registre->set('bdd_type', BDD_PROTOCOLE);
56
        $this->registre->set('bdd_hote', BDD_SERVEUR);
57
        $this->registre->set('bdd_nom', BDD_NOM_PRINCIPALE);
58
        $this->registre->set('bdd_utilisateur', BDD_UTILISATEUR);
59
        $this->registre->set('bdd_pass', BDD_MOT_DE_PASSE);
60
        $this->registre->set('base_url_application', new Net_URL2(URL_BASE));
61
        $this->_gestionnaire_exception = GestionnaireException::getInstance();
62
        $this->_gestionnaire_erreur = GestionnaireErreur::getInstance();
63
    }
64
 
65
    /**
66
    * Charge un modele donné et le rend disponible sous la forme $this->nom_modele
67
    *
68
    * @param string $nom_modele le nom du modèle à charger
69
    *
70
    * @return boolean false si le chargement à échoué, rien sinon
71
    */
72
    final protected function chargerModele($nom_modele)
73
    {
74
 
75
        $chemin_modele = ($this->registre->get('base_chemin_modele')).$nom_modele.'.php';
76
 
77
        if (!file_exists($chemin_modele)) {
78
            return false;
79
        }
80
 
81
        include_once $chemin_modele;
82
 
83
        if (!class_exists($nom_modele)) {
84
            return false;
85
        }
86
 
87
        $this->$nom_modele = new $nom_modele;
88
    }
89
 
90
    /**
91
     * Fonction prenant en paramètre le nom d'un squelette et un tableau associatif de données, en extrait les variables, charge le squelette
92
     * et cree une variable de classe contenant les deux combinés.
93
     *
94
     * @param String $nom_squelette le nom du squelette
95
     * @param Array  $donnees       un tableau associatif contenant les variables a injecter dans la vue
96
     *
97
     * @return boolean false si la vue n'existe pas, rien sinon
98
     */
99
    final protected function chargerVue($nom_squelette,$donnees)
100
    {
101
        $chemin_squelette = ($this->registre->get('base_chemin_squelette')).$nom_squelette.'.tpl.html';
102
 
103
        if (!file_exists($chemin_squelette)) {
104
            return false ;
105
        }
106
 
107
        $donnees['base_url'] = $this->registre->get('base_url_application');
108
 
109
        // on extrait les variables du tableau de données
110
        extract($donnees);
111
 
112
        // et on enclenche la bufferisation de sortie
113
        ob_start();
114
 
115
        // si les tags courts sont désactivés
116
        if ((bool) @ini_get('short_open_tag') === false) {
117
            // on remplace les tags par la syntaxe classique avec echo
118
            echo eval('?>'.preg_replace("/;*\s*\?>/", "; ?>", str_replace('<?=', '<?php echo ', file_get_contents($chemin_squelette))));
119
        } else {
120
            // sinon, on se contente d'inclure le squelette
121
            include $chemin_squelette;
122
        }
123
 
124
        // on récupère le buffer et on le vide
125
        $buffer = ob_get_contents();
126
        @ob_end_clean();
127
 
128
        // enfin on renvoie le contenu
129
        $this->$nom_squelette = $buffer;
130
    }
131
}
132
?>