Subversion Repositories Applications.annuaire

Rev

Rev 334 | Rev 358 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
120 aurelien 1
<?
2
/**
3
* PHP Version 5
4
*
5
* @category  PHP
6
* @package   annuaire
7
* @author    aurelien <aurelien@tela-botanica.org>
8
* @copyright 2010 Tela-Botanica
9
* @license   http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
10
* @version   SVN: <svn_id>
11
* @link      /doc/annuaire/
12
*/
13
 
14
/**
15
 *
16
 * Classe mère des controleurs de l'application, abstraite, elle contient
17
 * les fonctions utiles à tous les controleurs
18
 * @author aurelien
19
 *
20
 */
21
abstract class AppControleur extends Controleur {
22
 
23
	/**
24
	 * (fonction héritée de la classe Controleur)
25
	 * Avant chaque chargement de vue, on ajoute l'url de la page dans
26
	 * les variables à insérer.
27
	 * @param Array $donnes les données à insérer dans la vue
28
	 * @return Array $donnees les données modifiées
29
	 */
30
	public function preTraiterDonnees($donnees) {
31
 
32
		// ajout de l'url de l'appli
33
		$donnees['base_url'] = new Url(Config::get('base_url_application'));
34
 
182 aurelien 35
		$donnees['base_url_styles'] = $this->getUrlBase();
145 aurelien 36
 
182 aurelien 37
		$donnees['url_cette_page'] = $this->getUrlCettePage() ;
145 aurelien 38
 
182 aurelien 39
		$donnees['base_url_application'] = $this->getUrlBaseComplete();
145 aurelien 40
 
41
		$this->chargerModele('AnnuaireModele');
120 aurelien 42
 
43
		//ajout des variables d'identification
44
		$donnees['est_admin'] = Registre::getInstance()->get('est_admin');
45
		$donnees['identification_id'] =	Registre::getInstance()->get('identification_id');
46
		$donnees['identification_mail']	= Registre::getInstance()->get('identification_mail');
182 aurelien 47
 
143 aurelien 48
		$format = Config::get('date_format_simple');
49
 
50
		if($format) {
51
			$donnees['format_date_simple'] = $format;
52
		} else {
53
			$donnees['format_date_simple'] = 'd/m/Y';
54
		}
120 aurelien 55
 
56
		return $donnees;
57
	}
182 aurelien 58
 
59
	public function getUrlBase() {
60
 
61
		$base_vrai_chemin = str_replace(realpath($_SERVER['DOCUMENT_ROOT']),'',realpath(Application::getChemin()));
62
		$base_vrai_chemin .= '/';
63
 
64
		return new Url($base_vrai_chemin);
65
	}
120 aurelien 66
 
182 aurelien 67
	public function getUrlBaseComplete() {
68
		return new Url('http://'.$_SERVER['SERVER_NAME'].str_replace(realpath($_SERVER['DOCUMENT_ROOT']),'',realpath(Application::getChemin())));
69
	}
70
 
71
	public function getUrlCettePage() {
72
		return $_SERVER['SERVER_NAME'].$_SERVER['REQUEST_URI'];
73
	}
74
 
339 aurelien 75
	public static function getUrlConfirmationInscriptionAdmin($code_confirmation_inscription) {
76
 
77
		$url_cette_page = 'http://'.$_SERVER['SERVER_NAME'].str_replace('annuaire_utilisateur','annuaire_admin',$_SERVER['REQUEST_URI']);
78
		$base_url = new URL($url_cette_page);
79
		$base_url->setVariablesRequete(array());
80
		$base_url->setVariableRequete('m','annuaire_inscription_confirmation_admin');
81
		$base_url->setVariableRequete('id',$code_confirmation_inscription);
82
 
83
		return $base_url->getURL();
84
	}
85
 
86
	public static function getUrlConfirmationInscription($code_confirmation_inscription) {
87
 
88
		$url_cette_page = 'http://'.$_SERVER['SERVER_NAME'].$_SERVER['REQUEST_URI'];
89
		$base_url = new URL($url_cette_page);
90
		$base_url->setVariablesRequete(array());
91
		$base_url->setVariableRequete('m','annuaire_inscription_confirmation');
92
		$base_url->setVariableRequete('id',$code_confirmation_inscription);
93
 
94
		return $base_url->getURL();
95
	}
96
 
97
	public static function getUrlSuppressionInscriptionTemporaire($id_annuaire, $code_donnee_temporaire) {
98
 
99
		$url_cette_page = 'http://'.$_SERVER['SERVER_NAME'].$_SERVER['REQUEST_URI'];
100
		$base_url = new URL($url_cette_page);
101
		$base_url->setVariablesRequete(array());
102
		$base_url->setVariableRequete('m','annuaire_suppression_inscription_temp');
103
		$base_url->setVariableRequete('id',$code_donnee_temporaire);
104
		$base_url->setVariableRequete('id_annuaire',$id_annuaire);
105
 
106
		return $base_url->getURL();
107
	}
108
 
213 aurelien 109
	public static function getUrlConsultationProfil($id_annuaire, $id_utilisateur) {
110
 
111
		$url_consultation_profil = new Url(Config::get('base_url_application'));
112
		$url_consultation_profil->setVariableRequete('m','annuaire_fiche_utilisateur_consultation');
113
		$url_consultation_profil->setVariableRequete('id_annuaire',$id_annuaire);
114
		$url_consultation_profil->setVariableRequete('id_utilisateur',$id_utilisateur);
115
 
116
		return $url_consultation_profil;
117
	}
118
 
119
	public static function getUrlModificationProfil($id_annuaire, $id_utilisateur) {
120
 
121
		$url_modification_profil = new Url(Config::get('base_url_application'));
122
		$url_modification_profil->setVariableRequete('m','annuaire_formulaire_modification_inscription');
123
		$url_modification_profil->setVariableRequete('id_annuaire',$id_annuaire);
124
		$url_modification_profil->setVariableRequete('id_utilisateur',$id_utilisateur);
125
 
126
		return $url_modification_profil;
127
	}
128
 
129
	public static function getUrlOubliMotDePasse($id_annuaire,$id_utilisateur) {
130
 
131
		$url_oubli_mdp = new Url(Config::get('base_url_application'));
132
		$url_oubli_mdp->setVariableRequete('m','annuaire_afficher_formulaire_oubli_mdp');
133
		$url_oubli_mdp->setVariableRequete('id_annuaire',$id_annuaire);
134
		$url_oubli_mdp->setVariableRequete('id_utilisateur',$id_utilisateur);
135
 
136
		return $url_oubli_mdp;
137
	}
138
 
139
	public static function getUrlAjoutOuModificationImage($id_annuaire, $id_utilisateur) {
140
 
141
		$url_ajout_modification_image = new Url(Config::get('base_url_application'));
142
		$url_ajout_modification_image->setVariableRequete('m','annuaire_afficher_formulaire_ajout_image');
143
		$url_ajout_modification_image->setVariableRequete('id_annuaire',$id_annuaire);
144
		$url_ajout_modification_image->setVariableRequete('id_utilisateur',$id_utilisateur);
145
		return $url_ajout_modification_image;
146
 
147
	}
148
 
120 aurelien 149
	/**
150
	 * Renvoie le template de pagination, considérant des éléments donnés en paramètre
151
	 * @param int $numero_page le numéro de page en cours
152
	 * @param int $taille_page la taille de page
153
	 * @param int $total le nombre total de pages
154
	 * @param object $url_base l'url de base de la page
155
	 * @param array $valeurs les valeurs à concatener à l'url
156
	 * @return string le html contenu la template de pagination rempli avec les infos
157
	 */
158
	protected function paginer($numero_page = 1, $taille_page = 50, $total, $url_base, $valeurs) {
159
 
160
		// TODO, faire plus complexe, tri alphabétique etc...
161
		$page_precedente = $numero_page-1;
162
		$page_suivante = $numero_page+1;
163
 
164
		if($taille_page <= 0) {
165
			$taille_page = 1;
166
		}
167
 
182 aurelien 168
		$nombre_pages = ceil($total/$taille_page) ;
120 aurelien 169
 
170
		foreach($valeurs as $cle => $variable) {
171
			$url_base->setVariableRequete($cle,$variable);
172
		}
173
 
174
		if($numero_page < 2) {
175
			$page_precedente = false;
176
			$url_page_precedente = '';
177
		} else {
178
			$url_page_prec = clone($url_base);
179
				$url_page_prec->setVariableRequete('numero_page',($page_precedente));
180
				$url_page_prec->setVariableRequete('taille_page',($taille_page));
181
				$url_page_precedente = $url_page_prec->getUrl();
182
		}
183
 
184
		if($taille_page*($numero_page) >= $total) {
185
			$page_suivante = false;
186
			$url_page_suivante = '';
187
		} else {
188
			$url_page_suiv = clone($url_base);
189
				$url_page_suiv->setVariableRequete('numero_page',($page_suivante));
190
				$url_page_suiv->setVariableRequete('taille_page',($taille_page));
191
				$url_page_suivante = $url_page_suiv->getUrl();
192
		}
193
 
194
		$url_pages = array();
195
 
196
		for($i = 1; $i <= $nombre_pages ; $i++) {
197
 
198
				$url_page_prev = clone($url_base);
199
				$url_page_prev->setVariableRequete('numero_page',($i));
200
				$url_page_prev->setVariableRequete('taille_page',($taille_page));
201
				$url_pages[$i] = $url_page_prev->getUrl();
202
		}
203
 
204
		$donnees = array('url_pages' => $url_pages, 'numero_page' => $numero_page,
205
							'page_precedente' => $page_precedente, 'page_suivante' => $page_suivante,
206
							'url_page_precedente' => $url_page_precedente, 'url_page_suivante' => $url_page_suivante,
207
							'nombre_pages' => $nombre_pages, 'taille_page' => $taille_page);
208
		$donnees['base_url_pagination'] = $url_base;
209
 
210
		return $this->getVue(Config::get('dossier_squelettes_elements').'pagination',$donnees);
211
	}
212
 
213
 
214
	public function obtenirIdParMail($id_annuaire, $mail_utilisateur) {
215
 
216
		$this->chargerModele('AnnuaireModele');
217
		$id = $this->AnnuaireModele->obtenirIdParMail($id_annuaire, $mail_utilisateur);
218
 
219
		return $id;
220
	}
221
 
222
	public function utilisateurExiste($id_annuaire,$id, $utilise_mail = true) {
223
 
224
		$this->chargerModele('AnnuaireModele');
225
 
226
		if($utilise_mail) {
227
			$existe = $this->AnnuaireModele->utilisateurExisteParMail($id_annuaire,$id);
228
		} else {
229
			$existe = $this->AnnuaireModele->utilisateurExisteParId($id_annuaire,$id);
230
		}
231
 
232
		return $existe;
233
	}
234
 
213 aurelien 235
 
236
/** ---------------------------------	 Fonction de formatage de données communes aux classes ---------------------------------*/
237
 
238
	public static function formaterVersDateMysql($date) {
239
 
240
		$format = Config::get('date_format_simple');
241
 
242
		if(!isset($format)) {
243
			$format = 'd/m/Y';
244
		}
245
 
246
		$recherche = array('d','m','Y');
247
		$remplacement = array('([0-9]{1,2})','([0-9]{1,2})','([0-9]{4})');
248
 
249
		$pattern_date_simple = str_replace($recherche, $remplacement, $format);
120 aurelien 250
 
213 aurelien 251
		if(ereg($pattern_date_simple, $date)) {
252
			$date_tab = split('/', $date);
253
			$time = mktime(0,0,0,$date_tab[1],$date_tab[0],$date_tab[2]);
254
		} else {
255
			$time = strtotime($date);
256
		}
257
 
258
		return date('Y-m-d h:i:s', $time);
259
	}
260
 
261
	public static function formaterDateMysqlVersDateAnnuaire($date) {
262
 
263
		$format = Config::get('date_format_simple');
264
 
265
		if(!isset($format)) {
266
			$format = 'd/m/Y';
267
		}
268
 
269
		$time = strtotime($date);
270
		return date($format, $time);
271
	}
272
 
273
	public static function genererDateCouranteFormatMySql() {
274
		return date('Y-m-d h:i:s');
275
	}
217 aurelien 276
 
329 aurelien 277
	public static function genererDateCouranteFormatAnnuaire() {
278
		$date_mysql_courante = self::genererDateCouranteFormatMySql();
279
		return self::formaterDateMysqlVersDateAnnuaire($date_mysql_courante);
280
	}
281
 
294 aurelien 282
	public static function formaterMotPremiereLettreChaqueMotEnMajuscule($chaine) {
283
		$encodage = Config::get('appli_encodage');
284
 
285
		return str_replace(' - ', '-',
286
					mb_convert_case(
287
						mb_strtolower(
288
								str_replace('-', ' - ', $chaine),
289
								$encodage
290
						),
291
						MB_CASE_TITLE,
292
						$encodage
293
					)
294
				);
295
	}
296
 
297
	public static function formaterMotEnMajuscule($chaine) {
334 jpm 298
		return mb_convert_case($chaine, MB_CASE_UPPER, Config::get('appli_encodage'));
294 aurelien 299
	}
300
 
217 aurelien 301
	function aplatirTableauSansPreserverCles($tableau) {
302
 
303
	    $temp = array();
304
	    foreach ($tableau as $cle => $valeur) {
305
	        if (is_array($valeur)) {
306
	            $temp = array_merge($temp,$this->aplatirTableauSansPreserverCles($valeur));
307
	        } else {
308
	        	$temp[] = $valeur;
309
	        }
310
	    }
311
	    return $temp;
312
	}
213 aurelien 313
 
120 aurelien 314
/** ---------------------------------    Fonction d'extraction des champs de mappage -------------------------------------------*/
315
 
316
	/**
317
	 * Renvoie les champs de mappage correspondant à un annuaire donné
318
	 * @param int $id_annuaire l'indentifant de l'annuaire pour lequel on veut ces informations
319
	 * @return Array un tableau de mappage des champs
320
	 *
321
	 */
322
	protected function obtenirChampsMappageAnnuaire($id_annuaire) {
323
 
324
		$this->chargerModele('AnnuaireModele');
325
		$tableau_mappage = $this->AnnuaireModele->obtenirChampsMappageAnnuaire($id_annuaire);
326
 
327
		return $tableau_mappage;
328
	}
329
 
145 aurelien 330
	protected function obtenirNomsChampsMappageAnnuaire($id_annuaire) {
120 aurelien 331
 
145 aurelien 332
		$this->chargerModele('AnnuaireModele');
333
		$tableau_mappage = $this->AnnuaireModele->obtenirChampsMappageAnnuaire($id_annuaire);
334
 
335
		$this->chargerModele('MetadonneeModele');
336
		$metadonnees = $this->MetadonneeModele->chargerListeMetadonneeAnnuaire($id_annuaire);
337
 
338
		$tableau_nom_champs = array();
339
 
340
		foreach($metadonnees as $id_champ => $valeur) {
341
 
342
			// Si le champ fait partie des champs mappés
343
			$cle_champ_mappage = array_search($id_champ, $tableau_mappage[1]);
344
 
345
			if($cle_champ_mappage) {
346
				$tableau_nom_champs[$cle_champ_mappage] = $valeur['amc_abreviation'];
347
			}
348
		}
349
 
350
		return $tableau_nom_champs;
351
	}
352
 
353
 
354
 
355
 
120 aurelien 356
/** ---------------------------------    Fonction d'affichage des champs de metadonnées -------------------------------------------*/
357
 
358
	/**
359
	 * Charge et affiche le champ correspondant à la modification ou l'ajout d'un champ de metadonnée
360
	 * @param int $id_champ l'identifiant du champ demandé
361
	 * @return string la vue contenant le champ de formulaire correspondant
362
	 */
363
	public function afficherFormulaireChampMetadonnees($id_champ, $donnees) {
364
 
365
		// si le champ est restreint à une valeur de liste
366
		if($donnees['amc_ce_ontologie'] != 0) {
367
				$this->chargerModele('OntologieModele');
368
				$donnees['liste_valeurs'] = $this->OntologieModele->chargerListeOntologie($donnees['amc_ce_ontologie']);
369
		}
370
 
371
		$donnees['amc_id_champ'] = $id_champ;
372
 
373
		if(isset($donnees['amc_ce_template_affichage'])) {
374
			$nom_type_champ = $donnees['amc_ce_template_affichage'];
375
		} else {
376
			$this->chargerModele('MetadonneeModele');
377
			$nom_type_champ = $this->MetadonneeModele->renvoyerTypeAffichageParId($donnees['amc_ce_type_affichage']);
378
		}
379
 
380
		return $this->getVue(Config::get('dossier_squelettes_champs').$nom_type_champ,$donnees);
381
	}
382
 
383
 
213 aurelien 384
 
385
 
120 aurelien 386
/** ---------------------------------    Fonction d'existence et de génération des formulaires -------------------------------------------*/
387
 
213 aurelien 388
	public function annuaireAvoirFormulaireInscription($code_annuaire) {
389
		return $this->templateExiste($code_annuaire.'_inscription','formulaires/');
120 aurelien 390
	}
213 aurelien 391
 
392
	public function annuaireAvoirPageAccueilPostInscription($code_annuaire) {
393
		return $this->templateExiste($code_annuaire.'_inscription_confirmation', Config::get('dossier_squelettes_annuaires'));
394
	}
395
 
396
	public function annuaireAvoirFicheUtilisateur($code_annuaire) {
397
		return $this->templateExiste($code_annuaire.'_fiche','/fiches/');
398
	}
399
 
400
	public function annuaireAvoirFormulaireModificationInscription($code_annuaire) {
401
		return $this->templateExiste($code_annuaire.'_modification','/formulaires/');
402
	}
403
 
404
	public function annuaireAvoirPagePostDesinscription($code_annuaire) {
405
		return $this->templateExiste($code_annuaire.'_desinscription_confirmation','/annuaires/');
406
	}
407
 
408
	public function annuaireAvoirFormulaireRecherche($code_annuaire) {
409
		return $this->templateExiste($code_annuaire.'_recherche','/formulaires/');
410
	}
411
 
412
	public function annuaireAvoirPageResultatRecherche($code_annuaire) {
413
		return $this->templateExiste($code_annuaire.'_resultat_recherche', Config::get('dossier_squelettes_annuaires'));
414
	}
415
 
120 aurelien 416
	/**
213 aurelien 417
	 * Renvoie true si le template demandé existe, sinon faux
120 aurelien 418
	 * @param string $nom_formulaire le nom du formulaire demandé (qui est normalement le code d'un annuaire)
419
	 * @param string $dossier le nom du dossier sous dossier demandé
420
	 * @return boolean true si le formulaire existe, false sinon
421
	 */
422
	protected function templateExiste($nom_template, $dossier = '/') {
182 aurelien 423
 
120 aurelien 424
		return file_exists(Config::get('chemin_squelettes').$dossier.$nom_template.'.tpl.html');
425
	}
426
 
145 aurelien 427
 
428
	/**
429
	 * Renvoie une fiche utilisateur minimale auto-générée
430
	 * @param string $donnees les données à inclure dans le formulaire
431
	 * @return string la vue contenant le formulaire généré
432
	 */
433
	protected function genererFicheInscrit($donnees) {
120 aurelien 434
 
145 aurelien 435
		$formulaire_modele = $this->getVue(Config::get('dossier_squelettes_fiches').'fiche',$donnees);
436
 
437
		if($formulaire_modele) {
438
			return $formulaire_modele;
439
		} else {
440
			trigger_error("impossible de trouver le squelette de référence pour le formulaire");
441
		}
442
 
443
		return false;
444
	}
445
 
120 aurelien 446
	/**
447
	 * Renvoie un formulaire d'inscription minimal auto-généré
448
	 * @param string $donnees les donnée à inclure dans le formulaire
449
	 * @return string la vue contenant le formulaire généré
450
	 */
451
	protected function genererFormulaireInscription($donnees) {
452
 
453
		$formulaire_modele = $this->getVue(Config::get('dossier_squelettes_formulaires').'inscription',$donnees);
454
 
455
		if($formulaire_modele) {
456
			return $formulaire_modele;
457
		} else {
458
			trigger_error("impossible de trouver le squelette de référence pour le formulaire");
459
		}
460
 
461
		return false;
462
	}
145 aurelien 463
 
464
	/**
465
	 * Renvoie un formulaire d'inscription minimal auto-généré
466
	 * @param string $donnees les donnée à inclure dans le formulaire
467
	 * @return string la vue contenant le formulaire généré
468
	 */
469
	protected function genererFormulaireModificationInscription($donnees) {
120 aurelien 470
 
145 aurelien 471
		$formulaire_modele = $this->getVue(Config::get('dossier_squelettes_formulaires').'modification',$donnees);
472
 
473
		if($formulaire_modele) {
474
			return $formulaire_modele;
475
		} else {
476
			trigger_error("impossible de trouver le squelette de référence pour le formulaire");
477
		}
478
 
479
		return false;
480
	}
481
 
120 aurelien 482
	/**
483
	 * Renvoie un formulaire d'inscription minimal auto-généré
484
	 * @param string $donnees les donnée à inclure dans le formulaire
485
	 * @return string la vue contenant le formulaire généré
486
	 */
487
	protected function genererFormulaireRecherche($donnees) {
488
 
489
		$formulaire_modele = $this->getVue(Config::get('dossier_squelettes_formulaires').'recherche',$donnees);
490
 
491
		if($formulaire_modele) {
492
			return $formulaire_modele;
493
		} else {
494
			trigger_error("impossible de trouver le squelette de référence pour le formulaire");
495
		}
496
 
497
		return false;
498
	}
499
 
500
/** ---------------------------------    Fonction d'extraction d'informations utilisées entre autres par les web services -------------------------------------------*/
501
 
502
	public function obtenirValeursUtilisateur($id_annuaire, $id_utilisateur) {
503
 
504
		$this->chargerModele('AnnuaireModele');
505
		$annuaire = $this->AnnuaireModele->chargerAnnuaire($id_annuaire, false);
506
 
507
		$this->chargerModele('MetadonneeModele');
508
 
509
		$metadonnees = $this->MetadonneeModele->chargerListeMetadonneeAnnuaire($id_annuaire);
510
		$tableau_mappage = $this->obtenirChampsMappageAnnuaire($id_annuaire);
511
 
512
		$valeurs_annuaire = $this->AnnuaireModele->obtenirValeursUtilisateur($id_annuaire, $id_utilisateur,$tableau_mappage[0]);
513
		$valeurs_metadonnees= $this->MetadonneeModele->chargerListeValeursMetadonneesUtilisateur($id_annuaire, $id_utilisateur);
514
 
515
		foreach($tableau_mappage[0] as $cle => $nom_champ) {
516
 
517
			if($cle != 'champ_id') {
518
 
519
				$nom_champ_formulaire = $metadonnees[$tableau_mappage[1][$cle]]['amc_abreviation'];
294 aurelien 520
				$valeur = $valeurs_annuaire[$nom_champ] ;
120 aurelien 521
 
294 aurelien 522
				if($cle == 'champ_nom') {
523
					$valeur = AppControleur::formaterMotEnMajuscule($valeur);
524
				}
525
 
526
				if($cle == 'champ_prenom') {
527
					 $valeur = AppControleur::formaterMotPremiereLettreChaqueMotEnMajuscule($valeur);
528
				}
529
 
120 aurelien 530
				if(isset($valeurs_metadonnees[$nom_champ_formulaire])) {
531
					if(isset($valeurs_metadonnees[$nom_champ_formulaire]['amv_valeur']) && $valeurs_metadonnees[$nom_champ_formulaire]['amv_valeur'] != '') {
532
						$valeur = $valeurs_metadonnees[$nom_champ_formulaire]['amv_valeur'];
533
					}
534
					$informations_champ = array('amv_valeur' => $valeur,'amc_id_champ' => $tableau_mappage[1][$cle]) ;
535
					$valeurs_metadonnees[$nom_champ_formulaire] = array_merge($valeurs_metadonnees[$nom_champ_formulaire],$informations_champ);
536
				} else {
537
					$informations_champ = array('amv_valeur' => $valeur,'amc_id_champ' => $tableau_mappage[1][$cle]) ;
538
					$valeurs_metadonnees[$nom_champ_formulaire] = $informations_champ;
539
				}
540
			}
541
		}
542
 
543
		foreach($valeurs_metadonnees as $nom_champ => $valeur) {
544
			$verificateur = new VerificationControleur();
545
			$valeurs_metadonnees[$nom_champ] = $verificateur->verifierEtRemplacerValeurChampPourAffichage($valeur['amc_ce_type_affichage'],$valeur, 1);
546
		}
547
 
548
		return $valeurs_metadonnees;
549
	}
550
 
329 aurelien 551
	public function obtenirInfosUtilisateur($id_annuaire,$id, $mail = true) {
120 aurelien 552
 
553
		$this->chargerModele('AnnuaireModele');
554
 
555
		if($mail) {
556
			$id = $this->AnnuaireModele->obtenirIdParMail($id_annuaire,$id);
557
		}
558
 
559
		$champs_mappage = $this->AnnuaireModele->obtenirChampsMappageAnnuaire($id_annuaire);
560
 
561
		$valeurs = $this->AnnuaireModele->obtenirValeursUtilisateur($id_annuaire,$id, $champs_mappage[0]);
562
 
563
		// TODO: valeurs incomplètes, voir ce qu'on renvoie obligatoirement
564
		// et ce qu'on ne renvoie pas
339 aurelien 565
		$valeurs = array('fullname' => $valeurs[$champs_mappage[0]['champ_prenom']].' '.$valeurs[$champs_mappage[0]['champ_nom']],
120 aurelien 566
                           'nickname' => $valeurs[$champs_mappage[0]['champ_nom']],
213 aurelien 567
                           'dob' => '',
120 aurelien 568
                           'email' => $valeurs[$champs_mappage[0]['champ_mail']],
329 aurelien 569
                           'gender' => '',
120 aurelien 570
                           'postcode' => $valeurs[$champs_mappage[0]['champ_code_postal']],
329 aurelien 571
                           'country' => '',
120 aurelien 572
                           'language' => 'fr',
573
                           'timezone' => 'Europe/Paris');
574
 
329 aurelien 575
		return $valeurs;
120 aurelien 576
	}
577
 
578
	public function comparerIdentifiantMotDePasse($id_annuaire,$id_utilisateur,$mot_de_passe, $utilise_mail = true, $mdp_deja_crypte = true) {
579
 
580
		$this->chargerModele('AnnuaireModele');
581
 
582
		if($utilise_mail) {
583
			$id_utilisateur = $this->AnnuaireModele->obtenirIdParMail($id_annuaire,$id_utilisateur);
584
		}
585
 
586
		if(!$mdp_deja_crypte) {
587
			$mot_de_passe = VerificationControleur::encrypterMotDePasseStatic($mot_de_passe);
588
		}
589
 
590
		return $this->AnnuaireModele->comparerIdentifiantMotDePasse($id_annuaire,$id_utilisateur,$mot_de_passe);
591
	}
592
 
294 aurelien 593
}
594
 
595
?>