Subversion Repositories eFlore/Applications.cel

Rev

Rev 2129 | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 2129 Rev 2458
Line 1... Line 1...
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 {
Line 25... Line 19...
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)
-
 
32
	{
25
	public function getElement($uid) {
33
		// Controle detournement utilisateur
26
		// Controle detournement utilisateur
Line 34... Line -...
34
		$this->controleUtilisateur($uid[0]);
-
 
35
 
-
 
36
		$chercheur_images = new RechercheImage($this->config);
27
		$this->controleUtilisateur($uid[0]);
37
 
28
 
38
		$numero_page = 0;
-
 
39
		$taille_page = 50;
-
 
40
		$criteres = array();
29
		$numero_page = 0;
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'];
-
 
36
			unset($criteres['limite']);
Line 47... Line 37...
47
			unset($criteres['limite']);
37
		}
48
		}
-
 
49
 
38
		$debut = $taille_page * $numero_page;
50
		$debut = $taille_page*$numero_page ;
39
 
Line 51... Line 40...
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);
Line 53... Line 42...
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);
Line 57... Line 46...
57
 
46
 
58
		header("content-type: application/json") ;
47
		header('content-type: application/json');
59
		print $retour_encode ;
48
		print $retour_encode;
Line 60... Line 49...
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
	/**
-
 
68
	* Méthode appelée avec une requête de type DELETE.
56
	/**
69
	* Supprime les infos sur l'image et le fichier correspondant à l'ordre passé en parametre
57
	 * Méthode appelée avec une requête de type DELETE.
70
	* Supporte la suppression multiple en passant plusieurs numéros séparés par des virgules
-
 
71
    *
58
	 * Supprime les infos sur l'image et le fichier correspondant à l'ordre passé en parametre
72
    * @param int uid[0] id utilisateur
59
	 * Supporte la suppression multiple en passant plusieurs numéros séparés par des virgules
Line 73... Line 60...
73
	* @param string uid[1] : ordre(s) image(s) obligatoire(s) séparés par des virgules
60
	 *
74
	*
61
	 * @param int uid[0] id utilisateur
75
	*/
62
	 * @param string uid[1] : ordre(s) image(s) obligatoire(s) séparés par des virgules
76
	function deleteElement($uid){
-
 
77
 
63
	 */
78
	 	// Controle detournement utilisateur
64
	public function deleteElement($uid){
79
		$this->controleUtilisateur($uid[0]);
-
 
80
 
65
	 	// Controle detournement utilisateur
81
		if (!isset($uid[1]) || !$this->EstUneSuiteIdentifiantsImage($uid[1])) {
66
		$this->controleUtilisateur($uid[0]);
82
			return;
-
 
83
		}
67
 
84
 
68
		if (!isset($uid[1]) || !$this->EstUneSuiteIdentifiantsImage($uid[1])) {
85
		$ids_images = rtrim($uid[1], ',');
69
			return;
Line -... Line 70...
-
 
70
		}
-
 
71
		$ids_images = rtrim($uid[1], ',');
-
 
72
		$ids_images = explode(',',$ids_images);
-
 
73
		$gestionnaire_image = new GestionImage($this->config);
86
		$ids_images = explode(',',$ids_images);
74
		$suppression_image = $gestionnaire_image->supprimerImage($ids_images);
87
 
75
		$this->envoyer('OK');
88
	    $gestionnaire_image = new GestionImage($this->config);
-
 
89
	    $suppression_image = $gestionnaire_image->supprimerImage($ids_images);
-
 
90
 
76
		exit();
91
		$this->envoyer('OK');
-
 
92
		exit;
77
	}
93
	}
78
 
94
 
-
 
95
	private function estUneSuiteIdentifiantsImage($chaine) {
-
 
96
		$chaine = rtrim($chaine,',');
79
	/**
-
 
80
	 * Un ensemble d'identifiants est une suite d'identifiants séparés par des virgules
97
		// un ensemble d'identifiants est une suite d'identifiants séparés par des virgules
81
	 * avec ou sans virgule terminale