Subversion Repositories eFlore/Applications.eflore-consultation

Rev

Rev 1038 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
1038 aurelien 1
<?php
2
// In : utf8 url_encoded (get et post)
3
// Out : utf8
4
/**
5
 * La classe Widget analyser l'url et chage le widget correspondant.
6
 * Format d'url :
7
 * /widget/nom_du_widget?parametres1=ma_valeur1&parametre2=ma_valeur2
8
 * Les widget sont dans des dossiers en minuscule correspondant au nom de la classe du widget.
9
 * Exemple : /widget/carto avec la classe Carto.php dans le dossier carto.
10
 *
11
 *
12
 * @author jpm
13
 *
14
 */
15
class Widget {
16
 
17
 	/** Les paramètres de configuration extrait du fichier .ini */
18
    private static $config;
19
 
20
	/** Le nom du widget demandé. */
21
	private $widget = null;
22
 
23
	/** Les chemins où l'autoload doit chercher des classes. */
24
	private static $autoload_chemins = array();
25
 
26
	/** Les paramètres de l'url $_GET nettoyés. */
27
	private $parametres = null;
1447 delphine 28
	private $ressources = null;
1038 aurelien 29
 
30
	/**
31
	 * Constructeur.
32
	 * Parse le fichier de configuraion "widget.ini" et parse l'url à la recherche du widget demandé.
33
	 * @param str iniFile Configuration file to use
34
	 */
35
	public function __construct($fichier_ini = 'widget.ini.php') {
36
		// Chargement de la configuration
37
		self::$config = parse_ini_file($fichier_ini, TRUE);
38
 
39
		// Paramêtres de config dynamiques
40
		self::$config['chemins']['baseURLAbsoluDyn'] = 'http://'.$_SERVER['SERVER_NAME'].self::$config['chemins']['baseURL'].'%s';
41
 
42
		// Gestion de la mémoire maximum allouée aux services
43
		ini_set('memory_limit', self::$config['parametres']['limiteMemoire']);
44
 
45
		// Réglages de PHP
46
		setlocale(LC_ALL, self::$config['parametres']['locale']);
47
		date_default_timezone_set(self::$config['parametres']['fuseauHoraire']);
48
 
49
		// Gestion des erreurs
50
		error_reporting(self::$config['parametres']['erreurNiveau']);
51
 
52
		if (isset($_SERVER['REQUEST_URI']) && isset($_SERVER['QUERY_STRING'])) {
53
			$url_morceaux = $this->parserUrl();
54
			if (isset($url_morceaux[0])) {
1447 delphine 55
				$this->widget = array_shift($url_morceaux);
1038 aurelien 56
				self::$config['chemins']['widgetCourantDossier'] = self::$config['chemins']['widgetsDossier'].strtolower($this->widget).DIRECTORY_SEPARATOR;
57
				$this->chargerWidgetConfig();
1447 delphine 58
				if (isset($url_morceaux[0])) $this->ressources = $url_morceaux;
1038 aurelien 59
			}
1447 delphine 60
 
1038 aurelien 61
			// Chargement des chemins pour l'autoload
62
			$this->chargerCheminAutoload();
63
 
64
			// Enregistrement de la méthode gérant l'autoload des classes
65
			spl_autoload_register(array('Widget', 'chargerClasse'));
66
 
67
			// Nettoyage du $_GET (sécurité)
68
			$this->collecterParametres();
69
		} else {
70
			$e = 'Les widget nécessite les variables serveurs suivantes pour fonctionner : REQUEST_URI et QUERY_STRING.';
71
			trigger_error($e, E_USER_ERROR);
72
		}
73
	}
74
 
75
	private function parserUrl() {
76
		if (strlen($_SERVER['QUERY_STRING']) == 0) {
77
			$len = strlen($_SERVER['REQUEST_URI']);
78
		} else {
79
			$len = -(strlen($_SERVER['QUERY_STRING']) + 1);
80
		}
81
		$url = substr($_SERVER['REQUEST_URI'], strlen(self::$config['chemins']['baseURL']), $len);
82
		$url_morceaux = explode('/', $url);
83
		return $url_morceaux;
84
	}
85
 
86
	private function collecterParametres() {
87
		if (isset($_GET) && $_GET != '') {
88
			$this->nettoyerGet();
89
			$this->parametres = $_GET;
90
		}
91
	}
92
 
93
	private function nettoyerGet() {
94
		foreach ($_GET as $cle => $valeur) {
95
			$verifier = array('NULL', "\n", "\r", "\\", '"', "\x00", "\x1a", ';');
96
			$_GET[$cle] = strip_tags(str_replace($verifier, '', $valeur));
97
		}
98
	}
99
 
100
	private function chargerCheminAutoload() {
101
		$chemins_communs = explode(';', self::$config['chemins']['autoload']);
102
		$chemins_communs = array_map('trim', $chemins_communs);
103
		array_unshift($chemins_communs, '');
104
 
105
		$chemins_widget = array();
106
		if (isset(self::$config[$this->widget]['autoload'])) {
107
			$chemins_widget = explode(';', self::$config[$this->widget]['autoload']);
108
			foreach ($chemins_widget as $cle => $chemin) {
109
				$chemins_widget[$cle] = self::$config['chemins']['widgetCourantDossier'].trim($chemin);
110
			}
111
		}
112
 
113
		self::$autoload_chemins = array_merge($chemins_communs, $chemins_widget);
114
	}
115
 
116
	/**
117
	* La méthode chargerClasse() charge dynamiquement les classes trouvées dans le code.
118
	* Cette fonction est appelée par php5 quand il trouve une instanciation de classe dans le code.
119
	*
120
	*@param string le nom de la classe appelée.
121
	*@return void le fichier contenant la classe doit être inclu par la fonction.
122
	*/
123
	public static function chargerClasse($classe) {
124
		if (class_exists($classe)) {
125
			return null;
126
		}
127
		foreach (self::$autoload_chemins as $chemin) {
128
			$chemin = $chemin.$classe.'.php';
129
			if (file_exists($chemin)) {
130
				require_once $chemin;
131
			}
132
		}
133
	}
134
 
135
 
136
	/**
137
	 * Execute le widget.
138
	 */
139
	function executer() {
140
		if (!is_null($this->widget)) {
141
			$classe_widget = ucfirst($this->widget);
142
			$fichier_widget = self::$config['chemins']['widgetCourantDossier'].$classe_widget.'.php';
143
			if (file_exists($fichier_widget))  {
144
				include_once $fichier_widget;
145
				if (class_exists($classe_widget)) {
1447 delphine 146
					$widget = new $classe_widget(self::$config, $this->parametres, $this->ressources);
1038 aurelien 147
					$widget->executer();
148
				}
149
			}
150
		}
151
	}
152
 
153
	/**
154
	 * Charge le fichier de config spécifique du wiget et fusionne la config avec celle partagés par l'ensemble des widgets.
155
	 */
156
	private function chargerWidgetConfig() {
157
		$widget_config_ini_fichier = self::$config['chemins']['widgetCourantDossier'].'config.ini';
158
		if (file_exists($widget_config_ini_fichier))  {
159
			$widget_config = parse_ini_file($widget_config_ini_fichier, TRUE);
160
			self::$config = array_merge(self::$config, $widget_config);
161
		}
162
	}
163
}
164
?>