Subversion Repositories Applications.annuaire

Rev

Rev 143 | Rev 182 | 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
 
145 aurelien 35
		$base_vrai_chemin = str_replace(realpath($_SERVER['DOCUMENT_ROOT']),'',realpath(Application::getChemin()));
36
		$base_vrai_chemin .= '/';
37
 
38
		$donnees['base_url_styles'] = new Url($base_vrai_chemin);
39
 
120 aurelien 40
		$donnees['url_cette_page'] = $_SERVER['SERVER_NAME'].$_SERVER['REQUEST_URI'];
145 aurelien 41
 
42
		$this->chargerModele('AnnuaireModele');
120 aurelien 43
 
44
		//ajout des variables d'identification
45
		$donnees['est_admin'] = Registre::getInstance()->get('est_admin');
46
		$donnees['identification_id'] =	Registre::getInstance()->get('identification_id');
47
		$donnees['identification_mail']	= Registre::getInstance()->get('identification_mail');
143 aurelien 48
 
49
		$format = Config::get('date_format_simple');
50
 
51
		if($format) {
52
			$donnees['format_date_simple'] = $format;
53
		} else {
54
			$donnees['format_date_simple'] = 'd/m/Y';
55
		}
120 aurelien 56
 
57
		return $donnees;
58
	}
59
 
60
	/**
61
	 * Renvoie le template de pagination, considérant des éléments donnés en paramètre
62
	 * @param int $numero_page le numéro de page en cours
63
	 * @param int $taille_page la taille de page
64
	 * @param int $total le nombre total de pages
65
	 * @param object $url_base l'url de base de la page
66
	 * @param array $valeurs les valeurs à concatener à l'url
67
	 * @return string le html contenu la template de pagination rempli avec les infos
68
	 */
69
	protected function paginer($numero_page = 1, $taille_page = 50, $total, $url_base, $valeurs) {
70
 
71
		// TODO, faire plus complexe, tri alphabétique etc...
72
		$page_precedente = $numero_page-1;
73
		$page_suivante = $numero_page+1;
74
 
75
		if($taille_page <= 0) {
76
			$taille_page = 1;
77
		}
78
 
79
		$nombre_pages = round($total/$taille_page,'PHP_ROUND_HALF_DOWN') ;
80
 
81
		foreach($valeurs as $cle => $variable) {
82
			$url_base->setVariableRequete($cle,$variable);
83
		}
84
 
85
		if($numero_page < 2) {
86
			$page_precedente = false;
87
			$url_page_precedente = '';
88
		} else {
89
			$url_page_prec = clone($url_base);
90
				$url_page_prec->setVariableRequete('numero_page',($page_precedente));
91
				$url_page_prec->setVariableRequete('taille_page',($taille_page));
92
				$url_page_precedente = $url_page_prec->getUrl();
93
		}
94
 
95
		if($taille_page*($numero_page) >= $total) {
96
			$page_suivante = false;
97
			$url_page_suivante = '';
98
		} else {
99
			$url_page_suiv = clone($url_base);
100
				$url_page_suiv->setVariableRequete('numero_page',($page_suivante));
101
				$url_page_suiv->setVariableRequete('taille_page',($taille_page));
102
				$url_page_suivante = $url_page_suiv->getUrl();
103
		}
104
 
105
		$url_pages = array();
106
 
107
		for($i = 1; $i <= $nombre_pages ; $i++) {
108
 
109
				$url_page_prev = clone($url_base);
110
				$url_page_prev->setVariableRequete('numero_page',($i));
111
				$url_page_prev->setVariableRequete('taille_page',($taille_page));
112
				$url_pages[$i] = $url_page_prev->getUrl();
113
		}
114
 
115
		$donnees = array('url_pages' => $url_pages, 'numero_page' => $numero_page,
116
							'page_precedente' => $page_precedente, 'page_suivante' => $page_suivante,
117
							'url_page_precedente' => $url_page_precedente, 'url_page_suivante' => $url_page_suivante,
118
							'nombre_pages' => $nombre_pages, 'taille_page' => $taille_page);
119
		$donnees['base_url_pagination'] = $url_base;
120
 
121
		return $this->getVue(Config::get('dossier_squelettes_elements').'pagination',$donnees);
122
	}
123
 
124
 
