Subversion Repositories eFlore/Applications.cel

Rev

Rev 510 | Rev 576 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
420 jpm 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 paramètres de l'url $_GET nettoyés. */
24
	private $parametres = null;
25
 
26
	/**
27
	 * Constructeur.
28
	 * Parse le fichier de configuraion "widget.ini" et parse l'url à la recherche du widget demandé.
29
	 * @param str iniFile Configuration file to use
30
	 */
31
	public function __construct($fichier_ini = 'widget.ini.php') {
32
		// Chargement de la configuration
33
		self::$config = parse_ini_file($fichier_ini, TRUE);
34
 
424 jpm 35
		// Paramêtres de config dynamiques
36
		self::$config['chemins']['baseURLAbsoluDyn'] = 'http://'.$_SERVER['SERVER_NAME'].self::$config['chemins']['baseURL'].'%s';
37
 
420 jpm 38
		// Gestion de la mémoire maximum allouée aux services
39
		ini_set('memory_limit', self::$config['parametres']['limiteMemoire']);
40
 
424 jpm 41
		// Réglages de PHP
42
		setlocale(LC_ALL, self::$config['parametres']['locale']);
43
		date_default_timezone_set(self::$config['parametres']['fuseauHoraire']);
44
 
420 jpm 45
		// Gestion des erreurs
46
		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
 
51
		if (isset($_SERVER['REQUEST_URI']) && isset($_SERVER['QUERY_STRING'])) {
52
			$url_morceaux = $this->parserUrl();
53
			if (isset($url_morceaux[0])) {
54
				$this->widget = $url_morceaux[0];
55
			}
56
 
57
			// Nettoyage du $_GET (sécurité)
58
			$this->collecterParametres();
59
		} else {
60
			$e = 'Les widget nécessite les variables serveurs suivantes pour fonctionner : REQUEST_URI et QUERY_STRING.';
61
			trigger_error($e, E_USER_ERROR);
62
		}
63
	}
64
 
65
	private function parserUrl() {
66
		if (strlen($_SERVER['QUERY_STRING']) == 0) {
67
			$len = strlen($_SERVER['REQUEST_URI']);
68
		} else {
69
			$len = -(strlen($_SERVER['QUERY_STRING']) + 1);
70
		}
424 jpm 71
		$url = substr($_SERVER['REQUEST_URI'], strlen(self::$config['chemins']['baseURL']), $len);
420 jpm 72
		$url_morceaux = explode('/', $url);
73
		return $url_morceaux;
74
	}
75
 
76
	private function collecterParametres() {
77
		if (isset($_GET) && $_GET != '') {
78
			$this->nettoyerGet();
79
			$this->parametres = $_GET;
80
		}
81
	}
82
 
83
	private function nettoyerGet() {
84
		foreach ($_GET as $cle => $valeur) {
85
			$verifier = array('NULL', "\n", "\r", "\\", "'", '"', "\x00", "\x1a", ';');
86
			$_GET[$cle] = strip_tags(str_replace($verifier, '', $valeur));
87
		}
88
	}
89
 
90
	/**
542 jpm 91
	* La méthode chargerClasse() charge dynamiquement les classes trouvées dans le code.
420 jpm 92
	* Cette fonction est appelée par php5 quand il trouve une instanciation de classe dans le code.
93
	*
94
	*@param string le nom de la classe appelée.
95
	*@return void le fichier contenant la classe doit être inclu par la fonction.
96
	*/
97
	public static function chargerClasse($classe) {
98
		if (class_exists($classe)) {
99
			return null;
100
		}
101
 
424 jpm 102
		$chemins = array('', self::$config['chemins']['bibliothequeDossier']);
420 jpm 103
		foreach ($chemins as $chemin) {
104
			$chemin = $chemin.$classe.'.php';
105
			if (file_exists($chemin)) {
106
				require_once $chemin;
107
			}
108
		}
109
	}
110
 
111
 
112
	/**
542 jpm 113
	 * Execute le widget.
420 jpm 114
	 */
115
	function executer() {
116
		if (!is_null($this->widget)) {
117
			$classe_widget = ucfirst($this->widget);
510 jpm 118
			self::$config['chemins']['widgetCourantDossier'] = self::$config['chemins']['widgetsDossier'].strtolower($this->widget).DIRECTORY_SEPARATOR;
119
 
120
			$fichier_widget = self::$config['chemins']['widgetCourantDossier'].$classe_widget.'.php';
420 jpm 121
			if (file_exists($fichier_widget))  {
542 jpm 122
				$this->chargerWidgetConfig();
123
 
420 jpm 124
				include_once $fichier_widget;
125
				if (class_exists($classe_widget)) {
126
					$widget = new $classe_widget(self::$config, $this->parametres);
127
					$widget->executer();
128
				}
129
			}
130
		}
131
	}
542 jpm 132
 
133
	/**
134
	 * Charge le fichier de config spécifique du wiget et fusionne la config avec celle partagés par l'ensemble des widgets.
135
	 */
136
	private function chargerWidgetConfig() {
137
		$widget_config_ini_fichier = self::$config['chemins']['widgetCourantDossier'].DIRECTORY_SEPARATOR.'config.ini';
138
		if (file_exists($widget_config_ini_fichier))  {
139
			$widget_config = parse_ini_file($widget_config_ini_fichier, TRUE);
140
			self::$config = array_merge(self::$config, $widget_config);
141
		}
142
	}
420 jpm 143
}
144
?>