Subversion Repositories eFlore/Applications.cel

Rev

Rev 736 | Rev 959 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 736 Rev 899
Line 1... Line 1...
1
<?php
1
<?php
-
 
2
// ATTENTION ! Classe compatible uniquement avec nouveau format de bdd du cel //
2
/**
3
/**
3
 * Service recherche, et de suppression multiple d'images a partir de divers critères
-
 
4
 * Encodage en entrée : utf8
-
 
5
 * Encodage en sortie : utf8
4
* PHP Version 5
6
 *
5
*
-
 
6
* @category  PHP
-
 
7
* @package   jrest
7
 * @author Aurélien PERONNET <aurelien@tela-botanica.org>
8
* @author    Aurélien Peronnet <aurelien@tela-botanica.org>
8
 * @license GPL v3 <http://www.gnu.org/licenses/gpl.txt>
9
* @copyright 2010 Tela-Botanica
9
 * @license CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
10
* @license   http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
10
 * @version $Id$
11
* @version   SVN: <svn_id>
-
 
12
* @link      /doc/jrest/
11
 */
13
*/
-
 
14
 
-
 
15
/**
12
 Class InventoryImageList extends DBAccessor {
16
* InventoryImageList.php
13
 
17
*
14
	var $config;
18
* in : utf8
-
 
19
* out : utf8
15
 
20
*
16
	function InventoryImageList($config) {
21
* Service recherche, et de suppression multiple d'images a partir de divers critères
17
 
22
* 
18
		$this->config=$config;
-
 
19
	}
23
*/
-
 