125
	public function obtenirIdParMail($id_annuaire, $mail_utilisateur) {
126
 
127
		$this->chargerModele('AnnuaireModele');
128
		$id = $this->AnnuaireModele->obtenirIdParMail($id_annuaire, $mail_utilisateur);
129
 
130
		return $id;
131
	}
132
 
133
	public function utilisateurExiste($id_annuaire,$id, $utilise_mail = true) {
134
 
135
		$this->chargerModele('AnnuaireModele');
136
 
137
		if($utilise_mail) {
138
			$existe = $this->AnnuaireModele->utilisateurExisteParMail($id_annuaire,$id);
139
		} else {
140
			$existe = $this->AnnuaireModele->utilisateurExisteParId($id_annuaire,$id);
141
		}
142
 
143
		return $existe;
144
	}
145
 
146
 
147
/** ---------------------------------    Fonction d'extraction des champs de mappage -------------------------------------------*/
148
 
149
	/**
150
	 * Renvoie les champs de mappage correspondant à un annuaire donné
151
	 * @param int $id_annuaire l'indentifant de l'annuaire pour lequel on veut ces informations
152
	 * @return Array un tableau de mappage des champs
153
	 *
154
	 */
155
	protected function obtenirChampsMappageAnnuaire($id_annuaire) {
156
 
157
		$this->chargerModele('AnnuaireModele');
158
		$tableau_mappage = $this->AnnuaireModele->obtenirChampsMappageAnnuaire($id_annuaire);
159
 
160
		return $tableau_mappage;
161
	}
162
 
145 aurelien 163
	protected function obtenirNomsChampsMappageAnnuaire($id_annuaire) {
120 aurelien 164
 
145 aurelien 165
		$this->chargerModele('AnnuaireModele');
166
		$tableau_mappage = $this->AnnuaireModele->obtenirChampsMappageAnnuaire($id_annuaire);
167
 
168
		$this->chargerModele('MetadonneeModele');
169
		$metadonnees = $this->MetadonneeModele->chargerListeMetadonneeAnnuaire($id_annuaire);
170
 
171
		$tableau_nom_champs = array();
172
 
173
		foreach($metadonnees as $id_champ => $valeur) {
174
 
175
			// Si le champ fait partie des champs mappés
176
			$cle_champ_mappage = array_search($id_champ, $tableau_mappage[1]);
177
 
178
			if($cle_champ_mappage) {
179
				$tableau_nom_champs[$cle_champ_mappage] = $valeur['amc_abreviation'];
180
			}
181
		}
182
 
183
		return $tableau_nom_champs;
184
	}
185
 
186
 
187
 
188
 
120 aurelien 189
/** ---------------------------------    Fonction d'affichage des champs de metadonnées -------------------------------------------*/
190
 
191
	/**
192
	 * Charge et affiche le champ correspondant à la modification ou l'ajout d'un champ de metadonnée
193
	 * @param int $id_champ l'identifiant du champ demandé
194
	 * @return string la vue contenant le champ de formulaire correspondant
195
	 */
196
	public function afficherFormulaireChampMetadonnees($id_champ, $donnees) {
197
 
198
		// si le champ est restreint à une valeur de liste
199
		if($donnees['amc_ce_ontologie'] != 0) {
200
				$this->chargerModele('OntologieModele');
201
				$donnees['liste_valeurs'] = $this->OntologieModele->chargerListeOntologie($donnees['amc_ce_ontologie']);
202
		}
203
 
204
		$donnees['amc_id_champ'] = $id_champ;
205
 
206
		if(isset($donnees['amc_ce_template_affichage'])) {
207
			$nom_type_champ = $donnees['amc_ce_template_affichage'];
208
		} else {
209
			$this->chargerModele('MetadonneeModele');
210
			$nom_type_champ = $this->MetadonneeModele->renvoyerTypeAffichageParId($donnees['amc_ce_type_affichage']);
211
		}
212
 
213
		return $this->getVue(Config::get('dossier_squelettes_champs').$nom_type_champ,$donnees);
214
	}
215
 
216
 
217
/** ---------------------------------    Fonction d'existence et de génération des formulaires -------------------------------------------*/
218
 
219
	/**
220
	 * Renvoie le formulaire demandé s'il existe, sinon faux
221
	 * @param string $nom_formulaire le nom du formulaire demandé (qui est normalement le code d'un annuaire)
222
	 * @return boolean true si le formulaire existe, false sinon
223
	 */
