Subversion Repositories Applications.framework

Rev

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

Rev 268 Rev 274
1
<?php
1
<?php
2
// declare(encoding='UTF-8');
2
// declare(encoding='UTF-8');
3
/**
3
/**
4
 * Classe de base du Framework : 
4
 * Classe de base du Framework : 
5
 *  - fournissant des infos sur l'application, 
5
 *  - fournissant des infos sur l'application, 
6
 *  - paramétrant l'environnement de l'appli et du framework,
6
 *  - paramétrant l'environnement de l'appli et du framework,
7
 *  - réalisant des traitements sur les variables globales ($_GET, $_POST, $_COOKIE...)
7
 *  - réalisant des traitements sur les variables globales ($_GET, $_POST, $_COOKIE...)
8
 * 
8
 * 
9
 * Cette classe contient la fonction de chargement automatique de classes.
9
 * Cette classe contient la fonction de chargement automatique de classes.
10
 * Ce fichier doit toujours rester à la racine du framework car il initialise le chemin 
10
 * Ce fichier doit toujours rester à la racine du framework car il initialise le chemin 
11
 * de l'application en se basant sur son propre emplacement.
11
 * de l'application en se basant sur son propre emplacement.
12
 *
12
 *
13
 * @category	PHP 5.2
13
 * @category	PHP 5.2
14
 * @package	Framework
14
 * @package	Framework
15
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
15
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
16
 * @copyright	Copyright (c) 2010, Tela Botanica (accueil@tela-botanica.org)
16
 * @copyright	Copyright (c) 2010, Tela Botanica (accueil@tela-botanica.org)
17
 * @license	http://www.gnu.org/licenses/gpl.html Licence GNU-GPL-v3
17
 * @license	http://www.gnu.org/licenses/gpl.html Licence GNU-GPL-v3
18
 * @license	http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL-v2
18
 * @license	http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL-v2
19
 * @version	$Id: Framework.php 268 2010-12-25 17:06:01Z jpm $
19
 * @version	$Id: Framework.php 274 2010-12-28 15:37:22Z jpm $
20
 * @since		0.3
20
 * @since		0.3
21
 * @link		/doc/framework/
21
 * @link		/doc/framework/
22
 */
22
 */
