Subversion Repositories eFlore/Applications.del

Rev

Rev 1476 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 1476 Rev 1477
Line 13... Line 13...
13
 * @license	http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
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 $
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
15
 * @see http://www.tela-botanica.org/wikini/eflore/wakka.php?wiki=ApiIdentiplante01Observations
16
 */
16
 */
Line 17... Line -...
17
 
-
 
18
class Connecter {
-
 
19
	
-
 
20
	private $conteneur;
-
 
21
	private $gestionBdd;
-
 
22
	private $bdd;
-
 
23
	
-
 
24
	public function __construct(Conteneur $conteneur = null) {
-
 
25
		$this->conteneur = $conteneur == null ? new Conteneur() : $conteneur;
-
 
26
		$this->conteneur->chargerConfiguration('config_utilisateurs.ini');
-
 
27
		$this->gestionBdd = $conteneur->getGestionBdd();
17
 
28
		$this->bdd = $this->gestionBdd->getBdd();
-
 
Line 29... Line 18...
29
	}
18
class Connecter extends gestionUtilisateur {
30
	
19
	
31
	/**
20
	/**
32
	 * Méthode principale de la classe.
21
	 * Méthode principale de la classe.
33
	 * Lance la récupération des images dans la base et les place dans un objet ResultatService 
22
	 * Lance la récupération des images dans la base et les place dans un objet ResultatService 
34
	 * pour l'afficher.
23
	 * pour l'afficher.
35
	 * @param array $ressources les ressources situées après l'url de base (ex : http://url/ressource1/ressource2)
24
	 * @param array $ressources les ressources situées après l'url de base (ex : http://url/ressource1/ressource2)
36
	 * @param array $parametres les paramètres situés après le ? dans l'url
25
	 * @param array $parametres les paramètres situés après le ? dans l'url
37
	 * */
-
 
38
	public function consulter($ressources, $parametres) {
-
 
39
		session_start();
26
	 * */
40
		
27
	public function consulter($ressources, $parametres) {
Line 41... Line 28...
41
		$login = $ressources[0];
28
		$login = $ressources[0];
42
		$motDePasse = $ressources[1];
29
		$motDePasse = $ressources[1];
Line 49... Line 36...
49
		$resultat = new ResultatService();
36
		$resultat = new ResultatService();
50
		$resultat->corps = $utilisateur;
37
		$resultat->corps = $utilisateur;
51
		return $resultat;
38
		return $resultat;
52
	}
39
	}
Line 53... Line -...
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
	
40
	
62
	private function verifierUtilisateur($utilisateur) {
41
	private function verifierUtilisateur($utilisateur) {
63
		if ($utilisateur == null || sizeof($utilisateur) == 0 || sizeof($utilisateur) > 1) {
42
		if ($utilisateur == null || sizeof($utilisateur) == 0 || sizeof($utilisateur) > 1) {
64
			$e = 'Accès non autorisé';
43
			$e = 'Accès non autorisé';
65
			throw new Exception($e, RestServeur::HTTP_CODE_ACCES_NON_AUTORISE);
44
			throw new Exception($e, RestServeur::HTTP_CODE_ACCES_NON_AUTORISE);
66
		} else {
45
		} else {
67
			return $utilisateur[0];
46
			return $utilisateur[0];
68
		}
47
		}
69
	}
-
 
70
	
-
 
71
	function setUtilisateur($utilisateur, $remember=1) {
-
 
72
		$utilisateur['session_id'] = session_id();
-
 
73
		$utilisateur['connecte'] = true;
-
 
74
		$_SESSION["del_utilisateur"] = $utilisateur;
-
 
75
		return $utilisateur;
-
 
76
	}
-
 
77
	
-
 
78
	function setPersistentCookie($name, $value, $remember = 1) {
-
 
79
		SetCookie($name, $value, time() + ($remember ? (60*60*24*100) : (60*60)),'/');
-
 
80
		$_COOKIE[$name] = $value;
-
 
81
	}
-
 
82
	
-
 
83
	private function getUtilisateurAnonyme() {
-
 
84
		return array('connecte' => false,
-
 
85
								 'id_utilisateur' => session_id(),
-
 
86
								 'courriel' => '',
-
 
87
								 'mot_de_passe' => '',
-
 
88
								 'nom' => '',
-
 
89
								 'prenom' => '',
-
 
90
								 'session_id' => session_id()
-
 
91
		);
-
 
92
	}
-
 
93
	
-
 
94
	private function utilisateurEstIdentifie() {
-
 
95
			
-
 
96
		$login_utilisateur = false;
-
 
97
		if (!$login_utilisateur = $this->utilisateurEstIdentifieSession()) {
-
 
98
			$login_utilisateur = $this->utilisateurEstIdentifieCookie();
-
 
99
		}
-
 
100
	
-
 
101
		return $login_utilisateur;
-
 
102
	}
-
 
103
	
-
 
104
	function utilisateurEstIdentifieSession() {
-
 
105
		return (isset($_SESSION["del_utilisateur"]) && isset($_SESSION["del_utilisateur"])) ? $_SESSION["del_utilisateur"] : false;
-
 
106
	}
-
 
107
	
-
 
108
	function utilisateurEstIdentifieCookie() {
-
 
109
		return isset($_COOKIE["del_courriel"]) && ($this->identifierUtilisateurSansEncryptionMotDePasse($_COOKIE["del_name"], $_COOKIE["del_password"])) ? $_COOKIE["del_name"] : false;
-
 
110
	}
48
	}
111
}
49
}
112
?>
50
?>