Subversion Repositories eFlore/Applications.cel

Rev

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

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