Subversion Repositories eFlore/Applications.del

Rev

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

Rev 1448 Rev 1514
1
<?php
1
<?php
2
// declare(encoding='UTF-8');
2
// declare(encoding='UTF-8');
3
/**
3
/**
4
	* Le web service image récupère toutes les données de la table del_obs_images
4
	* Le web service image récupère toutes les données de la table del_obs_images
5
 * pour retourner une liste d'images associée à une observation
5
 * pour retourner une liste d'images associée à une observation
6
 *
6
 *
7
 * @category	php 5.2
7
 * @category	php 5.2
8
 * @package	del
8
 * @package	del
9
 * @subpackage images
9
 * @subpackage images
10
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
10
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
11
 * @copyright	Copyright (c) 2012, Tela Botanica (accueil@tela-botanica.org)
11
 * @copyright	Copyright (c) 2012, Tela Botanica (accueil@tela-botanica.org)
12
 * @license	http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
12
 * @license	http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
13
 * @license	http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
13
 * @license	http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
14
 * @version	$Id: Bdd.php 403 2012-02-22 14:35:20Z gduche $
14
 * @version	$Id: Bdd.php 403 2012-02-22 14:35:20Z gduche $
15
 * @see http://www.tela-botanica.org/wikini/eflore/wakka.php?wiki=ApiIdentiplante01Images
15
 * @see http://www.tela-botanica.org/wikini/eflore/wakka.php?wiki=ApiIdentiplante01Images
16
 */
16
 */
17
 
17
 
18
 
18
 
19
/**
19
/**
20
 * FONCTION TEMPORAIRE de debug pour afficher le contenu d'une variable en format lisible
20
 * FONCTION TEMPORAIRE de debug pour afficher le contenu d'une variable en format lisible
21
 * @param $r la variable à afficher
21
 * @param $r la variable à afficher
22
 * */
22
 * */
23
function debug($r) {
23
function debug($r) {
24
	echo '<pre>'.print_r($r, true).'</pre>';
24
	echo '<pre>'.print_r($r, true).'</pre>';
25
}
25
}
26
 
26
 
27
 
27
 
28
/**
28
/**
29
 * Le service ListeImages récupère les données des tables observation et images
29
 * Le service ListeImages récupère les données des tables observation et images
30
 * et les mets au format JSON pour identiplante / pictoflora 
30
 * et les mets au format JSON pour identiplante / pictoflora 
31
 * */
31
 * */
