Subversion Repositories Applications.framework

Rev

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

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