Subversion Repositories eFlore/Applications.del

Rev

Rev 1292 | Rev 1296 | Go to most recent revision | 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();
1294 jpm 120
		$donnees['guid'] = $this->creerUrlService();
1284 jpm 121
		$donnees['titre'] = 'pictoFlora : tags';
122
		$donnees['description'] = 'Ce flux regroupe les derniers tags des images de pictoFlora';
1231 gduche 123
		$donnees['lien_service'] = $this->creerUrlService();
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']);
185
		$tagueur = htmlspecialchars($this->creerTagueur($element));
1291 jpm 186
		$titre = "Tag «{$tag}» pour $nomSel par $tagueur";
1231 gduche 187
		return $titre;
188
	}
1284 jpm 189
 
1231 gduche 190
	private function creerDescription($donnees, $item) {
1285 jpm 191
		$idTag = htmlspecialchars($donnees['id_tag']);
192
		$idObs = htmlspecialchars($donnees['id_observation']);
1284 jpm 193
		$idImg = htmlspecialchars($donnees['id_image']);
194
		$urlImg = $this->getUrlImage($donnees['id_image']);
1292 jpm 195
		$miniatureUrl = $this->getUrlImage($donnees['id_image'], 'CRS');
196
		$nomSelActuel = htmlspecialchars($donnees['nom_sel']);
197
		$dateObs = htmlspecialchars(str_replace(' 00:00:00', '', $donnees['date_observation']));
198
		$lieuObs = htmlspecialchars($donnees['zone_geo']);
199
		$tag = htmlspecialchars($donnees['tag']);
200
		$dateTag = htmlspecialchars(strftime('%A %d %B %Y à %H:%M', strtotime($donnees['date'])));
201
		$auteurImg = htmlspecialchars($this->creerAuteurImg($donnees));
1284 jpm 202
		$tagueur = htmlspecialchars($this->creerTagueur($donnees));
203
 
1292 jpm 204
		$description = '<style>.champ{color:grey} .gauche{float:left;padding:0 20px 0 0;} ul{list-style-type:none;padding:0;}</style>'.
205
			'<h2>'."Tag pictoFlora #$idTag pour l'image #$idImg de l'observation #$idObs".'</h2>'.
206
			'<div class="gauche">'.
207
			'	<a href="'.$urlImg.'">'.
208
			'		<img src="'.$miniatureUrl.'" alt="Img #'.$idImg.'"/>'.
209
			'	</a>'.
210
			'</div>'.
211
			'<div class="gauche">'.
212
			"	<h3>Image #$idImg de l'observation #$idObs</h3>".
213
			'	<ul>'.
214
			'		<li><span class="champ">'."Auteur de l'image :</span> $auteurImg</li>".
215
			'		<li><span class="champ">'."Nom saisi actuel :</span> <em>$nomSelActuel</em></li>".
216
			'		<li><span class="champ">'."Lieu :</span> $lieuObs</li>".
217
			'		<li><span class="champ">'."Date :</span> $dateObs</li>".
218
			'	</ul>'.
219
			'</div>'.
220
			'<div class="gauche">'.
221
			"	<h3>Tag #$idTag</h3>".
222
			'	<ul>'.
223
			'		<li><span class="champ">'."Tag :</span> <strong>$tag</strong></li>".
224
			'		<li><span class="champ">'."Auteur :</span> $tagueur</li>".
225
			'		<li><span class="champ">'."Taguée le :</span> $dateTag</li>".
226
			'	</ul>'.
227
			'</div>';
1231 gduche 228
		return $description;
229
	}
1284 jpm 230
 
231
	private function getUrlImage($id, $format = 'L') {
232
		$url_tpl = $this->conteneur->getParametre('celImgUrlTpl');
233
		$id = sprintf('%09s', $id).$format;
234
		$url = sprintf($url_tpl, $id);
235
		return $url;
236
	}
237
 
