Subversion Repositories eFlore/Applications.cel

Rev

Rev 2045 | Rev 2458 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed

<?php
class InventoryKeywordTree extends Cel {
        
        //TODO : verifications des paramètres
        public static $gestion_mots_cles = null;
        
        private function getGestionMotsCles($mode) {
                if(self::$gestion_mots_cles == null) {
                        self::$gestion_mots_cles = new GestionMotsClesChemin($this->config, $mode);
                }
                return self::$gestion_mots_cles;
        }
        
        public function getElement($uid) {
                // Controle detournement utilisateur
                $id_utilisateur = $uid[1] ;
                $this->controleUtilisateur($uid[1]);
                
                $arbre = $this->getGestionMotsCles($uid[0])->obtenirArbre($id_utilisateur);
        
                $this->envoyerJson($arbre);
                return TRUE; // compat: pourquoi renvoyer true si vide ?
        }
        
        public function updateElement($uid, $pairs) {
                $id_utilisateur = $uid[1];
                $this->controleUtilisateur($uid[1]);
        
                $id_mot_cle = $pairs['id'];
                $action = $pairs['action'];
        
                if ($action == 'modification') {
                        $nouveau_nom = $pairs['motcle'];
                        $modification = $this->getGestionMotsCles($uid[0])->renommerMotCle($id_mot_cle, $nouveau_nom);
                } else if ($action == 'deplacement') {
                        $id_pere = $pairs['parent'];
                        $modification = $this->getGestionMotsCles($uid[0])->deplacerMotCle($id_mot_cle, $id_pere, $id_utilisateur);
                }
                
                $modification = ($modification !== false);
                if($modification) {
                        $this->envoyer("OK");
                }
                
                return $modification;
        }
        
        public function createElement($pairs) {
                // Controle detournement utilisateur
                $this->controleUtilisateur($pairs['identifiant']);
                
                $mode = $pairs['mode'];
                if($mode != 'obs' && $mode != 'images') {
                        return;
                }
                
                $id_utilisateur = $pairs['identifiant'];
                $mot_cle = $pairs['motcle'];
        
                $id_parent = $pairs['parent'];
                
                $id_nouveau_mot_cle = $this->getGestionMotsCles($mode)->insererParIdParent($mot_cle, $id_parent, $id_utilisateur);
                
                if($id_nouveau_mot_cle !== false) {
                        // on sort de self::createElement ==> JRest::(get|post) ==> JRest->created() qui fait header().
                        // or si nous dépassons ini_get(output_buffering) nous ne pouvons plus réécrire le code de retour
                        // HTTP, de plus, si ini_get(output_buffering) == off, nous enverrions un warning.
                        // d'où ce clone de JRest::created();
                        header('HTTP/1.0 201 Created');
                        echo $id_nouveau_mot_cle;
                        exit;
                } else {
                        // cf ci-dessus: JRest::badRequest
                        header('HTTP/1.0 400 Bad Request');
                        exit;
                }
        }
        
        public function deleteElement($uid) {
                
                $mode = $uid[0];
                $id_utilisateur = $uid[1];
                $id_mot_cle = $uid[2];
                
                $suppression = $this->getGestionMotsCles($mode)->supprimerMotCleParId($id_mot_cle, $id_utilisateur);
                
                if($suppression) {
                        $this->envoyer("OK");
                }
        }
}
?>