32
class ListeImages {
32
class ListeImages {
33
	
33
	
34
	
34
	
35
	// Variables :
35
	// Variables :
36
	// Configuration générale du service
36
	// Configuration générale du service
37
	private $conteneur;
37
	private $conteneur;
38
	private $navigation;
38
	private $navigation;
39
	private $bdd;
39
	private $bdd;
40
	private $gestionBdd;
40
	private $gestionBdd;
41
	
41
	
42
	// Parametres
42
	// Parametres
43
	private $ressources = array();
43
	private $ressources = array();
44
	private $parametres = array();
44
	private $parametres = array();
45
	private $masque;
45
	private $masque;
46
	
46
	
47
	private $tri = 'date_transmission';
47
	private $tri = 'date_transmission';
48
	private $directionTri = 'desc';
48
	private $directionTri = 'desc';
49
	private $formatRetour = 'XL';
49
	private $formatRetour = 'XL';
50
	
50
	
51
	private $imageIds = array();
51
	private $imageIds = array();
52
	
52
	
53
	
53
	
54
	/**
54
	/**
55
	 * Constructeur de l'application 
55
	 * Constructeur de l'application 
56
	 * Initialisation des variables générale de l'application
56
	 * Initialisation des variables générale de l'application
57
	 * @param Conteneu $conteneur le conteneur de classes de l'application
57
	 * @param Conteneu $conteneur le conteneur de classes de l'application
58
	 * */
58
	 * */
59
	public function __construct(Conteneur $conteneur = null) {
59
	public function __construct(Conteneur $conteneur = null) {
60
		$this->conteneur = $conteneur == null ? new Conteneur() : $conteneur;
60
		$this->conteneur = $conteneur == null ? new Conteneur() : $conteneur;
61
		$this->conteneur->chargerConfiguration('config_departements_bruts.ini');
61
		$this->conteneur->chargerConfiguration('config_departements_bruts.ini');
62
		$this->conteneur->chargerConfiguration('config_mapping_votes.ini');
62
		$this->conteneur->chargerConfiguration('config_mapping_votes.ini');
63
		$this->conteneur->chargerConfiguration('config_images.ini');
63
		$this->conteneur->chargerConfiguration('config_images.ini');
64
		$this->navigation = $conteneur->getNavigation();
64
		$this->navigation = $conteneur->getNavigation();
65
		$this->masque = $conteneur->getMasque();
65
		$this->masque = $conteneur->getMasque();
66
		$this->gestionBdd = $conteneur->getGestionBdd();
66
		$this->gestionBdd = $conteneur->getGestionBdd();
67
		$this->bdd = $this->gestionBdd->getBdd();	
67
		$this->bdd = $this->gestionBdd->getBdd();	
68
	}
68
	}
69
	
69
	
70
	
70
	
71
	/**
71
	/**
72
	 * Méthode principale de la classe.
72
	 * Méthode principale de la classe.
73
	 * Lance la récupération des images dans la base et les place dans un objet ResultatService
73
	 * Lance la récupération des images dans la base et les place dans un objet ResultatService
74
	 * pour l'afficher.
74
	 * pour l'afficher.
75
	 * @param array $ressources les ressources situées après l'url de base (ex : http://url/ressource1/ressource2)
75
	 * @param array $ressources les ressources situées après l'url de base (ex : http://url/ressource1/ressource2)
76
	 * @param array $parametres les paramètres situés après le ? dans l'url
76
	 * @param array $parametres les paramètres situés après le ? dans l'url
77
	 * */
77
	 * */
78
	public function consulter($ressources, $parametres) {
78
	public function consulter($ressources, $parametres) {
79
	
79
	
80
		$this->initialiserRessourcesEtParametres($ressources, $parametres);
80
		$this->initialiserRessourcesEtParametres($ressources, $parametres);
81
		
81
		
82
		$this->configurer();
82
		$this->configurer();
83
		$this->verifierConfiguration();
83
		$this->verifierConfiguration();
84
	
84
	
85
		$this->verifierParametresTri();
85
		$this->verifierParametresTri();
86
		$this->initialiserTri();
86
		$this->initialiserTri();
87
		
87
		
88
		$this->verifierParametreFormatRetour();
88
		$this->verifierParametreFormatRetour();
89
		$this->initialiserFormatRetour();
89
		$this->initialiserFormatRetour();
90
	
90
	
91
		$parametres = $this->nettoyerParametres($parametres);
91
		$parametres = $this->nettoyerParametres($parametres);
92
	
92
	
93
		// En fonction des paramètres de recherche, on n'effectue
93
		// En fonction des paramètres de recherche, on n'effectue
94
		// pas la même requête, pour optimiser les jointures et les
94
		// pas la même requête, pour optimiser les jointures et les
95
		// rapidités d'éxécution.
95
		// rapidités d'éxécution.
96
		$type = $this->getTypeRequete($ressources, $parametres);
96
		$type = $this->getTypeRequete($ressources, $parametres);
97
	
-
 
98
		switch ($type) {
97
		switch ($type) {
99
			case 'obs' :
98
			case 'obs' :
100
				$liaisons = $this->chargerLiaisonsObs();
99
				$liaisons = $this->chargerLiaisonsObs();
101
			break;
100
			break;
102
			case 'images' :
101
			case 'images' :
103
				$liaisons = $this->chargerLiaisonsImages();
102
				$liaisons = $this->chargerLiaisonsImages();
104
			break;
103
			break;
105
			case 'obs-images' :
104
			case 'obs-images' :
106
				$liaisons = $this->chargerLiaisons();
105
				$liaisons = $this->chargerLiaisons();
107
			break;
106
			break;
108
			case 'id':
107
			case 'id':
109
				$liaisons = $this->chargerLiaisonsParId();
108
				$liaisons = $this->chargerLiaisonsParId();
110
			break;
109
			break;
111
			default : //case simple !
110
			default : //case simple !
112
				$liaisons = $this->chargerLiaisonsSimple();
111
				$liaisons = $this->chargerLiaisonsSimple();
113
		}
112
		}
114
	
113
	
115
		$images = array();
114
		$images = array();
116
		if($liaisons) {
115
		if($liaisons) {
117
			// Partie commune à tous les cas : on complète les liaisons avec les informations des votes
116
			// Partie commune à tous les cas : on complète les liaisons avec les informations des votes
118
			// et des images, puis on affiche sous forme de JSON
117
			// et des images, puis on affiche sous forme de JSON
119
			$images = $this->chargerImage($liaisons);
118
			$images = $this->chargerImage($liaisons);
120
			$images = $this->chargerVotes($images);
119
			$images = $this->chargerVotes($images);
121
		}
120
		}
122
 
121
 
123
		$resultat = new ResultatService();
122
		$resultat = new ResultatService();
124
		if ($type == 'id') {
123
		if ($type == 'id') {
125
			$clefsImages =array_keys($images);
124
			$clefsImages =array_keys($images);
126
			$resultat->corps = $images[$clefsImages[0]];
125
			$resultat->corps = $images[$clefsImages[0]];
127
		} else {
126
		} else {
128
			$resultat->corps = array('entete' => $this->conteneur->getEntete(), 'resultats' => $images);
127
			$resultat->corps = array('entete' => $this->conteneur->getEntete(), 'resultats' => $images);
129
		}
128
		}
130
 
129
 
131
		return $resultat;
130
		return $resultat;
132
	}
131
	}
133
	
132
	
134
	
133
	
135
	
134
	
136
	/**************************************************************************************
135
	/**************************************************************************************
137
	 *								FONCTION LIEES AUX REQUETES 						  *
136
	 *								FONCTION LIEES AUX REQUETES 						  *
138
	 **************************************************************************************/
137
	 **************************************************************************************/
139
	
138
	
140
	/**
139
	/**
141
	 * Charger la clause WHERE en fonction des paramètres de masque
140
	 * Charger la clause WHERE en fonction des paramètres de masque
142
	 * */
141
	 * */
143
	private function chargerClauseWhere() {
142
	private function chargerClauseWhere() {
144
 
143
 
145
		$where = array();
144
		$where = array();
146
		$tableauMasque = $this->masque->getMasque();
145
		$tableauMasque = $this->masque->getMasque();
147
		if (!empty($tableauMasque)) {
146
		if (!empty($tableauMasque)) {
148
			foreach($tableauMasque as $idMasque => $valeurMasque) {
147
			foreach($tableauMasque as $idMasque => $valeurMasque) {
149
				//TODO: scinder ceci en fonctions réutilisables ?
148
				//TODO: scinder ceci en fonctions réutilisables ?
150
				// voir si c'est interessant par rapport à la recherche générale
149
				// voir si c'est interessant par rapport à la recherche générale
151
				$idMasque = str_replace('masque.', '', $idMasque);
150
				$idMasque = str_replace('masque.', '', $idMasque);
152
				switch ($idMasque) {
151
				switch ($idMasque) {
153
				// nom du masque => nom BDD
152
				// nom du masque => nom BDD
154
					case 'auteur' :
153
					case 'auteur' :
155
							$whereAuteur = ' '.$this->creerFiltreAuteur($this->masque->getMasque('auteur'));
154
							$whereAuteur = ' '.$this->creerFiltreAuteur($this->masque->getMasque('auteur'));
156
									if($whereAuteur != '') {
155
									if($whereAuteur != '') {
157
										$where[] = $whereAuteur;
156
										$where[] = $whereAuteur;
158
									}
157
									}
159
									break;
158
									break;
160
					case 'date' :
159
					case 'date' :
161
					$whereDate = ' '.$this->creerFiltreDate($valeurMasque);
160
					$whereDate = ' '.$this->creerFiltreDate($valeurMasque);
162
					if($whereDate != '') {
161
					if($whereDate != '') {
163
						$where[] = $whereDate;
162
						$where[] = $whereDate;
164
					}
163
					}
165
					break;
164
					break;
166
					case 'departement' :
165
					case 'departement' :
167
						$where[] = ' '.$this->creerFiltreIdZoneGeo($valeurMasque);
166
						$where[] = ' '.$this->creerFiltreIdZoneGeo($valeurMasque);
168
						break;
167
						break;
169
					case 'genre' :
168
					case 'genre' :
170
						$where[] = ' '.$this->mappingFiltre['ns'].' LIKE '.$this->proteger($valeurMasque.' %');
169
						$where[] = ' '.$this->mappingFiltre['ns'].' LIKE '.$this->proteger($valeurMasque.' %');
171
						break;
170
						break;
172
					case 'tag' :
171
					case 'tag' :
173
						$where[] = ' '.$this->creerFiltreMotsCles($valeurMasque);
172
						$where[] = ' '.$this->creerFiltreMotsCles($valeurMasque);
174
						break;
173
						break;
-
 
174
					case 'tag_cel' :
-
 
175
						$where[] = ' '.$this->creerFiltreMotsClesCel($valeurMasque);
-
 
176
						break;
-
 
177
					case 'tag_pictoflora' :
-
 
178
						$where[] = ' '.$this->creerFiltreMotsClesPictoflora($valeurMasque);
-
 
179
						break;
175
					case 'referentiel' :
180
					case 'referentiel' :
176
						$where[] = ' dob.nom_referentiel LIKE '.$this->proteger($valeurMasque.'%');
181
						$where[] = ' dob.nom_referentiel LIKE '.$this->proteger($valeurMasque.'%');
177
						break;
182
						break;
178
					case 'ns' :
183
					case 'ns' :
179
						$where[] = ' nom_sel LIKE '.$this->proteger($valeurMasque.'%');
184
						$where[] = ' nom_sel LIKE '.$this->proteger($valeurMasque.'%');
180
						break;
185
						break;
181
					case 'nn' :
186
					case 'nn' :
182
						$num_noms = $valeurMasque;
187
						$num_noms = $valeurMasque;
183
						$num_noms = explode(',', $num_noms);
188
						$num_noms = explode(',', $num_noms);
184
						$num_noms = array_map('intval', $num_noms);
189
						$num_noms = array_map('intval', $num_noms);
185
						$num_noms = array_filter($num_noms);
190
						$num_noms = array_filter($num_noms);
186
						$num_noms = implode(',', $num_noms);
191
						$num_noms = implode(',', $num_noms);
187
						$where[] = "(nom_sel_nn IN ($num_noms) OR nom_ret_nn IN ($num_noms)) ";
192
						$where[] = "(nom_sel_nn IN ($num_noms) OR nom_ret_nn IN ($num_noms)) ";
188
						break;
193
						break;
189
					case 'commune' :
194
					case 'commune' :
190
						$where[] = ' '.$this->mappingFiltre[$idMasque].' LIKE '.$this->proteger(str_replace(array('-',' '), '_', $valeurMasque).'%');
195
						$where[] = ' '.$this->mappingFiltre[$idMasque].' LIKE '.$this->proteger(str_replace(array('-',' '), '_', $valeurMasque).'%');
191
						break;
196
						break;
192
					case 'masque' :
197
					case 'masque' :
193
						$where[] = ' '.$this->creerFiltreMasqueGeneral($valeurMasque);
198
						$where[] = ' '.$this->creerFiltreMasqueGeneral($valeurMasque);
194
						break;
199
						break;
195
					default:
200
					default:
196
						$where[] = ' '.$this->mappingFiltre[$idMasque].' = '.$this->proteger($valeurMasque);
201
						$where[] = ' '.$this->mappingFiltre[$idMasque].' = '.$this->proteger($valeurMasque);
197
						break;
202
						break;
198
				}
203
				}
199
			}
204
			}
200
		}
205
		}
201
	
206
	
202
		if (!empty($where)) {
207
		if (!empty($where)) {
203
			return ' WHERE '.implode('AND', $where);
208
			return ' WHERE '.implode('AND', $where);
204
		} else {
209
		} else {
205
			return;
210
			return;
206
		}
211
		}
207
	}
212
	}
208
	
213
	
209
	/**
214
	/**
210
	 * Créer un masque général lorsque l'on souhaite utiliser le passe partout
215
	 * Créer un masque général lorsque l'on souhaite utiliser le passe partout
211
	 * @param la valeur du passe partout
216
	 * @param la valeur du passe partout
212
	 * */
217
	 * */
213
	private function creerFiltreMasqueGeneral($valeurMasque) {
218
	private function creerFiltreMasqueGeneral($valeurMasque) {
214
		//TODO: affecter d'aborder les variables, puis les tester pour les
219
		//TODO: affecter d'aborder les variables, puis les tester pour les
215
		// ajouter à la chaine
220
		// ajouter à la chaine
216
		$whereAuteur = $this->creerFiltreAuteur($valeurMasque);
221
		$whereAuteur = $this->creerFiltreAuteur($valeurMasque);
217
		$whereIdZoneGeo = $this->creerFiltreIdZoneGeo($valeurMasque);
222
		$whereIdZoneGeo = $this->creerFiltreIdZoneGeo($valeurMasque);
218
	
223
	
219
		$masqueGeneral = '( '.
224
		$masqueGeneral = '( '.
220
				(($whereAuteur != '') ? $whereAuteur.' OR ' : '' ).
225
				(($whereAuteur != '') ? $whereAuteur.' OR ' : '' ).
221
				(($whereIdZoneGeo != '') ? $whereIdZoneGeo.' OR ' : '' ).
226
				(($whereIdZoneGeo != '') ? $whereIdZoneGeo.' OR ' : '' ).
222
				'zone_geo LIKE '.$this->proteger($this->remplacerParJokerCaractere($valeurMasque).'%').' OR '.
227
				'zone_geo LIKE '.$this->proteger($this->remplacerParJokerCaractere($valeurMasque).'%').' OR '.
223
				$this->creerFiltreMotsCles($valeurMasque).' OR '.
228
				$this->creerFiltreMotsCles($valeurMasque).' OR '.
224
				'nom_sel LIKE '.$this->proteger($valeurMasque.'%').' OR '.
229
				'nom_sel LIKE '.$this->proteger($valeurMasque.'%').' OR '.
225
				'famille LIKE '.$this->proteger($valeurMasque.'%').' OR '.
230
				'famille LIKE '.$this->proteger($valeurMasque.'%').' OR '.
226
				'milieu LIKE '.$this->proteger($valeurMasque).' OR '.
231
				'milieu LIKE '.$this->proteger($valeurMasque).' OR '.
227
				$this->mappingFiltre['ns'].' LIKE '.$this->proteger('%'.$valeurMasque.'% %').' OR '.
232
				$this->mappingFiltre['ns'].' LIKE '.$this->proteger('%'.$valeurMasque.'% %').' OR '.
228
				$this->creerFiltreDate($valeurMasque).
233
				$this->creerFiltreDate($valeurMasque).
229
				') ';
234
				') ';
230
	
235
	
231
		return $masqueGeneral;
236
		return $masqueGeneral;
232
	}
237
	}
233
	
238
	
234
	/**
239
	/**
235
	 * Créer le filtre auteur en recherchant dans son nom, prénom, adresse email en fonction 
240
	 * Créer le filtre auteur en recherchant dans son nom, prénom, adresse email en fonction 
236
	 * de la chaine donnée 
241
	 * de la chaine donnée 
237
	 * @param la valeur recherchée
242
	 * @param la valeur recherchée
238
	 * */
243
	 * */
239
	private function creerFiltreAuteur($valeurMasque) {
244
	private function creerFiltreAuteur($valeurMasque) {
240
		$masque = '';
245
		$masque = '';
241
		$auteurId = $valeurMasque;
246
		$auteurId = $valeurMasque;
242
		if (is_numeric($auteurId)) {
247
		if (is_numeric($auteurId)) {
243
			$masque = ' ce_utilisateur = '.$auteurId;
248
			$masque = ' ce_utilisateur = '.$auteurId;
244
		} else {
249
		} else {
245
			if (strpos($auteurId, '@') === false) {
250
			if (strpos($auteurId, '@') === false) {
246
				$tableauNomPrenom = explode(' ',$auteurId, 2);
251
				$tableauNomPrenom = explode(' ',$auteurId, 2);
247
				if(count($tableauNomPrenom) == 2) {
252
				if(count($tableauNomPrenom) == 2) {
248
					// on teste potentiellement un nom prenom ou bien un prénom nom
253
					// on teste potentiellement un nom prenom ou bien un prénom nom
249
					$masque = '('.
254
					$masque = '('.
250
							'(nom LIKE '.$this->proteger($tableauNomPrenom[0].'%').' AND '.
255
							'(nom LIKE '.$this->proteger($tableauNomPrenom[0].'%').' AND '.
251
							'prenom LIKE '.$this->proteger($tableauNomPrenom[1].'%').') OR '.
256
							'prenom LIKE '.$this->proteger($tableauNomPrenom[1].'%').') OR '.
252
							'(nom LIKE '.$this->proteger($tableauNomPrenom[1].'%').' AND '.
257
							'(nom LIKE '.$this->proteger($tableauNomPrenom[1].'%').' AND '.
253
							'prenom LIKE '.$this->proteger($tableauNomPrenom[0].'%').') OR '.
258
							'prenom LIKE '.$this->proteger($tableauNomPrenom[0].'%').') OR '.
254
							'(dob.nom_utilisateur LIKE '.$this->proteger($tableauNomPrenom[0].'%').' AND '.
259
							'(dob.nom_utilisateur LIKE '.$this->proteger($tableauNomPrenom[0].'%').' AND '.
255
							'dob.prenom_utilisateur LIKE '.$this->proteger($tableauNomPrenom[1].'%').') OR '.
260
							'dob.prenom_utilisateur LIKE '.$this->proteger($tableauNomPrenom[1].'%').') OR '.
256
							'(dob.nom_utilisateur LIKE '.$this->proteger($tableauNomPrenom[1].'%').' AND '.
261
							'(dob.nom_utilisateur LIKE '.$this->proteger($tableauNomPrenom[1].'%').' AND '.
257
							'dob.prenom_utilisateur LIKE '.$this->proteger($tableauNomPrenom[0].'%').') OR '.
262
							'dob.prenom_utilisateur LIKE '.$this->proteger($tableauNomPrenom[0].'%').') OR '.
258
							'(nom LIKE '.$this->proteger($valeurMasque.'%').') OR '.
263
							'(nom LIKE '.$this->proteger($valeurMasque.'%').') OR '.
259
							'(prenom LIKE '.$this->proteger($valeurMasque.'%').') OR '.
264
							'(prenom LIKE '.$this->proteger($valeurMasque.'%').') OR '.
260
							'(dob.nom_utilisateur LIKE '.$this->proteger($valeurMasque.'%').') OR '.
265
							'(dob.nom_utilisateur LIKE '.$this->proteger($valeurMasque.'%').') OR '.
261
							'(dob.prenom_utilisateur LIKE '.$this->proteger($valeurMasque.'%').') '.
266
							'(dob.prenom_utilisateur LIKE '.$this->proteger($valeurMasque.'%').') '.
262
							')';
267
							')';
263
				} else {
268
				} else {
264
					$masque = '(
269
					$masque = '(
265
						            (nom LIKE '.$this->proteger($auteurId.'%').' OR '.
270
						            (nom LIKE '.$this->proteger($auteurId.'%').' OR '.
266
							            'prenom LIKE '.$this->proteger($auteurId.'%').' OR '.
271
							            'prenom LIKE '.$this->proteger($auteurId.'%').' OR '.
267
							            'dob.nom_utilisateur LIKE '.$this->proteger($auteurId.'%').' OR '.
272
							            'dob.nom_utilisateur LIKE '.$this->proteger($auteurId.'%').' OR '.
268
							            'dob.prenom_utilisateur LIKE '.$this->proteger($auteurId.'%').')'.
273
							            'dob.prenom_utilisateur LIKE '.$this->proteger($auteurId.'%').')'.
269
							            ')';
274
							            ')';
270
				}
275
				}
271
			} else {
276
			} else {
272
				$masque = " ( courriel LIKE ".$this->proteger($valeurMasque.'%').
277
				$masque = " ( courriel LIKE ".$this->proteger($valeurMasque.'%').
273
				" OR dob.courriel_utilisateur LIKE ".$this->proteger($valeurMasque.'%').")  ";
278
				" OR dob.courriel_utilisateur LIKE ".$this->proteger($valeurMasque.'%').")  ";
274
			}
279
			}
275
		}
280
		}
276
		return $masque;
281
		return $masque;
277
	}
282
	}
278
	
283
	
279
	
284
	
280
	/**
285
	/**
281
	 * Obtenir une chaine de caractère concaténant nom et prénom séparé par une virgule
286
	 * Obtenir une chaine de caractère concaténant nom et prénom séparé par une virgule
282
	 * @param String $auteurId l'identifiant de l'auteur
287
	 * @param String $auteurId l'identifiant de l'auteur
283
	 * @return String la chaine de concaténation
288
	 * @return String la chaine de concaténation
284
	 * */
289
	 * */
285
	private function getChaineNomPrenom($auteurId) {
290
	private function getChaineNomPrenom($auteurId) {
286
		$nomPrenom = explode(' ', $auteurId);
291
		$nomPrenom = explode(' ', $auteurId);
287
		$nomPrenom = $this->proteger($nomPrenom);
292
		$nomPrenom = $this->proteger($nomPrenom);
288
		$chaineNomPrenom = implode(', ', $nomPrenom);
293
		$chaineNomPrenom = implode(', ', $nomPrenom);
289
		return $chaineNomPrenom;
294
		return $chaineNomPrenom;
290
	}
295
	}
291
	
296
	
292
	/**
297
	/**
293
	 * Créer le filtre de recherche par zone géographique en fonction du masque
298
	 * Créer le filtre de recherche par zone géographique en fonction du masque
294
	 * @param $valeurMasque le terme de la recherche
299
	 * @param $valeurMasque le terme de la recherche
295
	 * */
300
	 * */
296
	private function creerFiltreIdZoneGeo($valeurMasque) {
301
	private function creerFiltreIdZoneGeo($valeurMasque) {
297
		$masque = '';
302
		$masque = '';
298
		$dept = $valeurMasque;
303
		$dept = $valeurMasque;
299
		if (is_numeric($dept)) {
304
		if (is_numeric($dept)) {
300
			$dept = sprintf('%02s', $dept);
305
			$dept = sprintf('%02s', $dept);
301
			$dept = sprintf("%-'_5s", $dept);
306
			$dept = sprintf("%-'_5s", $dept);
302
			$masque = " ce_zone_geo LIKE ".$this->proteger('INSEE-C:'.$dept);
307
			$masque = " ce_zone_geo LIKE ".$this->proteger('INSEE-C:'.$dept);
303
		} else {
308
		} else {
304
			$deptId = $this->conteneur->getParametre($dept);
309
			$deptId = $this->conteneur->getParametre($dept);
305
			if ($deptId != null) {
310
			if ($deptId != null) {
306
				$masque = " ce_zone_geo LIKE ".$this->proteger('INSEE-C:'.$deptId.'%');
311
				$masque = " ce_zone_geo LIKE ".$this->proteger('INSEE-C:'.$deptId.'%');
307
			} else {
312
			} else {
308
				$id = $this->obtenirIdDepartement($valeurMasque);
313
				$id = $this->obtenirIdDepartement($valeurMasque);
309
				$masque = " ce_zone_geo LIKE ".$this->proteger('INSEE-C:'.$id.'%');
314
				$masque = " ce_zone_geo LIKE ".$this->proteger('INSEE-C:'.$id.'%');
310
			}
315
			}
311
		}
316
		}
312
		return $masque;
317
		return $masque;
313
	}
318
	}
314
	
319
	
315
	/**
320
	/**
316
	 * Générer la chaine de recherche pour la date en  fonction du masque
321
	 * Générer la chaine de recherche pour la date en  fonction du masque
317
	 * @param $valeurMasque la date recherchée (AAAA ou JJ/MM/AAAA)
322
	 * @param $valeurMasque la date recherchée (AAAA ou JJ/MM/AAAA)
318
	 * */
323
	 * */
319
	private function creerFiltreDate($valeurMasque) {
324
	private function creerFiltreDate($valeurMasque) {
320
		//TODO: définir dans le fichier de config un tableau contenant plusieurs format de date
325
		//TODO: définir dans le fichier de config un tableau contenant plusieurs format de date
321
		// autorisés pour la recherche, qui seraient ajoutés au OR
326
		// autorisés pour la recherche, qui seraient ajoutés au OR
322
		$masque = '(';
327
		$masque = '(';
323
		$masque .= (is_numeric($valeurMasque)) ? ' YEAR(date_observation) = '.$this->proteger($valeurMasque).' OR ' : '';
328
		$masque .= (is_numeric($valeurMasque)) ? ' YEAR(date_observation) = '.$this->proteger($valeurMasque).' OR ' : '';
324
		$masque .= " DATE_FORMAT(date_observation, '%d/%m/%Y') = ".$this->proteger($valeurMasque).' '.
329
		$masque .= " DATE_FORMAT(date_observation, '%d/%m/%Y') = ".$this->proteger($valeurMasque).' '.
325
				')';
330
				')';
326
		return $masque;
331
		return $masque;
327
	}
332
	}
328
	
333
	
329
	/**
334
	/**
330
	 * Générer la chaine de recherche dans les mots clés en fonction du masque
335
	 * Générer la chaine de recherche dans les mots clés en fonction du masque
331
	 * @param $valeurMasque le mot clé recherché
336
	 * @param $valeurMasque le mot clé recherché
332
	 * */
337
	 * */
333
	private function creerFiltreMotsCles($valeurMasque) {
338
	private function creerFiltreMotsCles($valeurMasque) {
334
	
339
	
335
		$mots_cles = explode(' ', $valeurMasque);
340
		$mots_cles = explode(' ', $valeurMasque);
336
		$requeteMotsClesImg = array();
341
		$requeteMotsClesImg = array();
337
		$requeteMotsClesObs = array();
342
		$requeteMotsClesObs = array();
338
		$requeteMotsClesImgPublic = array();
343
		$requeteMotsClesImgPublic = array();
339
	
344
	
340
		foreach($mots_cles as $mot_cle) {
345
		foreach($mots_cles as $mot_cle) {
341
			//TODO: rechercher sur les mots clés normalisés dans tous les cas ?
346
			//TODO: rechercher sur les mots clés normalisés dans tous les cas ?
342
			$requeteMotsCles = $this->proteger('%'.$mot_cle.'%');
347
			$requeteMotsCles = $this->proteger('%'.$mot_cle.'%');
343
			$motsCleProtege = $this->proteger($this->normaliserMotCle('%'.$mot_cle.'%'));
348
			$motsCleProtege = $this->proteger($this->normaliserMotCle('%'.$mot_cle.'%'));
344
			$requeteMotsClesImgPublic[] = 'di.id_image IN (SELECT ce_image FROM del_image_tag WHERE tag_normalise LIKE '.$motsCleProtege.' AND actif = 1)';
349
			$requeteMotsClesImgPublic[] = 'di.id_image IN (SELECT ce_image FROM del_image_tag WHERE tag_normalise LIKE '.$motsCleProtege.' AND actif = 1)';
345
			$requeteMotsClesImg[] = 'di.mots_cles_texte LIKE '.$requeteMotsCles;
350
			$requeteMotsClesImg[] = 'di.mots_cles_texte LIKE '.$requeteMotsCles;
346
			$requeteMotsClesObs[] = 'dob.mots_cles_texte LIKE '.$requeteMotsCles;
351
			$requeteMotsClesObs[] = 'dob.mots_cles_texte LIKE '.$requeteMotsCles;
347
		}
352
		}
348
	
353
	
349
		$requeteMotsClesImgPublic = implode(' AND ', $requeteMotsClesImgPublic);
354
		$requeteMotsClesImgPublic = implode(' AND ', $requeteMotsClesImgPublic);
350
		$requeteMotsClesImg = implode(' AND ', $requeteMotsClesImg);
355
		$requeteMotsClesImg = implode(' AND ', $requeteMotsClesImg);
351
		$requeteMotsClesObs = implode(' AND ', $requeteMotsClesObs);
356
		$requeteMotsClesObs = implode(' AND ', $requeteMotsClesObs);
352
	
357
	
353
		$masque = '('.
358
		$masque = '('.
354
				'('.$requeteMotsClesImgPublic.') OR '.
359
				'('.$requeteMotsClesImgPublic.') OR '.
355
				'('.$requeteMotsClesImg.') OR '.
360
				'('.$requeteMotsClesImg.') OR '.
356
				'('.$requeteMotsClesObs.') '.
361
				'('.$requeteMotsClesObs.') '.
357
				')';
362
				')';
358
	
363
	
359
		return $masque;
364
		return $masque;
360
	}
365
	}
-
 
366
	
-
 
367
	/**
-
 
368
	* Générer la chaine de recherche dans les mots clés en fonction du masque
-
 
369
	* @param $valeurMasque le mot clé recherché
-
 
370
	* */
-
 
371
	private function creerFiltreMotsClesPictoflora($valeurMasque) {
-
 
372
	
-
 
373
		$mots_cles = explode(' ', $valeurMasque);
-
 
374
		$requeteMotsClesImg = array();
-
 
375
		$requeteMotsClesObs = array();
-
 
376
		$requeteMotsClesImgPublic = array();
-
 
377
	
-
 
378
		foreach($mots_cles as $mot_cle) {
-
 
379
			//TODO: rechercher sur les mots clés normalisés dans tous les cas ?
-
 
380
			$requeteMotsCles = $this->proteger('%'.$mot_cle.'%');
-
 
381
			$motsCleProtege = $this->proteger($this->normaliserMotCle('%'.$mot_cle.'%'));
-
 
382
			$requeteMotsClesImgPublic[] = 'di.id_image IN (SELECT ce_image FROM del_image_tag WHERE tag_normalise LIKE '.$motsCleProtege.' AND actif = 1)';
-
 
383
		}
-
 
384
	
-
 
385
		$requeteMotsClesImgPublic = implode(' AND ', $requeteMotsClesImgPublic);
-
 
386
	
-
 
387
		$masque = '('.$requeteMotsClesImgPublic.') ';
-
 
388
	
-
 
389
		return $masque;
-
 
390
	}
-
 
391
	
-
 
392
	private function creerFiltreMotsClesCel($valeurMasque) {
-
 
393
		$mots_cles = explode(' ', $valeurMasque);
-
 
394
		$requeteMotsClesImg = array();
-
 
395
		$requeteMotsClesObs = array();
-
 
396
		
-
 
397
		foreach($mots_cles as $mot_cle) {
-
 
398
			//TODO: rechercher sur les mots clés normalisés dans tous les cas ?
-
 
399
			$requeteMotsCles = $this->proteger('%'.$mot_cle.'%');
-
 
400
			$motsCleProtege = $this->proteger($this->normaliserMotCle('%'.$mot_cle.'%'));
-
 
401
			$requeteMotsClesImg[] = 'di.mots_cles_texte LIKE '.$requeteMotsCles;
-
 
402
			$requeteMotsClesObs[] = 'dob.mots_cles_texte LIKE '.$requeteMotsCles;
-
 
403
		}
-
 
404
		
-
 
405
		$requeteMotsClesImg = implode(' AND ', $requeteMotsClesImg);
-
 
406
		$requeteMotsClesObs = implode(' AND ', $requeteMotsClesObs);
-
 
407
		
-
 
408
		$masque = '('.
-
 
409
						'('.$requeteMotsClesImg.') OR '.
-
 
410
						'('.$requeteMotsClesObs.') '.
-
 
411
					')';
-
 
412
		
-
 
413
		return $masque;
-
 
414
	}
361
	
415
	
362
	// ??
416
	// ??
363
	private function assemblercomptageOccurencesMotsClesCel() {
417
	private function assemblercomptageOccurencesMotsClesCel() {
364
		$chaineMotsClesAffiches = $this->conteneur->getParametre('mots_cles_cel_affiches');
418
		$chaineMotsClesAffiches = $this->conteneur->getParametre('mots_cles_cel_affiches');
365
		$tabMotsClesAffiches = explode(',',$chaineMotsClesAffiches);
419
		$tabMotsClesAffiches = explode(',',$chaineMotsClesAffiches);
366
		$chaineSql = '';
420
		$chaineSql = '';
367
	
421
	
368
		// Comptage du nombre de mots clés officiels présents dans la chaine mots clés texte
422
		// Comptage du nombre de mots clés officiels présents dans la chaine mots clés texte
369
		foreach ($tabMotsClesAffiches as $motCle) {
423
		foreach ($tabMotsClesAffiches as $motCle) {
370
			if($chaineSql != '') {
424
			if($chaineSql != '') {
371
				$chaineSql .= ' + ';
425
				$chaineSql .= ' + ';
372
			}
426
			}
373
			$chaineSql .= 'IF(FIND_IN_SET('.$this->proteger($motCle).',di.mots_cles_texte) != 0, 1, 0)';
427
			$chaineSql .= 'IF(FIND_IN_SET('.$this->proteger($motCle).',di.mots_cles_texte) != 0, 1, 0)';
374
		}
428
		}
375
	
429
	
376
		return '('.$chaineSql.')';
430
		return '('.$chaineSql.')';
377
	}
431
	}
378
	
432
	
379
	private function getTri() {
433
	private function getTri() {
380
		$order = '';
434
		$order = '';
381
		if($this->doitJoindreTableVotes()) {
435
		if($this->doitJoindreTableVotes()) {
382
			$order = ' GROUP BY dvote.ce_image, dob.id_observation ORDER BY total_votes '.$this->directionTri.', date_transmission desc ';
436
			$order = ' GROUP BY dvote.ce_image, dob.id_observation ORDER BY total_votes '.$this->directionTri.', date_transmission desc ';
383
		} else if($this->doitJoindreTableTags()) {
437
		} else if($this->doitJoindreTableTags()) {
384
			$order = ' GROUP BY doi.id_image ORDER BY total_tags '.$this->directionTri.', date_transmission desc ';
438
			$order = ' GROUP BY doi.id_image ORDER BY total_tags '.$this->directionTri.', date_transmission desc ';
385
		} else {
439
		} else {
386
			$order = ' ORDER BY '.$this->tri.' '.$this->directionTri.' ';
440
			$order = ' ORDER BY '.$this->tri.' '.$this->directionTri.' ';
387
		}
441
		}
388
		return $order;
442
		return $order;
389
	}
443
	}
390
	
444
	
391
	/**
445
	/**
392
	 * Compter le nombre total d'images dans la base pour affichage dans entete.
446
	 * Compter le nombre total d'images dans la base pour affichage dans entete.
393
	 * */
447
	 * */
394
	private function getFoundRows() {
448
	private function getFoundRows() {
395
		$requete = 'SELECT FOUND_ROWS() AS nbre ';
449
		$requete = 'SELECT FOUND_ROWS() AS nbre ';
396
		$resultats = $this->bdd->recuperer($requete);
450
		$resultats = $this->bdd->recuperer($requete);
397
		return (int) $resultats['nbre'];
451
		return (int) $resultats['nbre'];
398
	}
452
	}
399
	
453
	
400
	
454
	
401
	/**
455
	/**
402
	 * En fonction des paramètres, générer les conditions de recherche 
456
	 * En fonction des paramètres, générer les conditions de recherche 
403
	 * des observations
457
	 * des observations
404
	 * */
458
	 * */
405
	private function getConditionsObs() {
459
	private function getConditionsObs() {
406
		$conditionsObs = array();
460
		$conditionsObs = array();
407
		$masques = $this->masque->getMasque();
461
		$masques = $this->masque->getMasque();
408
		if (isset($masques['masque'])) {
462
		if (isset($masques['masque'])) {
409
			$passe = $masques['masque'];
463
			$passe = $masques['masque'];
410
				
464
				
411
			// Si on a saisi le masque passe partout, alors on doit chercher dans tous les champs
465
			// Si on a saisi le masque passe partout, alors on doit chercher dans tous les champs
412
			// de la table observation (OR)
466
			// de la table observation (OR)
413
			$conditionLibre = array();
467
			$conditionLibre = array();
414
		
468
		
415
			if (!isset($masques['masque.ns'])) {
469
			if (!isset($masques['masque.ns'])) {
416
				$conditionsLibre[] = "nom_sel LIKE '$passe%'";
470
				$conditionsLibre[] = "nom_sel LIKE '$passe%'";
417
			}
471
			}
418
		
472
		
419
			if (!isset($masques['masque.famille'])) {
473
			if (!isset($masques['masque.famille'])) {
420
				$conditionsLibre[] = "famille LIKE '$passe%'";
474
				$conditionsLibre[] = "famille LIKE '$passe%'";
421
			}
475
			}
422
		
476
		
423
			if (!isset($masques['masque.milieu'])) {
477
			if (!isset($masques['masque.milieu'])) {
424
				$conditionsLibre[] = "nom_sel LIKE '$passe%'";
478
				$conditionsLibre[] = "nom_sel LIKE '$passe%'";
425
			}
479
			}
426
		
480
		
427
			if (!isset($masques['masque.date'])) {
481
			if (!isset($masques['masque.date'])) {
428
				$conditionsLibre[] = $this->creerFiltreDate($passe);
482
				$conditionsLibre[] = $this->creerFiltreDate($passe);
429
			}
483
			}
430
		
484
		
431
			if (!isset($masques['masque.auteur'])) {
485
			if (!isset($masques['masque.auteur'])) {
432
				$conditionsLibre[] = $this->creerFiltreAuteur($passe);
486
				$conditionsLibre[] = $this->creerFiltreAuteur($passe);
433
			}
487
			}
434
		
488
		
435
			/*
489
			/*
436
			 * FIXME : remplacer par motcle projet !
490
			 * FIXME : remplacer par motcle projet !
437
			* if (!isset($masques['masque.tag'])) {
491
			* if (!isset($masques['masque.tag'])) {
438
			$conditionsLibre[] = "mots_cles_texte LIKE '%$passe%'";
492
			$conditionsLibre[] = "mots_cles_texte LIKE '%$passe%'";
439
			}*/
493
			}*/
440
				
494
				
441
			$conditionsObs[] = implode(' OR ', $conditionsLibre);
495
			$conditionsObs[] = implode(' OR ', $conditionsLibre);
442
		}
496
		}
443
 
497
 
444
		// referentiel
498
		// referentiel
445
		if (isset($masques['masque.referentiel'])) {
499
		if (isset($masques['masque.referentiel'])) {
446
			$ref = $masques['masque.referentiel'];
500
			$ref = $masques['masque.referentiel'];
447
			$conditionsObs[] = "dob.nom_referentiel LIKE '$ref%'";
501
			$conditionsObs[] = "dob.nom_referentiel LIKE '$ref%'";
448
		}
502
		}
449
		
503
		
450
		// nom sel
504
		// nom sel
451
		if (isset($masques['masque.ns'])) {
505
		if (isset($masques['masque.ns'])) {
452
			$nom_sel = $masques['masque.ns'];
506
			$nom_sel = $masques['masque.ns'];
453
			$conditionsObs[] = "nom_sel LIKE '$nom_sel%'";
507
			$conditionsObs[] = "nom_sel LIKE '$nom_sel%'";
454
		}
508
		}
455
		
509
		
456
		// num nom
510
		// num nom
457
		if (isset($masques['masque.nn'])) {
511
		if (isset($masques['masque.nn'])) {
458
			$num_noms = $masques['masque.nn'];
512
			$num_noms = $masques['masque.nn'];
459
			$num_noms = explode(',', $num_noms);
513
			$num_noms = explode(',', $num_noms);
460
			$num_noms = array_map('intval', $num_noms);
514
			$num_noms = array_map('intval', $num_noms);
461
			$num_noms = array_filter($num_noms);
515
			$num_noms = array_filter($num_noms);
462
			$num_noms = implode(',', $num_noms);
516
			$num_noms = implode(',', $num_noms);
463
			$conditionsObs[] = "(nom_sel_nn IN ($num_noms) OR nom_ret_nn IN ($num_noms)) ";
517
			$conditionsObs[] = "(nom_sel_nn IN ($num_noms) OR nom_ret_nn IN ($num_noms)) ";
464
		}
518
		}
465
		
519
		
466
		// num taxon
520
		// num taxon
467
		if (isset($masques['masque.nt'])) {
521
		if (isset($masques['masque.nt'])) {
468
			$num_taxon = $masques['masque.nt'];
522
			$num_taxon = $masques['masque.nt'];
469
			$conditionsObs[] = 'nt = '.intval($num_taxon);
523
			$conditionsObs[] = 'nt = '.intval($num_taxon);
470
		}
524
		}
471
		
525
		
472
		// famille
526
		// famille
473
		if (isset($masques['masque.famille'])) {
527
		if (isset($masques['masque.famille'])) {
474
			$famille = $masques['masque.famille'];
528
			$famille = $masques['masque.famille'];
475
			$conditionsObs[] = "famille LIKE '$famille%'";
529
			$conditionsObs[] = "famille LIKE '$famille%'";
476
		}
530
		}
477
		
531
		
478
		// genre
532
		// genre
479
		if (isset($masques['masque.genre'])) {
533
		if (isset($masques['masque.genre'])) {
480
			$genre = $masques['masque.genre'];
534
			$genre = $masques['masque.genre'];
481
			$conditionsObs[] = "nom_sel LIKE '$genre%'";
535
			$conditionsObs[] = "nom_sel LIKE '$genre%'";
482
		}
536
		}
483
			
537
			
484
		// milieu
538
		// milieu
485
		if (isset($masques['masque.milieu'])) {
539
		if (isset($masques['masque.milieu'])) {
486
			$milieu = $masques['masque.milieu'];
540
			$milieu = $masques['masque.milieu'];
487
			$conditionsObs[] = "nom_sel LIKE '$milieu%'";
541
			$conditionsObs[] = "nom_sel LIKE '$milieu%'";
488
		}
542
		}
489
		
543
		
490
		// date
544
		// date
491
		if (isset($masques['masque.date'])) {
545
		if (isset($masques['masque.date'])) {
492
			$date = $masques['masque.date'];
546
			$date = $masques['masque.date'];
493
			$conditionsObs[] = $this->creerFiltreDate($date);
547
			$conditionsObs[] = $this->creerFiltreDate($date);
494
		}
548
		}
495
		
549
		
496
		// utilisateur
550
		// utilisateur
497
		if (isset($masques['masque.auteur'])) {
551
		if (isset($masques['masque.auteur'])) {
498
			$auteur = $masques['masque.auteur'];
552
			$auteur = $masques['masque.auteur'];
499
			$conditionsObs[] = $this->creerFiltreAuteur($auteur);
553
			$conditionsObs[] = $this->creerFiltreAuteur($auteur);
500
		}
554
		}
501
		
555
		
502
		// commune
556
		// commune
503
		if (isset($masques['masque.commune'])) {
557
		if (isset($masques['masque.commune'])) {
504
			$commune = $masques['masque.commune'];
558
			$commune = $masques['masque.commune'];
505
			$conditionsObs[] = " zone_geo LIKE ".$this->proteger(str_replace(array('-',' '), '_', $commune).'%');
559
			$conditionsObs[] = " zone_geo LIKE ".$this->proteger(str_replace(array('-',' '), '_', $commune).'%');
506
		}
560
		}
507
		
561
		
508
		// commune
562
		// commune
509
		if (isset($masques['masque.departement'])) {
563
		if (isset($masques['masque.departement'])) {
510
			$dept = $masques['masque.departement'];
564
			$dept = $masques['masque.departement'];
511
			$conditionsObs[] = $this->creerFiltreIdZoneGeo($dept);
565
			$conditionsObs[] = $this->creerFiltreIdZoneGeo($dept);
512
		}
566
		}
-
 
567
		
-
 
568
		if (isset($masques['masque.tag_cel'])) {
-
 
569
			$motsCles = $masques['masque.tag_cel'];
-
 
570
			$conditionsObs[] = $this->creerFiltreMotsClesCel($motsCles);
-
 
571
		}
513
 
572
 
514
		return $conditionsObs;
573
		return $conditionsObs;
515
	}
574
	}
516
	
575
	
517
	/**
576
	/**
518
	 * Obtenir le tableu de chaines de condition de requete images en fonction des masques
577
	 * Obtenir le tableu de chaines de condition de requete images en fonction des masques
519
	 * */
578
	 * */
520
	private function getConditionsImages() {
579
	private function getConditionsImages() {
521
		$conditionsImg = array();
580
		$conditionsImg = array();
522
		$masques = $this->masque->getMasque();
581
		$masques = $this->masque->getMasque();
523
		if (isset($masques['masque.tag'])) {
582
		if (isset($masques['masque.tag_pictoflora'])) {
524
			$tag = $masques['masque.tag'];
583
			$tag = $masques['masque.tag_pictoflora'];
525
			$conditionsImg[] = " dit.tag_normalise LIKE '$tag%' ";
-
 
526
			$conditionsImg[] = " di.mots_cles_texte LIKE '%$tag%' ";
584
			$conditionsImg[] = $this->creerFiltreMotsClesPictoflora($tag);
527
		}
585
		}
528
		
586
		
529
		return $conditionsImg;
587
		return $conditionsImg;
530
	}
588
	}
531
	
589
	
532
	
590
	
533
	/*-------------------------------------------------------------------------------
591
	/*-------------------------------------------------------------------------------
534
	 CHARGEMENT DES IMAGES
592
	 CHARGEMENT DES IMAGES
535
	--------------------------------------------------------------------------------*/
593
	--------------------------------------------------------------------------------*/
536
	/**
594
	/**
537
	 * Chargement depuis la bdd de toutes les liaisons entre images et observations
595
	 * Chargement depuis la bdd de toutes les liaisons entre images et observations
538
	 * Méthode appelée uniquement lorsque les paramètres sont vides
596
	 * Méthode appelée uniquement lorsque les paramètres sont vides
539
	 * */
597
	 * */
540
	private function chargerLiaisonsSimple() {
598
	private function chargerLiaisonsSimple() {
541
	
599
	
542
		// On récupère d'abord les N images de del_obs_image, éventuellement triées, 
600
		// On récupère d'abord les N images de del_obs_image, éventuellement triées, 
543
		// Et on complète avec les informations des observations associées
601
		// Et on complète avec les informations des observations associées
544
		$requeteImages = ' SELECT *, di.mots_cles_texte as mots_cles_texte_image '.
602
		$requeteImages = ' SELECT *, di.mots_cles_texte as mots_cles_texte_image '.
545
						 ' FROM del_obs_image doi '.
603
						 ' FROM del_obs_image doi '.
546
						 ' INNER JOIN del_image di ON doi.id_image = di.id_image ';
604
						 ' INNER JOIN del_image di ON doi.id_image = di.id_image ';
547
 
605
 
548
		// Si le tri se fait par date d'observation, on récupère les identifiants de N observations triées
606
		// Si le tri se fait par date d'observation, on récupère les identifiants de N observations triées
549
		if (isset($this->parametres['tri']) && $this->parametres['tri'] == 'date_observation') {
607
		if (isset($this->parametres['tri']) && $this->parametres['tri'] == 'date_observation') {
550
			
608
			
551
			$ordre = isset($this->parametres['ordre']) ? $this->parametres['ordre'] : 'DESC';
609
			$ordre = isset($this->parametres['ordre']) ? $this->parametres['ordre'] : 'DESC';
552
	
610
	
553
			$requeteIdObs = ' SELECT doi.id_image  as id_image '.
611
			$requeteIdObs = ' SELECT doi.id_image  as id_image '.
554
							' FROM del_obs_image doi '.
612
							' FROM del_obs_image doi '.
555
							' INNER JOIN del_observation dob ON dob.id_observation = doi.id_observation '.
613
							' INNER JOIN del_observation dob ON dob.id_observation = doi.id_observation '.
556
							' INNER JOIN del_image di ON doi.id_image = di.id_image '.
614
							' INNER JOIN del_image di ON doi.id_image = di.id_image '.
557
							' ORDER BY date_observation '.$ordre.', dob.id_observation '.$ordre;
615
							' ORDER BY date_observation '.$ordre.', dob.id_observation '.$ordre;
558
			$requeteIdObs .= $this->gestionBdd->getLimitSql();
616
			$requeteIdObs .= $this->gestionBdd->getLimitSql();
559
			
617
			
560
			// Récupérer les N observations triées par date
618
			// Récupérer les N observations triées par date
561
			$observations = $this->bdd->recupererTous($requeteIdObs . ' -- ' . __FILE__ . ':' . __LINE__);
619
			$observations = $this->bdd->recupererTous($requeteIdObs . ' -- ' . __FILE__ . ':' . __LINE__);
562
			
620
			
563
			$idsImages = array();
621
			$idsImages = array();
564
			foreach ($observations as $observation) {
622
			foreach ($observations as $observation) {
565
				$idsImages[] = $observation['id_image'];
623
				$idsImages[] = $observation['id_image'];
566
			}
624
			}
567
			
625
			
568
			$chaineIdImages = implode(',', $idsImages);
626
			$chaineIdImages = implode(',', $idsImages);
569
			$requeteImages .= ' WHERE doi.id_image IN ('.$chaineIdImages.') '.
627
			$requeteImages .= ' WHERE doi.id_image IN ('.$chaineIdImages.') '.
570
							  ' GROUP BY doi.id_image, doi.id_observation '.
628
							  ' GROUP BY doi.id_image, doi.id_observation '.
571
							  ' ORDER BY FIELD(doi.id_image,  '.$chaineIdImages.')'.
629
							  ' ORDER BY FIELD(doi.id_image,  '.$chaineIdImages.')'.
572
							  ' LIMIT '.$this->navigation->getLimite(); // On limite sur le nombre car les obs peuvent avoir plusieurs images
630
							  ' LIMIT '.$this->navigation->getLimite(); // On limite sur le nombre car les obs peuvent avoir plusieurs images
573
			
631
			
574
		} else {
632
		} else {
575
			$requeteImages .= ' GROUP BY doi.id_image, doi.id_observation ';
633
			$requeteImages .= ' GROUP BY doi.id_image, doi.id_observation ';
576
			$requeteImages .= ' ORDER BY doi.id_observation DESC';
634
			$requeteImages .= ' ORDER BY doi.id_observation DESC';
577
			$requeteImages .= $this->gestionBdd->getLimitSql();
635
			$requeteImages .= $this->gestionBdd->getLimitSql();
578
		}
636
		}
579
	
637
	
580
		$liaisons = $this->bdd->recupererTous($requeteImages . ' -- ' . __FILE__ . ':' . __LINE__);
638
		$liaisons = $this->bdd->recupererTous($requeteImages . ' -- ' . __FILE__ . ':' . __LINE__);
581
			
639
			
582
		// Ce n'est pas la peine de continuer s'il n'y a pas eu de résultats dans la table del_obs_images
640
		// Ce n'est pas la peine de continuer s'il n'y a pas eu de résultats dans la table del_obs_images
583
		if (!empty($liaisons)) {
641
		if (!empty($liaisons)) {
584
			
642
			
585
			$idsObservations = array();
643
			$idsObservations = array();
586
			foreach ($liaisons as $image) {
644
			foreach ($liaisons as $image) {
587
				$idObs = $image['id_observation'];
645
				$idObs = $image['id_observation'];
588
				$idsObservations[$idObs] = $idObs;
646
				$idsObservations[$idObs] = $idObs;
589
			}
647
			}
590
			
648
			
591
			$chaineIdObs = implode(',', $idsObservations);
649
			$chaineIdObs = implode(',', $idsObservations);
592
			
650
			
593
			
651
			
594
			// On récupère les observations qui complètent la requête précédente
652
			// On récupère les observations qui complètent la requête précédente
595
			$requeteObservations = ' SELECT * '.
653
			$requeteObservations = ' SELECT * '.
596
								   ' FROM del_observation dob '.
654
								   ' FROM del_observation dob '.
597
								   ' LEFT JOIN del_utilisateur du ON dob.ce_utilisateur = du.id_utilisateur '.
655
								   ' LEFT JOIN del_utilisateur du ON dob.ce_utilisateur = du.id_utilisateur '.
598
								   ' WHERE id_observation IN ('.$chaineIdObs.')';
656
								   ' WHERE id_observation IN ('.$chaineIdObs.')';
599
								   		
657
								   		
600
			$resultatsObservations = $this->bdd->recupererTous($requeteObservations . ' -- ' . __FILE__ . ':' . __LINE__);
658
			$resultatsObservations = $this->bdd->recupererTous($requeteObservations . ' -- ' . __FILE__ . ':' . __LINE__);
601
		
659
		
602
			// FIXME : Ca ne doit pas arriver, mais que se passe-t-il s'il n'y a pas d'observation pour l'image ?! 
660
			// FIXME : Ca ne doit pas arriver, mais que se passe-t-il s'il n'y a pas d'observation pour l'image ?! 
603
			
661
			
604
			// On range les observations dans un tableau pour pouvoir les retrouver par leur id :
662
			// On range les observations dans un tableau pour pouvoir les retrouver par leur id :
605
			$observations = array();
663
			$observations = array();
606
			foreach ($resultatsObservations as $id => $observation) {
664
			foreach ($resultatsObservations as $id => $observation) {
607
				$idObs = $observation['id_observation'];
665
				$idObs = $observation['id_observation'];
608
				$observations[$idObs] = $observation;
666
				$observations[$idObs] = $observation;
609
			}
667
			}
610
		
668
		
611
			// Enfin, pour chaque image préalablement récupérées, on complète avec les informations de l'observation
669
			// Enfin, pour chaque image préalablement récupérées, on complète avec les informations de l'observation
612
			// FIXME : peut-être peut-on utiliser un array_merge ici ? 
670
			// FIXME : peut-être peut-on utiliser un array_merge ici ? 
613
			foreach ($liaisons as $id => $liaison) {
671
			foreach ($liaisons as $id => $liaison) {
614
				$idObs = $liaison['id_observation'];
672
				$idObs = $liaison['id_observation'];
615
		
673
		
616
				$observation = $observations[$idObs];
674
				$observation = $observations[$idObs];
617
				foreach ($observation as $cle => $valeur) {
675
				foreach ($observation as $cle => $valeur) {
618
					$liaisons[$id][$cle] = $valeur;
676
					$liaisons[$id][$cle] = $valeur;
619
				}
677
				}
620
			}
678
			}
621
			
679
			
622
			
680
			
623
			// On compte à part les images issues de la jointure de del_obs_image et del_image car la fonction
681
			// On compte à part les images issues de la jointure de del_obs_image et del_image car la fonction
624
			// SQL_CALC_FOUND_ROWS dans la fonction requete image fait passer le temps d'éxécution de 0.0011 à 15s !
682
			// SQL_CALC_FOUND_ROWS dans la fonction requete image fait passer le temps d'éxécution de 0.0011 à 15s !
625
			$requeteNbImages = 'SELECT SUM(t.nb) as nb FROM (SELECT count(DISTINCT doi.id_image) as nb '.
683
			$requeteNbImages = 'SELECT SUM(t.nb) as nb FROM (SELECT count(DISTINCT doi.id_image) as nb '.
626
							   'FROM del_obs_image doi '.
684
							   'FROM del_obs_image doi '.
627
							   'INNER JOIN del_image di '.
685
							   'INNER JOIN del_image di '.
628
							   'ON di.id_image = doi.id_image '.
686
							   'ON di.id_image = doi.id_image '.
629
							   'GROUP BY doi.id_image, doi.id_observation) t ';
687
							   'GROUP BY doi.id_image, doi.id_observation) t ';
630
			$resultatNbImages = $this->bdd->recupererTous($requeteNbImages . ' -- ' . __FILE__ . ':' . __LINE__);
688
			$resultatNbImages = $this->bdd->recupererTous($requeteNbImages . ' -- ' . __FILE__ . ':' . __LINE__);
631
 
689
 
632
			$total = (int) $resultatNbImages[0]['nb'];
690
			$total = (int) $resultatNbImages[0]['nb'];
633
			$this->navigation->setTotal($total);
691
			$this->navigation->setTotal($total);
634
		}
692
		}
635
 
693
 
636
		return $liaisons;
694
		return $liaisons;
637
	}
695
	}
638
 
696
 
639
	/**
697
	/**
640
	 * Charge les liaisons pour une seule image dont l'id est spécifié dans l'URL
698
	 * Charge les liaisons pour une seule image dont l'id est spécifié dans l'URL
641
	 * Copie de chargerLiaisonsObs avec critère sur l'id_image uniquement
699
	 * Copie de chargerLiaisonsObs avec critère sur l'id_image uniquement
642
	 * Supporte seulement le masque sur referentiel
700
	 * Supporte seulement le masque sur referentiel
643
	 */
701
	 */
644
	private function chargerLiaisonsParId() {
702
	private function chargerLiaisonsParId() {
645
 
703
 
646
		$idImage = $this->ressources[0];
704
		$idImage = $this->ressources[0];
647
 
705
 
648
		// Récupérer les liaisons
706
		// Récupérer les liaisons
649
		$requeteObs = ' SELECT SQL_CALC_FOUND_ROWS dob.id_observation as id_observation, dob.nom_referentiel, nom_sel, nom_sel_nn, nt, famille, ce_zone_geo, zone_geo, lieudit, station, milieu, '.
707
		$requeteObs = ' SELECT SQL_CALC_FOUND_ROWS dob.id_observation as id_observation, dob.nom_referentiel, nom_sel, nom_sel_nn, nt, famille, ce_zone_geo, zone_geo, lieudit, station, milieu, '.
650
				' date_observation, dob.mots_cles_texte as mots_cles_texte, dob.commentaire as commentaire, di.mots_cles_texte as mots_cles_texte_image , date_transmission, '.
708
				' date_observation, dob.mots_cles_texte as mots_cles_texte, dob.commentaire as commentaire, di.mots_cles_texte as mots_cles_texte_image , date_transmission, '.
651
				' doi.id_image as id_image, di.ce_utilisateur as ce_utilisateur, prenom, nom, courriel, dob.prenom_utilisateur, dob.nom_utilisateur, dob.courriel_utilisateur, nom_original '.
709
				' doi.id_image as id_image, di.ce_utilisateur as ce_utilisateur, prenom, nom, courriel, dob.prenom_utilisateur, dob.nom_utilisateur, dob.courriel_utilisateur, nom_original '.
652
				'FROM del_observation dob '.
710
				'FROM del_observation dob '.
653
				' INNER JOIN del_obs_image doi ON dob.id_observation = doi.id_observation '.
711
				' INNER JOIN del_obs_image doi ON dob.id_observation = doi.id_observation '.
654
				' INNER JOIN del_image di ON doi.id_image = di.id_image '.
712
				' INNER JOIN del_image di ON doi.id_image = di.id_image '.
655
				' LEFT JOIN del_utilisateur du ON dob.ce_utilisateur = du.id_utilisateur '.
713
				' LEFT JOIN del_utilisateur du ON dob.ce_utilisateur = du.id_utilisateur '.
656
				' WHERE doi.id_image = '.intval($idImage);
714
				' WHERE doi.id_image = '.intval($idImage);
657
 
715
 
658
		if (isset($this->parametres['masque.referentiel'])) {
716
		if (isset($this->parametres['masque.referentiel'])) {
659
			$requeteObs .= " AND dob.nom_referentiel LIKE '" . $this->parametres['masque.referentiel'] . "%'";
717
			$requeteObs .= " AND dob.nom_referentiel LIKE '" . $this->parametres['masque.referentiel'] . "%'";
660
		}
718
		}
661
 
719
 
662
		$observations = $this->bdd->recupererTous($requeteObs . ' -- ' . __FILE__ . ':' . __LINE__);
720
		$observations = $this->bdd->recupererTous($requeteObs . ' -- ' . __FILE__ . ':' . __LINE__);
663
 
721
 
664
		$total = $this->getFoundRows();
722
		$total = $this->getFoundRows();
665
		$this->navigation->setTotal($total);
723
		$this->navigation->setTotal($total);
666
 
724
 
667
		return $observations;
725
		return $observations;
668
	}
726
	}
669
 
727
 
670
	/**
728
	/**
671
	 * Chargement depuis la bdd de toutes les liaisons entre images et observations
729
	 * Chargement depuis la bdd de toutes les liaisons entre images et observations
672
	 * Méthode appelée uniquement lorsque les paramètres concernent une observation
730
	 * Méthode appelée uniquement lorsque les paramètres concernent une observation
673
	 * */
731
	 * */
674
	private function chargerLiaisonsObs() {
732
	private function chargerLiaisonsObs() {
675
	
733
	
676
		// Récupérer les liaisons
734
		// Récupérer les liaisons
677
		$requeteObs = ' SELECT SQL_CALC_FOUND_ROWS dob.id_observation as id_observation, dob.nom_referentiel, nom_sel, nom_sel_nn, nt, famille, ce_zone_geo, zone_geo, lieudit, station, milieu, '.
735
		$requeteObs = ' SELECT SQL_CALC_FOUND_ROWS dob.id_observation as id_observation, dob.nom_referentiel, nom_sel, nom_sel_nn, nt, famille, ce_zone_geo, zone_geo, lieudit, station, milieu, '.
678
				 	  ' date_observation, dob.mots_cles_texte as mots_cles_texte, dob.commentaire as commentaire, di.mots_cles_texte as mots_cles_texte_image , date_transmission, '.
736
				 	  ' date_observation, dob.mots_cles_texte as mots_cles_texte, dob.commentaire as commentaire, di.mots_cles_texte as mots_cles_texte_image , date_transmission, '.
679
					  ' doi.id_image as id_image, di.ce_utilisateur as ce_utilisateur, prenom, nom, courriel, dob.prenom_utilisateur, dob.nom_utilisateur, dob.courriel_utilisateur, nom_original '.
737
					  ' doi.id_image as id_image, di.ce_utilisateur as ce_utilisateur, prenom, nom, courriel, dob.prenom_utilisateur, dob.nom_utilisateur, dob.courriel_utilisateur, nom_original '.
680
					  'FROM del_observation dob '.
738
					  'FROM del_observation dob '.
681
					  ' INNER JOIN del_obs_image doi ON dob.id_observation = doi.id_observation '.
739
					  ' INNER JOIN del_obs_image doi ON dob.id_observation = doi.id_observation '.
682
					  ' INNER JOIN del_image di ON doi.id_image = di.id_image '.
740
					  ' INNER JOIN del_image di ON doi.id_image = di.id_image '.
683
					  ' LEFT JOIN del_utilisateur du ON dob.ce_utilisateur = du.id_utilisateur ';
741
					  ' LEFT JOIN del_utilisateur du ON dob.ce_utilisateur = du.id_utilisateur ';
684
	
742
	
685
		// Récupérer les conditions sous forme de tableau
743
		// Récupérer les conditions sous forme de tableau
686
		$conditionsObs = $this->getConditionsObs();
744
		$conditionsObs = $this->getConditionsObs();
687
		
745
		
688
		if (!empty($conditionsObs)) {
746
		if (!empty($conditionsObs)) {
689
			$where = ' WHERE '.implode(' AND ', $conditionsObs);
747
			$where = ' WHERE '.implode(' AND ', $conditionsObs);
690
			$requeteObs .= $where;
748
			$requeteObs .= $where;
691
		}
749
		}
692
	
750
	
693
		// Gérer le tri (uniquement si c'est date_observation)
751
		// Gérer le tri (uniquement si c'est date_observation)
694
		if (isset($this->parametres['tri']) && $this->parametres['tri'] == 'date_observation') {
752
		if (isset($this->parametres['tri']) && $this->parametres['tri'] == 'date_observation') {
695
			$ordre = isset($this->parametres['ordre']) ? $this->parametres['ordre'] : 'DESC';
753
			$ordre = isset($this->parametres['ordre']) ? $this->parametres['ordre'] : 'DESC';
696
			$tri = ' ORDER BY '.$this->parametres['tri'].' '.$ordre.', doi.id_observation '.$ordre.' ';
754
			$tri = ' ORDER BY '.$this->parametres['tri'].' '.$ordre.', doi.id_observation '.$ordre.' ';
697
			$requeteObs .= $tri;
755
			$requeteObs .= $tri;
698
		}
756
		}
699
		
757
		
700
		$requeteObs .= $this->gestionBdd->getLimitSql();
758
		$requeteObs .= $this->gestionBdd->getLimitSql();
701
		$observations = $this->bdd->recupererTous($requeteObs . ' -- ' . __FILE__ . ':' . __LINE__);
759
		$observations = $this->bdd->recupererTous($requeteObs . ' -- ' . __FILE__ . ':' . __LINE__);
702
 
760
 
703
		$total = $this->getFoundRows();
761
		$total = $this->getFoundRows();
704
		$this->navigation->setTotal($total);
762
		$this->navigation->setTotal($total);
705
 
763
 
706
		return $observations;
764
		return $observations;
707
	}
765
	}
708
	
766
	
709
	/**
767
	/**
710
	 * Chargement depuis la bdd de toutes les liaisons entre images et observations
768
	 * Chargement depuis la bdd de toutes les liaisons entre images et observations
711
	 * Méthode appelée uniquement lorsque les paramètres concernent les images
769
	 * Méthode appelée uniquement lorsque les paramètres concernent les images
712
	 * */
770
	 * */
713
	private function chargerLiaisonsImages() {
771
	private function chargerLiaisonsImages() {
714
	
772
	
715
		// FIXME : si on faisait une requete à part pour compter, ca irait plus vite
773
		// FIXME : si on faisait une requete à part pour compter, ca irait plus vite
716
		// Récupérer tous les ID d'image en fonction des paramètres de recherche
774
		// Récupérer tous les ID d'image en fonction des paramètres de recherche
717
		$requeteImages = ' SELECT SQL_CALC_FOUND_ROWS '.
775
		$requeteImages = ' SELECT SQL_CALC_FOUND_ROWS '.
718
						 ' doi.id_image as id_image, dob.id_observation as id_observation, dob.nom_referentiel, nom_sel, nom_sel_nn, nt, famille, ce_zone_geo, zone_geo, lieudit, station, milieu, '.
776
						 ' doi.id_image as id_image, dob.id_observation as id_observation, dob.nom_referentiel, nom_sel, nom_sel_nn, nt, famille, ce_zone_geo, zone_geo, lieudit, station, milieu, '.
719
						 ' date_observation, dob.mots_cles_texte as mots_cles_texte, dob.commentaire as commentaire, di.mots_cles_texte as mots_cles_texte_image , date_transmission, '.
777
						 ' date_observation, dob.mots_cles_texte as mots_cles_texte, dob.commentaire as commentaire, di.mots_cles_texte as mots_cles_texte_image , date_transmission, '.
720
						 ' di.ce_utilisateur as ce_utilisateur, prenom, nom, courriel, dob.prenom_utilisateur, dob.nom_utilisateur, dob.courriel_utilisateur, nom_original '.
778
						 ' di.ce_utilisateur as ce_utilisateur, prenom, nom, courriel, dob.prenom_utilisateur, dob.nom_utilisateur, dob.courriel_utilisateur, nom_original '.
721
						 ' FROM del_obs_image doi '.
779
						 ' FROM del_obs_image doi '.
722
						 ' INNER JOIN del_image di ON doi.id_image = di.id_image '.
780
						 ' INNER JOIN del_image di ON doi.id_image = di.id_image '.
723
						 ' INNER JOIN del_observation dob ON dob.id_observation = doi.id_observation '.
781
						 ' INNER JOIN del_observation dob ON dob.id_observation = doi.id_observation '.
724
						 ' LEFT JOIN del_image_tag dit ON dit.ce_image = di.id_image '.
782
						 ' LEFT JOIN del_image_tag dit ON dit.ce_image = di.id_image '.
725
						 ' LEFT JOIN del_utilisateur du ON du.id_utilisateur = di.ce_utilisateur ';
783
						 ' LEFT JOIN del_utilisateur du ON du.id_utilisateur = di.ce_utilisateur ';
726
 
784
 
727
		$conditionsImg = $this->getConditionsImages();
785
		$conditionsImg = $this->getConditionsImages();
728
	
786
 
729
		if (!empty($conditionsImg)) {
787
		if (!empty($conditionsImg)) {
730
			$where = ' WHERE ('.implode(' OR ', $conditionsImg).') ';
788
			$where = ' WHERE ('.implode(' OR ', $conditionsImg).') ';
731
			$where .= ' AND dit.actif = 1 ';
789
			$where .= ' AND dit.actif = 1 ';
732
			$requeteImages .= $where;
790
			$requeteImages .= $where;
733
		}
791
		}
734
	
792
	
735
		// Gérer le tri, sur les votes ou sur les tags
793
		// Gérer le tri, sur les votes ou sur les tags
736
		if (isset($this->parametres['tri'])) {
794
		if (isset($this->parametres['tri'])) {
737
			
795
			
738
			$chaineTri = '';
796
			$chaineTri = '';
739
			$chaineOrdre = '';
797
			$chaineOrdre = '';
740
			
798
			
741
			if ($this->parametres['tri'] == 'votes') {
799
			if ($this->parametres['tri'] == 'votes') {
742
	
800
	
743
				$protocole = isset($this->parametres['protocole']) ? $this->parametres['protocole'] : 1;
801
				$protocole = isset($this->parametres['protocole']) ? $this->parametres['protocole'] : 1;
744
	
802
	
745
				$requeteVotes = ' SELECT doi.id_image as id_image, IF(divo.ce_protocole = '.$protocole.', AVG(divo.valeur), 0) as total_votes '.
803
				$requeteVotes = ' SELECT doi.id_image as id_image, IF(divo.ce_protocole = '.$protocole.', AVG(divo.valeur), 0) as total_votes '.
746
								' FROM del_obs_image doi '.
804
								' FROM del_obs_image doi '.
747
								' INNER JOIN del_image di ON doi.id_image = di.id_image '.
805
								' INNER JOIN del_image di ON doi.id_image = di.id_image '.
748
								' INNER JOIN del_observation dob ON dob.id_observation = doi.id_observation '.
806
								' INNER JOIN del_observation dob ON dob.id_observation = doi.id_observation '.
749
								' LEFT JOIN del_image_vote divo ON doi.id_image = divo.ce_image '.
807
								' LEFT JOIN del_image_vote divo ON doi.id_image = divo.ce_image '.
750
                                ' AND ce_protocole = '.$protocole.' ';
808
                                ' AND ce_protocole = '.$protocole.' ';
751
	
809
	
752
				// Et si on a cherché par tag ?
810
				// Et si on a cherché par tag ?
753
				if (isset($this->parametres['masque.tag'])) {
811
				if (isset($this->parametres['masque.tag'])) {
754
					$tag = $this->parametres['masque.tag'];
812
					$tag = $this->parametres['masque.tag'];
755
					$requeteVotes .= ' LEFT JOIN del_image_tag dit ON dit.ce_image = di.id_image ';
813
					$requeteVotes .= ' LEFT JOIN del_image_tag dit ON dit.ce_image = di.id_image ';
756
					$requeteVotes .= " WHERE (dit.tag_normalise LIKE '$tag%' OR  di.mots_cles_texte LIKE '%$tag%') AND dit.actif = 1 ";
814
					$requeteVotes .= " WHERE (dit.tag_normalise LIKE '$tag%' OR  di.mots_cles_texte LIKE '%$tag%') AND dit.actif = 1 ";
757
				}
815
				}
758
	
816
	
759
				$requeteVotes .= ' GROUP BY doi.id_image, doi.id_observation '.
817
				$requeteVotes .= ' GROUP BY doi.id_image, doi.id_observation '.
760
								 ' ORDER by total_votes '.$this->directionTri .', doi.id_observation '.$this->directionTri.' '.
818
								 ' ORDER by total_votes '.$this->directionTri .', doi.id_observation '.$this->directionTri.' '.
761
						$this->gestionBdd->getLimitSql();
819
						$this->gestionBdd->getLimitSql();
762
	
820
	
763
 
821
 
764
				$resultatsVotes = $this->bdd->recupererTous($requeteVotes . ' -- ' . __FILE__ . ':' . __LINE__);
822
				$resultatsVotes = $this->bdd->recupererTous($requeteVotes . ' -- ' . __FILE__ . ':' . __LINE__);
765
				$tabVotes = array();
823
				$tabVotes = array();
766
				foreach ($resultatsVotes as $vote) {
824
				foreach ($resultatsVotes as $vote) {
767
					$tabVotes[] = $vote['id_image'];
825
					$tabVotes[] = $vote['id_image'];
768
				}
826
				}
769
	
827
	
770
				$strVotes = empty($tabVotes) ? "''" : implode(',', $tabVotes);
828
				$strVotes = empty($tabVotes) ? "''" : implode(',', $tabVotes);
771
	
829
	
772
				// Et si on a cherché par tag ?
830
				// Et si on a cherché par tag ?
773
				if (isset($this->parametres['masque.tag'])) {
831
				if (isset($this->parametres['masque.tag'])) {
774
					$chaineTri .= ' AND ';
832
					$chaineTri .= ' AND ';
775
				} else {
833
				} else {
776
					$chaineTri .= ' WHERE ';
834
					$chaineTri .= ' WHERE ';
777
				}
835
				}
778
				
836
				
779
				
837
				
780
				$chaineTri .= '  doi.id_image IN ('.$strVotes.') ';
838
				$chaineTri .= '  doi.id_image IN ('.$strVotes.') ';
781
				$chaineOrdre = ' ORDER BY FIELD(doi.id_image, '.$strVotes.')  ';
839
				$chaineOrdre = ' ORDER BY FIELD(doi.id_image, '.$strVotes.')  ';
782
			}
840
			}
783
			
841
			
784
			if ($this->parametres['tri'] == 'tags') {
842
			if ($this->parametres['tri'] == 'tags') {
785
					
843
					
786
				$requetetags = ' SELECT SQL_CALC_FOUND_ROWS doi.id_image, COUNT(id_tag) as total_tags '.
844
				$requetetags = ' SELECT SQL_CALC_FOUND_ROWS doi.id_image, COUNT(id_tag) as total_tags '.
787
						' FROM del_obs_image doi LEFT JOIN del_image_tag dit ON dit.ce_image = doi.id_image AND dit.actif = 1 '.
845
						' FROM del_obs_image doi LEFT JOIN del_image_tag dit ON dit.ce_image = doi.id_image AND dit.actif = 1 '.
788
						 ' INNER JOIN del_image di ON doi.id_image = di.id_image '.
846
						 ' INNER JOIN del_image di ON doi.id_image = di.id_image '.
789
						 ' INNER JOIN del_observation dob ON dob.id_observation = doi.id_observation ';
847
						 ' INNER JOIN del_observation dob ON dob.id_observation = doi.id_observation ';
790
 
848
 
791
				if (isset($this->parametres['masque.tag'])) {
849
				if (isset($this->parametres['masque.tag_pictoflora'])) {
792
					// Et si on a cherché par tag ?
850
					// Et si on a cherché par tag ?
793
					$tag = $this->parametres['masque.tag'];
851
					$tag = $this->parametres['masque.tag_pictoflora'];
794
					$requetetags .= " WHERE (dit.tag_normalise LIKE '$tag%' OR  di.mots_cles_texte LIKE '%$tag%') ";
852
					$requetetags .= " WHERE (dit.tag_normalise LIKE '$tag%' OR  di.mots_cles_texte LIKE '%$tag%') ";
795
				}
853
				}
796
				
854
				
797
				$requetetags .= ' GROUP BY doi.id_image, doi.id_observation '.
855
				$requetetags .= ' GROUP BY doi.id_image, doi.id_observation '.
798
						' ORDER by total_tags '.$this->directionTri.', doi.id_observation '.$this->directionTri.
856
						' ORDER by total_tags '.$this->directionTri.', doi.id_observation '.$this->directionTri.
799
						$this->gestionBdd->getLimitSql();
857
						$this->gestionBdd->getLimitSql();
800
 
858
 
801
				$resultatstags = $this->bdd->recupererTous($requetetags . ' -- ' . __FILE__ . ':' . __LINE__);
859
				$resultatstags = $this->bdd->recupererTous($requetetags . ' -- ' . __FILE__ . ':' . __LINE__);
802
				$tabtags = array();
860
				$tabtags = array();
803
				foreach ($resultatstags as $tag) {
861
				foreach ($resultatstags as $tag) {
804
					$tabtags[] = $tag['id_image'];
862
					$tabtags[] = $tag['id_image'];
805
				}
863
				}
806
				$strtags = empty($tabtags) ? "''" : implode(',', $tabtags);
864
				$strtags = empty($tabtags) ? "''" : implode(',', $tabtags);
807
				
865
				
808
	
866
	
809
				// Et si on a cherché par tag ?
867
				// Et si on a cherché par tag ?
810
				if (isset($this->parametres['masque.tag'])) {
868
				if (isset($this->parametres['masque.tag_pictoflora'])) {
811
					$chaineTri .= ' AND ';
869
					$chaineTri .= ' AND ';
812
				} else {
870
				} else {
813
					$chaineTri .= ' WHERE ';
871
					$chaineTri .= ' WHERE ';
814
				}
872
				}
815
	
873
	
816
				$chaineTri .= ' doi.id_image IN ('.$strtags.') ';
874
				$chaineTri .= ' doi.id_image IN ('.$strtags.') ';
817
				$chaineOrdre = ' ORDER BY FIELD(doi.id_image, '.$strtags.') ';
875
				$chaineOrdre = ' ORDER BY FIELD(doi.id_image, '.$strtags.') ';
818
			}
876
			}
819
						
877
						
820
			$requeteImages .= $chaineTri.' GROUP BY doi.id_image, doi.id_observation '.$chaineOrdre;
878
			$requeteImages .= $chaineTri.' GROUP BY doi.id_image, doi.id_observation '.$chaineOrdre;
821
		} else {
879
		} else {
822
			$requeteImages .= ' GROUP BY doi.id_image, doi.id_observation'; // des fois, on a plusieurs observations pour la même image ...
880
			$requeteImages .= ' GROUP BY doi.id_image, doi.id_observation'; // des fois, on a plusieurs observations pour la même image ...
823
			$requeteImages .= $this->gestionBdd->getLimitSql();
881
			$requeteImages .= $this->gestionBdd->getLimitSql();
824
		}
882
		}
825
 
883
 
826
		$retour  = $this->bdd->recupererTous($requeteImages . ' -- ' . __FILE__ . ':' . __LINE__);
884
		$retour  = $this->bdd->recupererTous($requeteImages . ' -- ' . __FILE__ . ':' . __LINE__);
827
		$total = $this->getFoundRows();
885
		$total = $this->getFoundRows();
828
		$this->navigation->setTotal($total);
886
		$this->navigation->setTotal($total);
829
		
887
		
830
		return $retour;
888
		return $retour;
831
	}
889
	}
832
	
890
	
833
	/**
891
	/**
834
	 * Chargement depuis la bdd de toutes les liaisons entre images et observations
892
	 * Chargement depuis la bdd de toutes les liaisons entre images et observations
835
	 * */
893
	 * */
836
	private function chargerLiaisons() {
894
	private function chargerLiaisons() {
837
	
895
	
838
		$champs = array('dob.id_observation as id_observation', 'nom_sel', 'nom_sel_nn', 'nt', 'famille', 'dob.nom_referentiel', 'ce_zone_geo', 'zone_geo',
896
		$champs = array('dob.id_observation as id_observation', 'nom_sel', 'nom_sel_nn', 'nt', 'famille', 'dob.nom_referentiel', 'ce_zone_geo', 'zone_geo',
839
				'lieudit', 'station', 'milieu', 'date_observation', 'dob.mots_cles_texte as mots_cles_texte', 'dob.commentaire as commentaire',
897
				'lieudit', 'station', 'milieu', 'date_observation', 'dob.mots_cles_texte as mots_cles_texte', 'dob.commentaire as commentaire',
840
				'di.mots_cles_texte as mots_cles_texte_image ', 'date_transmission', 'di.id_image as id_image', 'di.ce_utilisateur as ce_utilisateur',
898
				'di.mots_cles_texte as mots_cles_texte_image ', 'date_transmission', 'di.id_image as id_image', 'di.ce_utilisateur as ce_utilisateur',
841
				'prenom', 'nom', 'courriel', 'dob.prenom_utilisateur', 'dob.nom_utilisateur', 'dob.courriel_utilisateur', 'nom_original');
899
				'prenom', 'nom', 'courriel', 'dob.prenom_utilisateur', 'dob.nom_utilisateur', 'dob.courriel_utilisateur', 'nom_original');
842
		// Attention le LEFT JOIN est indispensable pour ramener les images n'ayant pas de votes
900
		// Attention le LEFT JOIN est indispensable pour ramener les images n'ayant pas de votes
843
		// en cas de tri par votes
901
		// en cas de tri par votes
844
		$requeteLiaisons = 'SELECT DISTINCT SQL_CALC_FOUND_ROWS '.implode(', ',$champs).' '.
902
		$requeteLiaisons = 'SELECT DISTINCT SQL_CALC_FOUND_ROWS '.implode(', ',$champs).' '.
845
				($this->doitJoindreTableVotes() ?
903
				($this->doitJoindreTableVotes() ?
846
						', IF(dvote.ce_protocole = '.$this->parametres['protocole'].', AVG(dvote.valeur), 0) as total_votes ' :
904
						', IF(dvote.ce_protocole = '.$this->parametres['protocole'].', AVG(dvote.valeur), 0) as total_votes ' :
847
						''
905
						''
848
				).
906
				).
849
				($this->doitJoindreTableTags() ?
907
				($this->doitJoindreTableTags() ?
850
						// attention le DISTINCT est indispensable !
908
						// attention le DISTINCT est indispensable !
851
						', (COUNT(DISTINCT dtag.id_tag) + '.$this->assemblercomptageOccurencesMotsClesCel().') as total_tags ' :
909
						', (COUNT(DISTINCT dtag.id_tag) + '.$this->assemblercomptageOccurencesMotsClesCel().') as total_tags ' :
852
						''
910
						''
853
				).
911
				).
854
				'FROM '.$this->gestionBdd->formaterTable('del_obs_image', 'doi').
912
				'FROM '.$this->gestionBdd->formaterTable('del_obs_image', 'doi').
855
				'INNER JOIN del_image di '.
913
				'INNER JOIN del_image di '.
856
				'ON doi.id_image = di.id_image '.
914
				'ON doi.id_image = di.id_image '.
857
				'INNER JOIN del_observation dob '.
915
				'INNER JOIN del_observation dob '.
858
				'ON doi.id_observation = dob.id_observation '.
916
				'ON doi.id_observation = dob.id_observation '.
859
				'LEFT JOIN del_utilisateur du '.
917
				'LEFT JOIN del_utilisateur du '.
860
				'ON du.id_utilisateur = di.ce_utilisateur '.
918
				'ON du.id_utilisateur = di.ce_utilisateur '.
861
				($this->doitJoindreTableTags() ?
919
				($this->doitJoindreTableTags() ?
862
						'LEFT JOIN del_image_tag dtag '.
920
						'LEFT JOIN del_image_tag dtag '.
863
						'ON doi.id_image = dtag.ce_image AND dtag.actif = 1 ' :
921
						'ON doi.id_image = dtag.ce_image AND dtag.actif = 1 ' :
864
						''
922
						''
865
								).
923
								).
866
								($this->doitJoindreTableVotes() ?
924
								($this->doitJoindreTableVotes() ?
867
								'LEFT JOIN del_image_vote dvote '.
925
								'LEFT JOIN del_image_vote dvote '.
868
								'ON doi.id_image = dvote.ce_image AND dvote.ce_protocole = '.$this->parametres['protocole'] :
926
								'ON doi.id_image = dvote.ce_image AND dvote.ce_protocole = '.$this->parametres['protocole'] :
869
								''
927
								''
870
										);
928
										);
871
				$requeteLiaisons .= $this->chargerClauseWhere();
929
				$requeteLiaisons .= $this->chargerClauseWhere();
872
				$requeteLiaisons .= $this->getTri();
930
				$requeteLiaisons .= $this->getTri();
873
				$requeteLiaisons .= $this->gestionBdd->getLimitSql();
931
				$requeteLiaisons .= $this->gestionBdd->getLimitSql();
874
 
932
 
875
				$retour = $this->bdd->recupererTous($requeteLiaisons . ' -- ' . __FILE__ . ':' . __LINE__);
933
				$retour = $this->bdd->recupererTous($requeteLiaisons . ' -- ' . __FILE__ . ':' . __LINE__);
876
				$total = $this->getFoundRows();
934
				$total = $this->getFoundRows();
877
				$this->navigation->setTotal($total);
935
				$this->navigation->setTotal($total);
878
				return $retour;
936
				return $retour;
879
	}
937
	}
880
	
938
	
881
	
939
	
882
	/**
940
	/**
883
	 * Retourner un tableau d'images formaté en fonction des liaisons trouvées
941
	 * Retourner un tableau d'images formaté en fonction des liaisons trouvées
884
	 * @param $liaisons les liaisons de la table del_obs_images
942
	 * @param $liaisons les liaisons de la table del_obs_images
885
	 * */
943
	 * */
886
	private function chargerImage($liaisons) {
944
	private function chargerImage($liaisons) {
887
	
945
	
888
		$images = array();
946
		$images = array();
889
		foreach ($liaisons as $liaison) {
947
		foreach ($liaisons as $liaison) {
890
			$idImage = $liaison['id_image'];
948
			$idImage = $liaison['id_image'];
891
				
949
				
892
			if($liaison['ce_utilisateur'] == 0) {
950
			if($liaison['ce_utilisateur'] == 0) {
893
				$liaison['prenom'] = $liaison['prenom_utilisateur'];
951
				$liaison['prenom'] = $liaison['prenom_utilisateur'];
894
				$liaison['nom'] = $liaison['nom_utilisateur'];
952
				$liaison['nom'] = $liaison['nom_utilisateur'];
895
			}
953
			}
896
			// On enregistre l'ID de l'image pour n'effectuer qu'une seule requête par la suite
954
			// On enregistre l'ID de l'image pour n'effectuer qu'une seule requête par la suite
897
			$this->imageIds[] = $idImage;
955
			$this->imageIds[] = $idImage;
898
			$index = $liaison['id_image'].'-'.$liaison['id_observation'];
956
			$index = $liaison['id_image'].'-'.$liaison['id_observation'];
899
			$images[$index] = array('id_image' => $idImage, 'binaire.href' => $this->formaterLienImage($idImage),
957
			$images[$index] = array('id_image' => $idImage, 'binaire.href' => $this->formaterLienImage($idImage),
900
					'protocoles_votes' => array(),
958
					'protocoles_votes' => array(),
901
					'mots_cles_texte' => $liaison['mots_cles_texte_image'], 'observation' => $this->formaterObservation($liaison));
959
					'mots_cles_texte' => $liaison['mots_cles_texte_image'], 'observation' => $this->formaterObservation($liaison));
902
		}
960
		}
903
		return $images;
961
		return $images;
904
	}
962
	}
905
	
963
	
906
	/**
964
	/**
907
	 * Charger les votes pour chaque image
965
	 * Charger les votes pour chaque image
908
	 * */
966
	 * */
909
	private function chargerVotes($images) {
967
	private function chargerVotes($images) {
910
		$requeteVotes = 'SELECT v.*, p.* FROM '.
968
		$requeteVotes = 'SELECT v.*, p.* FROM '.
911
				$this->gestionBdd->formaterTable('del_image_vote', 'v').
969
				$this->gestionBdd->formaterTable('del_image_vote', 'v').
912
				' INNER JOIN del_image_protocole p '.
970
				' INNER JOIN del_image_protocole p '.
913
				'ON v.ce_protocole = p.id_protocole '.
971
				'ON v.ce_protocole = p.id_protocole '.
914
				$this->chargerClauseWhereVotes();
972
				$this->chargerClauseWhereVotes();
915
		$resultatsVotes = $this->bdd->recupererTous($requeteVotes . ' -- ' . __FILE__ . ':' . __LINE__);
973
		$resultatsVotes = $this->bdd->recupererTous($requeteVotes . ' -- ' . __FILE__ . ':' . __LINE__);
916
			
974
			
917
			
975
			
918
		//TODO : faire une méthode formater vote
976
		//TODO : faire une méthode formater vote
919
		$votes = $this->formaterVotes($resultatsVotes);
977
		$votes = $this->formaterVotes($resultatsVotes);
920
	
978
	
921
		foreach ($images as $id => $image) {
979
		foreach ($images as $id => $image) {
922
			if (isset($votes[$image['id_image']])) {
980
			if (isset($votes[$image['id_image']])) {
923
				$images[$id]['protocoles_votes'] = $votes[$image['id_image']];
981
				$images[$id]['protocoles_votes'] = $votes[$image['id_image']];
924
			}
982
			}
925
		}
983
		}
926
	
984
	
927
		return $images;
985
		return $images;
928
	}
986
	}
929
	
987
	
930
	private function chargerClauseWhereVotes() {
988
	private function chargerClauseWhereVotes() {
931
		if (sizeof($this->imageIds) > 0) {
989
		if (sizeof($this->imageIds) > 0) {
932
			$chaineImageIds = implode(',', $this->imageIds);
990
			$chaineImageIds = implode(',', $this->imageIds);
933
			$where[] = 'v.ce_image  IN ('.$chaineImageIds.')';
991
			$where[] = 'v.ce_image  IN ('.$chaineImageIds.')';
934
		}
992
		}
935
		if (isset($this->parametres['protocole'])) {
993
		if (isset($this->parametres['protocole'])) {
936
			$where[] = 'v.ce_protocole = '.$this->proteger($this->parametres['protocole']);
994
			$where[] = 'v.ce_protocole = '.$this->proteger($this->parametres['protocole']);
937
		}
995
		}
938
	
996
	
939
		$where = (!empty($where)) ? 'WHERE '.implode(' AND ', $where) : '';
997
		$where = (!empty($where)) ? 'WHERE '.implode(' AND ', $where) : '';
940
		return $where;
998
		return $where;
941
	}
999
	}
942
	
1000
	
943
	/**************************************************************************************
1001
	/**************************************************************************************
944
	 *		    			FONCTION DE CONFIGURATION ET UTILITAIRES					  *
1002
	 *		    			FONCTION DE CONFIGURATION ET UTILITAIRES					  *
945
	***************************************************************************************/
1003
	***************************************************************************************/
946
	/**
1004
	/**
947
	 * Enregistrer dans les variables de classe les paramètres et ressources
1005
	 * Enregistrer dans les variables de classe les paramètres et ressources
948
	 * @param $ressources
1006
	 * @param $ressources
949
	 * @param $parametres de recherche 
1007
	 * @param $parametres de recherche 
950
	 * */
1008
	 * */
951
	private function initialiserRessourcesEtParametres($ressources, $parametres) {
1009
	private function initialiserRessourcesEtParametres($ressources, $parametres) {
952
		$this->ressources = $ressources;
1010
		$this->ressources = $ressources;
953
		$this->parametres = $parametres;
1011
		$this->parametres = $parametres;
954
	}
1012
	}
955
	
1013
	
956
	/**
1014
	/**
957
	 * Configuration du service en fonction du fichier de config config_del.ini
1015
	 * Configuration du service en fonction du fichier de config config_del.ini
958
	 * */
1016
	 * */
959
	public function configurer() {
1017
	public function configurer() {
960
		$this->mappingFiltre = $this->conteneur->getParametre('mapping_masque');
1018
		$this->mappingFiltre = $this->conteneur->getParametre('mapping_masque');
961
		$this->mappingObservation = $this->conteneur->getParametre('mapping_observation');
1019
		$this->mappingObservation = $this->conteneur->getParametre('mapping_observation');
962
		$this->mappingVotes = $this->conteneur->getParametre('mapping_votes');
1020
		$this->mappingVotes = $this->conteneur->getParametre('mapping_votes');
963
	}
1021
	}
964
	
1022
	
965
	/**
1023
	/**
966
	 * Vérifier que le service est bien configuré
1024
	 * Vérifier que le service est bien configuré
967
	 * */
1025
	 * */
968
	public function verifierConfiguration() {
1026
	public function verifierConfiguration() {
969
	
1027
	
970
		$erreurs = array();
1028
		$erreurs = array();
971
		$tableauImages = $this->conteneur->getParametre('images');
1029
		$tableauImages = $this->conteneur->getParametre('images');
972
		if (empty($tableauImages)) {
1030
		if (empty($tableauImages)) {
973
			$erreurs[] = '- le fichier de configuration ne contient pas le tableau [images] ou celui-ci est vide ;';
1031
			$erreurs[] = '- le fichier de configuration ne contient pas le tableau [images] ou celui-ci est vide ;';
974
		} else {
1032
		} else {
975
			if ($this->conteneur->getParametre('url_service') == null) {
1033
			if ($this->conteneur->getParametre('url_service') == null) {
976
				$erreurs[] = '- paramètre "url_service" manquant ;';
1034
				$erreurs[] = '- paramètre "url_service" manquant ;';
977
			}
1035
			}
978
				
1036
				
979
			if ($this->conteneur->getParametre('url_images') == null) {
1037
			if ($this->conteneur->getParametre('url_images') == null) {
980
				$erreurs[] = '- paramètre "url_images" manquant ;';
1038
				$erreurs[] = '- paramètre "url_images" manquant ;';
981
			}
1039
			}
982
				
1040
				
983
		}
1041
		}
984
	
1042
	
985
		if (empty($this->mappingObservation)) {
1043
		if (empty($this->mappingObservation)) {
986
			$erreurs[] = '- le fichier de configuration ne contient pas le tableau [mapping_observation] ou celui-ci est vide ;';
1044
			$erreurs[] = '- le fichier de configuration ne contient pas le tableau [mapping_observation] ou celui-ci est vide ;';
987
		} else {
1045
		} else {
988
			$champsMappingObs = array('id_observation', 'date_observation', 'date_transmission', 'famille', 'nom_sel', 'nom_sel_nn', 'nt',
1046
			$champsMappingObs = array('id_observation', 'date_observation', 'date_transmission', 'famille', 'nom_sel', 'nom_sel_nn', 'nt',
989
					'ce_zone_geo', 'lieudit', 'station', 'milieu', 'ce_utilisateur', 'nom', 'prenom');
1047
					'ce_zone_geo', 'lieudit', 'station', 'milieu', 'ce_utilisateur', 'nom', 'prenom');
990
			foreach ($champsMappingObs as $champ) {
1048
			foreach ($champsMappingObs as $champ) {
991
				if (!isset($this->mappingObservation[$champ])) {
1049
				if (!isset($this->mappingObservation[$champ])) {
992
					$erreurs[] = '- le mapping du champ "'.$champ.'" pour l\'observation est manquant ;';
1050
					$erreurs[] = '- le mapping du champ "'.$champ.'" pour l\'observation est manquant ;';
993
				}
1051
				}
994
			}
1052
			}
995
		}
1053
		}
996
	
1054
	
997
		if (empty($this->mappingFiltre)) {
1055
		if (empty($this->mappingFiltre)) {
998
			$erreurs[] = '- le fichier de configuration ne contient pas le tableau [mapping_masque] ou celui-ci est vide ;';
1056
			$erreurs[] = '- le fichier de configuration ne contient pas le tableau [mapping_masque] ou celui-ci est vide ;';
999
		} else {
1057
		} else {
1000
			$champsMappingFiltre = array('famille', 'ns', 'nn', 'date', 'tag', 'commune');
1058
			$champsMappingFiltre = array('famille', 'ns', 'nn', 'date', 'tag', 'commune');
1001
			foreach ($champsMappingFiltre as $champ) {
1059
			foreach ($champsMappingFiltre as $champ) {
1002
				if (!isset($this->mappingFiltre[$champ])) {
1060
				if (!isset($this->mappingFiltre[$champ])) {
1003
					$erreurs[] = '- le mapping du champ "'.$champ.'" pour l\'observation est manquant ;';
1061
					$erreurs[] = '- le mapping du champ "'.$champ.'" pour l\'observation est manquant ;';
1004
				}
1062
				}
1005
			}
1063
			}
1006
		}
1064
		}
1007
	
1065
	
1008
		$tris_possibles = $this->conteneur->getParametre('tris_possibles');
1066
		$tris_possibles = $this->conteneur->getParametre('tris_possibles');
1009
		if (empty($tris_possibles)) {
1067
		if (empty($tris_possibles)) {
1010
			$erreurs[] = '- le fichier de configuration ne contient pas le parametre tris_possibles ou celui-ci est vide ;';
1068
			$erreurs[] = '- le fichier de configuration ne contient pas le parametre tris_possibles ou celui-ci est vide ;';
1011
		}
1069
		}
1012
	
1070
	
1013
		if (!empty($erreurs)) {
1071
		if (!empty($erreurs)) {
1014
			$e = 'Erreur lors de la configuration : '."\n";
1072
			$e = 'Erreur lors de la configuration : '."\n";
1015
			$e .= implode("\n", $erreurs);
1073
			$e .= implode("\n", $erreurs);
1016
			throw new Exception($e, RestServeur::HTTP_CODE_ERREUR);
1074
			throw new Exception($e, RestServeur::HTTP_CODE_ERREUR);
1017
		}
1075
		}
1018
	}
1076
	}
1019
	
1077
	
1020
	/** 
1078
	/** 
1021
	 * Verifier que les paramètres de tri sont bien autorisés et qu'ils sont au bon format.
1079
	 * Verifier que les paramètres de tri sont bien autorisés et qu'ils sont au bon format.
1022
	 */
1080
	 */
1023
	private function verifierParametresTri() {
1081
	private function verifierParametresTri() {
1024
	
1082
	
1025
		$erreurs = array();
1083
		$erreurs = array();
1026
		$tris_possibles = $this->conteneur->getParametre('tris_possibles');
1084
		$tris_possibles = $this->conteneur->getParametre('tris_possibles');
1027
		$tris_possibles_tableau = explode(',', $tris_possibles);
1085
		$tris_possibles_tableau = explode(',', $tris_possibles);
1028
		if(isset($this->parametres['tri']) && !in_array($this->parametres['tri'], $tris_possibles_tableau)) {
1086
		if(isset($this->parametres['tri']) && !in_array($this->parametres['tri'], $tris_possibles_tableau)) {
1029
			$erreurs[] = '- le type de tri demandé est incorrect, les valeurs possibles sont '.$tris_possibles.' ;';
1087
			$erreurs[] = '- le type de tri demandé est incorrect, les valeurs possibles sont '.$tris_possibles.' ;';
1030
		}
1088
		}
1031
	
1089
	
1032
		if(isset($this->parametres['tri']) && $this->parametres['tri'] == "votes") {
1090
		if(isset($this->parametres['tri']) && $this->parametres['tri'] == "votes") {
1033
			if(!isset($this->parametres['protocole']) || !is_numeric($this->parametres['protocole'])) {
1091
			if(!isset($this->parametres['protocole']) || !is_numeric($this->parametres['protocole'])) {
1034
				$erreurs[] = '- Le paramètre protocole est obligatoire en cas de tri par vote et doit être un entier ;';
1092
				$erreurs[] = '- Le paramètre protocole est obligatoire en cas de tri par vote et doit être un entier ;';
1035
			}
1093
			}
1036
		}
1094
		}
1037
	
1095
	
1038
		$directions_tri = array('asc', 'desc');
1096
		$directions_tri = array('asc', 'desc');
1039
		if(isset($this->parametres['ordre']) && !in_array($this->parametres['ordre'], $directions_tri)) {
1097
		if(isset($this->parametres['ordre']) && !in_array($this->parametres['ordre'], $directions_tri)) {
1040
			$erreurs[] = '- la direction du tri demandé est incorrecte, les valeurs supportées sont asc ou desc ;';
1098
			$erreurs[] = '- la direction du tri demandé est incorrecte, les valeurs supportées sont asc ou desc ;';
1041
		}
1099
		}
1042
			
1100
			
1043
		if (!empty($erreurs)) {
1101
		if (!empty($erreurs)) {
1044
			$e = 'Erreur lors de l\'analyse des parametres du tri : '."\n";
1102
			$e = 'Erreur lors de l\'analyse des parametres du tri : '."\n";
1045
			$e .= implode("\n", $erreurs);
1103
			$e .= implode("\n", $erreurs);
1046
			throw new Exception($e, RestServeur::HTTP_CODE_ERREUR);
1104
			throw new Exception($e, RestServeur::HTTP_CODE_ERREUR);
1047
		}
1105
		}
1048
	}
1106
	}
1049
	
1107
	
1050
	private function verifierParametreFormatRetour() {
1108
	private function verifierParametreFormatRetour() {
1051
		$erreurs = array();
1109
		$erreurs = array();
1052
		$formats_possibles_str = $this->conteneur->getParametre('formats_possibles');
1110
		$formats_possibles_str = $this->conteneur->getParametre('formats_possibles');
1053
		$formats_possibles = explode(',',$formats_possibles_str);
1111
		$formats_possibles = explode(',',$formats_possibles_str);
1054
 
1112
 
1055
		if(isset($this->parametres['format']) && !in_array($this->parametres['format'], $formats_possibles)) {
1113
		if(isset($this->parametres['format']) && !in_array($this->parametres['format'], $formats_possibles)) {
1056
			$erreurs[] = "- le format d'image demandé n'est pas supporté ; Les format supportés sont : ".$formats_possibles_str;
1114
			$erreurs[] = "- le format d'image demandé n'est pas supporté ; Les format supportés sont : ".$formats_possibles_str;
1057
		}
1115
		}
1058
			
1116
			
1059
		if (!empty($erreurs)) {
1117
		if (!empty($erreurs)) {
1060
			$e = 'Erreur lors de l\'analyse du format de retour demandé : '."\n";
1118
			$e = 'Erreur lors de l\'analyse du format de retour demandé : '."\n";
1061
			$e .= implode("\n", $erreurs);
1119
			$e .= implode("\n", $erreurs);
1062
			throw new Exception($e, RestServeur::HTTP_CODE_ERREUR);
1120
			throw new Exception($e, RestServeur::HTTP_CODE_ERREUR);
1063
		}
1121
		}
1064
	}
1122
	}
1065
	
1123
	
1066
	private function initialiserFormatRetour() {
1124
	private function initialiserFormatRetour() {
1067
		$this->formatRetour = isset($this->parametres['format']) ? $this->parametres['format'] : $this->formatRetour;
1125
		$this->formatRetour = isset($this->parametres['format']) ? $this->parametres['format'] : $this->formatRetour;
1068
	}
1126
	}
1069
 
1127
 
1070
	/**
1128
	/**
1071
	 * Initialiser les variables de tri depuis les paramètres  
1129
	 * Initialiser les variables de tri depuis les paramètres  
1072
	 * */
1130
	 * */
1073
	private function initialiserTri() {
1131
	private function initialiserTri() {
1074
		$this->tri = isset($this->parametres['tri']) ? $this->parametres['tri'] : $this->tri;
1132
		$this->tri = isset($this->parametres['tri']) ? $this->parametres['tri'] : $this->tri;
1075
		$this->directionTri = isset($this->parametres['ordre']) ? $this->parametres['ordre'] : $this->directionTri;
1133
		$this->directionTri = isset($this->parametres['ordre']) ? $this->parametres['ordre'] : $this->directionTri;
1076
	}
1134
	}
1077
	
1135
	
1078
	/** Pour eviter les requêtes trop gourmandes, on supprime les caractères passe-partout
1136
	/** Pour eviter les requêtes trop gourmandes, on supprime les caractères passe-partout
1079
	 * @param les paramètres de l'application
1137
	 * @param les paramètres de l'application
1080
	 * */
1138
	 * */
1081
	public function nettoyerParametres($parametres) {
1139
	public function nettoyerParametres($parametres) {
1082
		$parametresRetour = array();
1140
		$parametresRetour = array();
1083
		foreach ($parametres as $cle => $valeur) {
1141
		foreach ($parametres as $cle => $valeur) {
1084
			$valSansPourcent = trim($valeur, "% ");
1142
			$valSansPourcent = trim($valeur, "% ");
1085
			if ($valSansPourcent != '') {
1143
			if ($valSansPourcent != '') {
1086
				$parametresRetour[$cle] = $valeur;
1144
				$parametresRetour[$cle] = $valeur;
1087
			}
1145
			}
1088
		}
1146
		}
1089
		
1147
		
1090
		return $parametresRetour;
1148
		return $parametresRetour;
1091
	}
1149
	}
1092
	
1150
	
1093
	/**
1151
	/**
1094
	 * Nettoyer les jokers
1152
	 * Nettoyer les jokers
1095
	 * @param la valeur du masque
1153
	 * @param la valeur du masque
1096
	 * */
1154
	 * */
1097
	private function remplacerParJokerCaractere($valeurMasque) {
1155
	private function remplacerParJokerCaractere($valeurMasque) {
1098
		return str_replace(array('-',' '), '_', $valeurMasque);
1156
		return str_replace(array('-',' '), '_', $valeurMasque);
1099
	}
1157
	}
1100
 
1158
 
1101
	//TODO: déplacer les fonctions ci dessus et dessous dans une classe
1159
	//TODO: déplacer les fonctions ci dessus et dessous dans une classe
1102
	// utilitaire
1160
	// utilitaire
1103
	
1161
	
1104
	/**
1162
	/**
1105
	 * Supprimer les accents des chaines de caractères
1163
	 * Supprimer les accents des chaines de caractères
1106
	 * */
1164
	 * */
1107
	function supprimerAccents($str, $charset='utf-8')
1165
	function supprimerAccents($str, $charset='utf-8')
1108
	{
1166
	{
1109
		$str = htmlentities($str, ENT_NOQUOTES, $charset);
1167
		$str = htmlentities($str, ENT_NOQUOTES, $charset);
1110
	
1168
	
1111
		$str = preg_replace('#&([A-za-z])(?:acute|cedil|circ|grave|orn|ring|slash|th|tilde|uml);#', '\1', $str);
1169
		$str = preg_replace('#&([A-za-z])(?:acute|cedil|circ|grave|orn|ring|slash|th|tilde|uml);#', '\1', $str);
1112
		$str = preg_replace('#&([A-za-z]{2})(?:lig);#', '\1', $str); // pour les ligatures e.g. '&oelig;'
1170
		$str = preg_replace('#&([A-za-z]{2})(?:lig);#', '\1', $str); // pour les ligatures e.g. '&oelig;'
1113
		$str = preg_replace('#&[^;]+;#', '', $str); // supprime les autres caractères
1171
		$str = preg_replace('#&[^;]+;#', '', $str); // supprime les autres caractères
1114
	
1172
	
1115
		return $str;
1173
		return $str;
1116
	}
1174
	}
1117
	
1175
	
1118
	/**
1176
	/**
1119
	 * Normaliser en supprimant les accents et en mettant en minuscule
1177
	 * Normaliser en supprimant les accents et en mettant en minuscule
1120
	 * @param $mot_cle le mot recherché
1178
	 * @param $mot_cle le mot recherché
1121
	 * */
1179
	 * */
1122
	private function normaliserMotCle($mot_cle) {
1180
	private function normaliserMotCle($mot_cle) {
1123
		return mb_strtolower($this->supprimerAccents(trim($mot_cle)));
1181
		return mb_strtolower($this->supprimerAccents(trim($mot_cle)));
1124
	}
1182
	}
1125
	
1183
	
1126
	/**
1184
	/**
1127
	 * Récupérer le numéro du département d'un fichier de configuration
1185
	 * Récupérer le numéro du département d'un fichier de configuration
1128
	 * */
1186
	 * */
1129
	private function obtenirIdDepartement($nomDpt) {
1187
	private function obtenirIdDepartement($nomDpt) {
1130
	
1188
	
1131
		$nomDpt = $this->supprimerAccents($nomDpt);
1189
		$nomDpt = $this->supprimerAccents($nomDpt);
1132
		$nomDpt = strtolower(str_replace(' ','-',$nomDpt));
1190
		$nomDpt = strtolower(str_replace(' ','-',$nomDpt));
1133
	
1191
	
1134
		$idDpt = $this->conteneur->getParametre($nomDpt);
1192
		$idDpt = $this->conteneur->getParametre($nomDpt);
1135
		if($idDpt == null || $idDpt == ' ') {
1193
		if($idDpt == null || $idDpt == ' ') {
1136
			$idDpt = ' ';
1194
			$idDpt = ' ';
1137
		}
1195
		}
1138
		return $idDpt;
1196
		return $idDpt;
1139
	}
1197
	}
1140
	
1198
	
1141
	
1199
	
1142
	/**
1200
	/**
1143
	 * Obtenir le type de requête à exécuter en fonction des paramètres de recherche
1201
	 * Obtenir le type de requête à exécuter en fonction des paramètres de recherche
1144
	 * @param $parametres les paramètres de l'application
1202
	 * @param $parametres les paramètres de l'application
1145
	 * */
1203
	 * */
1146
	private function getTypeRequete($ressources, $parametres) {
1204
	private function getTypeRequete($ressources, $parametres) {
1147
 
1205
 
1148
		// une image par id 
1206
		// une image par id 
1149
		if ((count($ressources) == 1) && is_numeric($ressources[0])) {
1207
		if ((count($ressources) == 1) && is_numeric($ressources[0])) {
1150
			return 'id';
1208
			return 'id';
1151
		}
1209
		}
1152
 
1210
 
1153
		$typeRequete = 'simple';
1211
		$typeRequete = 'simple';
1154
		
1212
		
1155
		// Dans ce cas précis, les informations concernant le depart, la limite ou l'ordre ne 
1213
		// Dans ce cas précis, les informations concernant le depart, la limite ou l'ordre ne 
1156
		// rentre pas en compte dans le type de requête ; ce ne sont que des compléments.
1214
		// rentre pas en compte dans le type de requête ; ce ne sont que des compléments.
1157
		unset($parametres['navigation.depart']);
1215
		unset($parametres['navigation.depart']);
1158
		unset($parametres['navigation.limite']);
1216
		unset($parametres['navigation.limite']);
1159
		unset($parametres['ordre']);
1217
		unset($parametres['ordre']);
1160
		
1218
		
1161
		// En revanche, chaque masque est associé à un type de requête particulier.
1219
		// En revanche, chaque masque est associé à un type de requête particulier.
1162
		$masquesObservation = array('masque', 'masque.departement', 'masque.ns', 'masque.genre', 'masque.date', 'masque.commune', 'masque.famille', 'masque.auteur', 'masque.nn', 'masque.referentiel');
1220
		$masquesObservation = array('masque', 'masque.departement', 'masque.ns', 'masque.genre', 'masque.date', 'masque.commune', 'masque.famille', 'masque.auteur', 'masque.nn', 'masque.referentiel', 'masque.tag_cel');
1163
		$masquesImage = array('masque', 'masque.tag');
1221
		$masquesImage = array('masque', 'masque.tag_pictoflora');
1164
		
1222
		
1165
		// Le type de requête est défini par les tables qu'il doit inclure (observation, image, ou les deux) 
1223
		// Le type de requête est défini par les tables qu'il doit inclure (observation, image, ou les deux) 
1166
		$requeteSimple = false;
1224
		$requeteSimple = false;
1167
		$pourObservation = false;
1225
		$pourObservation = false;
1168
		$pourImage = false;
1226
		$pourImage = false;
1169
		
1227
		
1170
		// S'il n'y a aucun paramètre, on lance une requête simple
1228
		// S'il n'y a aucun paramètre, on lance une requête simple
1171
		if (empty($parametres)) {
1229
		if (empty($parametres)) {
1172
			$requeteSimple = true;
1230
			$requeteSimple = true;
1173
		}
1231
		}
1174
		
1232
		
1175
		// Si l'un des masques demandé concerne l'observation
1233
		// Si l'un des masques demandé concerne l'observation
1176
		foreach ($masquesObservation as $masque) {
1234
		foreach ($masquesObservation as $masque) {
1177
			if (isset($parametres[$masque])) {
1235
			if (isset($parametres[$masque])) {
1178
				$pourObservation = true;
1236
				$pourObservation = true;
1179
				break;
1237
				break;
1180
			}
1238
			}
1181
		}
1239
		}
1182
		
1240
		
1183
		// Si l'un des masques demandé concerne les images
1241
		// Si l'un des masques demandé concerne les images
1184
		foreach ($masquesImage as $masque) {
1242
		foreach ($masquesImage as $masque) {
1185
			if (isset($parametres[$masque])) {
1243
			if (isset($parametres[$masque])) {
1186
				$pourImage = true;
1244
				$pourImage = true;
1187
				break;
1245
				break;
1188
			}
1246
			}
1189
		}
1247
		}
1190
		
1248
		
1191
		// Selon les tri
1249
		// Selon les tri
1192
		if (isset($parametres['tri'])) {
1250
		if (isset($parametres['tri'])) {
1193
			switch ($parametres['tri']) {
1251
			switch ($parametres['tri']) {
1194
				case 'votes' :
1252
				case 'votes' :
1195
				case 'tags' :
1253
				case 'tags' :
1196
					$pourImage = true;
1254
					$pourImage = true;
1197
					break;
1255
					break;
1198
				default : //case 'date_observation' :
1256
				default : //case 'date_observation' :
1199
					if (sizeof($parametres) > 1) {
1257
					if (sizeof($parametres) > 1) {
1200
						$pourObservation = true;
1258
						$pourObservation = true;
1201
					}
1259
					}
1202
			}
1260
			}
1203
		}
1261
		}
1204
		
1262
		
1205
		// Vérifier la combinaison des booléens pour en déduire le type de requête
1263
		// Vérifier la combinaison des booléens pour en déduire le type de requête
1206
		if ($pourObservation && $pourImage) {
1264
		if ($pourObservation && $pourImage) {
1207
			$typeRequete = 'obs-images';
1265
			$typeRequete = 'obs-images';
1208
		} else {
1266
		} else {
1209
			if ($pourImage) {
1267
			if ($pourImage) {
1210
				$typeRequete = 'images';
1268
				$typeRequete = 'images';
1211
			} else if ($pourObservation) {
1269
			} else if ($pourObservation) {
1212
				$typeRequete = 'obs';
1270
				$typeRequete = 'obs';
1213
			} else { // if ($requeteSimple)
1271
			} else { // if ($requeteSimple)
1214
				$typeRequete = 'simple';
1272
				$typeRequete = 'simple';
1215
			}
1273
			}
1216
		}
1274
		}
1217
			
1275
			
1218
		return $typeRequete;
1276
		return $typeRequete;
1219
	}
1277
	}
1220
	
1278
	
1221
	
1279
	
1222
	private function doitJoindreTableVotes() {
1280
	private function doitJoindreTableVotes() {
1223
		return ($this->tri == 'votes');
1281
		return ($this->tri == 'votes');
1224
	}
1282
	}
1225
	
1283
	
1226
	private function doitJoindreTableTags() {
1284
	private function doitJoindreTableTags() {
1227
		return ($this->tri == 'tags');
1285
		return ($this->tri == 'tags');
1228
	}
1286
	}
1229
 
1287
 
1230
	/*-------------------------------------------------------------------------------
1288
	/*-------------------------------------------------------------------------------
1231
								FORMATER ET METTRE EN FORME
1289
								FORMATER ET METTRE EN FORME
1232
	--------------------------------------------------------------------------------*/
1290
	--------------------------------------------------------------------------------*/
1233
	
1291
	
1234
	/**
1292
	/**
1235
	*  Formater une observation depuis une ligne liaison
1293
	*  Formater une observation depuis une ligne liaison
1236
	*  @param $liaison liaison issue de la recherche
1294
	*  @param $liaison liaison issue de la recherche
1237
	*  @return $observation l'observation mise en forme
1295
	*  @return $observation l'observation mise en forme
1238
	* */
1296
	* */
1239
	private function formaterObservation($liaison) {
1297
	private function formaterObservation($liaison) {
1240
		$observation = array();
1298
		$observation = array();
1241
		foreach ($this->mappingObservation as $nomOriginal => $nomFinal) {
1299
		foreach ($this->mappingObservation as $nomOriginal => $nomFinal) {
1242
			$observation[$nomFinal] = $liaison[$nomOriginal];
1300
			$observation[$nomFinal] = $liaison[$nomOriginal];
1243
		}
1301
		}
1244
 
1302
 
1245
		return $observation;
1303
		return $observation;
1246
	}
1304
	}
1247
	
1305
	
1248
	/**
1306
	/**
1249
	*  Formater une observation depuis une ligne liaison
1307
	*  Formater une observation depuis une ligne liaison
1250
	*  @param $liaison liaison issue de la recherche
1308
	*  @param $liaison liaison issue de la recherche
1251
	*  @return $observation l'observation mise en forme
1309
	*  @return $observation l'observation mise en forme
1252
	* */
1310
	* */
1253
	private function formaterVotes($votes) {
1311
	private function formaterVotes($votes) {
1254
		$retour = array();
1312
		$retour = array();
1255
		foreach ($votes as $vote) {
1313
		foreach ($votes as $vote) {
1256
			$retour_vote = array();
1314
			$retour_vote = array();
1257
			foreach ($vote as $param=>$valeur) {
1315
			foreach ($vote as $param=>$valeur) {
1258
				if (strpos($this->mappingVotes[$param], 'protocole.') === 0) {
1316
				if (strpos($this->mappingVotes[$param], 'protocole.') === 0) {
1259
					$retour_protocole[$this->mappingVotes[$param]] = $valeur;
1317
					$retour_protocole[$this->mappingVotes[$param]] = $valeur;
1260
				} else {
1318
				} else {
1261
					$retour_vote[$this->mappingVotes[$param]] = $valeur;
1319
					$retour_vote[$this->mappingVotes[$param]] = $valeur;
1262
				}
1320
				}
1263
			}
1321
			}
1264
			if (!isset($retour[$vote['ce_image']][$vote['ce_protocole']])) {
1322
			if (!isset($retour[$vote['ce_image']][$vote['ce_protocole']])) {
1265
				$retour[$vote['ce_image']][$vote['ce_protocole']] = $retour_protocole;
1323
				$retour[$vote['ce_image']][$vote['ce_protocole']] = $retour_protocole;
1266
			}
1324
			}
1267
			$retour[$vote['ce_image']][$vote['ce_protocole']]['votes'][$vote['id_vote']] = $retour_vote;
1325
			$retour[$vote['ce_image']][$vote['ce_protocole']]['votes'][$vote['id_vote']] = $retour_vote;
1268
		}
1326
		}
1269
		
1327
		
1270
		return $retour;
1328
		return $retour;
1271
	}
1329
	}
1272
	
1330
	
1273
	/**
1331
	/**
1274
	 * Formater le lien de l'image en fonction du fichier de config et de l'identifiant de l'image
1332
	 * Formater le lien de l'image en fonction du fichier de config et de l'identifiant de l'image
1275
	 * */
1333
	 * */
1276
	private function formaterLienImage($idImage) {
1334
	private function formaterLienImage($idImage) {
1277
		$idImage = sprintf('%09s', $idImage);
1335
		$idImage = sprintf('%09s', $idImage);
1278
		$url = $this->conteneur->getParametre('url_images');
1336
		$url = $this->conteneur->getParametre('url_images');
1279
		$urlImage = sprintf($url, $idImage, $this->formatRetour);
1337
		$urlImage = sprintf($url, $idImage, $this->formatRetour);
1280
		return $urlImage;
1338
		return $urlImage;
1281
	}
1339
	}
1282
	
1340
	
1283
	private function proteger($valeur) {
1341
	private function proteger($valeur) {
1284
		if (is_array($valeur)) {
1342
		if (is_array($valeur)) {
1285
			return $this->bdd->protegerTableau($valeur);
1343
			return $this->bdd->protegerTableau($valeur);
1286
		} else {
1344
		} else {
1287
			return $this->bdd->proteger($valeur);
1345
			return $this->bdd->proteger($valeur);
1288
		}
1346
		}
1289
	}
1347
	}
1290
}
1348
}
1291
?>
1349
?>