224
	protected function formulaireExiste($nom_formulaire) {
225
 
226
		return $this->templateExiste($nom_formulaire.'_inscription', Config::get('dossier_squelettes_formulaires'));
227
	}
228
 
229
	/**
230
	 * Renvoie le template demandé s'il existe, sinon faux
231
	 * @param string $nom_formulaire le nom du formulaire demandé (qui est normalement le code d'un annuaire)
232
	 * @param string $dossier le nom du dossier sous dossier demandé
233
	 * @return boolean true si le formulaire existe, false sinon
234
	 */
235
	protected function templateExiste($nom_template, $dossier = '/') {
236
 
237
		return file_exists(Config::get('chemin_squelettes').$dossier.$nom_template.'.tpl.html');
238
	}
239
 
145 aurelien 240
 
241
	/**
242
	 * Renvoie une fiche utilisateur minimale auto-générée
243
	 * @param string $donnees les données à inclure dans le formulaire
244
	 * @return string la vue contenant le formulaire généré
245
	 */
246
	protected function genererFicheInscrit($donnees) {
120 aurelien 247
 
145 aurelien 248
		$formulaire_modele = $this->getVue(Config::get('dossier_squelettes_fiches').'fiche',$donnees);
249
 
250
		if($formulaire_modele) {
251
			return $formulaire_modele;
252
		} else {
253
			trigger_error("impossible de trouver le squelette de référence pour le formulaire");
254
		}
255
 
256
		return false;
257
	}
258
 
120 aurelien 259
	/**
260
	 * Renvoie un formulaire d'inscription minimal auto-généré
261
	 * @param string $donnees les donnée à inclure dans le formulaire
262
	 * @return string la vue contenant le formulaire généré
263
	 */
264
	protected function genererFormulaireInscription($donnees) {
265
 
266
		$formulaire_modele = $this->getVue(Config::get('dossier_squelettes_formulaires').'inscription',$donnees);
267
 
268
		if($formulaire_modele) {
269
			return $formulaire_modele;
270
		} else {
271
			trigger_error("impossible de trouver le squelette de référence pour le formulaire");
272
		}
273
 
274
		return false;
275
	}
145 aurelien 276
 
277
	/**
278
	 * Renvoie un formulaire d'inscription minimal auto-généré
279
	 * @param string $donnees les donnée à inclure dans le formulaire
280
	 * @return string la vue contenant le formulaire généré
281
	 */
282
	protected function genererFormulaireModificationInscription($donnees) {
120 aurelien 283
 
145 aurelien 284
		$formulaire_modele = $this->getVue(Config::get('dossier_squelettes_formulaires').'modification',$donnees);
285
 
286
		if($formulaire_modele) {
287
			return $formulaire_modele;
288
		} else {
289
			trigger_error("impossible de trouver le squelette de référence pour le formulaire");
290
		}
291
 
292
		return false;
293
	}
294
 
120 aurelien 295
	/**
296
	 * Renvoie un formulaire d'inscription minimal auto-généré
297
	 * @param string $donnees les donnée à inclure dans le formulaire
298
	 * @return string la vue contenant le formulaire généré
299
	 */
300
	protected function genererFormulaireRecherche($donnees) {
301
 
302
		$formulaire_modele = $this->getVue(Config::get('dossier_squelettes_formulaires').'recherche',$donnees);
303
 
304
		if($formulaire_modele) {
305
			return $formulaire_modele;
306
		} else {
307
			trigger_error("impossible de trouver le squelette de référence pour le formulaire");
308
		}
309
 
310
		return false;
311
	}
312
 
313
/** ---------------------------------    Fonction d'extraction d'informations utilisées entre autres par les web services -------------------------------------------*/
314
 
