Subversion Repositories Applications.annuaire

Rev

Rev 569 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
454 jpm 1
<?php
2
// declare(encoding='UTF-8');
3
/**
4
 * Service retournant les prénoms et nom  d'un utilisateur en fonction de son courriel.
5
 * UNe liste de courriel peut être passé dans la ressource.
6
 * Exemple :
7
 * /utilisateur/Prenom-nom-par-courriel/jpm@tela-botanica.org,aurelien@tela-botanica.org
8
 *
9
 * @category	php 5.2
10
 * @package		Annuaire::Services
11
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
12
 * @copyright	Copyright (c) 2010, Tela Botanica (accueil@tela-botanica.org)
13
 * @license		http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
14
 * @license		http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
15
 * @version		$Id$
16
 */
17
class Utilisateur extends JRestService {
18
 
19
	private $donnees = null;
20
	private $idAnnuaire = null;
21
	private $utilisateurId = null;
22
	private $metadonneeModele = null;
23
	private $annuaireModele = null;
24
	private $messagerieModele = null;
25
 
519 mathias 26
	const FORMAT_JSON = "json";
27
	const FORMAT_XML = "xml";
28
	const FORMAT_LDEHYDE = "méthanal"; // hihi hoho
29
 
536 mathias 30
	public function __construct($config, $demarrer_session = true) {
31
		parent::__construct($config, $demarrer_session);
32
		$this->idAnnuaire = Config::get('annuaire_defaut');
33
	}
34
 
454 jpm 35
	/*+----------------------------------------------------------------------------------------------------+*/
36
	// GET : consultation
37
 
38
	public function getElement($ressources){
39
		$this->ressources = $ressources;
40
		$infos = null;
41
 
42
		if (isset($this->ressources[0])) {
43
			if (preg_match('/^[0-9]+$/', $this->ressources[0])) {
44
				// ATTENTION : Ces web services ne doivent être accessible que depuis des applis installées sur nos serveurs
45
				// pour les communications inter-serveurs.
46
				$this->controlerIpAutorisees();
47
				$infos = $this->getInfosParId($this->ressources[0]);
48
			} else {
49
				$methode_demande = array_shift($this->ressources);
50
				$methode = $this->traiterNomMethodeGet($methode_demande);
51
				if (method_exists($this, $methode)) {
525 mathias 52
					$infos = $this->$methode($this->ressources[0]);
454 jpm 53
				} else {
54
					$this->messages[] = "Ce type de ressource '$methode_demande' n'est pas disponible pour la requete GET.";
55
				}
56
			}
57
		} else {
519 mathias 58
			$this->messages[] = "Le premier paramètre du chemin du service doit correspondre au type de ressource demandée.";
454 jpm 59
		}
60
 
519 mathias 61
		// possibilité d'envoyer en plusieurs formats @TODO faire ça plus proprement
62
		$format = self::FORMAT_JSON;
63
		$dernierIndex = count($this->ressources) - 1;
64
		if ($dernierIndex >= 0) {
65
			$dernierParametre = $this->ressources[$dernierIndex];
66
			if (in_array($dernierParametre, array(self::FORMAT_JSON, self::FORMAT_XML))) {
67
				$format = $dernierParametre;
68
			}
69
		}
70
 
454 jpm 71
		if (!is_null($infos)) {
519 mathias 72
			switch ($format) {
73
				case self::FORMAT_XML :
74
					$this->envoyerXml($infos);
75
				break;
76
				case self::FORMAT_JSON :
77
				default :
78
					$this->envoyerJson($infos);
79
			}
454 jpm 80
		} else {
81
			$info = 'Un problème est survenu : '.print_r($this->messages, true);
82
			$this->envoyerTxt($info);
83
		}
84
	}
556 mathias 85
 
86
	/**
573 mathias 87
	 * Méthode temporaire pour SmartForm
88
	 * @TODO virer cette méthode dès qu'on l'aura remplacée par le SSO
89
	 */
90
	public function getIdentiteConnectee() {
91
		if (isset($_COOKIE[$this->config['database_ident']['nom_cookie_persistant']])) {
92
 
93
			$cookie = $_COOKIE[$this->config['database_ident']['nom_cookie_persistant']];
94
			// le cookie de papyrus contient un md5 concaténé à l'email utilisateur
95
			$courriel = substr($cookie , 32, strlen($cookie));
96
 
97
			$id_utilisateur = $this->getAnnuaire()->obtenirIdParMail($this->idAnnuaire, $courriel);
98
			$infos = $this->getAnnuaire()->obtenirInfosUtilisateurParId($this->idAnnuaire, $id_utilisateur);
99
 
100
			$infos = array_pop($infos);
101
 
102
			$infos['pseudoUtilise'] = $this->obtenirPseudoUtilise($id_utilisateur);
103
			$infos['pseudo'] = $this->obtenirPseudo($id_utilisateur);
104
			$infos['intitule'] = $this->formaterIntitule($infos);
105
 
106
			$infos['nomWiki'] = $this->formaterNomWiki($infos);
107
 
108
			header("content-type: application/json");
109
			echo json_encode($infos);
110
		} else  {
111
			echo json_encode(array());
112
		}
113
 
114
		exit;
115
	}
116
 
117
	/**
556 mathias 118
	 * Crée un nom Wiki (de la forme "JeanTalus") à partir des données de l'utilisateur;
119
	 * gère l'utilisation du pseudo mais pas la collision de noms Wiki @TODO s'en occuper
120
	 *
121
	 * @param array $infos des infos de profil utilisateur - on admet qu'elles contiennent "intitule"
122
	 * @return string un nom wiki correspondant à l' "intitulé" de l'utilisateur (prénom-nom ou pseudo)
123
	 * 		ou la valeur par défaut de $defaut si celui-ci est fourni et si le nom Wiki n'a pu être construit
124
	 */
125
	public function formaterNomWiki($infos, $defaut="ProblemeNomWiki") {
569 mathias 126
		$nw = $this->convertirEnCamelCase($infos['intitule']);
556 mathias 127
		// on sait jamais
128
		if ($nw == "") {
129
			$nw = $defaut;
130
		}
131
 
132
		return $nw;
532 aurelien 133
	}
569 mathias 134
 
135
	protected function convertirEnCamelCase($str) {
136
		// Suppression des accents
137
		$str = $this->supprimerAccents($str);
138
		// Suppression des caractères non alphanumériques
139
		$str = preg_replace('/[^\da-z]/i', '', ucwords(strtolower($str)));
140
		return $str;
141
	}
556 mathias 142
 
143
	protected function supprimerAccents($str, $charset='utf-8') {
532 aurelien 144
		$str = htmlentities($str, ENT_NOQUOTES, $charset);
556 mathias 145
 
532 aurelien 146
		$str = preg_replace('#&([A-za-z])(?:acute|cedil|caron|circ|grave|orn|ring|slash|th|tilde|uml);#', '\1', $str);
147
		$str = preg_replace('#&([A-za-z]{2})(?:lig);#', '\1', $str); // pour les ligatures e.g. '&oelig;'
148
		$str = preg_replace('#&[^;]+;#', '', $str); // supprime les autres caractères
556 mathias 149
 
532 aurelien 150
		return $str;
151
	}
454 jpm 152
 
520 mathias 153
	/**
525 mathias 154
	 * Permet d'obtenir des infos pour un ou plusieurs ids utilisateurs indiqué(s) dans la ressource.
155
	 * RESSOURCE : /infos-par-ids/#id[,#id]*
156
	 * PARAMÈTRES : forceArrayOfArrays - si true, retourne un tableau associatif même s'il n'y a qu'un
157
	 * 		résultat (casse la rétrocompatibilté)
454 jpm 158
	 * RÉPONSE : Tableau possédant un courriel de la ressource en clé et en valeur :
159
	 *  - id : identifiant numérique de l'utilisateur
160
	 *  - pseudoUtilise : indique si on doit utiliser le pseudo à la place de Prénom NOM
161
	 *  - pseudo : pseudo de l'utilisateur.
162
	 *  - intitule : l'intitulé à affiche (choix auto entre "pseudo" et "prénom nom")
163
	 *  - prenom : prénom
164
	 *  - nom : nom de famille.
165
	 *  - courriel : courriel
166
	 */
525 mathias 167
	public function getInfosParIds($ids_utilisateurs, $forceArrayOfArrays = false) {
168
		$ids_utilisateurs = explode(',', $ids_utilisateurs);
169
		if (count($ids_utilisateurs) == 1) {
170
			// s'il n'y en a qu'un on ne passe pas un array
171
			$ids_utilisateurs = array_shift($ids_utilisateurs);
172
		}
173
		$infos = $this->getAnnuaire()->obtenirInfosUtilisateurParId($this->idAnnuaire, $ids_utilisateurs);
174
 
175
		foreach ($infos as $i => $info) {
176
			$infos[$i]['pseudoUtilise'] = $this->obtenirPseudoUtilise($info['id']);
177
			$infos[$i]['pseudo'] = $this->obtenirPseudo($info['id']);
178
			$infos[$i]['intitule'] = $this->formaterIntitule($infos[$i]);
179
		}
454 jpm 180
 
525 mathias 181
		// retrocompatibilité
182
		if (count($infos) == 1 && (! $forceArrayOfArrays)) {
183
			$infos = array_shift($infos);
184
		}
454 jpm 185
 
186
		return $infos;
187
	}
188
 
189
	/**
525 mathias 190
	 * Méthode rétrocompatible : appelle getInfosParIds et s'il n'y a qu'un résultat,
191
	 * ne retourne pas un tableau associatif mais un tableau simple
192
	 * @return array
193
	 */
194
	public function getInfosParId($ids_utilisateurs) {
195
		return $this->getInfosParIds($ids_utilisateurs, true);
196
	}
197
 
198
	/**
454 jpm 199
	 * Permet d'obtenir les prénoms et noms des courriels des utilisateurs indiqués dans la ressource.
200
	 * RESSOURCE : /utilisateur/prenom-nom-par-courriel/[courriel,courriel,...]
536 mathias 201
	 * PARAMÈTRES : $courriels des adresses courriel séparées par des virgules; si != null, sera utilisé à la place de la ressource d'URL
454 jpm 202
	 * RÉPONSE : Tableau possédant un courriel de la ressource en clé et en valeur :
203
	 *  - id : identifiant numérique de l'utilisateur
204
	 *  - prenom : prénom
205
	 *  - nom : nom de famille.
206
	 */
536 mathias 207
	public function getPrenomNomParCourriel($courriels) {
208
		$courriels = explode(',', $courriels);
454 jpm 209
		$infos = $this->getAnnuaire()->obtenirPrenomNomParCourriel($this->idAnnuaire, $courriels);
210
		return $infos;
211
	}
212
 
213
	/**
214
	 * Permet d'obtenir les identités des utilisateurs indiqués dans la ressource.
215
	 * RESSOURCE : /utilisateur/identite-par-courriel/[courriel,courriel,...]
536 mathias 216
	 * PARAMÈTRES : $courriels des adresses courriel séparées par des virgules; si != null, sera utilisé à la place de la ressource d'URL
454 jpm 217
	 * RÉPONSE : Tableau possédant un courriel de la ressource en clé et en valeur :
218
	 *  - id : identifiant numérique de l'utilisateur
219
	 *  - pseudoUtilise : indique si on doit utiliser le pseudo à la place de Prénom NOM
220
	 *  - pseudo : pseudo de l'utilisateur.
221
	 *  - prenom : prénom
222
	 *  - nom : nom de famille.
223
	 */
536 mathias 224
	public function getIdentiteParCourriel($courriels) {
454 jpm 225
		$infos_utilisateurs = array();
536 mathias 226
		$utilisateurs = $this->getPrenomNomParCourriel($courriels);
454 jpm 227
		foreach ($utilisateurs as $courriel => $utilisateur) {
228
			$id = $utilisateur['id'];
229
			$utilisateur['pseudo'] = $this->obtenirPseudo($id);
230
			$utilisateur['pseudoUtilise'] = $this->obtenirPseudoUtilise($id);
231
			$utilisateur['intitule'] = $this->formaterIntitule($utilisateur);
569 mathias 232
			$utilisateur['nomWiki'] = $this->formaterNomWiki($utilisateur);
488 aurelien 233
			$courriel = strtolower($courriel);
454 jpm 234
			$infos_utilisateurs[$courriel] = $utilisateur;
235
		}
236
		return $infos_utilisateurs;
237
	}
238
 
519 mathias 239
	/**
240
	 * Même principe que getIdentiteParCourriel() mais pour un seul courriel, et renvoie plus d'infos :
241
	 * RESSOURCE : /utilisateur/identite-complete-par-courriel/courriel[/format]
242
	 * PARAMÈTRES : format : "json" (par défaut) ou "xml" (pour
243
	 *   rétrocompatibilité avec le service eFlore_chatin/annuaire_tela/xxx/courriel)
244
	 * RÉPONSE : Tableau possédant un courriel de la ressource en clé et en valeur :
245
	 * - id : identifiant numérique de l'utilisateur
246
	 * - pseudoUtilise : indique si on doit utiliser le pseudo à la place de Prénom NOM
247
	 * - pseudo : pseudo de l'utilisateur.
248
	 * - prenom : prénom
249
	 * - nom : nom de famille.
250
	 * - mot_de_passe : le mot de passe haché (15% de matières grasses, peut contenir des traces de soja)
251
	 * - fonction
252
	 * - titre
253
	 * - site_web
254
	 * - adresse01
255
	 * - adresse02
256
	 * - code_postal
257
	 * - ville
258
	 * - departement
259
	 * - region
260
	 * - pays
261
	 * - date_inscription
262
	 */
263
	public function getIdentiteCompleteParCourriel() {
520 mathias 264
 
265
		$this->authentificationHttpSimple();
266
 
519 mathias 267
		$infos_utilisateurs = array();
268
		$courriel = $this->ressources[0];
269
		$utilisateur = $this->getAnnuaire()->obtenirMaximumInfosParCourriel($this->idAnnuaire, $courriel);
270
 
271
		$id = $utilisateur['id'];
272
		$utilisateur['pseudo'] = $this->obtenirPseudo($id);
273
		$utilisateur['pseudoUtilise'] = $this->obtenirPseudoUtilise($id);
274
		$utilisateur['intitule'] = $this->formaterIntitule($utilisateur);
275
 
276
		// ouksépabo
277
		$this->baliseMaitresse = "personne";
278
 
279
		return $utilisateur;
280
	}
281
 
454 jpm 282
	private function getAnnuaire() {
283
		if (!isset($this->annuaireModele)) {
284
			$this->annuaireModele = new AnnuaireModele();
285
		}
286
		return $this->annuaireModele;
287
	}
288
 
289
	private function getMeta() {
290
		if (!isset($this->metadonneeModele)) {
291
			$this->metadonneeModele = new MetadonneeModele();
292
		}
293
		return $this->metadonneeModele;
294
	}
295
 
296
	private function obtenirPseudo($id_utilisateur) {
297
		$pseudo = '';
298
		$id_champ_pseudo = $this->getMeta()->renvoyerIdChampMetadonneeParAbreviation($this->idAnnuaire, 'pseudo');
299
		if ($this->getMeta()->valeurExiste($id_champ_pseudo, $id_utilisateur)) {
300
			$pseudo = $this->getMeta()->obtenirValeurMetadonnee($id_champ_pseudo, $id_utilisateur);
301
		}
302
		return $pseudo;
303
	}
304
 
305
	private function obtenirPseudoUtilise($id_utilisateur) {
306
		$pseudo_utilise = false;
307
		$id_champ_utilise_pseudo = $this->getMeta()->renvoyerIdChampMetadonneeParAbreviation($this->idAnnuaire, 'utilise_pseudo');
308
		if ($this->getMeta()->valeurExiste($id_champ_utilise_pseudo, $id_utilisateur)) {
309
				$booleen = $this->getMeta()->obtenirValeurMetadonnee($id_champ_utilise_pseudo, $id_utilisateur);
310
				$pseudo_utilise = ($booleen == 0) ? false : true;
311
		}
312
		return $pseudo_utilise;
313
	}
314
 
315
	private function formaterIntitule($utilisateur) {
316
		$intitule = '';
317
		if ($utilisateur['pseudoUtilise'] && trim($utilisateur['pseudo']) != '') {
318
			$intitule = $utilisateur['pseudo'];
319
		} else {
320
			$intitule = $utilisateur['prenom'].' '.$utilisateur['nom'];
321
		}
322
		return $intitule;
323
	}
324
 
541 mathias 325
	/**
326
	 * Retourne la date de dernière modification du profil, piochée dans
327
	 * annu_triples
328
	 *
329
	 * @param numeric $id identifiant de l'utilisateur
330
	 * @param boolean $timestamp si true, fournira un timestamp Unix; si
331
	 * 		false, une date GMT sous forme de string
332
	 * @return mixed une date (string ou timestamp), ou null si la date
333
	 * 		n'a pas été trouvée dans les "triples" de l'annuaire
334
	 */
335
	public function getDateDerniereModifProfil($id, $timestamp=false) {
336
		$date = $this->getAnnuaire()->obtenirDateDerniereModificationProfil($this->idAnnuaire, $id);
542 mathias 337
		if (($timestamp === true) && ($date !== null)) {
541 mathias 338
			// normalement, strtotime accepte le format "yyyy-mm-dd hh:ii:ss"
339
			$date = strtotime($date);
340
		}
341
		return $date;
342
	}
343
 
454 jpm 344
	/*+----------------------------------------------------------------------------------------------------+*/
345
	// POST : mise à jour
346
 
347
	public function updateElement($ressources, $donnees) {
348
		$this->ressources = $ressources;
349
		$this->donnees = $donnees;
350
		$this->idAnnuaire = Config::get('annuaire_defaut');
351
 
352
		$infos = null;
353
		if (isset($this->ressources[0])) {
354
			$this->utilisateurId = array_shift($this->ressources);
355
			if (isset($this->ressources[0])) {
356
				$methode_demande = array_shift($this->ressources);
357
				$methode = $this->traiterNomMethodePost($methode_demande);
358
				if (method_exists($this, $methode)) {
359
					$infos = $this->$methode();
360
				} else {
361
					$this->messages[] = "Ce type de ressource '$methode_demande' n'est pas disponible pour la requete POST.";
362
				}
363
			} else {
364
				$this->messages[] = "La seconde ressource du service pour les requêtes POST doit correspondre au type de ressource demandée.";
365
			}
366
		} else {
367
			$this->messages[] = "La première ressource du service pour les requêtes POST doit être l'identifiant de l'utilisateur.";
368
		}
369
 
370
		if (!is_null($infos)) {
371
			$this->envoyerJson($infos);
372
		} else {
373
			$info = 'Un problème est survenu : '.print_r($this->messages, true);
374
			$this->envoyerTxt($info);
375
		}
376
	}
377
 
378
	/**
379
	 * Permet d'envoyer un message à un utilisateur.
380
	 * RESSOURCE : /utilisateur/[id]/message
381
	 * POST :
382
	 *  - sujet : contient le sujet du message à envoyer.
383
	 *  - message : contient le contenu du message à envoyer.
456 jpm 384
	 *  - message_txt : (optionnel) si format HTML, peut contenir le contenu du message au format texte comme alternative au HTML à envoyer.
385
	 *		Sinon le texte est extrait du HTML (attention à la mise en page!).
454 jpm 386
	 *  - utilisateur_courriel : contient le courriel de l'utilisateur qui envoie le message (Il doit être
387
	 *		inscrit dans l'annuaire par défaut de Tela Botanica).
388
	 *  - copies : peut contenir une liste de courriels séparés par des virguels auxquels une copie du
389
	 *		message sera envoyée.
390
	 *  - format (optionnel) : text ou html
391
	 * RÉPONSE :
392
	 *  - message : contient le message d'information concernant l'envoie.
393
	 */
394
	private function updateMessage() {
395
		$destinataireId = $this->utilisateurId;//$this->donnees['destinataire_id'];
396
		$sujet = stripslashes($this->donnees['sujet']);
397
		$contenu = stripslashes($this->donnees['message']);
456 jpm 398
		$contenuTxt = (isset($this->donnees['message_txt'])) ? $this->donnees['message_txt'] : null;
454 jpm 399
		$envoyeur = $this->donnees['utilisateur_courriel'];
466 mathias 400
		$adresse_reponse = (isset($this->donnees['reponse_courriel']) ? $this->donnees['reponse_courriel'] : $this->donnees['utilisateur_courriel']);
454 jpm 401
		$copies = array_key_exists('copies', $this->donnees) ? explode(',', $this->donnees['copies']) : null;
402
		$format = isset($this->donnees['format']) ? $this->donnees['format'] : 'text';
403
 
404
		$info = null;
405
		if ($this->estAutoriseMessagerie($envoyeur) || $this->getAnnuaire()->utilisateurExisteParMail($this->idAnnuaire, $envoyeur)) {
406
			// il est possible de passer directement un email ou bien un id utilisateur
407
			if(filter_var($destinataireId, FILTER_VALIDATE_EMAIL)) {
408
				$destinataire = $destinataireId;
409
			} else {
410
				$destinataire = $this->getAnnuaire()->obtenirMailParId($this->idAnnuaire, $destinataireId);
411
			}
412
			if ($destinataire) {
413
				if ($format == 'html') {
456 jpm 414
					if (isset($contenuTxt)) {
415
						$envoie = $this->getMessagerie()
466 mathias 416
							->envoyerMail($envoyeur, $destinataire, $sujet, $contenu, $contenuTxt, $adresse_reponse);
456 jpm 417
					} else {
418
						$envoie = $this->getMessagerie()
466 mathias 419
							->envoyerMail($envoyeur, $destinataire, $sujet, $contenu, '', $adresse_reponse);
456 jpm 420
					}
454 jpm 421
				} else {
466 mathias 422
					$envoie = $this->getMessagerie()->envoyerMailText($envoyeur, $destinataire, $sujet, $contenu, '', $adresse_reponse);
454 jpm 423
				}
424
				if ($envoie) {
425
					$info['message'] = "Votre message a bien été envoyé.";
426
					foreach ($copies as $copie) {
427
						$sujet = '[COPIE] '.$sujet;
428
						$contenu = "Message original envoyé par $envoyeur pour $destinataire.\n--\n".$contenu;
466 mathias 429
						$this->getMessagerie()->envoyerMailText($envoyeur, $copie, $sujet, $contenu, '', $adresse_reponse);
454 jpm 430
					}
431
				} else {
432
					$info['message'] = "Le message n'a pas pu être envoyé.";
433
				}
434
			} else {
435
				$info['message'] = "Aucun courriel ne correspond à l'id du destinataire.";
436
			}
437
		} else {
438
			$info['message'] = "Vous n'êtes pas inscrit à Tela Botanica avec le courriel : $envoyeur.\n".
439
				"Veuillez saisir votre courriel d'inscription ou vous inscrire à Tela Botanica.";
440
		}
441
		return $info;
442
	}
443
 
444
	private function getMessagerie() {
445
		if (!isset($this->messagerieModele)) {
446
			$this->messagerieModele = new MessageControleur();
447
		}
448
		return $this->messagerieModele;
449
	}
450
 
451
	/*+----------------------------------------------------------------------------------------------------+*/
452
	// PUT : ajout
453
 
454
	public function createElement($donnees) {
532 aurelien 455
 
454 jpm 456
		$this->donnees = $donnees;
457
		$this->idAnnuaire = Config::get('annuaire_defaut');
458
 
459
		$infos = null;
460
		if (isset($this->donnees['methode'])) {
461
			$methode_demande = $this->donnees['methode'];
462
			$methode = $this->traiterNomMethodePut($methode_demande);
463
			if (method_exists($this, $methode)) {
464
				$infos = $this->$methode();
465
			} else {
466
				$this->messages[] = "Ce type de méthode '$methode_demande' n'est pas disponible pour la requete PUT.";
467
			}
468
		} else {
469
			$this->messages[] = "Ce service n'est pas implémanté.";
470
		}
471
 
472
		if (!is_null($infos)) {
473
			$this->envoyerJson($infos);
474
		} else {
475
			$info = 'Un problème est survenu : '.print_r($this->messages, true);
476
			$this->envoyerTxt($info);
477
		}
478
	}
479
 
480
	/**
560 mathias 481
	 * Permet d'identifier un utilisateur, sans utiliser SSO (à l'ancienne).
454 jpm 482
	 * RESSOURCE : /utilisateur
483
	 * POST :
484
	 *  - methode = 'connexion' : methode doit valoir 'connexion' pour connecter l'utilisateur.
485
	 *  - courriel : contient le courriel de l'utilisateur .
486
	 *  - mdp : le mot de passe de l'utilisateur.
487
	 *  - persistance : true si on veut laisser l'utilisateur connecté au delà de la session sinon false
488
	 * RÉPONSE :
489
	 *  - identifie : indiquer si l'utilisateur a été identifié (true) ou pas (false)
490
	 *  - message : contient un message d'information complémentaire de l'état.
491
	 */
492
	private function createConnexion() {
493
		$courriel = stripslashes($this->donnees['courriel']);
494
		$mdp = stripslashes($this->donnees['mdp']);
495
		$persistance = (stripslashes($this->donnees['persistance']) == 'true') ? true : false;
496
 
497
		$infos = null;
498
		$infos['persistance'] = $persistance;
499
		if ($this->verifierAcces($courriel, $mdp)) {
500
			$infos['identifie'] = true;
501
			$infos['message'] = "Bienvenu.";
502
			$dureeCookie = 0;
503
			if ($persistance === true) {
504
				$dureeCookie = time()+3600*24*30;
505
				$this->creerCookiePersistant($dureeCookie, $courriel, $mdp);
506
			}
507
			$this->creerCookieUtilisateur($dureeCookie, $courriel);
508
			$infos['message'] = $_COOKIE;
509
		} else {
510
			$infos['identifie'] = false;
511
			$infos['message'] = "Le courriel ou le mot de passe saisi est incorrect.";
512
		}
513
		return $infos;
514
	}
532 aurelien 515
 
516
	/*+----------------------------------------------------------------------------------------------------+*/
517
	// DELETE : suppression
518
 
519
	/**
520
	 * Permet de déconnecter un utilisateur
521
	 * RESSOURCE : /utilisateur
522
	 * DELETE
523
	 */
524
	public function deleteElement($uid) {
525
		if($uid[0] == 'deconnexion') {
526
			$this->supprimerCookieUtilisateur();
527
		}
528
	}
454 jpm 529
}
530
?>