Subversion Repositories Applications.annuaire

Rev

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