Subversion Repositories Applications.framework

Rev

Rev 79 | Rev 84 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

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