Subversion Repositories Applications.wikini

Rev

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

<?php
abstract class Service extends RestService {
        
        //+----------------------------------------------------------------------------------------------------------------+
        // GESTION de l'ENVOIE au NAVIGATEUR

        protected function formaterEnJsonp($donnees = null, $encodage = 'utf-8') {
                $contenu = $_GET['callback'].'('.json_encode($donnees).');';
                return $contenu;
        }

        private function envoyerEnteteContenu($encodage, $mime) {
                if (!is_null($mime) && !is_null($encodage)) {
                        header("Content-Type: $mime; charset=$encodage");
                } else if (!is_null($mime) && is_null($encodage)) {
                        header("Content-Type: $mime");
                }
        }
        
        public function envoyerContenuJson($donnees = null, $encodage = 'utf-8') {
                $contenu = json_encode($donnees);
                $this->envoyerEnteteContenu($encodage, 'application/json');
                echo $contenu;
                exit;
        }
                
        protected function envoyerAuth($message_accueil, $message_echec) {
                header('HTTP/1.0 401 Unauthorized');
                header('WWW-Authenticate: Basic realm="'.mb_convert_encoding($message_accueil, 'ISO-8859-1', 'UTF-8').'"');
                header('Content-type: text/plain; charset=UTF-8');
                print $message_echec;
                exit(0);
        }
        
        protected function envoyerErreur($e) {
                RestServeur::envoyerEnteteStatutHttp($e->getCode());
                echo $e->getMessage();
        }
        
        protected function envoyerCreationEffectuee() {
                header('HTTP/1.1 201 Created');
                echo "OK";
        }
}
?>