Subversion Repositories eFlore/Applications.cel

Rev

Rev 1570 | Go to most recent revision | Show entire file | Regard whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 1570 Rev 1581
Line 1... Line 1...
1
<?php
1
<?php
2
/**
2
/**
-
 
3
 * Librairie de recherche d'observations à partir de divers critères.
-
 
4
 * Encodage en entrée : utf8
3
* PHP Version 5
5
 * Encodage en sortie : utf8
4
*
6
 *
5
* @category  PHP
7
 * @category  php 5.2
6
* @package   jrest
8
 * @package   cel
7
* @author    Aurélien Peronnet <aurelien@tela-botania.org>
9
 * @author    Aurélien Peronnet <aurelien@tela-botania.org>
8
* @copyright 2010 Tela-Botanica
10
 * @copyright 2010 Tela-Botanica
9
* @license   http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
11
 * @license   http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
10
* @version   SVN: <svn_id>
12
 * @version   SVN: <svn_id>
11
* @link      /doc/jrest/
13
 * @link      /doc/jrest/
12
*/
14
 */
13
 
-
 
14
/**
-
 
15
* in : utf8
-
 
16
* out : utf8
-
 
17
* 
-
 
18
* Librairie recherche d'observations a partir de divers critères
-
 
19
*
-
 
20
*/
-
 
