Subversion Repositories eFlore/Applications.cel

Rev

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

Rev Author Line No. Line
712 jpm 1
<?php
2
// declare(encoding='UTF-8');
3
/**
4
 * Widget fournissant des interfaces de saisies simplifiée pour différent projets.
5
 * Encodage en entrée : utf8
6
 * Encodage en sortie : utf8
7
 *
8
 * Cas d'utilisation et documentation :
9
 * @link http://www.tela-botanica.org/wikini/eflore/wakka.php?wiki=AideCELWidgetSaisie
10
 *
11
 * Paramètres :
12
 * ===> projet = chaine  [par défaut : Biodiversite34]
13
 * Indique quel projet nous voulons charger
14
 *
15
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
16
 * @license		GPL v3 <http://www.gnu.org/licenses/gpl.txt>
17
 * @license		CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
18
 * @version		$Id$
19
 * @copyright	Copyright (c) 2010, Tela Botanica (accueil@tela-botanica.org)
20
 */
21
class Saisie extends WidgetCommun {
1050 jpm 22
 
712 jpm 23
	const DS = DIRECTORY_SEPARATOR;
1345 aurelien 24
	const PROJET_DEFAUT = 'defaut';
1050 jpm 25
	const WS_SAISIE = "CelWidgetSaisie";
1345 aurelien 26
	const WS_NOM = "noms";
27
	const NS_PROJET = "bdtfx";
28
	const NS_PROJET_VERSION = "1.01";
29
	const EFLORE_API_VERSION = "0.1";
1050 jpm 30
 
719 jpm 31
	private $projet = null;
32
	private $configProjet = null;
1050 jpm 33
 
712 jpm 34
	/**
35
	 * Méthode appelée par défaut pour charger ce widget.
36
	 */
37
	public function executer() {
38
		$retour = null;
39
		extract($this->parametres);
40
 
1345 aurelien 41
		$this->projet = isset($projet) ? $projet : self::PROJET_DEFAUT;
719 jpm 42
		$this->chargerConfigProjet();
1050 jpm 43
 
1345 aurelien 44
		$service = isset($service) ? $service : 'widget';
719 jpm 45
		$methode = $this->traiterNomMethodeExecuter($service);
712 jpm 46
		if (method_exists($this, $methode)) {
47
			$retour = $this->$methode();
48
		} else {
49
			$this->messages[] = "Ce type de service '$methode' n'est pas disponible.";
50
		}
51
 
1050 jpm 52
		$contenu = null;
53
		$mime = null;
54
		if (is_array($retour) && array_key_exists('squelette', $retour)) {
719 jpm 55
			$ext = (isset($retour['squelette_ext'])) ? $retour['squelette_ext'] : '.tpl.html';
56
			$squelette = dirname(__FILE__).self::DS.'squelettes'.self::DS.$this->projet.self::DS.$retour['squelette'].$ext;
712 jpm 57
			$contenu = $this->traiterSquelettePhp($squelette, $retour['donnees']);
1050 jpm 58
			$mime = isset($retour['mime']) ? $retour['mime'] : null;
59
		} else {
60
			if (count($this->messages) == 0) {
61
				$this->messages[] = "La méthode du sous-service ne renvoie pas les données dans le bon format.";
62
			}
63
			$contenu = 'Un problème est survenu : '.print_r($this->messages, true);
712 jpm 64
		}
1050 jpm 65
 
66
		$this->envoyer($contenu, $mime);
712 jpm 67
	}
1050 jpm 68
 
719 jpm 69
	private function chargerConfigProjet() {
70
		$fichier_config = dirname(__FILE__).self::DS.'configurations'.self::DS.$this->projet.'.ini';
71
		if (file_exists($fichier_config)) {
72
			if (!$this->configProjet	= parse_ini_file($fichier_config)) {
73
				$this->messages[] = "Le fichier ini '$fichier_config' du projet n'a pu être chargé.";
1050 jpm 74
			}
719 jpm 75
		} else {
1345 aurelien 76
			$this->debug[] = "Le fichier ini '$fichier_config' du projet n'existe pas.";
719 jpm 77
		}
78
	}
1050 jpm 79
 
1345 aurelien 80
	public function executerWidget() {
1050 jpm 81
		$widget['squelette'] = $this->projet;
82
		$widget['donnees'] = array();
83
		$widget['donnees']['url_base'] = sprintf($this->config['chemins']['baseURLAbsoluDyn'], '');
84
		$widget['donnees']['url_ws_saisie'] = sprintf($this->config['chemins']['baseURLServicesCelTpl'], self::WS_SAISIE);
85
 
86
 
1345 aurelien 87
		if ($this->projet == 'defaut') {
88
			$urlWsNsTpl = $this->config['chemins']['baseURLServicesEfloreTpl'];
89
			$urlWsNs = sprintf($urlWsNsTpl, self::EFLORE_API_VERSION, self::NS_PROJET, self::WS_NOM);
90
			$widget['donnees']['url_ws_autocompletion_ns'] = $urlWsNs;
91
			$widget['donnees']['ns_referentiel'] = self::NS_PROJET.':'.self::NS_PROJET_VERSION;
92
			$widget['donnees']['ns_version'] = self::NS_PROJET_VERSION;
1418 aurelien 93
			if(self::especeEstImposee()) {
94
				$nom = self::executerChargementInfosTaxon($_GET['num_nom']);
95
				$widget['donnees']['espece_imposee'] = true;
96
				$widget['donnees']['nn_espece_defaut'] = $_GET['num_nom'];
97
				$widget['donnees']['nom_sci_espece_defaut'] = $nom;
98
			} else {
99
				$widget['donnees']['espece_imposee'] = false;
100
				$widget['donnees']['nn_espece_defaut'] = '';
101
				$widget['donnees']['nom_sci_espece_defaut'] = '';
102
			}
1345 aurelien 103
		} else {
104
			$widget['donnees']['taxons'] = $this->recupererListeTaxon();
105
			$widget['donnees']['milieux'] = $this->parserMilieux();
719 jpm 106
		}
1345 aurelien 107
		return  $widget;
719 jpm 108
	}
1050 jpm 109
 
1345 aurelien 110
	public function executerTaxons() {
111
		$widget['squelette'] = $this->projet.'_taxons';
112
		$widget['squelette_ext'] = '.tpl.js';
113
		$widget['donnees'] = array();
114
		$taxons = $this->recupererListeTaxon();
115
		$taxons_tries = array();
116
		foreach ($taxons as $taxon) {
117
			$taxons_tries[$taxon['num_nom_sel']] = $taxon;
118
		}
119
		$widget['donnees']['taxons'] = json_encode($taxons_tries);
120
		return  $widget;
121
	}
122
 
123
	private function recupererListeTaxon() {
124
		$taxons = null;
125
		$fichier_tsv = dirname(__FILE__).self::DS.'configurations'.self::DS.$this->projet.'_taxons.tsv';
126
		if (file_exists($fichier_tsv) && is_readable($fichier_tsv)) {
712 jpm 127
			$taxons = $this->decomposerFichierTsv($fichier_tsv);
1345 aurelien 128
			$taxons = self::trierTableauMd($taxons, array('nom_fr' => SORT_ASC));
129
		} else {
130
			$this->debug[] = "Impossible d'ouvrir le fichier '$fichier_tsv'.";
131
		}
132
		return $taxons;
133
	}
134
 
135
	private function decomposerFichierTsv($fichier, $delimiter = "\t"){
136
		$header = NULL;
137
		$data = array();
138
		if (($handle = fopen($fichier, 'r')) !== FALSE) {
139
			while (($row = fgetcsv($handle, 1000, $delimiter)) !== FALSE) {
140
				if (!$header) {
141
					$header = $row;
142
				} else {
143
					$data[] = array_combine($header, $row);
144
				}
145
			}
146
			fclose($handle);
147
		}
148
		return $data;
712 jpm 149
	}
1050 jpm 150
 
1345 aurelien 151
	private function parserMilieux() {
1050 jpm 152
		$infosMilieux = array();
153
		$milieux = explode('|', $this->configProjet['milieux']);
154
		foreach ($milieux as $milieu) {
155
			$details = explode(';', $milieu);
156
			if (isset($details[1])) {
157
				$infosMilieux[$details[0]] = $details[1];
158
			} else {
159
				$infosMilieux[$details[0]] = '';
160
			}
161
		}
1345 aurelien 162
		ksort($infosMilieux);
1050 jpm 163
		return $infosMilieux;
164
	}
1418 aurelien 165
 
166
	private function especeEstImposee() {
167
		return isset($_GET['num_nom']) && $_GET['num_nom'] != '';
168
	}
169
 
170
	private function executerChargementInfosTaxon($num_nom) {
171
		$url_service_infos = sprintf($this->config['chemins']['infosTaxonUrl'], $num_nom);
172
		$infos = json_decode(file_get_contents($url_service_infos));
173
		$resultat = (isset($infos->resultat) && isset($infos->resultat->$num_nom)) ? $infos->resultat->$num_nom->nom_sci : '';
174
		return $resultat;
175
	}
1050 jpm 176
 
1345 aurelien 177
	public function executerUploadImage() {
178
		$retour = array(
179
				'squelette' => $this->projet.'_image',
180
				'squelette_ext' => '.tpl.xml',
181
				'mime' => 'text/xml',
182
				'donnees' => array(
183
						'urlMiniature' => '',
184
						'imageNom' => '',
185
						'message' => '',
186
						'debogage' => ''));
187
		$message = '';
188
		$debogage = '';
189
		if ($_FILES['fichier']['error'] == UPLOAD_ERR_OK) {
190
			if (is_uploaded_file($_FILES['fichier']['tmp_name'])) {
1355 aurelien 191
				if ($this->verifierFormatJpeg($_FILES['fichier']['tmp_name'])) {
1345 aurelien 192
					$dossierStockage = $this->config['chemins']['imagesTempDossier'];
193
 
194
					$nomFichierOriginal = preg_replace('/[.](jpeg|jpg)$/i', '.jpg', strtolower($_FILES['fichier']['name']));
195
					$originalChemin = $dossierStockage.$nomFichierOriginal;
196
					$deplacementOk = move_uploaded_file($_FILES['fichier']['tmp_name'], $originalChemin);
197
 
198
					if ($deplacementOk === true) {
199
						$miniatureFichier = str_replace('.jpg', '_min.jpg', $nomFichierOriginal);
200
						$miniatureChemin = $dossierStockage.$miniatureFichier;
201
 
202
						// Parametres
203
						$largeurIdeale = 100;
204
						$hauteurIdeale = 100;
205
						$qualite = 85;
206
 
207
						// Calcul de la hauteur et de la largeur optimale de la miniature
208
						$taillesImgOriginale = getimagesize($originalChemin);
209
						$largeurOrigine = $taillesImgOriginale[0];
210
						$hauteurOrigine = $taillesImgOriginale[1];
211
 
212
						$largeurMin = $largeurIdeale;
213
						$hauteurMin = (int) ($hauteurOrigine * ($largeurIdeale / $largeurOrigine));
214
						if ($hauteurMin > $hauteurIdeale) {
215
							$hauteurMin = $hauteurIdeale;
216
							$largeurMin = (int)($largeurOrigine * ($hauteurMin / $hauteurOrigine));
217
						}
218
 
219
						// Création de la miniature
220
						$imageOriginale = imagecreatefromjpeg($originalChemin);
221
						$imageMiniature = imagecreatetruecolor($largeurMin, $hauteurMin);
222
						$couleurFond = imagecolorallocate($imageMiniature, 255, 255, 255);
223
						imagefill($imageMiniature, 0, 0, $couleurFond);
224
						imagecopyresized($imageMiniature, $imageOriginale, 0, 0, 0, 0, $largeurMin, $hauteurMin, $largeurOrigine, $hauteurOrigine);
225
						imagejpeg($imageMiniature, $miniatureChemin, $qualite);
226
						imagedestroy($imageMiniature);
227
						imagedestroy($imageOriginale);
228
 
229
						// Retour des infos
230
						$retour['donnees']['urlMiniature'] = sprintf($this->config['chemins']['imagesTempUrlTpl'], $miniatureFichier);
231
						$retour['donnees']['imageNom'] = $nomFichierOriginal;
232
					} else {
233
						$message = "L'image n'a pu être déplacé sur le serveur.";
234
					}
1355 aurelien 235
				} else {
236
					mail('aurelien@tela-botanica.org', 'image', '<pre>'.print_r($_FILES['fichier'],true).'</pre>');
1345 aurelien 237
					$message = "L'image n'est pas au format JPEG.";
238
				}
239
			} else {
240
				$message = "L'image n'a pu être téléversée.";
241
				$debogage = $message.print_r($_FILES, true);
242
			}
243
		} else {
244
			if ($_FILES['fichier']['error'] == UPLOAD_ERR_FORM_SIZE) {
245
				$message = "L'image téléversée excède la taille maximum autorisée.".
246
						"Veuillez modifier votre image avant de la téléverser à nouveau.";
247
			} else {
248
				$message = "Une erreur de transfert a eu lieu (téléversement interrompu).";
249
			}
250
			$debogage = "Code erreur : {$_FILES['fichier']['error']}. ".
251
					"Voir : http://php.net/manual/fr/features.file-upload.errors.php";
252
		}
253
		// Retour des infos
254
		$retour['donnees']['message'] = $message;
255
		$retour['donnees']['debogage'] = $debogage;
256
		return $retour;
1050 jpm 257
	}
1355 aurelien 258
 
259
	// Il ne faut pas utiliser l'index type du tableau files pour tester
260
	// si une image est en jpeg car le type renvoyé par les navigateurs
261
	// peut varier (ex. sous ie qui renvoie image/pjpeg
262
	private function verifierFormatJpeg($chemin) {
263
		// get imagesize renvoie un résultat consistant par contre
264
		$infos = getimagesize($chemin, $infos);
265
		return (isset($infos["mime"]) && $infos["mime"] == "image/jpeg");
266
	}
1345 aurelien 267
}
268
?>