Subversion Repositories Applications.framework

Rev

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

Rev 239 Rev 241
1
<?php
1
<?php
2
// declare(encoding='UTF-8');
2
// declare(encoding='UTF-8');
3
/**
3
/**
4
 * Config permet de charger automatiquement les fichiers ini du Framework et de l'application.
4
 * Config permet de charger automatiquement les fichiers ini du Framework et de l'application.
5
 * Elle offre l'accès en lecture seule aux paramètres de config.
5
 * Elle offre l'accès en lecture seule aux paramètres de config.
6
 * C'est une Singleton.
6
 * C'est une Singleton.
7
 * Si vous avez besoin de modifier dynamiquement des paramètres de configuration, utiliser le @see Registe, il est fait pour ça.
7
 * Si vous avez besoin de modifier dynamiquement des paramètres de configuration, utiliser le @see Registe, il est fait pour ça.
8
 * 
8
 * 
9
 * @category	PHP 5.2
9
 * @category	PHP 5.2
10
 * @package		Framework
10
 * @package	Framework
11
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
11
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
12
 * @copyright	Copyright (c) 2009, Tela Botanica (accueil@tela-botanica.org)
12
 * @copyright	Copyright (c) 2009, Tela Botanica (accueil@tela-botanica.org)
13
 * @license		http://www.gnu.org/licenses/gpl.html Licence GNU-GPL-v3
13
 * @license	http://www.gnu.org/licenses/gpl.html Licence GNU-GPL-v3
14
 * @license		http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL-v2 
14
 * @license	http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL-v2 
15
 * @version		SVN : $Id: Config.php 239 2010-11-25 18:04:00Z jpm $
15
 * @version	$Id: Config.php 241 2010-12-06 15:19:07Z jpm $
16
 * @link		/doc/framework/
16
 * @link		/doc/framework/
17
 */
17
 */
18
 
18
 
