Subversion Repositories eFlore/Applications.del

Rev

Rev 803 | Go to most recent revision | Details | Compare with Previous | 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 IdentificationAnonyme {
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) {
1475 aurelien 40
 
803 gduche 41
		// Lancement du service
42
		$temps_expiration = 60*60*24*100; // 100 jours
43
		session_set_cookie_params($temps_expiration);
44
 
45
		$utilisateur = $this->getUtilisateurAnonyme();
46
 
47
		$utilisateurParCookie = $this->utilisateurEstIdentifie();
48
		if ($utilisateurParCookie != null) {
49
			$utilisateurParCookie['connecte'] = true;
50
			$utilisateur = $utilisateurParCookie;
51
		}
52
 
53
		// Mettre en forme le résultat et l'envoyer pour affichage
54
		$resultat = new ResultatService();
55
		$resultat->corps = $utilisateur;
56
		return $resultat;
57
	}
58
 
59
	private function getUtilisateurAnonyme() {
60
		return array('connecte' => false,
61
					 'id_utilisateur' => session_id(),
62
					 'courriel' => '',
63
					 'mot_de_passe' => '',
64
					 'nom' => '',
1475 aurelien 65
					 'prenom' => '',
66
					 'session_id' => session_id()
803 gduche 67
		);
68
	}
69
 
1475 aurelien 70
	private function utilisateurEstIdentifie() {
803 gduche 71
		$utilisateur = null;
72
		if (($utilisateur = $this->utilisateurEstIdentifieSession()) == null) {
73
			$utilisateur = $this->utilisateurEstIdentifieCookie();
1475 aurelien 74
			if($utilisateur != null) {
75
				$utilisateur['session_id'] = session_id();
76
			}
803 gduche 77
		}
78
		return $utilisateur;
79
	}
80
 
81
	function utilisateurEstIdentifieSession() {
82
		$utilisateur = null;
1475 aurelien 83
		if (isset($_SESSION["del_utilisateur"]) && $_SESSION["del_utilisateur"] != "") {
803 gduche 84
		}
85
		return $utilisateur;
86
	}
87
 
1475 aurelien 88
	function utilisateurEstIdentifieCookie() {
89
		$retour = null;
90
		if(isset($_COOKIE["del_courriel"])) {
91
			$retour = $this->identifierUtilisateurSansEncryptionMotDePasse($_COOKIE["del_courriel"], $_COOKIE["del_password"]);
92
		}
93
		return $retour;
803 gduche 94
	}
95
 
96
	function identifierUtilisateurSansEncryptionMotDePasse($login, $mot_de_passe, $remember = 1) {
1475 aurelien 97
		$requete = 'SELECT id_utilisateur, nom, prenom, courriel, mot_de_passe FROM '.$this->gestionBdd->formaterTable('del_utilisateur', 'du').
803 gduche 98
					'WHERE courriel = '.$this->bdd->proteger($login).' '.
99
					'AND mot_de_passe = '.$this->bdd->proteger($mot_de_passe);
100
		$utilisateur = $this->bdd->recuperer($requete);
101
		return $utilisateur;
102
	}
103
}
104
?>