Subversion Repositories eFlore/Applications.del

Rev

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

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