Subversion Repositories Applications.framework

Rev

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

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