238
	private function creerAuteurImg($info) {
239
		$auteur = 'Anonyme';
240
		if ($info['auteur_prenom'] != '' && $info['auteur_nom'] != '') {
241
			$auteur = $info['auteur_prenom'].' '.$info['auteur_nom'].
242
				($this->fluxAdminDemande() ? ' ('.$donnees['auteur_courriel'].')' : '');
1231 gduche 243
		}
1284 jpm 244
		return $auteur;
1231 gduche 245
	}
1284 jpm 246
 
247
	private function creerTagueur($info) {
248
		$tagueur = $this->formaterNomTagueur($info).
249
			($this->fluxAdminDemande() ? ' ('.$donnees['tagueur_courriel'].')' : '');
250
		return $tagueur;
251
	}
252
 
253
	private function formaterNomTagueur($info) {
254
		$tagueur = 'Anonyme';
255
		if ($info['tagueur_prenom'] != '' && $info['tagueur_nom'] != '') {
256
			$tagueur = $info['tagueur_prenom'].' '.$info['tagueur_nom'];
257
		}
258
		return $tagueur;
259
	}
260
 
1231 gduche 261
	/**
1284 jpm 262
	 * Retrouver les derniers votes image
263
	 * */
264
	private function getDerniersVotesImage() {
1292 jpm 265
		$requete = 'SELECT DISTINCT id_tag, tag, date, '.
266
				'	do.id_observation, do.nom_sel, do.zone_geo, do.date_observation, doi.id_image, '.
1284 jpm 267
				'	duo.prenom AS tagueur_prenom, duo.nom AS tagueur_nom, duo.courriel AS tagueur_courriel, '.
268
				'	du.prenom AS auteur_prenom, du.nom AS auteur_nom, du.courriel AS auteur_courriel '.
269
				'FROM del_image_tag AS dit '.
270
				'	INNER JOIN del_obs_image AS doi '.
271
				'		ON ce_image = id_image '.
272
				'	INNER JOIN del_observation AS do '.
273
				'			ON doi.id_observation = do.id_observation '.
274
				'	LEFT JOIN del_utilisateur AS duo '.
275
				'		ON do.ce_utilisateur = duo.id_utilisateur '.
276
				'	LEFT JOIN del_utilisateur AS du '.
1285 jpm 277
				'		ON CAST(dit.ce_utilisateur AS UNSIGNED) = du.id_utilisateur '.
1284 jpm 278
				'WHERE actif = 1 '.
279
				$this->chargerClauseWhere().' '.
280
				'ORDER BY date DESC '.
281
				'LIMIT '.$this->navigation->getDepart().','.$this->navigation->getLimite();
282
		$elements = $this->gestionBdd->getBdd()->recupererTous($requete);
283
		return $elements;
284
	}
285
 
286
	/**
1231 gduche 287
	* Charger la clause WHERE en fonction des paramètres de masque
288
	* */
289
	private function chargerClauseWhere() {
290
		$where = array();
291
		$tableauMasque = $this->masque->getMasque();
292
		if (!empty($tableauMasque)) {
1284 jpm 293
			foreach ($tableauMasque as $idMasque => $valeurMasque) {
1231 gduche 294
				$idMasque = str_replace('masque.', '', $idMasque);
1284 jpm 295
				$champMasque = $this->mappingFiltre[$idMasque];
296
				$masqueMotif = $this->gestionBdd->getBdd()->proteger($valeurMasque);
297
 
1231 gduche 298
				switch ($idMasque) {
299
					case 'image':
1284 jpm 300
					//TODO : ajouter le protocole ? case 'protocole':
1231 gduche 301
					default:
1284 jpm 302
						$where[] = " $champMasque = $masqueMotif ";
1231 gduche 303
				}
1284 jpm 304
			}
1231 gduche 305
		}
1284 jpm 306
 
307
		$conditionsTxt = (!empty($where)) ? ' AND '.implode('AND', $where) : '';
308
		return $conditionsTxt;
1231 gduche 309
	}
1284 jpm 310
}
311
?>