Subversion Repositories eFlore/Applications.del

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
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);
47
		/*// Lancement du service
48
		$temps_expiration = 60*60*24*100; // 100 jours
49
		session_set_cookie_params($temps_expiration);
50
 
51
		$utilisateur = $this->getUtilisateurAnonyme();
52
 
53
		$login_utilisateur = $this->utilisateurEstIdentifie();
54
 
55
		if ($login_utilisateur) {
56
			$utilisateur = $this->chargerInfosUtilisateur($login_utilisateur);
57
			$utilisateur['connecte'] = true;
58
		}*/
59
 
60
		// Mettre en forme le résultat et l'envoyer pour affichage
61
		$resultat = new ResultatService();
62
		$resultat->corps = $utilisateur;
63
		return $resultat;
64
	}
65
 
66
	private function identifierUtilisateur($login, $motDePasse) {
67
		$requete = 'SELECT id_utilisateur, nom, prenom, courriel, mot_de_passe FROM '.$this->gestionBdd->formaterTable('del_utilisateur', 'du').
68
					'WHERE courriel = '.$this->bdd->proteger($login).' '.
69
					'AND mot_de_passe = MD5('.$this->bdd->proteger($motDePasse).')';
70
		$utilisateur = $this->bdd->recupererTous($requete);
71
		return $utilisateur;
72
	}
73
 
74
	private function verifierUtilisateur($utilisateur) {
75
		if ($utilisateur == null || sizeof($utilisateur) == 0 || sizeof($utilisateur) > 1) {
76
			$e = 'Accès non autorisé';
77
			throw new Exception($e, RestServeur::HTTP_CODE_ACCES_NON_AUTORISE);
78
		} else {
79
			return $utilisateur[0];
80
		}
81
	}
82
 
83
	function setUtilisateur($utilisateur, $remember=1) {
84
		$_SESSION["del_utilisateur"] = $utilisateur;
85
		$this->setPersistentCookie("del_courriel", $utilisateur["courriel"], $remember);
86
		$this->setPersistentCookie("del_password", $utilisateur["mot_de_passe"], $remember);
87
		$this->setPersistentCookie("del_remember", $remember, $remember);
88
		unset($utilisateur['mot_de_passe']);
89
		$utilisateur['connecte'] = true;
90
		return $utilisateur;
91
	}
92
 
93
	function setPersistentCookie($name, $value, $remember = 1) {
94
		SetCookie($name, $value, time() + ($remember ? (60*60*24*100) : (60*60)),'/');
95
		$_COOKIE[$name] = $value;
96
	}
97
 
98
	private function getUtilisateurAnonyme() {
99
		return array('connecte' => false,
100
								 'id_utilisateur' => session_id(),
101
								 'courriel' => '',
102
								 'mot_de_passe' => '',
103
								 'nom' => '',
104
								 'prenom' => ''
105
		);
106
	}
107
 
108
 
109
	function chargerInfosUtilisateur($login) {
110
 
111
		$resultat_selection_utilisateur = $this->getUtilisateurParLogin($login);
112
		$retour = false;
113
 
114
		if(is_array($resultat_selection_utilisateur)) {
115
			$retour = $resultat_selection_utilisateur;
116
		}
117
 
118
		return $retour;
119
	}
120
 
121
	private function getUtilisateurParLogin($login) {
122
		//$fichier_utilisateur = json_decode(file_get_contents(realpath(dirname(__FILE__)).'/mocks/utilisateursmock.json'));
123
		$retour = false;
124
		/*if(isset($fichier_utilisateur->$login)) {
125
			$retour = (array)$fichier_utilisateur->$login;
126
		}*/
127
		return $retour;
128
	}
129
 
130
	private function utilisateurEstIdentifie() {
131
 
132
		$login_utilisateur = false;
133
		if (!$login_utilisateur = $this->utilisateurEstIdentifieSession()) {
134
			$login_utilisateur = $this->utilisateurEstIdentifieCookie();
135
		}
136
 
137
		return $login_utilisateur;
138
	}
139
 
140
	function utilisateurEstIdentifieSession() {
141
		return (isset($_SESSION["del_user"]) && isset($_SESSION["del_user"]["courriel"])) ? $_SESSION["del_user"]["courriel"] : false;
142
	}
143
 
144
	function utilisateurEstIdentifieCookie() {
145
		return isset($_COOKIE["del_name"]) && ($this->identifierUtilisateurSansEncryptionMotDePasse($_COOKIE["del_name"], $_COOKIE["del_password"])) ? $_COOKIE["del_name"] : false;
146
	}
147
}
148
?>