Subversion Repositories eFlore/Applications.cel

Rev

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

Rev 927 Rev 959
1
<?php
1
<?php
2
// ATTENTION ! Classe compatible uniquement avec nouveau format de bdd du cel //
2
// ATTENTION ! Classe compatible uniquement avec nouveau format de bdd du cel //
3
/**
3
/**
4
* PHP Version 5
4
* PHP Version 5
5
*
5
*
6
* @category  PHP
6
* @category  PHP
7
* @package   jrest
7
* @package   jrest
8
* @author    Aurélien Peronnet <aurelien@tela-botanica.org>
8
* @author    Aurélien Peronnet <aurelien@tela-botanica.org>
9
* @copyright 2010 Tela-Botanica
9
* @copyright 2010 Tela-Botanica
10
* @license   http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
10
* @license   http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
11
* @version   SVN: <svn_id>
11
* @version   SVN: <svn_id>
12
* @link      /doc/jrest/
12
* @link      /doc/jrest/
13
*/
13
*/
14
 
14
 
15
/**
15
/**
16
* InventoryImageList.php
16
* InventoryImageList.php
17
*
17
*
18
* in : utf8
18
* in : utf8
19
* out : utf8
19
* out : utf8
20
*
20
*
21
* Service recherche, et de suppression multiple d'images a partir de divers critères
21
* Service recherche, et de suppression multiple d'images a partir de divers critères
22
* 
22
* 
23
*/
23
*/
24
 class InventoryImageList extends Cel {
24
 class InventoryImageList extends Cel {
25
 
25
 
26
	/**
26
	/**
27
	 * Recherche les images correspondant aux critères passés en paramètres
27
	 * Recherche les images correspondant aux critères passés en paramètres
28
	 * uid[0] : utilisateur obligatoire
28
	 * uid[0] : utilisateur obligatoire
29
	 * uid[1] : critères de filtrage de la forme critère1=valeur1;critère2=valeur2
29
	 * uid[1] : critères de filtrage de la forme critère1=valeur1;critère2=valeur2
30
	 */
30
	 */
31
	function getElement($uid)
31
	function getElement($uid)
32
	{
32
	{
33
		//TODO : remplacer le contenu du $uid[1] par le tableau $_GET;
33
		//TODO : remplacer le contenu du $uid[1] par le tableau $_GET;
34
		// Controle detournement utilisateur
34
		// Controle detournement utilisateur
35
	    session_start();
35
	    session_start();
36
		$this->controleUtilisateur($uid[0]);
36
		$this->controleUtilisateur($uid[0]);
37
		
37
		
38
		$chercheur_images = new RechercheImage($this->config);
38
		$chercheur_images = new RechercheImage($this->config);
39
 
39
 
40
		$numero_page = 0;
40
		$numero_page = 0;
41
		$taille_page = 50;
41
		$taille_page = 50;
42
		$criteres = array();
42
		$criteres = array();
43
 
43
 
44
		if(isset($uid[1]))
44
		if(isset($uid[1]))
45
		{
45
		{
46
			$criteres = $chercheur_images->parserRequeteCriteres($uid[1]) ;
46
			$criteres = $chercheur_images->parserRequeteCriteres($uid[1]);
47
			if(isset($criteres['numero_page']) && isset($criteres['limite'])) {
47
			if (isset($criteres['numero_page']) && isset($criteres['limite'])) {
48
				$numero_page = $criteres['numero_page'];
48
				$numero_page = $criteres['numero_page'];
-
 
49
				unset($criteres['numero_page']);
49
				$taille_page = $criteres['limite'];
50
				$taille_page = $criteres['limite'];
-
 
51
				unset($criteres['limite']);
50
			}
52
			}
51
		}
53
		}
-
 
54
		
-
 
55
		$debut = $taille_page*$numero_page ;
52
 
56
 
53
		$retour = $chercheur_images->rechercherImagesEtObservationAssociees($uid[0], $criteres, $numero_page, $taille_page);
57
		$retour = $chercheur_images->rechercherImagesEtObservationAssociees($uid[0], $criteres, $debut, $taille_page);
54
 
58
 
55
		$retour_encode = json_encode($retour) ;
59
		$retour_encode = json_encode($retour) ;
56
		$retour_encode = $this->nettoyerCaracteresNuls($retour_encode);
60
		$retour_encode = $this->nettoyerCaracteresNuls($retour_encode);
57
 
61
 
58
		header("content-type: application/json") ;
62
		header("content-type: application/json") ;
59
		print $retour_encode ;
63
		print $retour_encode ;
60
		exit() ;
64
		exit() ;
61
	}
65
	}
62
 
66
 
63
	private function nettoyerCaracteresNuls($chaine) {
67
	private function nettoyerCaracteresNuls($chaine) {
64
		return str_replace('\u0000','',$chaine);	
68
		return str_replace('\u0000','',$chaine);	
65
	}
69
	}
66
	
70
	
67
	/**
71
	/**
68
	* Méthode appelée avec une requête de type DELETE.
72
	* Méthode appelée avec une requête de type DELETE.
69
	* Supprime les infos sur l'image et le fichier correspondant à l'ordre passé en parametre
73
	* Supprime les infos sur l'image et le fichier correspondant à l'ordre passé en parametre
70
	* Supporte la suppression multiple en passant plusieurs numéros séparés par des virgules
74
	* Supporte la suppression multiple en passant plusieurs numéros séparés par des virgules
71
    * 
75
    * 
72
    * @param int uid[0] id utilisateur
76
    * @param int uid[0] id utilisateur
73
	* @param string uid[1] : ordre(s) image(s) obligatoire(s) séparés par des virgules
77
	* @param string uid[1] : ordre(s) image(s) obligatoire(s) séparés par des virgules
74
	* 
78
	* 
75
	*/
79
	*/
76
	function deleteElement($uid){
80
	function deleteElement($uid){
77
 
81
 
78
	 	// Controle detournement utilisateur
82
	 	// Controle detournement utilisateur
79
	    session_start();
83
	    session_start();
80
		$this->controleUtilisateur($uid[0]);
84
		$this->controleUtilisateur($uid[0]);
81
 
85
 
82
		if (!isset($uid[1]) || !$this->EstUneSuiteIdentifiantsImage($uid[1])) {
86
		if (!isset($uid[1]) || !$this->EstUneSuiteIdentifiantsImage($uid[1])) {
83
			return;
87
			return;
84
		}
88
		}
85
		
89
		
86
		$ordres_images = explode(',',$uid[1]);
90
		$ordres_images = explode(',',$uid[1]);
87
 
91
 
88
	    $gestionnaire_image = new GestionImage($this->config);
92
	    $gestionnaire_image = new GestionImage($this->config);
89
	    $suppression_image = $gestionnaire_image->supprimerImage($uid[0], $ordres_images);
93
	    $suppression_image = $gestionnaire_image->supprimerImage($uid[0], $ordres_images);
90
 
94
 
91
		$this->envoyer('OK');
95
		$this->envoyer('OK');
92
		exit;
96
		exit;
93
	}
97
	}
94
	
98
	
95
	private function estUneSuiteIdentifiantsImage($chaine) {
99
	private function estUneSuiteIdentifiantsImage($chaine) {
96
		
100
		
97
		// un ensemble d'identifiants est une suite d'identifiants séparés par des virgules
101
		// un ensemble d'identifiants est une suite d'identifiants séparés par des virgules
98
		// sans virgule terminale
102
		// sans virgule terminale
99
		$reg_exp = "/^(([0-9])+,)*([0-9])+$/";
103
		$reg_exp = "/^(([0-9])+,)*([0-9])+$/";
100
		
104
		
101
		return preg_match($reg_exp, $chaine);	
105
		return preg_match($reg_exp, $chaine);	
102
	}
106
	}
103
}
107
}
104
?>
108
?>