Subversion Repositories Applications.referentiel

Rev

Rev 399 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
6 jpm 1
<?php
2
// declare(encoding='UTF-8');
3
/**
4
 * Classe Controleur générale partagée par les différents modules de l'application.
5
 *
6
 * @package		Referentiel
7
 * @category	Php5.2
8
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
9
 * @copyright	2010 Tela-Botanica
10
 * @license		http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
11
 * @license		http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
12
 * @version		SVN: $Id$
13
 */
14
abstract class AppliControleur extends Controleur {
15
 
16
	const RENDU_TETE = 'tete';
17
	const RENDU_CORPS = 'corps';
18
	const RENDU_PIED = 'pied';
37 jpm 19
	const RENDU_NAVIGATION = 'navigation';
20
	const RENDU_MENU = 'menu';
6 jpm 21
 
22
	// FIXME : voir s'il est plus intéressant d'utiliser une méthode dans les classes filles
23
	protected $url = null;
26 jpm 24
	private $parametres = array();
46 jpm 25
	protected $manuel = null;
26 jpm 26
	private $sortie = array();
27
	private $messages = null;
6 jpm 28
 
26 jpm 29
	//+----------------------------------------------------------------------------------------------------------------+
30
	// Constructeur
31
 
6 jpm 32
	public function __construct()  {
33
		$registre = Registre::getInstance();
34
		$this->parametres = $registre->get('parametres');
35
		$this->url = $this->parametres['url'];
46 jpm 36
		// Chargement des infos du manuel technique des référentiels
203 delphine 37
		$this->manuel = parse_ini_file(Config::get('chemin_appli').DS.'..'.DS.'configurations'.DS.Config::get('manuel'));
6 jpm 38
		parent::__construct();
39
	}
40
 
26 jpm 41
	//+----------------------------------------------------------------------------------------------------------------+
42
	// Accesseurs
43
 
6 jpm 44
	/**
26 jpm 45
	 * Retourne le tableau de sortie à utiliser dans le controleur principal de l'application.
46
	 */
47
	public function getSortie() {
48
		return $this->sortie;
49
	}
50
 
51
	/**
6 jpm 52
	 * Attribue à la bonne position de sortie un contenu.
53
	 */
54
	protected function setSortie($position, $contenu, $fusionner = false) {
55
		if ($this->verifierExistencePosition($position)) {
56
			if ($fusionner) {
57
				$this->sortie[$position] .= $contenu;
58
			} else {
59
				$this->sortie[$position] = $contenu;
60
			}
61
		}
62
	}
63
 
64
	/**
26 jpm 65
	 * Retourne le tableau des messages
66
	 */
67
	protected function getMessages() {
68
		return $this->messages;
69
	}
70
	/**
71
	 * Ajoute un message
72
	 */
73
	protected function addMessage($message) {
74
		if ('' != $message) {
75
			$this->messages[] = $message;
76
		}
77
	}
78
 
79
 
80
	//+----------------------------------------------------------------------------------------------------------------+
81
	// Méthodes
82
 
83
	/**
6 jpm 84
	 * Vérifie l'existence de la position indiquée pour son utilisation dans le tableau de sortie.
85
	 * @param string la position à tester.
86
	 * @return bool true si la position est valide, sinon false.
87
	 */
88
	private function verifierExistencePosition($position) {
89
		$existe = true;
90
		if ($position != self::RENDU_TETE &&
91
			$position != self::RENDU_CORPS &&
37 jpm 92
			$position != self::RENDU_PIED &&
93
			$position != self::RENDU_NAVIGATION &&
94
			$position != self::RENDU_MENU) {
6 jpm 95
			trigger_error("La position '$position' n'est pas une valeur prédéfinie.", E_USER_WARNING);
96
			$existe = false;
97
		}
98
		return $existe;
99
	}
100
 
101
	/**
102
	 * Execute l'action d'un module donnée et fusionne le résultat avec le tableau de sortie.
103
	 */
104
	protected function executerAction($ClasseModule, $action) {
105
		$module = new $ClasseModule();
106
		$module->$action();
107
		$this->fusionnerSortie($module->getSortie());
70 delphine 108
	}
109
 
134 delphine 110
	protected function executerActionReferentiel($ClasseModule, $action, $referentiel, $afficheMoteur = null) {
70 delphine 111
		$module = new $ClasseModule();
134 delphine 112
		$module->$action($referentiel, $afficheMoteur);
70 delphine 113
		$this->fusionnerSortie($module->getSortie());
6 jpm 114
 
115
	}
116
 
117
	/**
118
	 * Fusionne un tableau de sortie par défaut avec le tableau passé en paramêtre.
119
	 * @param array le tableau à fusionner
120
	 */
121
	private function fusionnerSortie($sortie) {
122
		$this->sortie = array_merge($this->sortie, $sortie);
123
	}
124
 
125
	protected function postraiterDonnees(&$tableau) {
126
		if (count($tableau) > 0) {
127
			foreach ($tableau as $cle => &$valeur) {
128
				if ($valeur == '') {
129
					$valeur = '&nbsp;';
130
				} else if (is_string($valeur)) {
33 jpm 131
					$valeur = $this->remplacerEsperluette($valeur);
6 jpm 132
				} else if (is_array($valeur)) {
133
					$this->postraiterDonnees($valeur);
134
				}
135
			}
136
		}
137
	}
33 jpm 138
 
139
	protected function traiterEsperluette(&$tableau) {
140
		if (count($tableau) > 0) {
141
			foreach ($tableau as $cle => &$valeur) {
142
				if (is_string($valeur)) {
143
					$valeur = $this->remplacerEsperluette($valeur);
144
				} else if (is_array($valeur)) {
145
					$this->traiterEsperluette($valeur);
146
				}
147
			}
148
		}
149
	}
150
 
57 jpm 151
	protected function remplacerEsperluette($txt) {
33 jpm 152
		$txt = preg_replace('/&(?!([a-z]+|#[0-9]+|#x[0-9a-f]+);)/i', '&amp;', $txt, -1);
153
		return $txt;
154
	}
45 jpm 155
 
57 jpm 156
	protected function supprimerSlash($doc) {
157
		if (is_string($doc)) {
158
			$doc = stripslashes($doc);
58 jpm 159
		} else if (is_array($doc) && count($doc) > 0) {
160
			foreach ($doc as $cle => $valeur) {
161
				$doc[$cle] = $this->supprimerSlash($valeur);
57 jpm 162
			}
163
		}
164
		return $doc;
165
	}
166
 
45 jpm 167
	protected function initialiserModulePrincipal() {
399 killian 168
		$GLOBALS['module_principal'] = null;
45 jpm 169
	}
170
 
171
	protected function definirCommeModulePrincipal($module_nom) {
399 killian 172
		$GLOBALS['module_principal'] = $module_nom;
45 jpm 173
	}
174
 
175
	private function getModulePrincipalCourant() {
400 killian 176
		if (array_key_exists('module_principal', $GLOBALS)) {
177
			return $GLOBALS['module_principal'];
178
		}
45 jpm 179
	}
180
 
37 jpm 181
	/**
182
	 * Construction du menu et stockage dans le conteneur de sortie RENDU_MENU.
183
	 *
184
	 * @param string $referentiel code du référentiel.
185
	 */
186
	protected function construireMenu($referentiel) {
187
		$menu['nom'] = 'Accueil';
47 jpm 188
		$menu['url'] = $this->obtenirUrlMenuAccueil();
271 delphine 189
		$menu['activite'] = (($this->getModulePrincipalCourant() == 'Accueil') ? 'actif' : 'inactif');
190
		$menu['title'] = "Liste des référentiels consultables.";
37 jpm 191
		$donnees['menus'][] = $menu;
271 delphine 192
		$menu['nom'] = 'Consultation';
193
		$menu['url'] = $this->obtenirUrlMenuConsultation($referentiel);
194
		$menu['activite'] = ((preg_match('/^(?:Consultation|Recherche|FicheTaxon)$/', $this->getModulePrincipalCourant())) ? 'actif' : 'inactif');
195
		$menu['title'] = "Interroger la base en cours de travail.";
196
		$donnees['menus'][] = $menu;
300 aurelien 197
		$menu['nom'] = 'Arbre taxo';
295 aurelien 198
		$menu['url'] = $this->obtenirUrlMenuArbre($referentiel);
199
		$menu['activite'] = (($this->getModulePrincipalCourant() == 'Arbre') ? 'actif' : 'inactif');
200
		$menu['title'] = "Consulter l'aborescence du référentiel";
201
		$donnees['menus'][] = $menu;
37 jpm 202
		$menu['nom'] = 'Tests';
203
		$menu['url'] = $this->obtenirUrlMenuTest($referentiel);
271 delphine 204
		$menu['activite'] = (($this->getModulePrincipalCourant() == 'Test') ? 'actif' : 'inactif securise');
205
		$menu['title'] = "Réservé aux coordinateurs. Contrôler les données saisies.";
37 jpm 206
		$donnees['menus'][] = $menu;
207
		$menu['nom'] = 'Versionnage';
208
		$menu['url'] = $this->obtenirUrlMenuVersionnage($referentiel);
271 delphine 209
		$menu['activite'] = (($this->getModulePrincipalCourant() == 'Versionnage') ? 'actif' : 'inactif securise');
272 delphine 210
		$menu['title'] = "Réservé aux coordinateurs. Générer une version de la base.";
37 jpm 211
		$donnees['menus'][] = $menu;
276 aurelien 212
		$menu['nom'] = 'Informations et téléchargements';
271 delphine 213
		$menu['url'] = $this->obtenirUrlMenuInformations($referentiel);
214
		$menu['activite'] = (($this->getModulePrincipalCourant() == 'Informations') ? 'actif' : 'inactif');
276 aurelien 215
		$menu['title'] = "Informations sur le projet et téléchargements.";
37 jpm 216
		$donnees['menus'][] = $menu;
217
		$this->setSortie(self::RENDU_MENU, $this->getVue('menu', $donnees), false);
218
	}
219
	/**
220
	 * Construction du fil d'ariane et stockage dans le conteneur de sortie RENDU_NAVIGATION.
221
	 *
222
	 * @param $referentiel code du référentiel
223
	 * @param $id_traitement id du traitement
224
	 * @param $id_resultat id du résultat
225
	 */
226
	protected function construireFilAriane($referentiel = null, $id_traitement = null, $id_resultat = null) {
227
		$entree['nom'] = 'Accueil';
228
		$entree['url'] = $this->obtenirUrlMenuAccueil();
229
		$donnees['entrees'][] = $entree;
230
 
231
		if (isset($referentiel)) {
271 delphine 232
			$entree['nom'] = 'Informations '.strtoupper($referentiel);
37 jpm 233
			$entree['url'] = $this->obtenirUrlDetailReferentiel($referentiel);
234
			$donnees['entrees'][] = $entree;
235
 
45 jpm 236
			$module_principal = $this->getModulePrincipalCourant();
237
			if (isset($module_principal)) {
238
				$entree['nom'] = $module_principal;
239
				$entree['url'] = $this->obtenirUrlMenu($module_principal, $referentiel);
37 jpm 240
				$donnees['entrees'][] = $entree;
241
			}
242
 
243
			if (isset($id_traitement)) {
244
				$entree['nom'] = "Traitement #$id_traitement";
245
				$entree['url'] = $this->obtenirUrlFicheTraitement($referentiel, $id_traitement);
246
				$donnees['entrees'][] = $entree;
247
			}
248
 
249
			if (isset($id_resultat)) {
250
				$entree['nom'] = "Résultat #$id_resultat";
251
				$entree['url'] = $this->obtenirUrlFicheResultat($referentiel, $id_resultat);
252
				$donnees['entrees'][] = $entree;
253
			}
254
		}
255
 
256
		$this->setSortie(self::RENDU_NAVIGATION, $this->getVue('fil_ariane', $donnees), false);
257
	}
33 jpm 258
 
37 jpm 259
	protected function obtenirUrlDetailReferentiel($referentiel) {
260
		$this->url->setRequete(false);
271 delphine 261
		$this->url->setVariableRequete('module', 'Informations');
37 jpm 262
		$this->url->setVariableRequete('ref', $referentiel);
263
		$url = $this->url->getURL();
264
		$this->url->unsetVariablesRequete(array('module', 'action', 'ref'));
265
		return $url;
266
	}
267
 
325 delphine 268
	protected function obtenirUrlDetailReferentielTelechargement($referentiel) {
269
		$this->url->setRequete(false);
270
		$this->url->setVariableRequete('module', 'Informations');
271
		$this->url->setVariableRequete('action', 'telecharger');
272
		$this->url->setVariableRequete('ref', $referentiel);
273
		$url = $this->url->getURL();
274
		$this->url->unsetVariablesRequete(array('module', 'action', 'ref'));
275
		return $url;
276
	}
277
 
271 delphine 278
	protected function obtenirUrlMenuInformations($referentiel) {
279
		return $this->obtenirUrlMenu('Informations', $referentiel);
280
	}
281
 
37 jpm 282
	protected function obtenirUrlMenuAccueil() {
283
		return $this->obtenirUrlMenu('Accueil');
284
	}
285
 
286
	protected function obtenirUrlMenuTest($referentiel) {
287
		return $this->obtenirUrlMenu('Test', $referentiel);
288
	}
289
 
290
	protected function obtenirUrlMenuVersionnage($referentiel) {
291
		return $this->obtenirUrlMenu('Versionnage', $referentiel);
292
	}
293
 
46 jpm 294
	protected function obtenirUrlDemandeVersionnage($referentiel) {
295
		$this->url->setRequete(false);
296
		$this->url->setVariableRequete('module', 'Versionnage');
297
		$this->url->setVariableRequete('action', 'demanderTraitement');
298
		$this->url->setVariableRequete('ref', $referentiel);
299
		$url = $this->url->getURL();
300
		$this->url->unsetVariablesRequete(array('module', 'action', 'ref'));
301
		return $url;
302
	}
303
 
37 jpm 304
	protected function obtenirUrlMenuConsultation($referentiel) {
305
		return $this->obtenirUrlMenu('Consultation', $referentiel);
306
	}
307
 
295 aurelien 308
	protected function obtenirUrlMenuArbre($referentiel) {
309
		return $this->obtenirUrlMenu('Arbre', $referentiel);
310
	}
311
 
300 aurelien 312
	protected function obtenirUrlMenuBranche($referentiel, $num_nom) {
313
		$this->url->setRequete(false);
314
		$this->url->setVariableRequete('module', 'Arbre');
315
		$this->url->setVariableRequete('action', 'afficherBranche');
316
		$this->url->setVariableRequete('ref', $referentiel);
317
		$this->url->setVariableRequete('num_nom', $num_nom);
318
		$url = $this->url->getURL();
319
		$this->url->unsetVariablesRequete(array('module', 'action', 'ref', 'num_nom'));
320
		return $url;
321
	}
322
 
323
	protected function obtenirUrlMenuBrancheSynonyme($referentiel, $num_nom) {
324
		$this->url->setRequete(false);
325
		$this->url->setVariableRequete('module', 'Arbre');
326
		$this->url->setVariableRequete('action', 'afficherBrancheSynonyme');
327
		$this->url->setVariableRequete('ref', $referentiel);
328
		$this->url->setVariableRequete('num_nom', $num_nom);
329
		$url = $this->url->getURL();
330
		$this->url->unsetVariablesRequete(array('module', 'action', 'ref', 'num_nom'));
331
		return $url;
332
	}
333
 
37 jpm 334
	private function obtenirUrlMenu($menu, $referentiel = null) {
335
		$this->url->setRequete(false);
336
		$this->url->setVariableRequete('module', $menu);
337
		if (isset($referentiel)) {
338
			$this->url->setVariableRequete('ref', $referentiel);
339
		}
340
		$url = $this->url->getURL();
341
		$this->url->unsetVariablesRequete(array('module', 'ref'));
342
		return $url;
343
	}
344
 
345
	protected function obtenirUrlFicheTraitement($referentiel, $id_traitement) {
346
		$this->url->setRequete(false);
347
		$this->url->setVariableRequete('module', 'Traitement');
348
		$this->url->setVariableRequete('id-t', $id_traitement);
349
		$this->url->setVariableRequete('ref', $referentiel);
350
		$url = $this->url->getURL();
351
		$this->url->unsetVariablesRequete(array('module', 'id-t', 'ref'));
352
		return $url;
353
	}
354
 
355
	protected function obtenirUrlFicheResultat($referentiel, $id_resultat) {
356
		$this->url->setRequete(false);
357
		$this->url->setVariableRequete('module', 'Resultat');
358
		$this->url->setVariableRequete('id-r', $id_resultat);
359
		$this->url->setVariableRequete('ref', $referentiel);
360
		$url = $this->url->getURL();
361
		$this->url->unsetVariablesRequete(array('module', 'id-r', 'ref'));
362
		return $url;
363
	}
39 jpm 364
 
77 delphine 365
	protected function obtenirUrlRecherche($referentiel = null, $txt = null) {
70 delphine 366
		$this->url->setRequete(false);
77 delphine 367
		if (!is_null($referentiel)) {
368
			$this->url->setVariableRequete('ref', $referentiel);
369
		}
70 delphine 370
		$this->url->setVariableRequete('module', 'Recherche');
371
		$this->url->setVariableRequete('action', 'rechercher');
372
		if (!is_null($txt)) {
373
			$this->url->setVariableRequete('recherche', $txt);
374
		}
375
		$url = $this->url->getURL();
376
		$this->url->unsetVariablesRequete(array('ref', 'module', 'action', 'recherche'));
377
		return $url;
378
	}
103 jpm 379
	protected function obtenirUrlFicheTaxon($referentiel, $num_nom = null) {
77 delphine 380
		$this->url->setRequete(false);
381
		$this->url->setVariableRequete('ref', $referentiel);
382
		$this->url->setVariableRequete('module', 'FicheTaxon');
383
		if (!is_null($num_nom)) {
384
			$this->url->setVariableRequete('num_nom', $num_nom);
385
		}
386
		$url = clone $this->url;
387
		$this->url->unsetVariablesRequete(array('module', 'id'));
388
		return $url->getURL();
389
	}
70 delphine 390
 
39 jpm 391
	/**
392
	 * Lance l'ajout d'un traitement
393
	 */
394
	protected function ajouterTraitement($referentiel_code, $script_nom) {
51 jpm 395
		$this->ajouterTraitementParametre($referentiel_code, null, $script_nom);
396
	}
397
 
398
	/**
399
	 * Lance l'ajout d'un traitement
400
	 */
401
	protected function ajouterTraitementParametre($referentiel_code, $parametres_serialises, $script_nom) {
39 jpm 402
		if (is_null($referentiel_code)) {
156 jpm 403
			$this->addMessage("Aucun code de projet de référentiel n'est indiqué (Ex. bdtfx).");
39 jpm 404
		} else {
46 jpm 405
			$traitements_a_supprimer = null;
39 jpm 406
			$traitementDao = new TraitementDao();
407
			$resultat_traitement_en_attente = $traitementDao->getTraitementsEnAttente($referentiel_code, $script_nom);
408
			if ($resultat_traitement_en_attente) {
46 jpm 409
				foreach ($resultat_traitement_en_attente as $traitement) {
410
					$difference = $this->differenceEnSecondeEntreDeuxDates($traitement['meta_date_creation'], date ("Y-m-d H:i:s"));
411
					Debug::printr("Différence attente : $difference > ".Config::get('ddv_traitement_attente'));
412
					if ($difference > Config::get('ddv_traitement_attente')) {
413
						$traitements_a_supprimer[] = $traitement['id_traitement'];
414
						$this->addMessage("Le traitement #{$traitement['id_traitement']} était en attente depuis plus de 5mn, il a été supprimé.");
415
					} else {
416
						$this->addMessage("Un traitement est déjà en attente...");
417
					}
418
				}
39 jpm 419
			} else {
420
				$resultat_traitement_en_cours = $traitementDao->getTraitementsEnCours($referentiel_code, $script_nom);
421
				if ($resultat_traitement_en_cours) {
46 jpm 422
					foreach ($resultat_traitement_en_cours as $traitement) {
423
						$difference = $this->differenceEnSecondeEntreDeuxDates($traitement['date_debut'], date ("Y-m-d H:i:s"));
424
						Debug::printr("Différence en cours : $difference > ".Config::get('ddv_traitement_en_cours'));
425
						if ($difference > Config::get('ddv_traitement_en_cours')) {
426
							$traitements_a_supprimer[] = $traitement['id_traitement'];
427
							$this->addMessage("Le traitement #{$traitement['id_traitement']} était en cours depuis plus de 5mn, il a été supprimé.");
428
						} else {
429
							$this->addMessage("Un traitement est déjà en cours...");
430
						}
431
					}
39 jpm 432
				} else {
51 jpm 433
					$resultat = $traitementDao->ajouterTraitementParametre($referentiel_code, $parametres_serialises, $script_nom);
39 jpm 434
					if ($resultat != false) {
435
						$this->addMessage("Le traitement #'$resultat' a été ajouté.");
436
						$this->lancerScript($referentiel_code, $script_nom);
437
					} else {
438
						$this->addMessage("Un problème est survenu lors de la tentative d'ajout du traitement.");
439
					}
440
				}
441
			}
46 jpm 442
			// Suppression des traitements posant problème
443
			if (count($traitements_a_supprimer) > 0) {
444
				$traitementDao->supprimer($traitements_a_supprimer);
445
			}
39 jpm 446
		}
447
	}
448
 
46 jpm 449
	private function differenceEnSecondeEntreDeuxDates($date_01, $date_02) {
450
		if (floatval(phpversion()) >= 5.3 ) {
451
			$d1 = new DateTime($date_01);
452
			$d2 = new DateTime($date_02);
453
			$difference_absolue = true;
454
			$diff = $d1->diff($d2, $difference_absolue);
455
			$nbre_secondes = $diff->format('s');
456
		} else {
457
			$nbre_secondes = abs(round((strtotime($date_01) - strtotime($date_02))));
458
		}
459
		return $nbre_secondes;
460
	}
461
 
39 jpm 462
	/**
463
	 * Lance le script d'execution des traitements
464
	 */
465
	protected function lancerScript($referentiel_code, $script_nom) {
466
		$php = Config::get('chemin_bin_php');
467
		$exe = Config::get('chemin_script');
468
		$action = 'tout';
469
		$log = Config::get('chemin_script_log');
46 jpm 470
		$limite_memoire = Config::get('script_limite_memoire');
471
		$commande = "$php -d memory_limit=$limite_memoire -f $exe $script_nom -p $referentiel_code -a $action > $log &";
39 jpm 472
 
473
		if ($this->verifierSafeModeOff() === false) {
474
			$e = "Le safe_mode est actif sur ce serveur.";
475
		} else if ($this->verifierAccesFonctionExec() === false) {
476
			$e = "La fonction 'exec()' fait partie des fonctions désactivées sur ce serveur (voir disable_functions).";
477
		} else {
478
			$this->addMessage("Lancement du script effectuant les traitements.");
479
			exec($commande);
480
		}
481
 
482
		// Affichage des message de paramêtrage du serveur si nécessaire
483
		if (Config::get('script_messages') == true) {
484
			$message_erreur_tpl = "%s\n.".
485
				"Il est nécessaire de configurer le lancement du script via une tache dans le cron.\n".
486
				"La commande à lancer est : <code>$commande</code>";
487
			$this->addMessage(sprintf($message_erreur_tpl, $e));
488
		}
489
	}
490
 
491
	private function verifierSafeModeOff() {
492
		return ('1' == ini_get('safe_mode')) ? false : true;
493
	}
494
 
495
	private function verifierAccesFonctionExec() {
496
		$disabled = explode(', ', ini_get('disable_functions'));
497
		return !in_array('exec', $disabled);
498
	}
120 jpm 499
 
500
	//+----------------------------------------------------------------------------------------------------------------+
276 aurelien 501
	// GESTION DES FICHIERS A TELECHARGER
502
 
503
	/**
504
	* Crée la liste d'url des fichiers à télécharger pour un traitement donné
505
	* @param Array $infos_traitement tableau contenant les informations du traitement
506
	*
507
	* @return Array un tableau contenant la liste des urls des fichiers à télécharger
508
	*/
509
	protected function obtenirUrlsZipPourTraitement($infos_traitement) {
328 mathias 510
		$urls_zip = array();
276 aurelien 511
		if (isset($infos_traitement['script']) && $infos_traitement['script'] == 'versionnage') {
512
			$meta = unserialize($infos_traitement['script_parametres']);
513
			$projet = strtolower($infos_traitement['referentiel_code']);
514
			$version = str_replace('.', '_', $meta['version']);
515
			$fichier_zip_bdnt = $projet.'_v'.$version.'.zip';
516
			$url_zip_bdnt = sprintf(Config::get('url_zip_tpl'), $fichier_zip_bdnt);
517
			if ($this->testerUrl($url_zip_bdnt)) {
518
				$urls_zip[$fichier_zip_bdnt] = $url_zip_bdnt;
519
			}
520
		}
521
		return $urls_zip;
522
	}
523
 
524
	/**
525
	* Teste une url donnée, en tentant de l'ouvrir et de la fermer
526
	*
527
	* @return boolean un booléen indiquant le succès ou non de l'opération
528
	*/
529
	protected function testerUrl($url) {
530
		//TODO: voir si on peut inclure cette fonction dans le framework
531
		ini_set('allow_url_fopen', '1');
532
		return (@fclose(@fopen($url, 'r'))) ? true : false;
533
	}
534
 
535
	//+----------------------------------------------------------------------------------------------------------------+
120 jpm 536
	// GESTION DU CLIENT REST
537
 
538
	protected function getRestClient() {
539
		if (! isset($this->restClient)) {
540
			$this->restClient = new RestClient();
541
		}
542
		return $this->restClient;
543
	}
544
 
545
	//+----------------------------------------------------------------------------------------------------------------+
546
	// GESTION DE L'IDENTIFICATION
547
 
548
	protected function getAuthIdentifiant() {
549
		$id = (isset($_SERVER['PHP_AUTH_USER'])) ? $_SERVER['PHP_AUTH_USER'] : null;
550
		return $id;
551
	}
552
 
553
	protected function getAuthMotDePasse() {
554
		$mdp = (isset($_SERVER['PHP_AUTH_PW'])) ? $_SERVER['PHP_AUTH_PW'] : null;
555
		return $mdp;
556
	}
557
 
558
	public function authentifierCoordinateur() {
559
		$message_accueil = "Veuillez vous identifier avec votre compte Tela Botanica.";
560
		$message_echec = "Accès limité aux coordinateurs du projet.\n".
561
			"Votre tentative d'identification a échoué.\n".
562
			"Actualiser la page pour essayer à nouveau si vous êtes bien inscrit comme coordinateur.";
563
		return $this->authentifier($message_accueil, $message_echec);
564
	}
565
 
566
	private function authentifier($message_accueil, $message_echec) {
567
		$id = $this->getAuthIdentifiant();
568
		if (!isset($id)) {
569
			$this->envoyerAuth($message_accueil, $message_echec);
570
		} else {
346 mathias 571
			$autorisation = $this->etreCoordinateurAutorise($id);
120 jpm 572
			if ($autorisation == false) {
573
				$this->envoyerAuth($message_accueil, $message_echec);
574
			}
575
		}
576
		return true;
577
	}
578
 
579
	public function etreCoordinateurAutorise($identifiant) {
580
		$mdp = md5($this->getAuthMotDePasse());
581
		$url = sprintf(Config::get('authentification.serviceUrlTpl'), $identifiant, $mdp);
582
		$json = $this->getRestClient()->envoyerRequeteConsultation($url);
583
		$existe = json_decode($json);
584
		$admin = $this->etreCoordinateur($identifiant) ? true : false;
585
		$autorisation = ($existe && $admin) ? true : false;
586
		return $autorisation;
587
	}
588
 
589
	public function etreCoordinateur($courriel) {
590
		$coordinateurs = Config::get('authentification.coordinateurs');
591
		$courriels_autorises = explode(',', $coordinateurs);
592
 
593
		$autorisation = (in_array($courriel, $courriels_autorises)) ? true : false ;
594
		return $autorisation;
595
	}
596
 
597
	private function envoyerAuth($message_accueil, $message_echec) {
598
		header('HTTP/1.0 401 Unauthorized');
599
		header('WWW-Authenticate: Basic realm="'.mb_convert_encoding($message_accueil, 'ISO-8859-1', 'UTF-8').'"');
600
		header('Content-type: text/plain; charset=UTF-8');
601
		print $message_echec;
602
		exit(0);
603
	}
399 killian 604
}