Subversion Repositories eFlore/Applications.del

Rev

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

Rev Author Line No. Line
1231 gduche 1
<?php
2
/**
1284 jpm 3
 * Service fournissant des informations concernant les tags sur les images de DEL en fonction d'un protocole
1231 gduche 4
 * au format RSS1, RSS2 ou ATOM.
5
 * Encodage en entrée : utf8
6
 * Encodage en sortie : utf8
1284 jpm 7
 *
1231 gduche 8
 * @author Grégoire DUCHE <gregoire@tela-botanica.org>
9
 * @license GPL v3 <http://www.gnu.org/licenses/gpl.txt>
10
 * @license CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
11
 * @version $Id$
12
 * @copyright 2010
13
 */
14
class SyndicationTagsParProtocole {
1284 jpm 15
 
1231 gduche 16
	/**
17
	 * Paramètres du service
18
	 * */
19
	private $ressources = null;
20
	private $parametres = null;
21
	private $format = null;
22
	private $service = null;
23
	private $squelette = null;
24
	private $squelette_dossier = null;
25
	private $masque = array();
26
	private $mappingFiltre = array();
27
	private $conteneur = null;
28
	private $gestionBdd = null;
29
	private $navigation = null;
30
	private $type_rss = null;
1284 jpm 31
 
1231 gduche 32
	/**
33
	 * Constructeur
34
	 * Initialiser les configurations
35
	 * */
36
	public function __construct(Conteneur $conteneur = null) {
37
		$this->conteneur = $conteneur == null ? new Conteneur() : $conteneur;
38
		$this->conteneur->chargerConfiguration('config_syndication_tagsparprotocole.ini');
39
		$this->mappingFiltre = $this->conteneur->getParametre('mapping_masque');
40
		$this->masque = $conteneur->getMasque();
41
		$this->gestionBdd = $conteneur->getGestionBdd();
42
		$this->navigation = $conteneur->getNavigation();
43
	}
1284 jpm 44
 
1231 gduche 45
	/**
1284 jpm 46
	 * Consulter
1231 gduche 47
	 * Méthode par défaut pour récupérer l'ensemble des tags.
48
	 * Vérifie la configuration et retourne les derniers tags formatés
49
	 * */
1284 jpm 50
	public function consulter($params = array()) {
51
		$this->verifierConfiguration();
1231 gduche 52
		$this->type_rss = $params[1];
53
		if ($this->fluxAdminDemande()) {
54
			$this->demanderAutorisationAdmin();
1284 jpm 55
		}
56
 
1231 gduche 57
		$donnees_brutes = $this->getDerniersVotesImage();
1284 jpm 58
		$commentaires_formates = $this->formaterPourRss($donnees_brutes) ;
1231 gduche 59
		return $commentaires_formates;
60
	}
1284 jpm 61
 
1231 gduche 62
	/**
63
	* Vérifier que le service est bien configuré
64
	* */
65
	public function verifierConfiguration() {
66
		$erreurs = array();
1284 jpm 67
 
1231 gduche 68
		if (empty($this->mappingFiltre)) {
69
			$erreurs[] = '- le fichier de configuration ne contient pas le tableau [mapping_masque] ou celui-ci est vide ;';
70
		} else {
71
			$champsMappingFiltre = array('image', 'protocole');
72
			foreach ($champsMappingFiltre as $champ) {
73
				if (!isset($this->mappingFiltre[$champ])) {
74
					$erreurs[] = '- le mapping du champ "'.$champ.'" pour le commentaire est manquant ;';
75
				}
76
			}
77
		}
1284 jpm 78
 
1231 gduche 79
		if (!empty($erreurs)) {
80
			$e = 'Erreur lors de la configuration : '."\n";
81
			$e .= implode("\n", $erreurs);
82
			throw new Exception($e, RestServeur::HTTP_CODE_ERREUR);
83
		}
84
	}
1284 jpm 85
 
1231 gduche 86
	/**
87
	 * Verifier si le flux admin est demandé
88
	 */
89
	private function fluxAdminDemande() {
1284 jpm 90
		return $this->conteneur->getParametre('admin') != null && $this->conteneur->getParametre('admin') == 1;
1231 gduche 91
	}
1284 jpm 92
 
1231 gduche 93
	/**
94
	 * Si le flux est un flux admin, demander un mot de passe
95
	 * */
96
	private function demanderAutorisationAdmin() {
97
		$verification = new ControleAcces($this->conteneur);
98
		$verification->demanderAuthentificationAdmin();
99
	}
1284 jpm 100
 
1231 gduche 101
	/**
102
	 * Formater les données pour mettre en page le RSS
103
	 * */
104
	private function formaterPourRss($elements) {
105
		$donnees = $this->construireDonneesCommunesAuFlux($elements);
106
		foreach ($elements as $element) {
1232 gduche 107
			$identifiants[$element['id_tag']] = $element['id_tag'];
1231 gduche 108
		}
109
		foreach ($elements as $element) {
110
			$donnees['items'][] = $this->construireDonneesCommunesAuxItems($element);
111
		}
112
		return $donnees;
113
	}
1284 jpm 114
 
1231 gduche 115
	/**
116
	 * Générer les métadonnées du flux (titre, dates, editeur etc.)
117
	 * */
118
	private function construireDonneesCommunesAuFlux($infos) {
119
		$donnees = array();
1307 jpm 120
		$donnees['guid'] = htmlspecialchars($this->creerUrlService());
1284 jpm 121
		$donnees['titre'] = 'pictoFlora : tags';
122
		$donnees['description'] = 'Ce flux regroupe les derniers tags des images de pictoFlora';
1307 jpm 123
		$donnees['lien_service'] = htmlspecialchars($this->creerUrlService());
1231 gduche 124
		$donnees['lien_del'] = $this->conteneur->getParametre('pictoAppliLien');
125
		$donnees['editeur'] = $this->conteneur->getParametre('editeur');
126
		$derniere_info_en_date = reset($infos);
127
		$date_modification_timestamp = strtotime($derniere_info_en_date['date']);
128
		$donnees['date_maj_RSS'] = date(DATE_RSS, $date_modification_timestamp);
129
		$donnees['date_maj_ATOM'] = date(DATE_ATOM, $date_modification_timestamp);
130
		$donnees['date_maj_W3C'] = date(DATE_W3C, $date_modification_timestamp);
131
		$donnees['annee_courante'] = date('Y');
132
		$donnees['generateur'] = 'DEL - SyndicationCommentaire';
133
		$donnees['generateur_version'] = (preg_match('/([0-9]+)/', '$Revision$', $match)) ?  $match[1] : '0';
1284 jpm 134
		return $donnees;
1231 gduche 135
	}
1284 jpm 136
 
1231 gduche 137
	/**
138
	 * Générer le lien du flux RSS
139
	 * */
140
	private function creerUrlService() {
1292 jpm 141
		$url_service = 'http://'.$_SERVER['SERVER_NAME'].$_SERVER['REQUEST_URI'];
1231 gduche 142
		return $url_service;
143
	}
1284 jpm 144
 
1231 gduche 145
	/**
146
	 * Générer les données communes & spécifiques à chaque item
147
	 * */
148
	private function construireDonneesCommunesAuxItems($info) {
149
		$item = array();
150
		$date_modification_timestamp = strtotime($info['date']);
151
		$item['date_maj_simple'] = strftime('%A %d %B %Y à %H:%M', $date_modification_timestamp);
152
		$item['date_maj_RSS'] = date(DATE_RSS, $date_modification_timestamp);
153
		$item['date_maj_ATOM'] = date(DATE_ATOM, $date_modification_timestamp);
154
		$item['date_maj_W3C'] = date(DATE_W3C, $date_modification_timestamp);
155
		$item['titre'] = $this->creerTitre($info);
156
		$item['guid'] = $this->creerGuidItem($info);
157
		$item['lien'] = $this->creerLienItem($info);
158
		$item['categorie'] = $this->creerCategorie($item);
159
		$item['description'] = $this->creerDescription($info, $item);
160
		$item['description_encodee'] = htmlspecialchars($this->creerDescription($info, $item));
1294 jpm 161
		$item['modifier_par'] = $this->formaterNomTagueur($info);
1231 gduche 162
		return $item;
163
	}
1284 jpm 164
 
1231 gduche 165
	private function creerCategorie($element) {
166
		$categorie = 'Tag protocole';
167
		$categorie = htmlentities($categorie);
168
		return $categorie;
169
	}
1284 jpm 170
 
1231 gduche 171
	private function creerGuidItem($element) {
1232 gduche 172
		$guid = sprintf($this->conteneur->getParametre('tagParProtocole'), $element['id_tag']);
1231 gduche 173
		return $guid;
174
	}
175
 
176
	private function creerLienItem($element) {
1232 gduche 177
		// TODO : ajouter un lien vers la plateforme validation de picto lorsqu'elle sera dispo
178
		$lien = $this->conteneur->getParametre('pictofloraFicheObsTpl');
1231 gduche 179
		return $lien;
180
	}
1284 jpm 181
 
1231 gduche 182
	private function creerTitre($element) {
1284 jpm 183
		$tag = $element['tag'];
184
		$nomSel = htmlspecialchars($element['nom_sel']);
1296 jpm 185
		$tagueur = htmlspecialchars($this->formaterNomTagueur($element));
186
		$auteurImg = $this->formaterNomAuteurImg($element);
187
		$titre = "Tag «{$tag}» par $tagueur pour $nomSel de $auteurImg";
1231 gduche 188
		return $titre;
189
	}
1284 jpm 190
 
1231 gduche 191
	private function creerDescription($donnees, $item) {
1285 jpm 192
		$idTag = htmlspecialchars($donnees['id_tag']);
193
		$idObs = htmlspecialchars($donnees['id_observation']);
1284 jpm 194
		$idImg = htmlspecialchars($donnees['id_image']);
195
		$urlImg = $this->getUrlImage($donnees['id_image']);
1292 jpm 196
		$miniatureUrl = $this->getUrlImage($donnees['id_image'], 'CRS');
197
		$nomSelActuel = htmlspecialchars($donnees['nom_sel']);
198
		$dateObs = htmlspecialchars(str_replace(' 00:00:00', '', $donnees['date_observation']));
199
		$lieuObs = htmlspecialchars($donnees['zone_geo']);
200
		$tag = htmlspecialchars($donnees['tag']);
201
		$dateTag = htmlspecialchars(strftime('%A %d %B %Y à %H:%M', strtotime($donnees['date'])));
202
		$auteurImg = htmlspecialchars($this->creerAuteurImg($donnees));
1284 jpm 203
		$tagueur = htmlspecialchars($this->creerTagueur($donnees));
204
 
1292 jpm 205
		$description = '<style>.champ{color:grey} .gauche{float:left;padding:0 20px 0 0;} ul{list-style-type:none;padding:0;}</style>'.
206
			'<h2>'."Tag pictoFlora #$idTag pour l'image #$idImg de l'observation #$idObs".'</h2>'.
207
			'<div class="gauche">'.
208
			'	<a href="'.$urlImg.'">'.
209
			'		<img src="'.$miniatureUrl.'" alt="Img #'.$idImg.'"/>'.
210
			'	</a>'.
211
			'</div>'.
212
			'<div class="gauche">'.
213
			"	<h3>Image #$idImg de l'observation #$idObs</h3>".
214
			'	<ul>'.
215
			'		<li><span class="champ">'."Auteur de l'image :</span> $auteurImg</li>".
216
			'		<li><span class="champ">'."Nom saisi actuel :</span> <em>$nomSelActuel</em></li>".
217
			'		<li><span class="champ">'."Lieu :</span> $lieuObs</li>".
218
			'		<li><span class="champ">'."Date :</span> $dateObs</li>".
219
			'	</ul>'.
220
			'</div>'.
221
			'<div class="gauche">'.
222
			"	<h3>Tag #$idTag</h3>".
223
			'	<ul>'.
224
			'		<li><span class="champ">'."Tag :</span> <strong>$tag</strong></li>".
225
			'		<li><span class="champ">'."Auteur :</span> $tagueur</li>".
226
			'		<li><span class="champ">'."Taguée le :</span> $dateTag</li>".
227
			'	</ul>'.
228
			'</div>';
1231 gduche 229
		return $description;
230
	}
1284 jpm 231
 
232
	private function getUrlImage($id, $format = 'L') {
233
		$url_tpl = $this->conteneur->getParametre('celImgUrlTpl');
234
		$id = sprintf('%09s', $id).$format;
235
		$url = sprintf($url_tpl, $id);
236
		return $url;
237
	}
238
 
239
	private function creerAuteurImg($info) {
1296 jpm 240
		$auteur = $this->formaterNomAuteurImg($info).
241
			($this->fluxAdminDemande() ? ' ('.$info['auteur_courriel'].')' : '');
242
		return $auteur;
243
	}
244
 
245
	private function formaterNomAuteurImg($info) {
1284 jpm 246
		$auteur = 'Anonyme';
247
		if ($info['auteur_prenom'] != '' && $info['auteur_nom'] != '') {
1296 jpm 248
			$auteur = $info['auteur_prenom'].' '.$info['auteur_nom'];
1231 gduche 249
		}
1284 jpm 250
		return $auteur;
1231 gduche 251
	}
1284 jpm 252
 
253
	private function creerTagueur($info) {
254
		$tagueur = $this->formaterNomTagueur($info).
1296 jpm 255
			($this->fluxAdminDemande() ? ' ('.$info['tagueur_courriel'].')' : '');
1284 jpm 256
		return $tagueur;
257
	}
258
 
259
	private function formaterNomTagueur($info) {
260
		$tagueur = 'Anonyme';
261
		if ($info['tagueur_prenom'] != '' && $info['tagueur_nom'] != '') {
262
			$tagueur = $info['tagueur_prenom'].' '.$info['tagueur_nom'];
263
		}
264
		return $tagueur;
265
	}
266
 
1231 gduche 267
	/**
1284 jpm 268
	 * Retrouver les derniers votes image
269
	 * */
270
	private function getDerniersVotesImage() {
1292 jpm 271
		$requete = 'SELECT DISTINCT id_tag, tag, date, '.
272
				'	do.id_observation, do.nom_sel, do.zone_geo, do.date_observation, doi.id_image, '.
1296 jpm 273
				'	duo.prenom AS auteur_prenom, duo.nom AS auteur_nom, duo.courriel AS auteur_courriel, '.
274
				'	du.prenom AS tagueur_prenom, du.nom AS tagueur_nom, du.courriel AS tagueur_courriel '.
1284 jpm 275
				'FROM del_image_tag AS dit '.
276
				'	INNER JOIN del_obs_image AS doi '.
277
				'		ON ce_image = id_image '.
278
				'	INNER JOIN del_observation AS do '.
279
				'			ON doi.id_observation = do.id_observation '.
280
				'	LEFT JOIN del_utilisateur AS duo '.
281
				'		ON do.ce_utilisateur = duo.id_utilisateur '.
282
				'	LEFT JOIN del_utilisateur AS du '.
1309 jpm 283
				'		ON if((CHAR_LENGTH(dit.ce_utilisateur) <> 32),CAST(dit.ce_utilisateur AS unsigned),0) '.
284
				'			= du.id_utilisateur '.
1284 jpm 285
				'WHERE actif = 1 '.
286
				$this->chargerClauseWhere().' '.
287
				'ORDER BY date DESC '.
288
				'LIMIT '.$this->navigation->getDepart().','.$this->navigation->getLimite();
289
		$elements = $this->gestionBdd->getBdd()->recupererTous($requete);
290
		return $elements;
291
	}
292
 
293
	/**
1231 gduche 294
	* Charger la clause WHERE en fonction des paramètres de masque
295
	* */
296
	private function chargerClauseWhere() {
297
		$where = array();
298
		$tableauMasque = $this->masque->getMasque();
299
		if (!empty($tableauMasque)) {
1284 jpm 300
			foreach ($tableauMasque as $idMasque => $valeurMasque) {
1231 gduche 301
				$idMasque = str_replace('masque.', '', $idMasque);
1284 jpm 302
				$champMasque = $this->mappingFiltre[$idMasque];
303
				$masqueMotif = $this->gestionBdd->getBdd()->proteger($valeurMasque);
304
 
1231 gduche 305
				switch ($idMasque) {
306
					case 'image':
1284 jpm 307
					//TODO : ajouter le protocole ? case 'protocole':
1231 gduche 308
					default:
1284 jpm 309
						$where[] = " $champMasque = $masqueMotif ";
1231 gduche 310
				}
1284 jpm 311
			}
1231 gduche 312
		}
1284 jpm 313
 
314
		$conditionsTxt = (!empty($where)) ? ' AND '.implode('AND', $where) : '';
315
		return $conditionsTxt;
1231 gduche 316
	}
1284 jpm 317
}
318
?>