Subversion Repositories eFlore/Applications.del

Rev

Rev 1820 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

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