315
	public function obtenirValeursUtilisateur($id_annuaire, $id_utilisateur) {
316
 
317
		$this->chargerModele('AnnuaireModele');
318
		$annuaire = $this->AnnuaireModele->chargerAnnuaire($id_annuaire, false);
319
 
320
		$this->chargerModele('MetadonneeModele');
321
 
322
		$metadonnees = $this->MetadonneeModele->chargerListeMetadonneeAnnuaire($id_annuaire);
323
		$tableau_mappage = $this->obtenirChampsMappageAnnuaire($id_annuaire);
324
 
325
		$valeurs_annuaire = $this->AnnuaireModele->obtenirValeursUtilisateur($id_annuaire, $id_utilisateur,$tableau_mappage[0]);
326
		$valeurs_metadonnees= $this->MetadonneeModele->chargerListeValeursMetadonneesUtilisateur($id_annuaire, $id_utilisateur);
327
 
328
		foreach($tableau_mappage[0] as $cle => $nom_champ) {
329
 
330
			if($cle != 'champ_id') {
331
 
332
				$nom_champ_formulaire = $metadonnees[$tableau_mappage[1][$cle]]['amc_abreviation'];
333
				$valeur = $valeurs_annuaire[$nom_champ] ;
334
 
335
				if(isset($valeurs_metadonnees[$nom_champ_formulaire])) {
336
					if(isset($valeurs_metadonnees[$nom_champ_formulaire]['amv_valeur']) && $valeurs_metadonnees[$nom_champ_formulaire]['amv_valeur'] != '') {
337
						$valeur = $valeurs_metadonnees[$nom_champ_formulaire]['amv_valeur'];
338
					}
339
					$informations_champ = array('amv_valeur' => $valeur,'amc_id_champ' => $tableau_mappage[1][$cle]) ;
340
					$valeurs_metadonnees[$nom_champ_formulaire] = array_merge($valeurs_metadonnees[$nom_champ_formulaire],$informations_champ);
341
				} else {
342
					$informations_champ = array('amv_valeur' => $valeur,'amc_id_champ' => $tableau_mappage[1][$cle]) ;
343
					$valeurs_metadonnees[$nom_champ_formulaire] = $informations_champ;
344
				}
345
			}
346
		}
347
 
348
		foreach($valeurs_metadonnees as $nom_champ => $valeur) {
349
			$verificateur = new VerificationControleur();
350
			$valeurs_metadonnees[$nom_champ] = $verificateur->verifierEtRemplacerValeurChampPourAffichage($valeur['amc_ce_type_affichage'],$valeur, 1);
351
		}
352
 
353
		return $valeurs_metadonnees;
354
	}
355
 
356
	public function obtenirInfosUtilisateurOpenId($id_annuaire,$id, $mail = true) {
357
 
358
		$this->chargerModele('AnnuaireModele');
359
 
360
		if($mail) {
361
			$id = $this->AnnuaireModele->obtenirIdParMail($id_annuaire,$id);
362
		}
363
 
364
		$champs_mappage = $this->AnnuaireModele->obtenirChampsMappageAnnuaire($id_annuaire);
365
 
366
		$valeurs = $this->AnnuaireModele->obtenirValeursUtilisateur($id_annuaire,$id, $champs_mappage[0]);
367
 
368
		// TODO: valeurs incomplètes, voir ce qu'on renvoie obligatoirement
369
		// et ce qu'on ne renvoie pas
370
		$valeurs_open_id = array('fullname' => $valeurs[$champs_mappage[0]['champ_nom']].' '.$valeurs[$champs_mappage[0]['champ_prenom']],
371
                           'nickname' => $valeurs[$champs_mappage[0]['champ_nom']],
372
                           'dob' => '25/10/1984',
373
                           'email' => $valeurs[$champs_mappage[0]['champ_mail']],
374
                           'gender' => 'M',
375
                           'postcode' => $valeurs[$champs_mappage[0]['champ_code_postal']],
376
                           'country' => 'FR',
377
                           'language' => 'fr',
378
                           'timezone' => 'Europe/Paris');
379
 
380
		return $valeurs_open_id;
381
	}
382
 
383
	public function comparerIdentifiantMotDePasse($id_annuaire,$id_utilisateur,$mot_de_passe, $utilise_mail = true, $mdp_deja_crypte = true) {
384
 
385
		$this->chargerModele('AnnuaireModele');
386
 
387
		if($utilise_mail) {
388
			$id_utilisateur = $this->AnnuaireModele->obtenirIdParMail($id_annuaire,$id_utilisateur);
389
		}
390
 
391
		if(!$mdp_deja_crypte) {
392
			$mot_de_passe = VerificationControleur::encrypterMotDePasseStatic($mot_de_passe);
393
		}
394
 
395
		return $this->AnnuaireModele->comparerIdentifiantMotDePasse($id_annuaire,$id_utilisateur,$mot_de_passe);
396
	}
397
 
398
}