Subversion Repositories eFlore/Applications.cel

Rev

Rev 868 | Go to most recent revision | Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
862 aurelien 1
<?php
2
/**
3
 * librairie recherche d'images a partir de divers critères
4
 * Encodage en entrée : utf8
5
 * Encodage en sortie : utf8
6
 *
7
 * @author Aurélien PERONNET <aurelien@tela-botanica.org>
8
 * @license GPL v3 <http://www.gnu.org/licenses/gpl.txt>
9
 * @license CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
10
 * @version $Id$
11
 */
12
class RechercheImage extends Cel {
13
 
14
 
15
	function rechercherImagesEtObservationAssociees($id_utilisateur, $criteres, $numero_page, $taille_page)
16
	{
17
		$images_trouvees = $this->rechercherImages($id_utilisateur, $criteres, $numero_page, $taille_page);
18
 
19
		$retour = array();
20
 
21
		foreach($images_trouvees as $image)
22
		{
23
			$image['id_observation'] = $this->obtenirInformationsObservationsAssociees($id_utilisateur,$image['id_image']);
24
			$retour[] = $image ;
25
		}
26
 
27
		return $retour;
28
	}
29
 
30
	// TODO: fonction temporaire
31
	public function parserRequeteCriteres($chaine_criteres) {
32
		$criteres_parses = array();
33
		$criteres = explode("&", $chaine_criteres) ;
34
 
35
		foreach($criteres as &$critere) {
36
			$criteres_parses[] = explode("=",$critere) ;
37
		}
38
 
39
		return $criteres_parses;
40
	}
41
 
42
	// TODO: fonction temporaire
43
	private function formaterDateSqlVersDateAvecSlash($date_sql) {
44
 
45
		$date_formatee = '';
46
 
47
		$date = split("-",$date_sql) ;
48
		if(count($date) > 2)
49
		{
50
			$image['date_prise_de_vue'] = $date[2].'/'.$date[1].'/'.$date[0] ;
51
		}
52
 
53
		return $date_formatee;
54
	}
55
 
56
	public function rechercherImages($id_utilisateur, $criteres, $numero_page = 0 , $taille_page = 50) {
57
 
58
		$requete_recherche_images = 'SELECT * FROM cel_images WHERE ce_utilisateur = "'.$id_utilisateur.'"' ;
59
 
60
		$sous_requete_recherche = $this->fabriquerSousRequeteRecherche($id_utilisateur, $criteres);
61
 
62
		$requete_recherche_images .= $sous_requete_recherche;
63
 
64
		$debut = $taille_page*$numero_page ;
65
		$requete_recherche_image .= ' ORDER BY ordre LIMIT '.$debut.','.$taille_page ;
66
 
67
		$resultats_images = array();
68
		$resultats_images = $this->requeter($requete_recherche_images);
69
 
70
		return $resultats_images;
71
	}
72
 
73
	public function compterImages($id_utilisateur, $criteres) {
74
 
75
		$requete_recherche_images = 'SELECT COUNT(*) as nb_images FROM cel_images WHERE ce_utilisateur = "'.$id_utilisateur.'"' ;
76
		$sous_requete_recherche = $this->fabriquerSousRequeteRecherche($id_utilisateur, $criteres);
77
 
78
		$requete_recherche_images .= $sous_requete_recherche;
79
		$nb_images = 0;
80
 
81
		$resultat_requete_nombre_images = $this->requeter($requete_recherche_images);
82
 
83
		if($resultat_requete_nombre_images && is_array($resultat_requete_nombre_images) && count($resultat_requete_nombre_images) > 0) {
84
			$nb_images = $resultat_requete_nombre_images[0]['nb_images'];
85
		}
86
 
87
		return $nb_images;
88
	}
89
 
90
	public function obtenirInformationsObservationsAssociees($id_utilisateur, $id_image) {
91
 
92
		$requete_table_liaison = 'SELECT id_observation FROM cel_obs_images WHERE id_image = '.$id_image.' AND id_utilisateur ="'.$id_utilisateur.'"';
93
 
94
		$resultats_liaisons_images = $this->requeter($requete_table_liaison);
95
 
96
		$ids_obs = '';
97
 
98
		foreach($resultats_liaisons_images as $liaison) {
99
			$ids_obs .= $liaison['id_observation'].",";
100
		}
101
		$ids_obs = rtrim($ids_obs,',');
102
		$infos_obs = '';
103
 
104
		if(trim($ids_obs) != '') {
105
			$requete_obs_liees = 'SELECT * FROM cel_obs WHERE id_observation IN  ('.$ids_obs.') AND ce_utilisateur ="'.$id_utilisateur.'"';
106
			$resultat_obs_liees = $this->requeter($requete_obs_liees);
107
 
108
			foreach($resultat_obs_liees as $obs_liee)
109
			{
110
				$infos_obs .= $obs_liee['ordre'].'#'.$obs_liee['nom_sel'].'#'.$obs_liee['transmission'].';;' ;
111
			}
112
		}
113
 
114
		return $infos_obs;
115
	}
116
 
117
	private function fabriquerSousRequeteRecherche($id_utilisateur, $criteres) {
118
 
119
		$sous_requete = ' AND ';
120
 
121
		foreach($criteres as $nom_valeur)
122
		{
123
			if(count($nom_valeur) == 0) {
124
				continue;
125
			}
126
 
127
			switch($nom_valeur[0]) {
128
 
129
				case "mots_cles";
130
					$mots_cles = rtrim($nom_valeur[1], ',') ;
131
					$mots_cles_liste = explode("," , $mots_cles) ;
132
 
133
					foreach($mots_cles_liste as $mot_cle)
134
					{
135
						$sous_requete .= $nom_valeur[0].' LIKE "%'.$this->proteger($mot_cle).'%"' ;
136
						$sous_requete .= ' AND ' ;
137
					}
138
				break;
139
 
140
				case "commentaire":
141
					$mots_comment_liste = explode(" " , $nom_valeur[1]) ;
142
 
143
					foreach($mots_comment_liste as $mot_comment)
144
					{
145
						$mot_comment = trim($mot_comment) ;
146
						$sous_requete .= $nom_valeur[0].' LIKE "%'.$this->proteger($mot_comment).'%"' ;
147
						$sous_requete .= ' AND ' ;
148
					}
149
				break;
150
 
151
				case "annee":
152
				case "mois":
153
				case "jour":
154
					$sous_requete .= $this->fabriquerSousRequeteRechercheDate($nom_valeur[0], $nom_valeur[1]) ;
155
					$sous_requete .= ' AND ' ;
156
				break;
157
 
158
				case "tampon":
159
					$ids_tampon = rtrim($nom_valeur[1], ',') ;
160
					$sous_requete .= 'id_images IN ( '.$this->proteger($ids_tampon).')' ;
161
				break;
162
 
163
				case "recherche_generale":
164
					$sous_requete .= $this->fabriquerSousRequeteRechercheGenerale($id_utilisateur, $nom_valeur[1]);
165
					$sous_requete .= ' AND ';
166
				break;
167
 
168
				default:
169
					$sous_requete .= $nom_valeur[0].' = "'.$this->proteger($nom_valeur[1]) ;
170
					$sous_requete .= '" AND ' ;
171
				break;
172
			}
173
		}
174
 
175
		$sous_requete = rtrim($sous_requete,' AND ');
176
 
177
		return $sous_requete;
178
	}
179
 
180
	private function fabriquerSousRequeteRechercheGenerale($id_utilisateur, $chaine_recherche) {
181
 
182
		$requete_recherche_taxon .= 'SELECT id_image
183
								FROM cel_obs_images
184
								WHERE id_observation IN ' .
185
								'(SELECT id_observation ' .
186
									'FROM cel_obs '.
187
									'WHERE ce_utilisateur ="'.$id_utilisateur.'" '.
188
									'AND nom_sel LIKE "'.$chaine_recherche.'%" '.
189
								')';
190
 
191
		$requete_recherche_comm = ' commentaire LIKE "%'.$chaine_recherche.'%" ';
192
 
193
		$requete_recherche_generale = '(id_image IN ( '.($requete_recherche_taxon).') OR ('.$requete_recherche_comm.'))' ;
194
 
195
		return $requete_recherche_generale;
196
	}
197
 
198
	private function fabriquerSousRequeteRechercheDate($intervalle, $valeur) {
199
 
200
		$correspondance_champ = array('annee' => 'YEAR','mois' => 'MONTH','jour' => 'DAY');
201
 
202
		$requete_recherche_date = '';
203
 
204
		if(is_numeric($valeur) && $valeur != "00") {
205
			$requete_recherche_date = $correspondance_champ[$intervalle].'(ci_meta_date) = "'.$valeur.'" ';
206
		} else {
207
			$requete_recherche_date = '(date_prise_de_vue IS NULL OR date_prise_de_vue = "0000-00-00")';
208
		}
209
 
210
		return $requete_recherche_date;
211
	}
212
}
213
?>