23
class Framework {
23
class Framework {
24
 
24
 
25
	/** Variable statique indiquant que les tableaux _GET et _POST ont déjà été encodé au format de l'appli. */
25
	/** Variable statique indiquant que les tableaux _GET et _POST ont déjà été encodé au format de l'appli. */
26
	private static $encodage = false;
26
	private static $encodage = false;
27
	
27
	
28
	/** Tableau d'informations sur l'application */
28
	/** Tableau d'informations sur l'application */
29
	private static $info = null;
29
	private static $info = null;
30
	
30
	
31
	/** Chemin de base de l'application */
31
	/** Chemin de base de l'application */
32
	private static $chemin = null;
32
	private static $chemin = null;
33
 
33
 
34
	/** Tableau des noms des paramètres à définir dans le fichier de config car obligatoirement nécessaire à cette classe.*/
34
	/** Tableau des noms des paramètres à définir dans le fichier de config car obligatoirement nécessaire à cette classe.*/
35
	private static $parametres_obligatoires = array('chemin_controleurs', 'chemin_modeles', 'chemin_bibliotheque', 
35
	private static $parametres_obligatoires = array('chemin_controleurs', 'chemin_modeles', 'chemin_bibliotheque', 
36
		'fw_url_arg_separateur_entree', 'fw_url_arg_separateur_sortie',
36
		'url_arg_separateur_entree', 'url_arg_separateur_sortie',
37
		'sortie_encodage', 'appli_encodage');
37
		'encodage_sortie', 'encodage_appli');
38
	
38
	
39
	/**
39
	/**
40
	 * Initialise l'environnement nécessaire au Framework : constantes globales, méthodeles autoload, séparateur d'arguments 
40
	 * Initialise l'environnement nécessaire au Framework : constantes globales, méthodeles autoload, séparateur d'arguments 
41
	 * d'url.
41
	 * d'url.
42
	 * Cette méthode est appelée automatiquement suite à la définition du chemin de l'application via Application::setChemin().
42
	 * Cette méthode est appelée automatiquement suite à la définition du chemin de l'application via Application::setChemin().
43
	 */
43
	 */
44
	private static function initialiserEnvironnement() {
44
	private static function initialiserEnvironnement() {
45
		self::enregistrerMethodesAutoload();
45
		self::enregistrerMethodesAutoload();
46
		self::initialiserUrl();
46
		self::initialiserUrl();
47
	}
47
	}
48
	
48
	
49
	/**
49
	/**
50
	 * Initialise différentes classes du Framework nécessaires pour le fonctionnement de l'application.
50
	 * Initialise différentes classes du Framework nécessaires pour le fonctionnement de l'application.
51
	 * Ces classes sont ensuites controlées via les fichiers de config.ini.
51
	 * Ces classes sont ensuites controlées via les fichiers de config.ini.
52
	 * Elle est appelée automatiquement suite à la définition du chemin de l'application via Application::setChemin().
52
	 * Elle est appelée automatiquement suite à la définition du chemin de l'application via Application::setChemin().
53
	 */
53
	 */
54
	private static function initialiserFramework() {
54
	private static function initialiserFramework() {
55
		GestionnaireException::configurer();
55
		GestionnaireException::configurer();
56
		//Log::configurer();		
56
		//Log::configurer();		
57
		self::verifierEtReencoderTableauRequete();
57
		self::verifierEtReencoderTableauRequete();
58
	}
58
	}
59
	
59
	
60
	/**
60
	/**
61
	 * Redéfinit des constantes globales utiles pour le Framework et les applis.
61
	 * Redéfinit des constantes globales utiles pour le Framework et les applis.
62
	 */
62
	 */
63
	private static function definirConstantesGlobales() {
63
	private static function definirConstantesGlobales() {
64
		/** Redéfinition de la constante DIRECTORY_SEPARATOR en version abrégée DS */
64
		/** Redéfinition de la constante DIRECTORY_SEPARATOR en version abrégée DS */
65
		if (!defined('DS')) {
65
		if (!defined('DS')) {
66
			define('DS', DIRECTORY_SEPARATOR);
66
			define('DS', DIRECTORY_SEPARATOR);
67
		}
67
		}
68
		/** Redéfinition de la constante PATH_SEPARATOR en version abrégée PS */
68
		/** Redéfinition de la constante PATH_SEPARATOR en version abrégée PS */
69
		if (!defined('PS')) {
69
		if (!defined('PS')) {
70
			define('PS', PATH_SEPARATOR);
70
			define('PS', PATH_SEPARATOR);
71
		}
71
		}
72
	}
72
	}
73
	
73
	
74
	private static function enregistrerMethodesAutoload() {
74
	private static function enregistrerMethodesAutoload() {
75
		spl_autoload_register(array(get_class(), 'autoloadFw'));
75
		spl_autoload_register(array(get_class(), 'autoloadFw'));
76
		
76
		
77
		// Vérification des paramètres de configuration obligatoire pour assurer le fonctionnement du Framework
77
		// Vérification des paramètres de configuration obligatoire pour assurer le fonctionnement du Framework
78
		Config::verifierPresenceParametres(self::$parametres_obligatoires);
78
		Config::verifierPresenceParametres(self::$parametres_obligatoires);
79
		
79
		
80
		// Initialisation du gestionnaire d'erreur avant toute chose
80
		// Initialisation du gestionnaire d'erreur avant toute chose
81
		GestionnaireException::initialiser();
81
		GestionnaireException::initialiser();
82
		
82
		
83
		spl_autoload_register(array(get_class(), 'autoloadAppliDefaut'));
83
		spl_autoload_register(array(get_class(), 'autoloadAppliDefaut'));
84
		
84
		
85
		// Autoload défini par l'application
85
		// Autoload défini par l'application
86
		if (function_exists('__autoload')) {
86
		if (function_exists('__autoload')) {
87
			spl_autoload_register('__autoload');
87
			spl_autoload_register('__autoload');
88
		}
88
		}
89
	}
89
	}
90
	
90
	
91
	/**
91
	/**
92
	 * Autoload pour le Framework.
92
	 * Autoload pour le Framework.
93
	 */
93
	 */
94
	private static function autoloadFw($nom_classe_fw) {
94
	private static function autoloadFw($nom_classe_fw) {
95
		$dossiers_classes = array(	dirname(__FILE__).DS,
95
		$dossiers_classes = array(	dirname(__FILE__).DS,
96
									dirname(__FILE__).DS.'utilitaires'.DS);
96
									dirname(__FILE__).DS.'utilitaires'.DS);
97
		foreach ($dossiers_classes as $chemin) {
97
		foreach ($dossiers_classes as $chemin) {
98
			$fichier_a_tester = $chemin.$nom_classe_fw.'.php';
98
			$fichier_a_tester = $chemin.$nom_classe_fw.'.php';
99
			if (file_exists($fichier_a_tester)) {
99
			if (file_exists($fichier_a_tester)) {
100
				include_once $fichier_a_tester;
100
				include_once $fichier_a_tester;
101
				return null;
101
				return null;
102
			}
102
			}
103
		}
103
		}
104
	}
104
	}
105
	
105
	
106
	/**
106
	/**
107
	 * Autoload par défaut pour l'application
107
	 * Autoload par défaut pour l'application
108
	 */
108
	 */
109
	private static function autoloadAppliDefaut($nom_classe) {
109
	private static function autoloadAppliDefaut($nom_classe) {
110
		$dossiers_classes = array(	Config::get('chemin_controleurs'),
110
		$dossiers_classes = array(	Config::get('chemin_controleurs'),
111
									Config::get('chemin_modeles'),
111
									Config::get('chemin_modeles'),
112
									Config::get('chemin_bibliotheque'));
112
									Config::get('chemin_bibliotheque'));
113
	
113
	
114
		foreach ($dossiers_classes as $chemin) {
114
		foreach ($dossiers_classes as $chemin) {
115
			$fichier_a_tester = $chemin.$nom_classe.'.php';
115
			$fichier_a_tester = $chemin.$nom_classe.'.php';
116
			if (file_exists($fichier_a_tester)) {
116
			if (file_exists($fichier_a_tester)) {
117
				include_once $fichier_a_tester;
117
				include_once $fichier_a_tester;
118
				return null;
118
				return null;
119
			}
119
			}
120
		}
120
		}
121
	}
121
	}
122
	
122
	
123
	/**
123
	/**
124
	 * Initialise le format des urls.
124
	 * Initialise le format des urls.
125
	 */
125
	 */
126
	private static function initialiserUrl() {
126
	private static function initialiserUrl() {
127
		ini_set('arg_separator.input', Config::get('fw_url_arg_separateur_entree'));
127
		ini_set('arg_separator.input', Config::get('furl_arg_separateur_entree'));
128
		ini_set('arg_separator.output', Config::get('fw_url_arg_separateur_sortie'));
128
		ini_set('arg_separator.output', Config::get('url_arg_separateur_sortie'));
129
	}
129
	}
130
		
130
		
131
	/**
131
	/**
132
	 * Permet d'indiquer le chemin de base de l'Application.
132
	 * Permet d'indiquer le chemin de base de l'Application.
133
	 * Cette méthode doit obligatoirement être utilisée par l'application pour que le Framework fonctionne correctement.
133
	 * Cette méthode doit obligatoirement être utilisée par l'application pour que le Framework fonctionne correctement.
134
	 * @param string $chemin_fichier_principal chemin de base
134
	 * @param string $chemin_fichier_principal chemin de base
135
	 */
135
	 */
136
	public static function setCheminAppli($chemin_fichier_principal) {
136
	public static function setCheminAppli($chemin_fichier_principal) {
137
		if (self::$chemin === null) {
137
		if (self::$chemin === null) {
138
			if (!file_exists($chemin_fichier_principal)) {
138
			if (!file_exists($chemin_fichier_principal)) {
139
				trigger_error("Le fichier indiqué n'existe pas. Utilisez __FILE__ dans la méthode setCheminAppli().", E_USER_ERROR);
139
				trigger_error("Le fichier indiqué n'existe pas. Utilisez __FILE__ dans la méthode setCheminAppli().", E_USER_ERROR);
140
			} else {
140
			} else {
141
				self::definirConstantesGlobales();
141
				self::definirConstantesGlobales();
142
				self::$chemin = dirname($chemin_fichier_principal).DS;
142
				self::$chemin = dirname($chemin_fichier_principal).DS;
143
				self::initialiserEnvironnement();
143
				self::initialiserEnvironnement();
144
				self::initialiserFramework();
144
				self::initialiserFramework();
145
			}
145
			}
146
		} else {
146
		} else {
147
			trigger_error("Le chemin de l'application a déjà été enregistré auprès du Framework", E_USER_WARNING);
147
			trigger_error("Le chemin de l'application a déjà été enregistré auprès du Framework", E_USER_WARNING);
148
		}
148
		}
149
	}
149
	}
150
 
150
 
151
	/**
151
	/**
152
	 * accesseur pour le chemin
152
	 * accesseur pour le chemin
153
	 * @return string le chemin
153
	 * @return string le chemin
154
	 */
154
	 */
155
	public static function getCheminAppli() {
155
	public static function getCheminAppli() {
156
		return self::$chemin;
156
		return self::$chemin;
157
	}
157
	}
158
 
158
 
159
	/** Le tableau des informations sur l'application possède les clés suivantes :
159
	/** Le tableau des informations sur l'application possède les clés suivantes :
160
	 * - nom : nom de l'application
160
	 * - nom : nom de l'application
161
	 * - abr : abréviation de l'application
161
	 * - abr : abréviation de l'application
162
	 * - encodage : encodage de l'application (ISO-8859-15, UTF-8...)
162
	 * - encodage : encodage de l'application (ISO-8859-15, UTF-8...)
163
	 *
163
	 *
164
	 * @param array $info tableau fournissant des informations sur l'application
164
	 * @param array $info tableau fournissant des informations sur l'application
165
	 * @return void
165
	 * @return void
166
	 */
166
	 */
167
	public static function setInfoAppli($info) {
167
	public static function setInfoAppli($info) {
168
		if (self::$info === null) {
168
		if (self::$info === null) {
169
			self::$info = $info;
169
			self::$info = $info;
170
		} else {
170
		} else {
171
			trigger_error("Le informations de l'application ont déjà été enregistrées auprès du Framework", E_USER_WARNING);
171
			trigger_error("Le informations de l'application ont déjà été enregistrées auprès du Framework", E_USER_WARNING);
172
		}
172
		}
173
	}
173
	}
174
 
174
 
175
	/**
175
	/**
176
	 * Accesseur pour le tableau d'infos sur l'application.
176
	 * Accesseur pour le tableau d'infos sur l'application.
177
	 * @param string $cle la clé à laquelle on veut accéder
177
	 * @param string $cle la clé à laquelle on veut accéder
178
	 */
178
	 */
179
	public static function getInfoAppli($cle = null) {
179
	public static function getInfoAppli($cle = null) {
180
		if ($cle !== null) {
180
		if ($cle !== null) {
181
			if (isset(self::$info[$cle])) {
181
			if (isset(self::$info[$cle])) {
182
				return self::$info[$cle];
182
				return self::$info[$cle];
183
			}
183
			}
184
		} else {
184
		} else {
185
			return self::$info;
185
			return self::$info;
186
		}
186
		}
187
	}
187
	}
188
	
188
	
189
	/**
189
	/**
190
	 * Procédure vérifiant l'encodage des tableaux $_GET et $_POST et les transcodant dans l'encodage de l'application
190
	 * Procédure vérifiant l'encodage des tableaux $_GET et $_POST et les transcodant dans l'encodage de l'application
191
	 */
191
	 */
192
	protected static function verifierEtReencoderTableauRequete() {
192
	protected static function verifierEtReencoderTableauRequete() {
193
		if (self::$encodage == false && Config::get('sortie_encodage') != Config::get('appli_encodage')) {
193
		if (self::$encodage == false && Config::get('encodage_sortie') != Config::get('encodage_appli')) {
194
			$_POST = self::encoderTableau($_POST, Config::get('appli_encodage'), Config::get('sortie_encodage'));
194
			$_POST = self::encoderTableau($_POST, Config::get('encodage_appli'), Config::get('encodage_sortie'));
195
			$_GET = self::encoderTableau($_GET, Config::get('appli_encodage'), Config::get('sortie_encodage'));
195
			$_GET = self::encoderTableau($_GET, Config::get('encodage_appli'), Config::get('encodage_sortie'));
196
			
196
			
197
			// Traitement des magic quotes
197
			// Traitement des magic quotes
198
			self::verifierEtTraiterSlashTableauRequete();
198
			self::verifierEtTraiterSlashTableauRequete();
199
						
199
						
200
			self::$encodage = true;
200
			self::$encodage = true;
201
		}
201
		}
202
	}
202
	}
203
	
203
	
204
	/**
204
	/**
205
	 * Procédure vérifiant l'activation des magic quotes et remplacant les slash dans les tableaux de requete
205
	 * Procédure vérifiant l'activation des magic quotes et remplacant les slash dans les tableaux de requete
206
	 */
206
	 */
207
	private static function verifierEtTraiterSlashTableauRequete() {
207
	private static function verifierEtTraiterSlashTableauRequete() {
208
		if (get_magic_quotes_gpc()) {
208
		if (get_magic_quotes_gpc()) {
209
			if (!function_exists('nettoyerSlashProfond')) {
209
			if (!function_exists('nettoyerSlashProfond')) {
210
				function nettoyerSlashProfond($valeur) {
210
				function nettoyerSlashProfond($valeur) {
211
					return ( is_array($valeur) ) ? array_map('nettoyerSlashProfond', $valeur) : stripslashes($valeur);
211
					return ( is_array($valeur) ) ? array_map('nettoyerSlashProfond', $valeur) : stripslashes($valeur);
212
				}
212
				}
213
			}
213
			}
214
			$_GET = array_map('nettoyerSlashProfond', $_GET);
214
			$_GET = array_map('nettoyerSlashProfond', $_GET);
215
			$_POST = array_map('nettoyerSlashProfond', $_POST);
215
			$_POST = array_map('nettoyerSlashProfond', $_POST);
216
			$_COOKIE = array_map('nettoyerSlashProfond', $_COOKIE);
216
			$_COOKIE = array_map('nettoyerSlashProfond', $_COOKIE);
217
		}
217
		}
218
	}
218
	}
219
 
219
 
220
	/**
220
	/**
221
	 * Fonction récursive transcodant toutes les valeurs d'un tableau de leur encodage d'entrée vers un encodage de sortie donné
221
	 * Fonction récursive transcodant toutes les valeurs d'un tableau de leur encodage d'entrée vers un encodage de sortie donné
222
	 * @param $tableau Array Un tableau de données à encoder
222
	 * @param $tableau Array Un tableau de données à encoder
223
	 * @param $encodage_sortie String l'encodage vers lequel on doit transcoder
223
	 * @param $encodage_sortie String l'encodage vers lequel on doit transcoder
224
	 * @param $encodage_entree String l'encodage original des chaines du tableau (optionnel)
224
	 * @param $encodage_entree String l'encodage original des chaines du tableau (optionnel)
225
	 * @return Array Le tableau encodé dans l'encodage de sortie
225
	 * @return Array Le tableau encodé dans l'encodage de sortie
226
	 *
226
	 *
227
	 */
227
	 */
228
	final static protected function encoderTableau($tableau, $encodage_sortie, $encodage_entree = null) {
228
	final static protected function encoderTableau($tableau, $encodage_sortie, $encodage_entree = null) {
229
		if (is_array($tableau)) {
229
		if (is_array($tableau)) {
230
			foreach ($tableau as $cle => $valeur) {
230
			foreach ($tableau as $cle => $valeur) {
231
				if (is_array($valeur)) {
231
				if (is_array($valeur)) {
232
				 	$tableau[$cle] = self::encoderTableau($valeur, $encodage_sortie, $encodage_entree);
232
				 	$tableau[$cle] = self::encoderTableau($valeur, $encodage_sortie, $encodage_entree);
233
				} else {
233
				} else {
234
					$tableau[$cle] = mb_convert_encoding($valeur, $encodage_sortie, $encodage_entree);
234
					$tableau[$cle] = mb_convert_encoding($valeur, $encodage_sortie, $encodage_entree);
235
				}
235
				}
236
			}
236
			}
237
		}
237
		}
238
		return $tableau;
238
		return $tableau;
239
	}
239
	}
240
}
240
}
241
?>
241
?>