Subversion Repositories Applications.framework

Rev

Rev 208 | Rev 230 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 208 Rev 221
Line 1... Line 1...
1
<?php
1
<?php
2
// declare(encoding='UTF-8');
2
// declare(encoding='UTF-8');
3
/**
3
/**
-
 
4
 * Classe de base du Framework : 
4
 * Classe fournissant des informations au Framework sur l'application.
5
 *  - fournissant des infos sur l'application, 
-
 
6
 *  - paramétrant l'environnement de l'appli et du framework,
-
 
7
 *  - réalisant des traitements sur les variables globales ($_GET, $_POST, $_COOKIE...)
-
 
8
 * 
-
 
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 
-
 
11
 * de l'application en se basant sur son propre emplacement.
5
 *
12
 *
6
 * @category	PHP 5.2
13
 * @category	PHP 5.2
7
 * @package		Framework
14
 * @package	Framework
8
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
15
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
9
 * @copyright	Copyright (c) 2009, Tela Botanica (accueil@tela-botanica.org)
16
 * @copyright	Copyright (c) 2009, Tela Botanica (accueil@tela-botanica.org)
10
 * @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
11
 * @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
12
 * @version		SVN : $Id: Application.php 208 2010-11-03 09:42:54Z gduche $
19
 * @version	SVN : $Id: Framework.php 221 2010-11-10 13:28:36Z jpm $
13
 * @link		/doc/framework/
20
 * @link		/doc/framework/
14
 */
21
 */
