Subversion Repositories eFlore/Applications.cel

Rev

Rev 2129 | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

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