24
 class InventoryImageList extends Cel {
20
 
25
 
21
 
26
	/**
22
	// renvoie l'enregistrement correspond � une image
27
	 * Recherche les images correspondant aux critères passés en paramètres
-
 
28
	 * uid[0] : utilisateur obligatoire
-
 
29
	 * uid[1] : critères de filtrage de la forme critère1=valeur1;critère2=valeur2
-
 
30
	 */
23
	function getElement($uid)
31
	function getElement($uid)
24
	{
32
	{
25
			// uid[0] : utilisateur obligatoire
-
 
26
			// uid[1] : crit�res de filtrage de la forme crit�re1:valeur1;crit�re2:valeur2
33
		//TODO : remplacer le contenu du $uid[1] par le tableau $_GET;
27
 
-
 
28
		// Controle detournement utilisateur
34
		// Controle detournement utilisateur
29
	    session_start();
35
	    session_start();
30
		$this->controleUtilisateur($uid[0]);
36
		$this->controleUtilisateur($uid[0]);
-
 
37
		
-
 
38
		$chercheur_images = new RechercheImage($this->config);
Line -... Line 39...
-
 
39
 
31
 
40
		$numero_page = 0;
32
		$DB=$this->connectDB($this->config,'cel_db');
-
 
33
 
41
		$taille_page = 50;
Line 34... Line 42...
34
		$criteres = array() ;
42
		$criteres = array();
35
 
43
 
36
		if(isset($uid[1]))
44
		if(isset($uid[1]))
37
		{
-
 
38
			$criteres = explode("&", $uid[1]) ;
-
 
39
		}
45
		{
40
 
-
 
41
		$query='SELECT * FROM cel_images WHERE ci_ce_utilisateur = "'.$uid[0].'" AND ' ;
-
 
42
 
-
 
43
		$numero_page = 0 ;
-
 
44
		$limite = 50 ;
-
 
45
 
-
 
46
		foreach($criteres as $pair)
-
 
47
		{
-
 
48
			$nom_valeur = explode("=",$pair) ;
-
 
49
 
-
 
50
			if(sizeof($nom_valeur) != 0)
-
 
51
			{
-
 
52
					if($nom_valeur[0] == "ci_limite")
-
 
53
					{
-
 
54
						$limite = $DB->escapeSimple($nom_valeur[1]) ;
-
 
55
					}
-
 
56
					elseif($nom_valeur[0] == "ci_numero_page")
46
			$criteres = $chercheur_images->parserRequeteCriteres($uid[1]) ;
57
					{
-
 
58
						$numero_page = $DB->escapeSimple($nom_valeur[1]) ;
-
 
59
					}
-
 
60
					elseif($nom_valeur[0] == "ci_meta_mots_cles")
-
 
61
					{
-
 
62
						$mots_cles = rtrim($nom_valeur[1], ',') ;
-
 
63
						$mots_cles_liste = explode("," , $mots_cles) ;
-
 
64
 
-
 
65
						foreach($mots_cles_liste as $mot_cle)
-
 
66
						{
-
 
67
							$query .= $nom_valeur[0].' LIKE "%'.$DB->escapeSimple($mot_cle).'%"' ;
-
 
68
							$query .= ' AND ' ;
-
 
69
						}
-
 
70
					}
-
 
71
					elseif($nom_valeur[0] == "ci_meta_comment")
-
 
72
					{
-
 
73
						$mots_comment_liste = explode(" " , $nom_valeur[1]) ;
-
 
74
 
-
 
75
						foreach($mots_comment_liste as $mot_comment)
47
			if(isset($criteres['numero_page']) && isset($criteres['limite'])) {
76
						{
-
 
77
							$mot_comment = trim($mot_comment) ;
-
 
78
							$query .= $nom_valeur[0].' LIKE "%'.$DB->escapeSimple($mot_comment).'%"' ;
-
 
79
							$query .= ' AND ' ;
-
 
80
						}
-
 
81
					}
-
 
82
					elseif($nom_valeur[0] == "annee" || $nom_valeur[0] == "mois" || $nom_valeur[0] == "jour")
-
 
83
					{
-
 
84
						$query .= $this->fabriquerSousRequeteRechercheDate($nom_valeur[0], $nom_valeur[1]) ;
-
 
85
						$query .= ' AND ' ;
-
 
86
					}
-
 
87
					elseif($nom_valeur[0] == "ci_id_tampon")
-
 
88
					{
-
 
89
						$ids_tampon = rtrim($nom_valeur[1], ',') ;
-
 
90
						$query .= 'ci_id_image IN ( '.$DB->escapeSimple($ids_tampon).')' ;
-
 
91
					}
-
 
92
					elseif($nom_valeur[0] == "ci_recherche_generale")
-
 
93
					{
-
 
94
						$query .= $this->fabriquerSousRequeteRechercheGenerale($uid[0], $nom_valeur[1]);
-
 
95
						$query .= ' AND ';
-
 
96
					}
-
 
97
					else
-
 
98
					{
-
 
99
						$query .= $nom_valeur[0].' = "'.$DB->escapeSimple($nom_valeur[1]) ;
-
 
100
						$query .= '" AND ' ;
48
				$numero_page = $criteres['numero_page'];
101
					}
49
				$taille_page = $criteres['limite'];
Line 102... Line -...
102
			}
-
 
103
		}
-
 
104
 
-
 
105
		$debut = $limite*$numero_page ;
-
 
106
 
-
 
107
		$query = rtrim($query,' AND ') ;
-
 
108
		
-
 
109
		$query .= ' ORDER BY ci_ordre LIMIT '.$debut.','.$limite ;
-
 
110
 
-
 
111
		$res =& $DB->query($query);
-
 
112
                if (PEAR::isError($res)) {
-
 
113
 
-
 
114
                	die($res->getMessage());
-
 
115
                }
-
 
116
 
-
 
117
		$result = array() ;
-
 
118
 
-
 
119
		while($image = $res->fetchrow(DB_FETCHMODE_ASSOC))
-
 
120
		{
-
 
121
			$date = split("-",$image['ci_meta_date']) ;
-
 
122
			if(count($date) > 2)
-
 
123
			{
-
 
124
				$image['ci_meta_date'] = $date[2].'/'.$date[1].'/'.$date[0] ;
-
 
125
			}
-
 
126
 
50
			}
127
			$image['ci_ce_observation'] = '';
-
 
128
 
-
 
129
			$requete_table_liaison = 'SELECT coi_ce_observation FROM cel_obs_images WHERE coi_ce_image = '.$image['ci_id_image'].' AND coi_ce_utilisateur ="'.$uid[0].'"';
-
 
130
						
-
 
131
			$res_table_liaison =& $DB->query($requete_table_liaison);
-
 
132
            if (PEAR::isError($res_table_liaison)) {
-
 
133
 
-
 
134
            	die($res_table_liaison->getMessage());
-
 
135
            }
-
 
136
 
-
 
137
			$ids_obs = '';
-
 
138
			while($liaison = $res_table_liaison->fetchrow(DB_FETCHMODE_ASSOC))
-
 
Line 139... Line 51...
139
			{
51
		}
-
 
52
 
Line 140... Line -...
140
				$ids_obs .= $liaison['coi_ce_observation'].",";
-
 
141
			}
-
 
142
 
-
 
143
			$ids_obs = rtrim($ids_obs,',');
-
 
144
 
-
 
145
			if(trim($ids_obs) != '') {
-
 
146
				$requete_obs_liees = 'SELECT * FROM cel_inventory WHERE ordre IN  ('.$ids_obs.') AND identifiant ="'.$uid[0].'"';
-
 
147
				$res_obs_liees =& $DB->query($requete_obs_liees);
-
 
148
	            if (PEAR::isError($res_obs_liees)) {
-
 
149
 
-
 
150
	            	die($res_obs_liees->getMessage());
-
 
151
	            }
-
 
152
 
-
 
153
				while($obs_liee = $res_obs_liees->fetchrow(DB_FETCHMODE_ASSOC))
-
 
154
				{
-
 
155
					$image['ci_ce_observation'] .= $obs_liee['ordre'].'#'.$obs_liee['nom_sel'].'#'.$obs_liee['transmission'].';;' ;
-
 
156
				}
-
 
157
			}
-
 
158
 
-
 
159
			$result[] = $image ;
-
 
160
		}
-
 
161
 
53
		$retour = $chercheur_images->rechercherImagesEtObservationAssociees($uid[0], $criteres, $numero_page, $taille_page);
162
		$res = json_encode($result) ;
54
 
163
		
55
		$retour_encode = json_encode($retour) ;
164
		$res = str_replace('\u0000','',$res);
56
		$retour_encode = $this->nettoyerCaracteresNuls($retour_encode);
Line -... Line 57...
-
 
57
 
-
 
58
		header("content-type: application/json") ;
-
 
59
		print $retour_encode ;
Line 165... Line 60...
165
 
60
		exit() ;
166
		header("content-type: text/html") ;
61
	}
Line 167... Line 62...
167
		print $res ;
62
 
168
		exit() ;
63
	private function nettoyerCaracteresNuls($chaine) {
-
 
64
		return str_replace('\u0000','',$chaine);	
-
 
65
	}
-
 
66
	
-
 
67
	function updateElement($uid,$pairs)
-
 
68
	{
169
	}
69
 
170
 
70
	}
171
	
-
 
172
	function updateElement($uid,$pairs)
-
 
173
	{
-
 
174
 
-
 
175
	}
71
	
176
 
72
	/**
177
	function deleteElement($uid)
73
	* @param int uid[0] : utilisateur obligatoire
Line 178... Line -...
178
	{
-
 
179
 
-
 
180
		// uid[0] : utilisateur obligatoire
74
	* @param string uid[1] : identifiant(s) image(s) obligatoire(s)
Line 181... Line 75...
181
	// uid[1] : identifiant(s) image(s) obligatoire(s)
75
	*  
182
 
-
 
183
	 // Controle detournement utilisateur
-
 
184
	    session_start();
-
 
185
		$this->controleUtilisateur($uid[0]);
76
	*/ 
186
 
77
	function deleteElement($uid)
187
		$DB=$this->connectDB($this->config,'cel_db');
78
	{
188
 
79
	 	// Controle detournement utilisateur
189
		$id = rtrim($uid[1],",") ;
80
	    session_start();
190
 
-
 
191
		if (isset($id)) {
-
 
192
	           	$query="DELETE FROM cel_images WHERE ci_id_image in (".$DB->escapeSimple($id) .")";
81
		$this->controleUtilisateur($uid[0]);
193
				$query_sup_lien = "DELETE FROM cel_obs_images WHERE coi_ce_image in (".$DB->escapeSimple($id) .")";
82
 
194
		}
-
 
195
 
-
 
196
		$res =& $DB->query($query);
83
		$ids_images = rtrim($uid[1],",") ;
197
 
-
 
198
		if (PEAR::isError($res)) {
84
 
199
			die($res->getMessage());
85
		if (isset($ids_images)) {
200
		}
86
			
201
		else
87
			$ids_images_proteges = $this->proteger($ids_images);
202
		{
88
			
203
			$res =& $DB->query($query_sup_lien);
89
	        $requete_suppression_images = "DELETE FROM cel_images WHERE id_image in (".$ids_images_proteges.")";
204
			if(PEAR::isError($res))
90
			$requete_suppression_liens = "DELETE FROM cel_obs_images WHERE id_image in (".$ids_images_proteges.")";
205
			{
-
 
206
				die($res->getMessage());
-
 
207
			}
-
 
208
 
91
			
209
			$id_fichiers = explode(",",$id) ;
-
 
210
			foreach($id_fichiers as $en_cours)
-
 
211
			{
-
 
212
				$manipulateur_image = new ImageRecreation($this->config);
-
 
213
            	$manipulateur_image->detruireImageSurDisque($id);
-
 
214
			}
-
 
215
 
-
 
216
			echo "OK" ;
-
 
217
			exit() ;
-
 
218
		}
-
 
219
	}
-
 
220
	
-
 
221
	private function fabriquerSousRequeteRechercheGenerale($id_utilisateur, $chaine_recherche) {
-
 
222
		
-
 
Line 223... Line -...
223
		$requete_recherche_taxon .= 'SELECT coi_ce_image 
-
 
224
								FROM cel_obs_images
-
 
225
								WHERE coi_ce_observation IN ' .
-
 
226
								'(SELECT ordre ' .
-
 
227
									'FROM cel_inventory '.
-
 
228
									'WHERE identifiant ="'.$id_utilisateur.'" '.
-
 
229
									'AND nom_sel LIKE "'.$chaine_recherche.'%" '.
-
 
230
								')';
-
 
231
								
-
 
232
		$requete_recherche_comm = ' ci_meta_comment LIKE "%'.$chaine_recherche.'%" ';
92
			$supression_images_bdd = $this->executer($requete_suppression_images);
233
		
-
 
234
		$requete_recherche_generale = '(ci_id_image IN ( '.($requete_recherche_taxon).') OR ('.$requete_recherche_comm.'))' ;
-
 
235
							
-
 
236
		return $requete_recherche_generale;
93
			$supression_liens = $this->executer($requete_suppression_liens);
237
	}
-
 
238
	
-
 
239
	private function fabriquerSousRequeteRechercheDate($intervalle, $valeur) {
-
 
240
		
-
 
241
		$correspondance_champ = array('annee' => 'YEAR','mois' => 'MONTH','jour' => 'DAY');
94
			
242
		
95
			$ids_fichiers = explode(",",$ids_images) ;
243
		$requete_recherche_date = '';
96
			foreach($ids_fichiers as $en_cours)
244
 
97
			{