Subversion Repositories eFlore/Applications.cel

Rev

Go to most recent revision | Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
424 jpm 1
<?php
575 jpm 2
// declare(encoding='UTF-8');
424 jpm 3
/**
4
 * Service fournissant une carte dynamique des obsertions publiques du CEL.
5
 * Encodage en entrée : utf8
6
 * Encodage en sortie : utf8
7
 *
575 jpm 8
 * Cas d'utilisation et documentation :
9
 * @link http://www.tela-botanica.org/wikini/eflore/wakka.php?wiki=AideCELWidgetCarto
424 jpm 10
 *
575 jpm 11
 * Paramètres :
12
 * ===> utilisateur = identifiant
13
 * Affiche seulement les observations d'un utilisateur donné. L'identifiant correspond au courriel de
14
 * l'utilisateur avec lequel il s'est inscrit sur Tela Botanica.
15
 * ===> dept = code_du_département
16
 * Affiche seulement les observations pour le département français métropolitain indiqué. Les codes de département utilisables
17
 * sont : 01 à 19, 2A, 2B et 21 à 95.
18
 * ===> projet = mot-clé
19
 * Affiche seulement les observations pour le projet d'observations indiqué. Dans l'interface du CEL, vous pouvez taguer vos
20
 * observations avec un mot-clé de projet. Si vous voulez regrouper des observations de plusieurs utilisateurs, communiquez un
21
 * mot-clé de projet à vos amis et visualisez les informations ainsi regroupées.
22
 * ===> num_taxon = num_taxon
23
 * Affiche seulement les observations pour la plante indiquée. Le num_taxon correspond au numéro taxonomique de la plante.
24
 * Ce numéro est disponible dans les fiches d'eFlore. Par exemple, pour "Poa bulbosa L." le numéro taxonomique vaut 7080.
25
 *
26
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
27
 * @license	GPL v3 <http://www.gnu.org/licenses/gpl.txt>
28
 * @license	CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
29
 * @version	$Id$
30
 * @copyright	Copyright (c) 2010, Tela Botanica (accueil@tela-botanica.org)
424 jpm 31
 */
