* @author Jean-Pascal MILCENT * @author Aurelien PERONNET * @license GPL v3 * @license CECILL v2 * @copyright 1999-2014 Tela Botanica */ class InventoryImageList extends Cel { /** * Recherche les images correspondant aux critères passés en paramètres * uid[0] : utilisateur obligatoire * $_GET : critères de filtrage de la forme critère1=valeur1;critère2=valeur2 */ public function getElement($uid) { // Controle detournement utilisateur $this->controleUtilisateur($uid[0]); $numero_page = 0; $taille_page = 50; $criteres = $_GET; if (isset($criteres['numero_page']) && isset($criteres['limite'])) { $numero_page = $criteres['numero_page']; unset($criteres['numero_page']); $taille_page = $criteres['limite']; unset($criteres['limite']); } $debut = $taille_page * $numero_page; $chercheur_images = new RechercheImage($this->config); $retour = $chercheur_images->rechercherImagesEtObservationAssociees($uid[0], $criteres, $debut, $taille_page); $retour = $chercheur_images->formaterPourEnvoiCel($retour); $retour_encode = json_encode($retour); $retour_encode = $this->nettoyerCaracteresNuls($retour_encode); header('content-type: application/json'); print $retour_encode; exit(); } private function nettoyerCaracteresNuls($chaine) { return str_replace('\u0000','',$chaine); } /** * Méthode appelée avec une requête de type DELETE. * Supprime les infos sur l'image et le fichier correspondant à l'ordre passé en parametre * Supporte la suppression multiple en passant plusieurs numéros séparés par des virgules * * @param int uid[0] id utilisateur * @param string uid[1] : ordre(s) image(s) obligatoire(s) séparés par des virgules */ public function deleteElement($uid){ // Controle detournement utilisateur $this->controleUtilisateur($uid[0]); if (!isset($uid[1]) || !$this->EstUneSuiteIdentifiantsImage($uid[1])) { return; } $ids_images = rtrim($uid[1], ','); $ids_images = explode(',',$ids_images); $gestionnaire_image = new GestionImage($this->config); $suppression_image = $gestionnaire_image->supprimerImage($ids_images); $this->envoyer('OK'); exit(); } /** * Un ensemble d'identifiants est une suite d'identifiants séparés par des virgules * avec ou sans virgule terminale */ private function estUneSuiteIdentifiantsImage($chaine) { $chaine = rtrim($chaine,','); $reg_exp = "/^(([0-9])+,)*([0-9])+$/"; return preg_match($reg_exp, $chaine); } }