15
class Application {
22
class Framework {
Line 16... Line 23...
16
 
23
 
17
	/** Variable statique indiquant que les tableaux _GET et _POST ont déjà été encodé au format de l'appli. */
24
	/** Variable statique indiquant que les tableaux _GET et _POST ont déjà été encodé au format de l'appli. */
Line 18... Line -...
18
	private static $encodage = false;
-
 
19
	
25
	private static $encodage = false;
20
	/**
-
 
21
	 * Tableau d'informations sur l'application
26
	
22
	 */
27
	/** Tableau d'informations sur l'application */
23
	private static $info = null;
28
	private static $info = null;
24
	/**
-
 
25
	 * Chemin de base de l'application
29
	
Line 26... Line 30...
26
	 */
30
	/** Chemin de base de l'application */
-
 
31
	private static $chemin = null;
-
 
32
 
-
 
33
	/**
-
 
34
	 * Initialise l'environnement nécessaire au Framework : constantes globales, méthodeles autoload, séparateur d'arguments 
-
 
35
	 * d'url.
-
 
36
	 * Cette méthode est appelée automatiquement suite à la définition du chemin de l'application via Application::setChemin().
-
 
37
	 */
-
 
38
	private static function initialiserEnvironnement() {
-
 
39
		self::definirConstantesGlobales();
-
 
40
		self::enregistrerMethodesAutoload();
-
 
41
		self::initialiserUrl();
27
	private static $chemin = null;
42
	}
28
 
43
	
29
	/**
44
	/**
30
	 * Initialise différentes classes du Framework nécessaires pour le fonctionnement de l'application.
45
	 * Initialise différentes classes du Framework nécessaires pour le fonctionnement de l'application.
31
	 * Ces classes sont ensuites controlées via les fichiers de config.ini.
46
	 * Ces classes sont ensuites controlées via les fichiers de config.ini.
32
	 * Elle est appelée automatiquement suite à la définition du chemin de l'application via Application::setChemin().
-
 
33
	 */
-
 
34
	private static function initialiser() {
-
 
35
		// Initialiser les arguments des urls
47
	 * Elle est appelée automatiquement suite à la définition du chemin de l'application via Application::setChemin().
36
		self::initialiserUrl();
-
 
37
		// Configuration du gestionnaire d'exception
48
	 */
38
		GestionnaireException::configurer();
49
	private static function initialiserFramework() {
39
		// Configuration du gestionnaire de logs
50
		GestionnaireException::configurer();
-
 
51
		//Log::configurer();		
-
 
52
		self::verifierEtReencoderTableauRequete();
-
 
53
	}
-
 
54
	
-
 
55
	/**
-
 
56
	 * Redéfinit des constantes globales utiles pour le Framework et les applis.
-
 
57
	 */
-
 
58
	private static function definirConstantesGlobales() {
-
 
59
		/** Redéfinition de la constante DIRECTORY_SEPARATOR en version abrégée DS */
-
 
60
		if (!defined('DS')) {
-
 
61
			define('DS', DIRECTORY_SEPARATOR);
-
 
62
		}
-
 
63
		/** Redéfinition de la constante PATH_SEPARATOR en version abrégée PS */
-
 
64
		if (!defined('PS')) {
-
 
65
			define('PS', PATH_SEPARATOR);
-
 
66
		}
-
 
67
	}
-
 
68
	
-
 
69
	private static function enregistrerMethodesAutoload() {
-
 
70
		spl_autoload_register(array(get_class(), 'autoloadFw'));
-
 
71
	
-
 
72
		// Initialisation du gestionnaire d'erreur avant toute chose
-
 
73
		GestionnaireException::initialiser();
-
 
74
		
-
 
75
		spl_autoload_register(array(get_class(), 'autoloadAppliDefaut'));
-
 
76
		
-
 
77
		// Autoload défini par l'application
-
 
78
		if (function_exists('__autoload')) {
-
 
79
			spl_autoload_register('__autoload');
-
 
80
		}
-
 
81
	}
-
 
82
	
-
 
83
	/**
-
 
84
	 * Autoload pour le Framework.
-
 
85
	 */
-
 
86
	private static function autoloadFw($nom_classe_fw) {
-
 
87
		$dossiers_classes = array(	dirname(__FILE__).DS,
-
 
88
									dirname(__FILE__).DS.'utilitaires'.DS);
-
 
89
		foreach ($dossiers_classes as $chemin) {
-
 
90
			$fichier_a_tester = $chemin.$nom_classe_fw.'.php';
-
 
91
			if (file_exists($fichier_a_tester)) {
-
 
92
				include_once $fichier_a_tester;
-
 
93
				return null;
-
 
94
			}
-
 
95
		}
-
 
96
	}
-
 
97
	
-
 
98
	/**
-
 
99
	 * Autoload par défaut pour l'application
-
 
100
	 */
-
 
101
	private static function autoloadAppliDefaut($nom_classe) {
-
 
102
		$dossiers_classes = array(	Config::get('chemin_controleurs'),
-
 
103
									Config::get('chemin_modeles'),
-
 
104
									Config::get('chemin_bibliotheque'));
-
 
105
	
-
 
106
		foreach ($dossiers_classes as $chemin) {
-
 
107
			$fichier_a_tester = $chemin.$nom_classe.'.php';
-
 
108
			if (file_exists($fichier_a_tester)) {
-
 
109
				include_once $fichier_a_tester;
-
 
110
				return null;
40
		//Log::configurer();		
111
			}
41
		self::verifierEtReencoderTableauRequete();
112
		}
42
	}
113
	}
43
 
114
	
44
	/**
115
	/**
45
	 * Initialise le format des urls.
116
	 * Initialise le format des urls.
Line 52... Line 123...
52
	/**
123
	/**
53
	 * Permet d'indiquer le chemin de base de l'Application.
124
	 * Permet d'indiquer le chemin de base de l'Application.
54
	 * Cette méthode doit obligatoirement être utilisée par l'application pour que le Framework fonctionne correctement.
125
	 * Cette méthode doit obligatoirement être utilisée par l'application pour que le Framework fonctionne correctement.
55
	 * @param string $chemin_fichier_principal chemin de base
126
	 * @param string $chemin_fichier_principal chemin de base
56
	 */
127
	 */
57
	public static function setChemin($chemin_fichier_principal) {
128
	public static function setCheminAppli($chemin_fichier_principal) {
58
		if (self::$chemin === null) {
129
		if (self::$chemin === null) {
59
			if (!file_exists($chemin_fichier_principal)) {
130
			if (!file_exists($chemin_fichier_principal)) {
60
				trigger_error("Le fichier indiqué n'existe pas. Utilisez __FILE__ dans la méthode set().", E_USER_ERROR);
131
				trigger_error("Le fichier indiqué n'existe pas. Utilisez __FILE__ dans la méthode setCheminAppli().", E_USER_ERROR);
61
			} else {
132
			} else {
-
 
133
				self::initialiserEnvironnement();
62
				self::$chemin = dirname($chemin_fichier_principal).DS;
134
				self::$chemin = dirname($chemin_fichier_principal).DS;
63
				self::initialiser();
135
				self::initialiserFramework();
64
			}
136
			}
65
		} else {
137
		} else {
66
			trigger_error("Le chemin de l'application a déjà été enregistré auprès du Framework", E_USER_WARNING);
138
			trigger_error("Le chemin de l'application a déjà été enregistré auprès du Framework", E_USER_WARNING);
67
		}
139
		}
68
	}
140
	}
Line 69... Line 141...
69
 
141
 
70
	/**
142
	/**
71
	 * accesseur pour le chemin
143
	 * accesseur pour le chemin
72
	 * @return string le chemin
144
	 * @return string le chemin
73
	 */
145
	 */
74
	public static function getChemin() {
146
	public static function getCheminAppli() {
75
		return self::$chemin;
147
		return self::$chemin;
Line 76... Line 148...
76
	}
148
	}
77
 
149
 
Line 81... Line 153...
81
	 * - encodage : encodage de l'application (ISO-8859-15, UTF-8...)
153
	 * - encodage : encodage de l'application (ISO-8859-15, UTF-8...)
82
	 *
154
	 *
83
	 * @param array $info tableau fournissant des informations sur l'application
155
	 * @param array $info tableau fournissant des informations sur l'application
84
	 * @return void
156
	 * @return void
85
	 */
157
	 */
86
	public static function setInfo($info) {
158
	public static function setInfoAppli($info) {
87
		if (self::$info === null) {
159
		if (self::$info === null) {
88
			self::$info = $info;
160
			self::$info = $info;
89
		} else {
161
		} else {
90
			trigger_error("Le informations de l'application ont déjà été enregistrées auprès du Framework", E_USER_WARNING);
162
			trigger_error("Le informations de l'application ont déjà été enregistrées auprès du Framework", E_USER_WARNING);
91
		}
163
		}
92
	}
164
	}
Line 93... Line 165...
93
 
165
 
94
	/**
166
	/**
95
	 * accesseur pour le tableau d'infos
167
	 * Accesseur pour le tableau d'infos sur l'application.
96
	 * @param string $cle la clé à laquelle on veut accéder
168
	 * @param string $cle la clé à laquelle on veut accéder
97
	 */
169
	 */
98
	public static function getInfo($cle = null) {
170
	public static function getInfoAppli($cle = null) {
99
		if ($cle !== null) {
171
		if ($cle !== null) {
100
			if (isset(self::$info[$cle])) {
172
			if (isset(self::$info[$cle])) {
101
				return self::$info[$cle];
173
				return self::$info[$cle];
102
			}
174
			}
103
		} else {
175
		} else {
104
			return self::$info;
176
			return self::$info;
105
		}
177
		}
Line 106... Line 178...
106
	}
178
	}
107
	
179
	
108
/**
180
	/**
109
	 * Procédure vérifiant l'encodage des tableaux $_GET et $_POST et les transcodant dans l'encodage de l'application
181
	 * Procédure vérifiant l'encodage des tableaux $_GET et $_POST et les transcodant dans l'encodage de l'application
110
	 */
182
	 */
111
	protected static function verifierEtReencoderTableauRequete() {
183
	protected static function verifierEtReencoderTableauRequete() {
112
		if (self::$encodage == false && Config::get('sortie_encodage') != Config::get('appli_encodage')) {
184
		if (self::$encodage == false && Config::get('sortie_encodage') != Config::get('appli_encodage')) {
Line 113... Line 185...
113
			$_POST = self::encoderTableau($_POST, Config::get('appli_encodage'), Config::get('sortie_encodage'));
185
			$_POST = self::encoderTableau($_POST, Config::get('appli_encodage'), Config::get('sortie_encodage'));
114
			$_GET = self::encoderTableau($_GET, Config::get('appli_encodage'), Config::get('sortie_encodage'));
186
			$_GET = self::encoderTableau($_GET, Config::get('appli_encodage'), Config::get('sortie_encodage'));
Line 115... Line 187...
115
			
187
			
116
			// traitement des magic quotes
188
			// Traitement des magic quotes
117
			self::verifierEtTraiterSlashTableauRequete();
189
			self::verifierEtTraiterSlashTableauRequete();
Line 118... Line 190...
118
						
190
						
119
			self::$encodage = true;
191
			self::$encodage = true;
120
		}
192
		}
121
	}
193
	}
122
	
-
 
123
	/**
194
	
124
	 * Procédure vérifiant l'activation des magic quotes et remplacant les slash dans les tableaux de requete
-
 
125
	 */
195
	/**
126
	private static function verifierEtTraiterSlashTableauRequete() {
196
	 * Procédure vérifiant l'activation des magic quotes et remplacant les slash dans les tableaux de requete
127
		
-
 
128
		if ( get_magic_quotes_gpc() ) {
-
 
129
 
197
	 */
130
			if (!function_exists('stripslashes_deep')) {
-
 
131
			    function stripslashes_deep( $value ) {
-
 
132
			
-
 
133
					return ( is_array($value) )
198
	private static function verifierEtTraiterSlashTableauRequete() {
134
					    ? array_map('stripslashes_deep', $value)
-
 
135
					    : stripslashes($value);
-
 
136
			
-
 
137
			    } // end of 'stripslashes_deep()'
199
		if (get_magic_quotes_gpc()) {
-
 
200
			if (!function_exists('nettoyerSlashProfond')) {
-
 
201
				function nettoyerSlashProfond($valeur) {
-
 
202
					return ( is_array($valeur) ) ? array_map('nettoyerSlashProfond', $valeur) : stripslashes($valeur);
138
			
203
				}
139
			    $_GET = array_map('stripslashes_deep', $_GET);
204
			}
Line 140... Line 205...
140
			    $_POST = array_map('stripslashes_deep', $_POST);
205
			$_GET = array_map('nettoyerSlashProfond', $_GET);
141
			    $_COOKIE = array_map('stripslashes_deep', $_COOKIE);
206
			$_POST = array_map('nettoyerSlashProfond', $_POST);