Subversion Repositories Applications.annuaire

Rev

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