21
class RechercheObservation extends Cel {
15
class RechercheObservation extends Cel {
Line 22... Line 16...
22
	
16
 
23
	public function obtenirIdObservationsPourOrdre($id_utilisateur, $ordre) {
-
 
24
		
17
	public function obtenirIdObservationsPourOrdre($id_utilisateur, $ordre) {
Line 25... Line 18...
25
		$requete_selection_id = 'SELECT id_observation FROM cel_obs WHERE ordre ';
18
		$requete_selection_id = 'SELECT id_observation FROM cel_obs WHERE ordre ';
26
		
19
 
27
		if(is_array($ordre)) {
20
		if (is_array($ordre)) {
28
			$ordre = array_map(array($this,'proteger'), $ordre);
21
			$ordre = array_map(array($this,'proteger'), $ordre);
29
			$requete_selection_id .= ' IN ('.implode(',',$ordre).') ';
22
			$requete_selection_id .= ' IN ('.implode(',',$ordre).') ';
30
		} else {
23
		} else {
Line 31... Line 24...
31
			$requete_selection_id .= ' = '.$this->proteger($ordre).' ';
24
			$requete_selection_id .= ' = '.$this->proteger($ordre).' ';
32
		}
25
		}
Line 33... Line 26...
33
		
26
 
Line 34... Line 27...
34
		$requete_selection_id .= ' AND ce_utilisateur = '.$this->proteger($id_utilisateur);
27
		$requete_selection_id .= ' AND ce_utilisateur = '.$this->proteger($id_utilisateur).
35
		$requete_selection_id .= ' ORDER BY id_observation';
28
			' ORDER BY id_observation';
Line 45... Line 38...
45
		
38
 
46
		return $ids;
39
		return $ids;
Line 47... Line 40...
47
	}
40
	}
48
	
-
 
49
	public function rechercherObservations($id_utilisateur = null, $criteres = array(), $debut = 0, $limite = 50) {
41
 
Line 50... Line 42...
50
		
42
	public function rechercherObservations($id_utilisateur = null, $criteres = array(), $debut = 0, $limite = 50) {
51
 		$requete_selection_observations = 'SELECT * FROM cel_obs ';
43
		$requete_selection_observations = 'SELECT * FROM cel_obs ';
52
 		
44
 
Line 68... Line 60...
68
 
60
 
69
		return $resultats_observations;
61
		return $resultats_observations;
Line 70... Line 62...
70
	}
62
	}
71
	
-
 
72
	public function compterObservations($id_utilisateur = null, $criteres = array()) {
63
 
Line 73... Line 64...
73
		
64
	public function compterObservations($id_utilisateur = null, $criteres = array()) {
74
 		$requete_selection_observations = 'SELECT COUNT(*) as nb_obs FROM cel_obs ';
65
 		$requete_selection_observations = 'SELECT COUNT(*) as nb_obs FROM cel_obs ';
75
 		
66
 
Line 93... Line 84...
93
		
84
 
94
		return $nb_obs;
85
		return $nb_obs;
Line 95... Line 86...
95
	}
86
	}
96
	
-
 
97
	public function formaterPourEnvoiCel($tableau_observations) {
87
 
98
		
88
	public function formaterPourEnvoiCel($tableau_observations) {
99
		$ids = array();
89
		$ids = array();
100
		foreach($tableau_observations as &$observation) {
90
		foreach ($tableau_observations as &$observation) {
Line 109... Line 99...
109
			$mots_cles_chaine = rtrim($mots_cles_chaine,';');
99
			$mots_cles_chaine = rtrim($mots_cles_chaine,';');
110
			$observation['mots_cles'] = $mots_cles_chaine;
100
			$observation['mots_cles'] = $mots_cles_chaine;
Line 111... Line 101...
111
			
101
 
112
			foreach($observation as $champ => $valeur) {
102
			foreach ($observation as $champ => $valeur) {
113
				if($valeur == 'NULL') {
103
				if ($valeur == 'NULL') {
114
					$observation[$champ] = "";
104
					$observation[$champ] = '';
115
				}
105
				}
116
			}
106
			}
Line 117... Line 107...
117
		}
107
		}
Line 127... Line 117...
127
		
117
 
128
		return $tableau_observations;
118
		return $tableau_observations;
Line 129... Line 119...
129
	}
119
	}
130
	
120
 
131
	public function obtenirCourrielUtilisateurPourIdObs($id_obs) {
121
	public function obtenirCourrielUtilisateurPourIdObs($id_obs) {
Line 132... Line 122...
132
		$requete = 'SELECT courriel_utilisateur FROM cel_obs WHERE '.
122
		$id_obs = $this->proteger($id_obs);
Line 133... Line 123...
133
			         'id_observation = '.$this->proteger($id_obs);  
123
		$requete = "SELECT courriel_utilisateur FROM cel_obs WHERE id_observation = $id_obs";
134
	
124
 
135
		$utilisateur_courriel = $this->executerRequete($requete);
125
		$utilisateur_courriel = $this->executerRequete($requete);
136
	
126
 
137
		$retour = false;
-
 
138
		if(!empty($utilisateur_courriel) && isset($utilisateur_courriel[0]['courriel_utilisateur'])) {
127
		$retour = false;
139
			$retour = $utilisateur_courriel[0]['courriel_utilisateur'];
128
		if (!empty($utilisateur_courriel) && isset($utilisateur_courriel[0]['courriel_utilisateur'])) {
Line 140... Line 129...
140
		}
129
			$retour = $utilisateur_courriel[0]['courriel_utilisateur'];
141
	
-
 
142
		return $retour;
130
		}
143
	}
131
		return $retour;
144
	
132
	}
145
	private function getIdsMotsClesObservation($id_observation) {
-
 
146
		
133
 
147
		$requete_selection_mots_cles = 'SELECT DISTINCT id_mot_cle_obs '.
134
	private function getIdsMotsClesObservation($id_observation) {
Line 148... Line 135...
148
									   'FROM cel_obs_mots_cles '.
135
		$requete_selection_mots_cles = 'SELECT DISTINCT id_mot_cle_obs '.
149
									   'WHERE id_observation = '.$id_observation;
136
			'FROM cel_obs_mots_cles '.
150
					   
137
			"WHERE id_observation = $id_observation ";
151
		return $this->executerRequete($requete_selection_mots_cles);	
138
		return $this->executerRequete($requete_selection_mots_cles);
152
	}
-
 
153
	
139
	}
154
	// TODO: fonction temporaire
140
 
155
	public function parserRequeteCriteres($chaine_criteres) {
141
	// TODO: fonction temporaire
156
		$criteres_parses = array();
142
	public function parserRequeteCriteres($chaine_criteres) {
157
		$criteres = explode("&", $chaine_criteres) ;	
143
		$criteres_parses = array();
158
 
144
		$criteres = explode('&', $chaine_criteres) ;
159
		foreach($criteres as &$critere) {
-
 
160
			$nom_valeur = explode("=",$critere) ;
145
		foreach ($criteres as &$critere) {
161
			if(count($nom_valeur) >= 2) {
146
			$nom_valeur = explode('=', $critere) ;
Line 162... Line 147...
162
				$criteres_parses[$nom_valeur[0]] = $nom_valeur[1];
147
			if (count($nom_valeur) >= 2) {
163
			}
-
 
164
		}
148
				$criteres_parses[$nom_valeur[0]] = $nom_valeur[1];
165
		
-
 
166
		return $criteres_parses;
149
			}
167
	}
-
 
168
	
150
		}
169
	private function fabriquerSousRequeteRecherche($id_utilisateur, $criteres) {
151
		return $criteres_parses;
170
		
152
	}
Line 171... Line 153...
171
		$sous_requete = '';
153
 
172
		
-
 
173
		foreach ($criteres as $nom => $valeur)
154
	private function fabriquerSousRequeteRecherche($id_utilisateur, $criteres) {
174
		{
155
		$sous_requete = '';
175
			if($valeur == null || trim($nom) == "" || trim($valeur) == "") {
156
		foreach ($criteres as $nom => $valeur) {
176
				continue;	
157
			if ($valeur == null || trim($nom) == '' || trim($valeur) == '') {
177
			}
-
 
178
						
158
				continue;
179
			switch ($nom) {
159
			}
180
				
160
 
181
				case "mots_cles";
161
			switch ($nom) {
182
					$sous_requete .= $this->creerSousRequeteMotsCles($valeur);
162
				case "mots_cles";
183
					$sous_requete .= ' AND ';
163
					$sous_requete .= $this->creerSousRequeteMotsCles($valeur);
184
				break;
164
					$sous_requete .= ' AND ';
185
				
165
					break;
186
				case 'annee':
-
 
187
					if($valeur == "NULL") {
166
				case 'annee':
188
						$sous_requete .= "(date_observation IS NULL OR year(date_observation) = 0000)" ;
167
					if ($valeur == "NULL") {
189
					} else {
168
						$sous_requete .= "(date_observation IS NULL OR year(date_observation) = 0000)" ;
190
						$sous_requete .= "(year(date_observation) = ".$this->proteger($valeur).")" ;
169
					} else {
191
					}
170
						$sous_requete .= "(year(date_observation) = ".$this->proteger($valeur).")" ;
192
					$sous_requete .= ' AND ' ;
171
					}
193
				break;
172
					$sous_requete .= ' AND ' ;
194
				
173
					break;
195
				case 'mois':
-
 
196
					if($valeur == "NULL") {
174
				case 'mois':
197
						$sous_requete .= "date_observation IS NULL OR month(date_observation) = 00" ;
175
					if ($valeur == "NULL") {
198
					} else {
176
						$sous_requete .= "date_observation IS NULL OR month(date_observation) = 00" ;
199
						$sous_requete .= "month(date_observation) = ".$this->proteger($valeur) ;
177
					} else {
200
					}
178
						$sous_requete .= "month(date_observation) = ".$this->proteger($valeur) ;
201
					$sous_requete .= ' AND ' ;
179
					}
202
				break;
180
					$sous_requete .= ' AND ' ;
203
				
181
					break;
204
				case 'jour':
-
 
205
					if($valeur == "NULL") {
182
				case 'jour':
206
						$sous_requete .= "date_observation IS NULL OR day(date_observation) = 00" ;
183
					if ($valeur == "NULL") {
207
					} else {
184
						$sous_requete .= "date_observation IS NULL OR day(date_observation) = 00" ;
208
						$sous_requete .= "day(date_observation) = ".$this->proteger($valeur) ;
185
					} else {
209
					}
186
						$sous_requete .= "day(date_observation) = ".$this->proteger($valeur) ;
Line 222... Line 199...
222
							}
199
							}
223
							$sous_requete = rtrim($sous_requete,' OR ').') ';
200
							$sous_requete = rtrim($sous_requete,' OR ').') ';
224
						} else {
201
						} else {
225
							$sous_requete .= "(ce_zone_geo LIKE ".$this->proteger('INSEE-C:'.$valeur.'___').')';
202
							$sous_requete .= "(ce_zone_geo LIKE ".$this->proteger('INSEE-C:'.$valeur.'___').')';
226
						}
203
						}
227
						
-
 
228
					}
204
					}
229
					$sous_requete .= ' AND ' ;
205
					$sous_requete .= ' AND ' ;
230
				break;
206
					break;
231
				
-
 
232
				case 'commune':
207
				case 'commune':
233
					if($valeur == "NULL") {
208
					if ($valeur == "NULL") {
234
						$sous_requete .= "(zone_geo IS NULL OR zone_geo = '')";
209
						$sous_requete .= "(zone_geo IS NULL OR zone_geo = '')";
235
					} else {
210
					} else {
236
						$sous_requete .= "(zone_geo = ".$this->proteger($valeur).')';
211
						$sous_requete .= "(zone_geo = ".$this->proteger($valeur).')';
237
					}
212
					}
238
					$sous_requete .= ' AND ' ;
213
					$sous_requete .= ' AND ' ;
239
				break;
214
					break;
240
								
-
 
241
                case 'id_mots_cles':
215
				case 'id_mots_cles':
242
                    $liste_mc = '"'.str_replace(';','","',$valeur).'"';
216
					$liste_mc = '"'.str_replace(';','","',$valeur).'"';
243
                    $sous_requete .= '' ;   
217
					$sous_requete .= '' ;
244
                    $sous_requete .= 'id_observation IN (SELECT id_observation FROM cel_obs_mots_cles WHERE id_mot_cle_obs IN ('.$liste_mc.'))';
218
					$sous_requete .= 'id_observation IN (SELECT id_observation FROM cel_obs_mots_cles WHERE id_mot_cle_obs IN ('.$liste_mc.'))';
245
                    $sous_requete .= ' AND ' ;
219
					$sous_requete .= ' AND ' ;
Line 262... Line 236...
262
                				" nom_ret LIKE ".$valeur_protegee." OR".
236
								" nom_ret LIKE ".$valeur_protegee." OR".
263
                				" famille LIKE ".$valeur_protegee.
237
								" famille LIKE ".$valeur_protegee.
264
                				" ) AND ";
238
								" ) AND ";
265
                break;
239
					break;
266
				default:
240
				default:
267
					if(trim($nom) != '')
241
					if (trim($nom) != '') {
268
					{
-
 
269
						$sous_requete .= $nom." = ".$this->proteger($valeur) ;
242
						$sous_requete .= $nom." = ".$this->proteger($valeur) ;
270
						$sous_requete .= ' AND ' ;
243
						$sous_requete .= ' AND ';
271
					}				
244
					}
272
					if(trim($nom) == "NULL") {
245
					if (trim($nom) == 'NULL') {
273
						$sous_requete .= "(".$nom." IS NULL OR ".$nom." = '')" ;
246
						$sous_requete .= "($nom IS NULL OR $nom = '')";
274
						$sous_requete .= ' AND ' ;
247
						$sous_requete .= ' AND ';
275
					}
248
					}
276
				break;
249
					break;
277
			}
250
			}
278
		}
