| 803 | gduche | 1 | <?php
 | 
        
           |  |  | 2 | // declare(encoding='UTF-8');
 | 
        
           |  |  | 3 | /**
 | 
        
           |  |  | 4 | 	* Le web service observations récupère toutes les observations et, pour chacune d'elle, les
 | 
        
           |  |  | 5 | 	* images qui lui sont associées.
 | 
        
           |  |  | 6 |  *
 | 
        
           |  |  | 7 |  * @category	php 5.2
 | 
        
           |  |  | 8 |  * @package	del
 | 
        
           |  |  | 9 |  * @subpackage images
 | 
        
           |  |  | 10 |  * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
 | 
        
           |  |  | 11 |  * @copyright	Copyright (c) 2012, Tela Botanica (accueil@tela-botanica.org)
 | 
        
           |  |  | 12 |  * @license	http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
 | 
        
           |  |  | 13 |  * @license	http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
 | 
        
           |  |  | 14 |  * @version	$Id: Bdd.php 403 2012-02-22 14:35:20Z gduche $
 | 
        
           |  |  | 15 |  * @see http://www.tela-botanica.org/wikini/eflore/wakka.php?wiki=ApiIdentiplante01Observations
 | 
        
           |  |  | 16 |  */
 | 
        
           |  |  | 17 |   | 
        
           |  |  | 18 | class Connecter {
 | 
        
           |  |  | 19 |   | 
        
           |  |  | 20 | 	private $conteneur;
 | 
        
           |  |  | 21 | 	private $gestionBdd;
 | 
        
           |  |  | 22 | 	private $bdd;
 | 
        
           |  |  | 23 |   | 
        
           |  |  | 24 | 	public function __construct(Conteneur $conteneur = null) {
 | 
        
           |  |  | 25 | 		session_start();
 | 
        
           |  |  | 26 | 		$this->conteneur = $conteneur == null ? new Conteneur() : $conteneur;
 | 
        
           |  |  | 27 | 		$this->conteneur->chargerConfiguration('config_utilisateurs.ini');
 | 
        
           |  |  | 28 | 		$this->gestionBdd = $conteneur->getGestionBdd();
 | 
        
           |  |  | 29 | 		$this->bdd = $this->gestionBdd->getBdd();
 | 
        
           |  |  | 30 | 	}
 | 
        
           |  |  | 31 |   | 
        
           |  |  | 32 | 	/**
 | 
        
           |  |  | 33 | 	 * Méthode principale de la classe.
 | 
        
           |  |  | 34 | 	 * Lance la récupération des images dans la base et les place dans un objet ResultatService
 | 
        
           |  |  | 35 | 	 * pour l'afficher.
 | 
        
           |  |  | 36 | 	 * @param array $ressources les ressources situées après l'url de base (ex : http://url/ressource1/ressource2)
 | 
        
           |  |  | 37 | 	 * @param array $parametres les paramètres situés après le ? dans l'url
 | 
        
           |  |  | 38 | 	 * */
 | 
        
           |  |  | 39 | 	public function consulter($ressources, $parametres) {
 | 
        
           |  |  | 40 |   | 
        
           |  |  | 41 | 		$login = $ressources[0];
 | 
        
           |  |  | 42 | 		$motDePasse = $ressources[1];
 | 
        
           |  |  | 43 |   | 
        
           |  |  | 44 | 		$utilisateur = $this->identifierUtilisateur($login, $motDePasse);
 | 
        
           |  |  | 45 | 		$utilisateur = $this->verifierUtilisateur($utilisateur);
 | 
        
           |  |  | 46 | 		$utilisateur = $this->setUtilisateur($utilisateur);
 | 
        
           | 1172 | aurelien | 47 |   | 
        
           | 803 | gduche | 48 | 		// Mettre en forme le résultat et l'envoyer pour affichage
 | 
        
           |  |  | 49 | 		$resultat = new ResultatService();
 | 
        
           |  |  | 50 | 		$resultat->corps = $utilisateur;
 | 
        
           |  |  | 51 | 		return $resultat;
 | 
        
           |  |  | 52 | 	}
 | 
        
           |  |  | 53 |   | 
        
           |  |  | 54 | 	private function identifierUtilisateur($login, $motDePasse) {
 | 
        
           |  |  | 55 | 		$requete = 'SELECT id_utilisateur, nom, prenom, courriel, mot_de_passe FROM '.$this->gestionBdd->formaterTable('del_utilisateur', 'du').
 | 
        
           |  |  | 56 | 					'WHERE courriel = '.$this->bdd->proteger($login).' '.
 | 
        
           |  |  | 57 | 					'AND mot_de_passe = MD5('.$this->bdd->proteger($motDePasse).')';
 | 
        
           |  |  | 58 | 		$utilisateur = $this->bdd->recupererTous($requete);
 | 
        
           |  |  | 59 | 		return $utilisateur;
 | 
        
           |  |  | 60 | 	}
 | 
        
           |  |  | 61 |   | 
        
           |  |  | 62 | 	private function verifierUtilisateur($utilisateur) {
 | 
        
           |  |  | 63 | 		if ($utilisateur == null || sizeof($utilisateur) == 0 || sizeof($utilisateur) > 1) {
 | 
        
           |  |  | 64 | 			$e = 'Accès non autorisé';
 | 
        
           |  |  | 65 | 			throw new Exception($e, RestServeur::HTTP_CODE_ACCES_NON_AUTORISE);
 | 
        
           |  |  | 66 | 		} else {
 | 
        
           |  |  | 67 | 			return $utilisateur[0];
 | 
        
           |  |  | 68 | 		}
 | 
        
           |  |  | 69 | 	}
 | 
        
           |  |  | 70 |   | 
        
           |  |  | 71 | 	function setUtilisateur($utilisateur, $remember=1) {
 | 
        
           |  |  | 72 | 		$_SESSION["del_utilisateur"] = $utilisateur;
 | 
        
           |  |  | 73 | 		$this->setPersistentCookie("del_courriel", $utilisateur["courriel"], $remember);
 | 
        
           |  |  | 74 | 		$this->setPersistentCookie("del_password", $utilisateur["mot_de_passe"], $remember);
 | 
        
           |  |  | 75 | 		$this->setPersistentCookie("del_remember", $remember, $remember);
 | 
        
           |  |  | 76 | 		unset($utilisateur['mot_de_passe']);
 | 
        
           |  |  | 77 | 		$utilisateur['connecte'] = true;
 | 
        
           |  |  | 78 | 		return $utilisateur;
 | 
        
           |  |  | 79 | 	}
 | 
        
           |  |  | 80 |   | 
        
           |  |  | 81 | 	function setPersistentCookie($name, $value, $remember = 1) {
 | 
        
           |  |  | 82 | 		SetCookie($name, $value, time() + ($remember ? (60*60*24*100) : (60*60)),'/');
 | 
        
           |  |  | 83 | 		$_COOKIE[$name] = $value;
 | 
        
           |  |  | 84 | 	}
 | 
        
           |  |  | 85 |   | 
        
           |  |  | 86 | 	private function getUtilisateurAnonyme() {
 | 
        
           |  |  | 87 | 		return array('connecte' => false,
 | 
        
           |  |  | 88 | 								 'id_utilisateur' => session_id(),
 | 
        
           |  |  | 89 | 								 'courriel' => '',
 | 
        
           |  |  | 90 | 								 'mot_de_passe' => '',
 | 
        
           |  |  | 91 | 								 'nom' => '',
 | 
        
           |  |  | 92 | 								 'prenom' => ''
 | 
        
           |  |  | 93 | 		);
 | 
        
           |  |  | 94 | 	}
 | 
        
           |  |  | 95 |   | 
        
           |  |  | 96 | 	private function utilisateurEstIdentifie() {
 | 
        
           |  |  | 97 |   | 
        
           |  |  | 98 | 		$login_utilisateur = false;
 | 
        
           |  |  | 99 | 		if (!$login_utilisateur = $this->utilisateurEstIdentifieSession()) {
 | 
        
           |  |  | 100 | 			$login_utilisateur = $this->utilisateurEstIdentifieCookie();
 | 
        
           |  |  | 101 | 		}
 | 
        
           |  |  | 102 |   | 
        
           |  |  | 103 | 		return $login_utilisateur;
 | 
        
           |  |  | 104 | 	}
 | 
        
           |  |  | 105 |   | 
        
           |  |  | 106 | 	function utilisateurEstIdentifieSession() {
 | 
        
           | 1252 | aurelien | 107 | 		return (isset($_SESSION["del_courriel"]) && isset($_SESSION["del_courriel"])) ? $_SESSION["del_courriel"] : false;
 | 
        
           | 803 | gduche | 108 | 	}
 | 
        
           |  |  | 109 |   | 
        
           |  |  | 110 | 	function utilisateurEstIdentifieCookie() {
 | 
        
           | 1252 | aurelien | 111 | 		return isset($_COOKIE["del_courriel"]) && ($this->identifierUtilisateurSansEncryptionMotDePasse($_COOKIE["del_name"], $_COOKIE["del_password"])) ? $_COOKIE["del_name"] : false;
 | 
        
           | 803 | gduche | 112 | 	}
 | 
        
           |  |  | 113 | }
 | 
        
           |  |  | 114 | ?>
 |