Subversion Repositories Applications.framework

Rev

Rev 89 | Rev 105 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

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