19
class Config {
19
class Config {
20
 
-
 
21
	/**
20
 
22
	 * instance de la classe pointant sur elle même (pour le pattern singleton)
-
 
23
	 */
21
	/** Instance de la classe pointant sur elle même (pour le pattern singleton). */
24
	private static $instance = null;
-
 
25
 
22
	private static $instance = null;
26
	/**
-
 
27
	 * paramètres de configuration
23
 
28
	 */
-
 
29
	private static $parametres = array();
-
 
30
 
-
 
31
	/**
24
	/** Paramètres de configuration. */
32
	 * Constructeur vide
25
	private static $parametres = array();
33
	 */
26
 
34
	private function __construct() {
27
	private function __construct() {
35
		// Définition de paramètres avant chargement du config.ini
28
		// Définition de paramètres avant chargement du config.ini
36
		self::$parametres = array(
29
		self::$parametres = array(
37
			'fw_fichier_config' => 'config%s.ini',
30
			'fw_fichier_config' => 'config%s.ini',
38
			'fw_chemin' => dirname(__FILE__).DS
31
			'fw_chemin' => dirname(__FILE__).DS
39
			);
32
			);
40
 
33
 
41
		// Chargement du fichier config.ini du Framework
34
		// Chargement du fichier config.ini du Framework
42
		$existe = self::parserFichierIni(self::$parametres['fw_chemin'].sprintf(self::$parametres['fw_fichier_config'], ''));
35
		$existe = self::parserFichierIni(self::$parametres['fw_chemin'].sprintf(self::$parametres['fw_fichier_config'], ''));
43
		if ($existe === false) {
36
		if ($existe === false) {
44
			trigger_error("Veuillez configurer le Framework en renommant le fichier config.defaut.ini en config.ini.", E_USER_ERROR);
37
			trigger_error("Veuillez configurer le Framework en renommant le fichier config.defaut.ini en config.ini.", E_USER_ERROR);
45
		}
38
		}
46
 
39
 
47
		// Chargement du fichier config.ini par défaut de l'application
40
		// Chargement du fichier config.ini par défaut de l'application
48
		$chemin_config_defaut_appli = self::$parametres['chemin_configurations'].sprintf(self::$parametres['fw_fichier_config'], '');
41
		$chemin_config_defaut_appli = self::$parametres['chemin_configurations'].sprintf(self::$parametres['fw_fichier_config'], '');
49
		self::parserFichierIni($chemin_config_defaut_appli);
42
		self::parserFichierIni($chemin_config_defaut_appli);
50
 
43
 
51
		// Chargement des fichiers config.ini contextuels
44
		// Chargement des fichiers config.ini contextuels
52
		if (PHP_SAPI == 'cli') {// mode console
45
		if (PHP_SAPI == 'cli') {// mode console
53
			foreach ($_SERVER['argv'] as $cle => $valeur) {
46
			foreach ($_SERVER['argv'] as $cle => $valeur) {
54
				if ($valeur == '-contexte') {
47
				if ($valeur == '-contexte') {
55
					chargerFichierContexte($_SERVER['argv'][($cle+1)]);
48
					chargerFichierContexte($_SERVER['argv'][($cle+1)]);
56
					break;
49
					break;
57
				}
50
				}
58
			}
51
			}
59
		} else {// mode web
52
		} else {// mode web
60
			// Pour Papyrus
53
			// Pour Papyrus
61
			if (defined('PAP_VERSION')) {
54
			if (defined('PAP_VERSION')) {
62
				self::chargerFichierContexte('papyrus');
55
				self::chargerFichierContexte('papyrus');
63
			}
56
			}
64
			// Via le fichie .ini par défaut de l'appli
57
			// Via le fichie .ini par défaut de l'appli
65
			if (Config::existeValeur('info.contexte', self::$parametres)) {
58
			if (Config::existeValeur('info.contexte', self::$parametres)) {
66
				self::chargerFichierContexte(Config::get('info.contexte'));
59
				self::chargerFichierContexte(Config::get('info.contexte'));
67
			}
60
			}
68
 
61
 
69
			// Chargement du contexte présent dans le GET
62
			// Chargement du contexte présent dans le GET
70
			if (isset($_GET['contexte'])) {
63
			if (isset($_GET['contexte'])) {
71
				$_GET['contexte'] = strip_tags($_GET['contexte']);
64
				$_GET['contexte'] = strip_tags($_GET['contexte']);
72
				self::chargerFichierContexte($_GET['contexte']);
65
				self::chargerFichierContexte($_GET['contexte']);
73
			}
66
			}
74
 
67
 
75
			// Chargement du contexte présent dans le POST
68
			// Chargement du contexte présent dans le POST
76
			if (isset($_POST['contexte'])) {
69
			if (isset($_POST['contexte'])) {
77
				$_POST['contexte'] = strip_tags($_POST['contexte']);
70
				$_POST['contexte'] = strip_tags($_POST['contexte']);
78
				self::chargerFichierContexte($_POST['contexte']);
71
				self::chargerFichierContexte($_POST['contexte']);
79
			}
72
			}
80
		}
73
		}
81
	}
74
	}
82
 
75
 
83
	/**
76
	/**
84
	 * Charge le fichier de config correspondant au contexte
77
	 * Charge le fichier de config correspondant au contexte
85
	 * @param string $contexte le contexte
78
	 * @param string $contexte le contexte
86
	 */
79
	 */
87
	private static function chargerFichierContexte($contexte) {
80
	private static function chargerFichierContexte($contexte) {
88
		$chemin_config_appli_contextuel = self::$parametres['chemin_configurations'];
81
		$chemin_config_appli_contextuel = self::$parametres['chemin_configurations'];
89
		$chemin_config_appli_contextuel .= sprintf(self::$parametres['fw_fichier_config'], '_'.$contexte);
82
		$chemin_config_appli_contextuel .= sprintf(self::$parametres['fw_fichier_config'], '_'.$contexte);
90
		self::parserFichierIni($chemin_config_appli_contextuel);
83
		self::parserFichierIni($chemin_config_appli_contextuel);
91
	}
84
	}
92
 
85
 
93
	/**
86
	/**
94
	 * Parse le fichier ini donné en paramètre
87
	 * Parse le fichier ini donné en paramètre
95
	 * @param string $fichier_ini nom du fichier ini à parser
88
	 * @param string $fichier_ini nom du fichier ini à parser
96
	 * @return array tableau contenant les paramètres du fichier ini
89
	 * @return array tableau contenant les paramètres du fichier ini
97
	 */
90
	 */
98
	private static function parserFichierIni($fichier_ini) {
91
	private static function parserFichierIni($fichier_ini) {
99
		$retour = false;
92
		$retour = false;
100
		if (file_exists($fichier_ini)) {
93
		if (file_exists($fichier_ini)) {
101
			$ini = parse_ini_file($fichier_ini, true);
94
			$ini = parse_ini_file($fichier_ini, true);
102
			$ini = self::analyserTableauIni($ini);
95
			$ini = self::analyserTableauIni($ini);
103
			self::fusionner($ini);
96
			self::fusionner($ini);
104
			$retour = true;
97
			$retour = true;
105
		}
98
		}
106
		return $retour;
99
		return $retour;
107
	}
100
	}
108
 
101
 
109
	/**
102
	/**
110
	 * fusionne un tableau de paramètres avec le tableau de paramètres global
103
	 * Fusionne un tableau de paramètres avec le tableau de paramètres global
111
	 * @param array $ini le tableau à fusionner
104
	 * @param array $ini le tableau à fusionner
112
	 */
105
	 */
113
	private static function fusionner(array $ini) {
106
	private static function fusionner(array $ini) {
114
		self::$parametres = array_merge(self::$parametres, $ini);
107
		self::$parametres = array_merge(self::$parametres, $ini);
115
	}
108
	}
116
 
109
 
117
	/**
110
	/**
118
	 * renvoie la valeur demandé grâce une chaine de paramètres
111
	 * Renvoie la valeur demandée grâce une chaîne de paramètres
119
	 * @param string $param la chaine de paramètres
112
	 * @param string $param la chaine de paramètres
120
	 * @param array $config le tableau de paramètre
113
	 * @param array $config le tableau de paramètre
121
	 * @return string la valeur de la chaine demandée
114
	 * @return string la valeur de la chaine demandée
122
	 */
115
	 */
123
	private static function getValeur($param, $config) {
116
	private static function getValeur($param, $config) {
124
		if ($param === null) {
117
		if ($param === null) {
125
			return null;
118
			return null;
126
		} else {
119
		} else {
127
			if (isset($config[$param])) {
120
			if (isset($config[$param])) {
128
				return $config[$param];
121
				return $config[$param];
129
			} else if (strpos($param, '.') !== false) {
122
			} else if (strpos($param, '.') !== false) {
130
				$pieces = explode('.', $param, 2);
123
				$pieces = explode('.', $param, 2);
131
				if (strlen($pieces[0]) && strlen($pieces[1])) {
124
				if (strlen($pieces[0]) && strlen($pieces[1])) {
132
					if (isset($config[$pieces[0]])) {
125
					if (isset($config[$pieces[0]])) {
133
					   if (is_array($config[$pieces[0]])) {
126
					   if (is_array($config[$pieces[0]])) {
134
					   		return self::getValeur($pieces[1], $config[$pieces[0]]);
127
					   		return self::getValeur($pieces[1], $config[$pieces[0]]);
135
					   }
128
					   }
136
					}
129
					}
137
				}
130
				}
138
			} else {
131
			} else {
139
				return null;
132
				return null;
140
			}
133
			}
141
		}
134
		}
142
	}
135
	}
143
 
136
 
144
	/**
137
	/**
145
	 * Teste si param existe dans le tableau config
138
	 * Teste si param existe dans le tableau config
146
	 * @param string $param nom du paramètre
139
	 * @param string $param nom du paramètre
147
	 * @param array tableau de configuration
140
	 * @param array tableau de configuration
148
	 */
141
	 */
149
	private static function existeValeur($param, $config) {
142
	private static function existeValeur($param, $config) {
150
		$retour = false;
143
		$retour = false;
151
		if (self::getValeur($param, $config) !== null) {
144
		if (self::getValeur($param, $config) !== null) {
152
			$retour = true;
145
			$retour = true;
153
		}
146
		}
154
		return $retour;
147
		return $retour;
155
	}
148
	}
156
 
149
 
157
	/**
150
	/**
158
	 * Vérifie si l'instance de classe à été crée, si non la crée
151
	 * Vérifie si l'instance de classe à été crée, si non la crée
159
	 */
152
	 */
160
	private static function verifierCreationInstance() {
153
	private static function verifierCreationInstance() {
161
		if (empty(self::$instance)) {
154
		if (empty(self::$instance)) {
162
			self::$instance = new Config();
155
			self::$instance = new Config();
163
		}
156
		}
164
	}
157
	}
165
 
158
 
166
	/**
159
	/**
167
	 * analyse un tableau de paramètres
160
	 * Analyse un tableau de paramètres.
168
	 * @param array $config le tableau de paramètres
161
	 * @param array $config le tableau de paramètres
169
	 * @return array le tableau analysé
162
	 * @return array le tableau analysé
170
	 */
163
	 */
171
	private static function analyserTableauIni($config = array()) {
164
	private static function analyserTableauIni($config = array()) {
172
		foreach ($config as $cle => &$valeur) {
165
		foreach ($config as $cle => &$valeur) {
173
			if (is_array($valeur)) {
166
			if (is_array($valeur)) {
174
				$config[$cle] = self::analyserTableauIni($valeur);
167
				$config[$cle] = self::analyserTableauIni($valeur);
175
			} else {
168
			} else {
176
				self::evaluerReferences($config, $cle);
169
				self::evaluerReferences($config, $cle);
177
				self::evaluerPhp($config, $cle);
170
				self::evaluerPhp($config, $cle);
178
				self::evaluerCle($config, $cle, $config[$cle]);
171
				self::evaluerCle($config, $cle, $config[$cle]);
179
			}
172
			}
180
		}
173
		}
181
		return $config;
174
		return $config;
182
	}
175
	}
183
 
176
 
184
	/**
177
	/**
185
	 * dans le cas des chaine de configuration à sous clé (ex.: cle.souscle)
178
	 * Dans le cas des chaine de configuration à sous clé (ex.: cle.souscle)
186
	 * evalue les valeurs correspondantes et crée les sous tableaux associés
179
	 * évalue les valeurs correspondantes et crée les sous tableaux associés.
187
	 * @param array $config tableau de configuration (par référence)
180
	 * @param array $config tableau de configuration (par référence)
188
	 * @param string $cle la cle dans le tableau
181
	 * @param string $cle la cle dans le tableau
189
	 * @param string $valeur la valeur à affecter
182
	 * @param string $valeur la valeur à affecter
190
	 */
183
	 */
191
	private static function evaluerCle(&$config, $cle, $valeur) {
184
	private static function evaluerCle(&$config, $cle, $valeur) {
192
		if (strpos($cle, '.') !== false) {
185
		if (strpos($cle, '.') !== false) {
193
			unset($config[$cle]);
186
			unset($config[$cle]);
194
			$pieces = explode('.', $cle, 2);
187
			$pieces = explode('.', $cle, 2);
195
			if (strlen($pieces[0]) && strlen($pieces[1])) {
188
			if (strlen($pieces[0]) && strlen($pieces[1])) {
196
				if (isset($config[$pieces[0]]) && !is_array($config[$pieces[0]])) {
189
				if (isset($config[$pieces[0]]) && !is_array($config[$pieces[0]])) {
197
					$m = "Ne peut pas créer de sous-clé pour '{$pieces[0]}' car la clé existe déjà";
190
					$m = "Ne peut pas créer de sous-clé pour '{$pieces[0]}' car la clé existe déjà";
198
					trigger_error($m, E_USER_WARNING);
191
					trigger_error($m, E_USER_WARNING);
199
				} else {
192
				} else {
200
					$config[$pieces[0]][$pieces[1]] = $valeur;
193
					$config[$pieces[0]][$pieces[1]] = $valeur;
201
					$config[$pieces[0]] = self::evaluerCle($config[$pieces[0]], $pieces[1], $valeur);
194
					$config[$pieces[0]] = self::evaluerCle($config[$pieces[0]], $pieces[1], $valeur);
202
				}
195
				}
203
			} else {
196
			} else {
204
				$m = "Clé invalide '$cle'";
197
				$m = "Clé invalide '$cle'";
205
				trigger_error($m, E_USER_WARNING);
198
				trigger_error($m, E_USER_WARNING);
206
			}
199
			}
207
		} else {
200
		} else {
208
			$config[$cle] = $valeur;
201
			$config[$cle] = $valeur;
209
		}
202
		}
210
		return $config;
203
		return $config;
211
	}
204
	}
212
 
205
 
213
	/**
206
	/**
214
	 * Evalue les valeurs de références à une clé dans le tableau config (cas du ref:cle)
207
	 * Évalue les valeurs de références à une clé dans le tableau config (cas du ref:cle).
215
	 * @param array $config tableau de configuration
208
	 * @param array $config tableau de configuration
216
	 * @param string $cle la clé dont il faut évaluer les références
209
	 * @param string $cle la clé dont il faut évaluer les références
217
	 */
210
	 */
218
	private static function evaluerReferences(&$config, $cle) {
211
	private static function evaluerReferences(&$config, $cle) {
219
		if (preg_match_all('/{ref:([A-Za-z0-9_.-]+)}/', $config[$cle], $correspondances,  PREG_SET_ORDER)) {
212
		if (preg_match_all('/{ref:([A-Za-z0-9_.-]+)}/', $config[$cle], $correspondances,  PREG_SET_ORDER)) {
220
			foreach ($correspondances as $ref) {
213
			foreach ($correspondances as $ref) {
221
				$config[$cle] = str_replace($ref[0], self::getValeur($ref[1], $config), $config[$cle]);
214
				$config[$cle] = str_replace($ref[0], self::getValeur($ref[1], $config), $config[$cle]);
222
			}
215
			}
223
		}
216
		}
224
	}
217
	}
225
 
218
 
226
	/**
219
	/**
227
	 * Evalue le code php contenu dans un clé tu tableau config
220
	 * Évalue le code php contenu dans un clé tu tableau config.
228
	 * @param array $config tableau de configuration (par référence)
221
	 * @param array $config tableau de configuration (par référence)
229
	 * @param string $cle le clé du tableau dont il faut évaluer la valeur
222
	 * @param string $cle le clé du tableau dont il faut évaluer la valeur
230
	 */
223
	 */
231
	private static function evaluerPhp(&$config, $cle) {
224
	private static function evaluerPhp(&$config, $cle) {
232
		if (preg_match('/^php:(.+)$/', $config[$cle], $correspondances)) {
225
		if (preg_match('/^php:(.+)$/', $config[$cle], $correspondances)) {
233
			eval('$config["'.$cle.'"] = '.$correspondances[1].';');
226
			eval('$config["'.$cle.'"] = '.$correspondances[1].';');
234
		}
227
		}
235
	}
228
	}
236
 
229
 
237
	/**
230
	/**
238
	 * Charge un fichier ini dans le tableau des paramètres de l'appli
231
	 * Charge un fichier ini dans le tableau des paramètres de l'appli.
239
	 * @param string $fichier_ini le nom du fichier à charger
232
	 * @param string $fichier_ini le nom du fichier à charger
240
	 * @return array le fichier ini parsé
233
	 * @return array le fichier ini parsé
241
	 */
234
	 */
242
	public static function charger($fichier_ini) {
235
	public static function charger($fichier_ini) {
243
		self::verifierCreationInstance();
236
		self::verifierCreationInstance();
244
		return self::parserFichierIni($fichier_ini);
237
		return self::parserFichierIni($fichier_ini);
245
	}
238
	}
246
 
239
 
247
	/**
240
	/**
248
	 * Acesseur pour la valeur d'un paramètre
241
	 * Accesseur pour la valeur d'un paramètre.
249
	 * @param string $param le nom du paramètre
242
	 * @param string $param le nom du paramètre
250
	 * @return string la valeur du paramètre
243
	 * @return string la valeur du paramètre
251
	 */
244
	 */
252
	public static function get($param = null) {
245
	public static function get($param = null) {
253
		self::verifierCreationInstance();
246
		self::verifierCreationInstance();
254
		return self::getValeur($param, self::$parametres);
247
		return self::getValeur($param, self::$parametres);
255
	}
248
	}
256
 
249
 
257
	/**
250
	/**
258
	 * Vérifie si la valeur d'un paramètre existe
251
	 * Vérifie si la valeur d'un paramètre existe.
259
	 * @param string $param le nom du paramètre
252
	 * @param string $param le nom du paramètre
260
	 * @return boolean vrai si le paramètre existe, false sinon
253
	 * @return boolean vrai si le paramètre existe, false sinon
261
	 */
254
	 */
262
	public static function existe($param) {
255
	public static function existe($param) {
263
		self::verifierCreationInstance();
256
		self::verifierCreationInstance();
264
		return self::existeValeur($param, self::$parametres);
257
		return self::existeValeur($param, self::$parametres);
265
	}
258
	}
-
 
259
	
-
 
260
	/**
-
 
261
	 * Vérifie que tous les paramêtres de config nécessaires au fonctionnement d'une classe existe dans les fichiers
-
 
262
	 * de configurations.
-
 
263
	 * L'utilisation de cette méthode depuis la classe Config évite de faire appel à une classe supplémentaire.
-
 
264
	 * 
-
 
265
	 * @param array $parametres tableau des noms des paramètres de la config à verifier.
-
 
266
	 * @return boolean true si tous les paramétres sont présents sinon false.
-
 
267
	 */
-
 
268
	public static function verifierPresenceParametres(Array $parametres) {
-
 
269
		$ok = true;
-
 
270
		foreach ($parametres as $param) {
-
 
271
			if (is_null(self::get($param))) {
-
 
272
				$classe = get_class();
-
 
273
				$m = "L'utilisation de la classe $classe nécessite de définir '$param' dans un fichier de configuration.";
-
 
274
				trigger_error($m, E_USER_ERROR);
-
 
275
				$ok = false;
-
 
276
			}
-
 
277
		}
-
 
278
		return $ok;
-
 
279
	}
266
}
280
}
267
?>
281
?>