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