Subversion Repositories eFlore/Applications.del

Rev

Rev 1793 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

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