Subversion Repositories Applications.framework

Rev

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

Rev 199 Rev 206
Line 7... Line 7...
7
 * @package		Framework
7
 * @package		Framework
8
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
8
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
9
 * @copyright	Copyright (c) 2009, Tela Botanica (accueil@tela-botanica.org)
9
 * @copyright	Copyright (c) 2009, Tela Botanica (accueil@tela-botanica.org)
10
 * @license		http://www.gnu.org/licenses/gpl.html Licence GNU-GPL-v3
10
 * @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
11
 * @license		http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL-v2
12
 * @version		SVN : $Id: Application.php 199 2010-07-05 14:33:04Z jpm $
12
 * @version		SVN : $Id: Application.php 206 2010-10-18 14:05:20Z aurelien $
13
 * @link		/doc/framework/
13
 * @link		/doc/framework/
14
 */
14
 */
15
class Application {
15
class Application {
Line -... Line 16...
-
 
16
 
-
 
17
	/** Variable statique indiquant que les tableaux _GET et _POST ont déjà été encodé au format de l'appli. */
-
 
18
	private static $encodage = false;
16
 
19
	
17
	/**
20
	/**
18
	 * Tableau d'informations sur l'application
21
	 * Tableau d'informations sur l'application
19
	 */
22
	 */
20
	private static $info = null;
23
	private static $info = null;
Line 32... Line 35...
32
		// Initialiser les arguments des urls
35
		// Initialiser les arguments des urls
33
		self::initialiserUrl();
36
		self::initialiserUrl();
34
		// Configuration du gestionnaire d'exception
37
		// Configuration du gestionnaire d'exception
35
		GestionnaireException::configurer();
38
		GestionnaireException::configurer();
36
		// Configuration du gestionnaire de logs
39
		// Configuration du gestionnaire de logs
37
		//Log::configurer();
40
		//Log::configurer();		
-
 
41
		self::verifierEtReencoderTableauRequete();
38
	}
42
	}
Line 39... Line 43...
39
 
43
 
40
	/**
44
	/**
41
	 * Initialise le format des urls.
45
	 * Initialise le format des urls.
Line 98... Line 102...
98
			}
102
			}
99
		} else {
103
		} else {
100
			return self::$info;
104
			return self::$info;
101
		}
105
		}
102
	}
106
	}
-
 
107
	
-
 
108
/**
-
 
109
	 * Procédure vérifiant l'encodage des tableaux $_GET et $_POST et les transcodant dans l'encodage de l'application
-
 
110
	 */
-
 
111
	protected static function verifierEtReencoderTableauRequete() {
-
 
112
		if (self::$encodage == false && Config::get('sortie_encodage') != Config::get('appli_encodage')) {
-
 
113
			$_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'));
-
 
115
			
-
 
116
			// traitement des magic quotes
-
 
117
			self::verifierEtTraiterSlashTableauRequete();
-
 
118
						
-
 
119
			self::$encodage = true;
-
 
120
		}
-
 
121
	}
-
 
122
	
-
 
123
	/**
-
 
124
	 * Procédure vérifiant l'activation des magic quotes et remplacant les slash dans les tableaux de requete
-
 
125
	 */
-
 
126
	private static function verifierEtTraiterSlashTableauRequete() {
-
 
127
		
-
 
128
		if ( get_magic_quotes_gpc() ) {
-
 
129
 
-
 
130
			if (!function_exists('stripslashes_deep')) {
-
 
131
			    function stripslashes_deep( $value ) {
-
 
132
			
-
 
133
					return ( is_array($value) )
-
 
134
					    ? array_map('stripslashes_deep', $value)
-
 
135
					    : stripslashes($value);
-
 
136
			
-
 
137
			    } // end of 'stripslashes_deep()'
-
 
138
			
-
 
139
			    $_GET = array_map('stripslashes_deep', $_GET);
-
 
140
			    $_POST = array_map('stripslashes_deep', $_POST);
-
 
141
			    $_COOKIE = array_map('stripslashes_deep', $_COOKIE);
-
 
142
			}
-
 
143
		}
-
 
144
	}
-
 
145
 
-
 
146
	/**
-
 
147
	 * Fonction récursive transcodant toutes les valeurs d'un tableau de leur encodage d'entrée vers un encodage de sortie donné
-
 
148
	 * @param $tableau Array Un tableau de données à encoder
-
 
149
	 * @param $encodage_sortie String l'encodage vers lequel on doit transcoder
-
 
150
	 * @param $encodage_entree String l'encodage original des chaines du tableau (optionnel)
-
 
151
	 * @return Array Le tableau encodé dans l'encodage de sortie
-
 
152
	 *
-
 
153
	 */
-
 
154
	final static protected function encoderTableau($tableau, $encodage_sortie, $encodage_entree = null) {
-
 
155
		if (is_array($tableau)) {
-
 
156
			foreach ($tableau as $cle => $valeur) {
-
 
157
				if (is_array($valeur)) {
-
 
158
				 	$tableau[$cle] = self::encoderTableau($valeur, $encodage_sortie, $encodage_entree);
-
 
159
				} else {
-
 
160
					$tableau[$cle] = mb_convert_encoding($valeur, $encodage_sortie, $encodage_entree);
-
 
161
				}
-
 
162
			}
-
 
163
		}
-
 
164
		return $tableau;
-
 
165
	}
103
}
166
}
104
167