Subversion Repositories eFlore/Applications.del

Rev

Rev 1172 | Go to most recent revision | Blame | Last modification | View Log | RSS feed

<?php
// declare(encoding='UTF-8');
/**
        * Le web service observations récupère toutes les observations et, pour chacune d'elle, les
        * images qui lui sont associées.
 *
 * @category    php 5.2
 * @package     del
 * @subpackage images
 * @author              Jean-Pascal MILCENT <jpm@tela-botanica.org>
 * @copyright   Copyright (c) 2012, Tela Botanica (accueil@tela-botanica.org)
 * @license     http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
 * @license     http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
 * @version     $Id: Bdd.php 403 2012-02-22 14:35:20Z gduche $
 * @see http://www.tela-botanica.org/wikini/eflore/wakka.php?wiki=ApiIdentiplante01Observations
 */

class Connecter {
        
        private $conteneur;
        private $gestionBdd;
        private $bdd;
        
        public function __construct(Conteneur $conteneur = null) {
                session_start();
                $this->conteneur = $conteneur == null ? new Conteneur() : $conteneur;
                $this->conteneur->chargerConfiguration('config_utilisateurs.ini');
                $this->gestionBdd = $conteneur->getGestionBdd();
                $this->bdd = $this->gestionBdd->getBdd();
        }
        
        /**
         * Méthode principale de la classe.
         * Lance la récupération des images dans la base et les place dans un objet ResultatService 
         * pour l'afficher.
         * @param array $ressources les ressources situées après l'url de base (ex : http://url/ressource1/ressource2)
         * @param array $parametres les paramètres situés après le ? dans l'url
         * */
        public function consulter($ressources, $parametres) {
                
                $login = $ressources[0];
                $motDePasse = $ressources[1];
                
                $utilisateur = $this->identifierUtilisateur($login, $motDePasse);
                $utilisateur = $this->verifierUtilisateur($utilisateur);
                $utilisateur = $this->setUtilisateur($utilisateur);
        
                // Mettre en forme le résultat et l'envoyer pour affichage
                $resultat = new ResultatService();
                $resultat->corps = $utilisateur;
                return $resultat;
        }
        
        private function identifierUtilisateur($login, $motDePasse) {
                $requete = 'SELECT id_utilisateur, nom, prenom, courriel, mot_de_passe FROM '.$this->gestionBdd->formaterTable('del_utilisateur', 'du').
                                        'WHERE courriel = '.$this->bdd->proteger($login).' '.
                                        'AND mot_de_passe = MD5('.$this->bdd->proteger($motDePasse).')';
                $utilisateur = $this->bdd->recupererTous($requete);
                return $utilisateur;
        }
        
        private function verifierUtilisateur($utilisateur) {
                if ($utilisateur == null || sizeof($utilisateur) == 0 || sizeof($utilisateur) > 1) {
                        $e = 'Accès non autorisé';
                        throw new Exception($e, RestServeur::HTTP_CODE_ACCES_NON_AUTORISE);
                } else {
                        return $utilisateur[0];
                }
        }
        
        function setUtilisateur($utilisateur, $remember=1) {
                $_SESSION["del_utilisateur"] = $utilisateur;
                $this->setPersistentCookie("del_courriel", $utilisateur["courriel"], $remember);
                $this->setPersistentCookie("del_password", $utilisateur["mot_de_passe"], $remember);
                $this->setPersistentCookie("del_remember", $remember, $remember);
                unset($utilisateur['mot_de_passe']);
                $utilisateur['connecte'] = true;
                return $utilisateur;
        }
        
        function setPersistentCookie($name, $value, $remember = 1) {
                SetCookie($name, $value, time() + ($remember ? (60*60*24*100) : (60*60)),'/');
                $_COOKIE[$name] = $value;
        }
        
        private function getUtilisateurAnonyme() {
                return array('connecte' => false,
                                                                 'id_utilisateur' => session_id(),
                                                                 'courriel' => '',
                                                                 'mot_de_passe' => '',
                                                                 'nom' => '',
                                                                 'prenom' => ''
                );
        }
        
        private function utilisateurEstIdentifie() {
                        
                $login_utilisateur = false;
                if (!$login_utilisateur = $this->utilisateurEstIdentifieSession()) {
                        $login_utilisateur = $this->utilisateurEstIdentifieCookie();
                }
        
                return $login_utilisateur;
        }
        
        function utilisateurEstIdentifieSession() {
                return (isset($_SESSION["del_courriel"]) && isset($_SESSION["del_courriel"])) ? $_SESSION["del_courriel"] : false;
        }
        
        function utilisateurEstIdentifieCookie() {
                return isset($_COOKIE["del_courriel"]) && ($this->identifierUtilisateurSansEncryptionMotDePasse($_COOKIE["del_name"], $_COOKIE["del_password"])) ? $_COOKIE["del_name"] : false;
        }
}
?>