251
		}
279
		
-
 
280
		$sous_requete = rtrim($sous_requete,' AND ');
252
		$sous_requete = rtrim($sous_requete,' AND ');
281
		return $sous_requete;
253
		return $sous_requete;
282
	}
254
	}
Line 283... Line 255...
283
	
255
 
Line 336... Line 308...
336
		}
308
		}
337
		return $requete;
309
		return $requete;
338
	}
310
	}
Line 339... Line 311...
339
	
311
 
340
	private function estUnvaleurZeroNulle($valeur) {
312
	private function estUnvaleurZeroNulle($valeur) {
341
		return $valeur == "000null";
313
		return $valeur == '000null';
Line 342... Line 314...
342
	}
314
	}
343
	
315
 
344
	private function traiterRequeteValeurZeroNulle($valeur) {
316
	private function traiterRequeteValeurZeroNulle($valeur) {
345
		$champs = array('annee' => 'date_observation',
317
		$champs = array('annee' => 'date_observation',
346
						'mois' => 'date_observation',
318
			'mois' => 'date_observation',
347
						'jour' => 'date_observation',
319
			'jour' => 'date_observation',
348
						'departement' => 'ce_zone_geo',
-
 
349
						'commune' => 'zone_geo'
-
 
350
		);	
320
			'departement' => 'ce_zone_geo',
351
		
321
			'commune' => 'zone_geo');
352
		return $sous_requete .= $champs[$valeur]." = ".$this->proteger("");
322
		return $sous_requete .= $champs[$valeur]." = ".$this->proteger("");
353
	}	
323
	}
354
}
324
}