Subversion Repositories Applications.annuaire

Rev

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