Subversion Repositories eFlore/Applications.del

Compare Revisions

Ignore whitespace Rev 802 → Rev 803

/trunk/services/modules/0.1/utilisateurs/IdentificationAnonyme.php
New file
0,0 → 1,100
<?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 IdentificationAnonyme {
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) {
// Lancement du service
$temps_expiration = 60*60*24*100; // 100 jours
session_set_cookie_params($temps_expiration);
$utilisateur = $this->getUtilisateurAnonyme();
$utilisateurParCookie = $this->utilisateurEstIdentifie();
if ($utilisateurParCookie != null) {
$utilisateurParCookie['connecte'] = true;
$utilisateur = $utilisateurParCookie;
}
// Mettre en forme le résultat et l'envoyer pour affichage
$resultat = new ResultatService();
$resultat->corps = $utilisateur;
return $resultat;
}
private function getUtilisateurAnonyme() {
return array('connecte' => false,
'id_utilisateur' => session_id(),
'courriel' => '',
'mot_de_passe' => '',
'nom' => '',
'prenom' => ''
);
}
private function utilisateurEstIdentifie() {
$utilisateur = null;
if (($utilisateur = $this->utilisateurEstIdentifieSession()) == null) {
$utilisateur = $this->utilisateurEstIdentifieCookie();
}
return $utilisateur;
}
function utilisateurEstIdentifieSession() {
$utilisateur = null;
if (isset($_SESSION["del_utilisateur"])) {
$utilisateur = $_SESSION["del_utilisateur"];
unset($utilisateur['mot_de_passe']);
}
return $utilisateur;
}
function utilisateurEstIdentifieCookie() {
return isset($_COOKIE["del_courriel"]) && ($utilisateur = $this->identifierUtilisateurSansEncryptionMotDePasse($_COOKIE["del_courriel"], $_COOKIE["del_password"])) ? $utilisateur : false;
}
function identifierUtilisateurSansEncryptionMotDePasse($login, $mot_de_passe, $remember = 1) {
$requete = 'SELECT id_utilisateur, nom, prenom, courriel FROM '.$this->gestionBdd->formaterTable('del_utilisateur', 'du').
'WHERE courriel = '.$this->bdd->proteger($login).' '.
'AND mot_de_passe = '.$this->bdd->proteger($mot_de_passe);
$utilisateur = $this->bdd->recuperer($requete);
return $utilisateur;
}
}
?>