Subversion Repositories eFlore/Applications.del

Rev

Rev 1795 | 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
/**
1820 jpm 4
 * Permet de connecter un utilisateur à DEL.
803 gduche 5
 *
1820 jpm 6
 * @category   DEL
7
 * @package    Services
8
 * @subpackage Utilisateurs
9
 * @version    0.1
10
 * @author     Mathias CHOUET <mathias@tela-botanica.org>
11
 * @author     Jean-Pascal MILCENT <jpm@tela-botanica.org>
12
 * @author     Aurelien PERONNET <aurelien@tela-botanica.org>
13
 * @license    GPL v3 <http://www.gnu.org/licenses/gpl.txt>
14
 * @license    CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
15
 * @copyright  1999-2014 Tela Botanica <accueil@tela-botanica.org>
803 gduche 16
 */
17
 
1610 jpm 18
class Connecter extends GestionUtilisateur {
19
 
803 gduche 20
	/**
21
	 * Méthode principale de la classe.
1610 jpm 22
	 * Lance la récupération des images dans la base et les place dans un objet ResultatService
803 gduche 23
	 * pour l'afficher.
24
	 * @param array $ressources les ressources situées après l'url de base (ex : http://url/ressource1/ressource2)
25
	 * @param array $parametres les paramètres situés après le ? dans l'url
26
	 * */
27
	public function consulter($ressources, $parametres) {
28
		$login = $ressources[0];
29
		$motDePasse = $ressources[1];
1610 jpm 30
 
803 gduche 31
		$utilisateur = $this->identifierUtilisateur($login, $motDePasse);
32
		$utilisateur = $this->verifierUtilisateur($utilisateur);
33
		$utilisateur = $this->setUtilisateur($utilisateur);
1610 jpm 34
 
803 gduche 35
		// Mettre en forme le résultat et l'envoyer pour affichage
36
		$resultat = new ResultatService();
37
		$resultat->corps = $utilisateur;
38
		return $resultat;
39
	}
1610 jpm 40
 
803 gduche 41
	private function verifierUtilisateur($utilisateur) {
42
		if ($utilisateur == null || sizeof($utilisateur) == 0 || sizeof($utilisateur) > 1) {
43
			$e = 'Accès non autorisé';
44
			throw new Exception($e, RestServeur::HTTP_CODE_ACCES_NON_AUTORISE);
45
		} else {
46
			return $utilisateur[0];
47
		}
48
	}
1795 jpm 49
}