32
class Carto extends WidgetCommun {
464 delphine 33
	const DS = DIRECTORY_SEPARATOR;
836 jpm 34
	const SERVICE_CARTO_NOM = 'CelWidgetMap';
35
	const SERVICE_CARTO_ACTION_DEFAUT = 'carte-defaut';
424 jpm 36
 
836 jpm 37
	private $carte = null;
38
	private $utilisateur = null;
39
	private $projet = null;
40
	private $dept = null;
41
	private $num_taxon = null;
42
	private $station = null;
43
	private $format = null;// Format des obs pour les stations (tableau/liste)
44
 
424 jpm 45
	/**
575 jpm 46
	 * Méthode appelée par défaut pour charger ce widget.
424 jpm 47
	 */
48
	public function executer() {
49
		$retour = null;
836 jpm 50
		$this->extraireParametres();
424 jpm 51
 
836 jpm 52
		$methode = $this->traiterNomMethodeExecuter($this->carte);
471 jpm 53
		if (method_exists($this, $methode)) {
54
			$retour = $this->$methode();
424 jpm 55
		} else {
471 jpm 56
			$this->messages[] = "Ce type de service '$methode' n'est pas disponible.";
424 jpm 57
		}
58
 
59
		if (is_null($retour)) {
60
			$info = 'Un problème est survenu : '.print_r($this->messages, true);
61
			$this->envoyer($info);
62
		} else {
543 jpm 63
			$squelette = dirname(__FILE__).self::DS.'squelettes'.self::DS.$retour['squelette'].'.tpl.html';
424 jpm 64
			$html = $this->traiterSquelettePhp($squelette, $retour['donnees']);
65
			$this->envoyer($html);
66
		}
67
	}
836 jpm 68
 
69
	public function extraireParametres() {
70
		extract($this->parametres);
71
		$this->carte = (isset($carte) ? $carte : self::SERVICE_CARTO_ACTION_DEFAUT);
72
		$this->utilisateur = (isset($utilisateur) ? $utilisateur : '*');
73
		$this->projet = (isset($projet) ? $projet : '*');
74
		$this->dept = (isset($dept) ? $dept : '*');
837 jpm 75
		$this->commune = (isset($commune) ? $commune : '*');
836 jpm 76
		$this->num_taxon = (isset($num_taxon) ? $num_taxon : '*');
77
		$this->station = (isset($station) ? $station : null);
78
		$this->format = (isset($format) ? $format : null);
79
	}
424 jpm 80
 
81
	/**
82
	 * Carte par défaut
83
	 */
84
	public function executerCarteDefaut() {
85
		$widget = null;
836 jpm 86
		$url_json = $this->contruireUrlServiceCarto('carte-defaut-json');
424 jpm 87
		$url_base = sprintf($this->config['chemins']['baseURLAbsoluDyn'], '');
88
 
89
		// Création des infos du widget
836 jpm 90
		$widget['donnees']['url_cel_carto'] = $this->contruireUrlServiceCarto();
424 jpm 91
		$widget['donnees']['url_json'] = $url_json;
92
		$widget['donnees']['url_base'] = $url_base;
836 jpm 93
		$widget['donnees']['utilisateur'] = $this->utilisateur;
94
		$widget['donnees']['projet'] = $this->projet;
95
		$widget['donnees']['dept'] = $this->dept;
837 jpm 96
		$widget['donnees']['commune'] = $this->commune;
836 jpm 97
		$widget['donnees']['num_taxon'] = $this->num_taxon;
490 jpm 98
		$widget['donnees']['taxons'] = $this->chargerTaxons();
836 jpm 99
		if ($this->num_taxon != '*') {
559 jpm 100
			$taxon_courrant = current($widget['donnees']['taxons']);
101
			$widget['donnees']['taxon_nom'] = $taxon_courrant['nom'];
102
		}
424 jpm 103
		$widget['squelette'] = 'carte_defaut';
464 delphine 104
 
836 jpm 105
		if (isset($this->dept)) {
464 delphine 106
			// si on veut afficher les limites départemmentales on va compter et chercher les noms de fichiers
836 jpm 107
			$fichiersKml = $this->chercherFichierKml();
108
			$urls = null;
599 jpm 109
			foreach ($fichiersKml as $kml => $dossier){
574 jpm 110
				$url_limites_communales = sprintf($this->config['carto']['limitesCommunaleUrlTpl'], $dossier, $kml);
836 jpm 111
				$urls[] = $url_limites_communales;
464 delphine 112
			}
836 jpm 113
			$widget['donnees']['url_limites_communales'] = json_encode($urls);
464 delphine 114
		}
465 delphine 115
 
424 jpm 116
		return $widget;
117
	}
464 delphine 118
 
836 jpm 119
	private function contruireUrlServiceCarto($action = null) {
120
		// Création url données json
121
		$url = sprintf($this->config['chemins']['baseURLServicesCelTpl'], self::SERVICE_CARTO_NOM);
122
		if ($action) {
123
			$url .= "/$action";
124
 
125
			$parametres_retenus = array();
837 jpm 126
			$parametres_a_tester = array('station', 'utilisateur', 'projet', 'dept', 'commune', 'num_taxon');
836 jpm 127
			foreach ($parametres_a_tester as $param) {
128
				if ($this->$param != null && $this->$param != '*') {
129
					$parametres_retenus[$param] = $this->$param;
130
				}
131
			}
132
			if (count($parametres_retenus) > 0) {
133
				$parametres_url = array();
134
				foreach ($parametres_retenus as $cle => $valeur) {
135
					$parametres_url[] = $cle.'='.$valeur;
136
				}
137
				$url .= '?'.implode('&', $parametres_url);
138
			}
139
		}
140
		$this->debug[] = $url;
141
		// Prendre en compte param "station"
142
		return $url;
143
	}
144
 
490 jpm 145
	private function chargerTaxons() {
146
		// Récupération des données au format Json
836 jpm 147
		$url = $this->contruireUrlServiceCarto('taxons');
698 jpm 148
		$json = $this->getDao()->consulter($url);
490 jpm 149
		$donnees = json_decode($json);
150
 
151
		// Post-traitement des données
152
		$taxons = $this->traiterTaxons($donnees);
153
 
154
		return $taxons;
155
	}
156
 
157
	private function traiterTaxons($donnees) {
158
		$taxons = array();
159
		if (is_array($donnees) && count($donnees) > 0) {
160
			foreach ($donnees as $donnee) {
534 jpm 161
				if (!isset($taxons[$donnee->num_taxon]) && ! $this->etreVide($donnee->nom_ret)) {
490 jpm 162
					$taxon = array();
163
					$taxon['nn'] = $donnee->num_nom_ret;
164
					$taxon['nt'] = $donnee->num_taxon;
165
					$taxon['nom'] = $this->nettoyerTexte($donnee->nom_ret);
166
					$taxon['famille'] = $this->nettoyerTexte($donnee->famille);
167
					$taxons[$donnee->num_taxon] = $taxon;
168
				}
169
			}
170
		}
171
		return $taxons;
172
	}
173
 
836 jpm 174
	private function chercherFichierKml(){
574 jpm 175
		$chemins = explode(',', $this->config['carto']['communesKmzChemin']);
836 jpm 176
		$departements = explode(',', $this->dept);// plrs code de départements peuvent être demandés séparés par des virgules
599 jpm 177
		$departements_trouves = array();
178
		$fichiers = array();
574 jpm 179
		foreach ($chemins as $dossier_chemin) {
180
			if ($dossier_ressource = opendir($dossier_chemin)) {
181
				while ($element = readdir($dossier_ressource)) {
182
					if ($element != '.' && $element != '..') {
599 jpm 183
						foreach ($departements as $departement) {
184
							$nom_dossier = basename($dossier_chemin);
185
							if (!isset($departements_trouves[$departement]) || $departements_trouves[$departement] == $nom_dossier) {
186
								$dept_protege = preg_quote($departement);
187
								if (!is_dir($dossier_chemin.'/'.$element) && preg_match("/^$dept_protege(?:_[0-9]+|)\.km[lz]$/", $element)) {
188
									$fichiers[$element] = $nom_dossier;
189
									$departements_trouves[$departement] = $nom_dossier;
190
								}
191
							}
574 jpm 192
						}
543 jpm 193
					}
464 delphine 194
				}
574 jpm 195
				closedir($dossier_ressource);
464 delphine 196
			}
197
		}
599 jpm 198
 
574 jpm 199
		return $fichiers;
471 jpm 200
	}
201
 
202
	/**
203
	 * Tableau des observations d'une station
204
	 */
205
	public function executerObservations() {
206
		$widget = null;
837 jpm 207
		$observations = $this->chargerObservations();
208
		$nbre_obs = $this->chargerObservationsNbre();
475 jpm 209
 
471 jpm 210
		// Création des infos du widget
475 jpm 211
		if (isset($observations['commune'])) {
212
			$commune = $observations['commune'];
213
			unset($observations['commune']);
214
			$widget['donnees']['commune'] = $commune;
215
		}
547 jpm 216
 
217
		$obs_ids = null;
218
		if (isset($observations['ids'])) {
219
			$obs_ids = $observations['ids'];
220
			unset($observations['ids']);
221
		}
222
		$widget['squelette'] = $this->choisirFormatSortie(count($observations));
223
 
224
		if ($widget['squelette'] == 'obs_liste' && $obs_ids != null && count($obs_ids) > 0) {
225
			$widget['donnees']['images'] = $this->chargerImages($obs_ids);
226
		}
227
 
471 jpm 228
		$widget['donnees']['observations'] = $observations;
836 jpm 229
		$widget['donnees']['station_id'] = $this->station;
837 jpm 230
		$widget['donnees']['nbre_obs_total'] = $nbre_obs;
471 jpm 231
 
232
		return $widget;
464 delphine 233
	}
471 jpm 234
 
837 jpm 235
	private function chargerPagination($url_tpl, $nbre) {
236
 
237
	}
238
 
239
	private function chargerObservationsNbre() {
471 jpm 240
		// Récupération des données au format Json
837 jpm 241
		$url = $this->contruireUrlServiceCarto('observations-nombre');
242
		$json = $this->getDao()->consulter($url);
243
		$nbre = json_decode($json);
244
		return $nbre;
245
	}
246
 
247
	private function chargerObservations() {
248
		// Récupération des données au format Json
836 jpm 249
		$url = $this->contruireUrlServiceCarto('observations');
698 jpm 250
		$json = $this->getDao()->consulter($url);
471 jpm 251
		$donnees = json_decode($json);
252
 
253
		// Post-traitement des données
254
		$observations = $this->traiterObservations($donnees);
255
 
256
		return $observations;
257
	}
258
 
259
	private function traiterObservations($donnees) {
260
		$observations = array();
261
		if (is_array($donnees) && count($donnees) > 0) {
262
			foreach ($donnees as $donnee) {
263
				$observation = array();
547 jpm 264
				$observation['id'] = $donnee->id;
507 jpm 265
				$observation['nn'] = $this->etreVide($donnee->num_nom_sel) ? null : $donnee->num_nom_sel;
471 jpm 266
				$observation['nom'] = $this->nettoyerTexte($donnee->nom_sel);
545 jpm 267
				$observation['date'] = $this->formaterDate($donnee->date_observation, '%d/%m/%Y');
471 jpm 268
				$observation['lieu'] = $this->traiterLieu($donnee);
269
				$observation['observateur'] = $this->tronquerCourriel($donnee->identifiant);
270
 
271
				$observations[] = $observation;
272
				$observations['commune'] = $this->nettoyerTexte($donnee->location);
547 jpm 273
				$observations['ids'][] = $donnee->id;
471 jpm 274
			}
275
		}
276
		return $observations;
277
	}
278
 
279
	private function traiterLieu($donnee) {
280
		$lieu = array();
281
		if (isset($donnee->lieudit) && ! empty($donnee->lieudit)) {
282
			$lieu[] = $donnee->lieudit;
283
		}
284
		if (isset($donnee->milieu) && ! empty($donnee->milieu)) {
285
			$lieu[] = $donnee->milieu;
286
		}
287
		return implode(', ', $lieu);
288
	}
289
 
290
	private function choisirFormatSortie($observations_nbre) {
291
		$sortie = 'obs_tableau';
836 jpm 292
		if (isset($this->format) && $this->format != '*') {
293
			$sortie = ($this->format == 'tableau' ) ? 'obs_tableau' : 'obs_liste';
471 jpm 294
		} else {
295
			$sortie = ($observations_nbre > 4) ? 'obs_tableau' : 'obs_liste';
296
		}
297
		return $sortie;
298
	}
299
 
547 jpm 300
	private function chargerImages($obs_ids) {
301
		// Récupération des données au format Json
302
		$service = 'CelImage/liste-ids?obsId='.implode(',', $obs_ids);
303
		$url = sprintf($this->config['chemins']['baseURLServicesCelTpl'], $service);
836 jpm 304
		$this->debug[] = $url;
698 jpm 305
		$json = $this->getDao()->consulter($url);
547 jpm 306
		$donnees = json_decode($json);
307
 
308
		// Post-traitement des données
309
		$images = $this->traiterImages($donnees);
310
 
311
		return $images;
312
	}
313
 
314
	private function traiterImages($donnees) {
315
		$images = array();
316
		//echo '<br/><pre>'.print_r($donnees,true).'</pre>';
317
		if (count($donnees) > 0) {
318
			foreach ($donnees as $id_obs => $id_images) {
319
				foreach ($id_images as $id_img) {
320
					$urls['id'] = $id_img;
629 jpm 321
					$urls['miniature'] = $this->getUrlImage($id_img, 'CXS');
322
					$urls['normale'] = $this->getUrlImage($id_img, 'XL');
547 jpm 323
					$images[$id_obs][] = $urls;
324
				}
325
			}
326
		}
327
		return $images;
328
	}
329
 
501 jpm 330
	/**
331
	 * Afficher message d'avertissement.
332
	 */
333
	public function executerAvertissement() {
334
		$widget = null;
335
 
336
		// Création des infos du widget
337
		$widget['donnees']['url_base'] = sprintf($this->config['chemins']['baseURLAbsoluDyn'], '');
338
		$widget['squelette'] = 'avertissement';
339
 
340
		return $widget;
341
	}
424 jpm 342
}