Subversion Repositories Applications.framework

Rev

Rev 197 | Rev 206 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
95 jpm 1
<?php
96 jpm 2
// declare(encoding='UTF-8');
3
/**
129 aurelien 4
 * Classe fournissant des informations au Framework sur l'application.
5
 *
186 jpm 6
 * @category	PHP 5.2
7
 * @package		Framework
8
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
9
 * @copyright	Copyright (c) 2009, Tela Botanica (accueil@tela-botanica.org)
10
 * @license		http://www.gnu.org/licenses/gpl.html Licence GNU-GPL-v3
197 aurelien 11
 * @license		http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL-v2
186 jpm 12
 * @version		SVN : $Id: Application.php 199 2010-07-05 14:33:04Z jpm $
13
 * @link		/doc/framework/
129 aurelien 14
 */
95 jpm 15
class Application {
96 jpm 16
 
129 aurelien 17
	/**
186 jpm 18
	 * Tableau d'informations sur l'application
129 aurelien 19
	 */
96 jpm 20
	private static $info = null;
129 aurelien 21
	/**
186 jpm 22
	 * Chemin de base de l'application
129 aurelien 23
	 */
95 jpm 24
	private static $chemin = null;
96 jpm 25
 
129 aurelien 26
	/**
186 jpm 27
	 * Initialise différentes classes du Framework nécessaires pour le fonctionnement de l'application.
28
	 * Ces classes sont ensuites controlées via les fichiers de config.ini.
29
	 * Elle est appelée automatiquement suite à la définition du chemin de l'application via Application::setChemin().
30
	 */
31
	private static function initialiser() {
199 jpm 32
		// Initialiser les arguments des urls
33
		self::initialiserUrl();
189 jpm 34
		// Configuration du gestionnaire d'exception
35
		GestionnaireException::configurer();
36
		// Configuration du gestionnaire de logs
197 aurelien 37
		//Log::configurer();
186 jpm 38
	}
197 aurelien 39
 
186 jpm 40
	/**
199 jpm 41
	 * Initialise le format des urls.
42
	 */
43
	private static function initialiserUrl() {
44
		ini_set('arg_separator.input', Config::get('fw_url_arg_separateur_entree'));
45
		ini_set('arg_separator.output', Config::get('fw_url_arg_separateur_sortie'));
46
	}
47
 
48
	/**
186 jpm 49
	 * Permet d'indiquer le chemin de base de l'Application.
50
	 * Cette méthode doit obligatoirement être utilisée par l'application pour que le Framework fonctionne correctement.
129 aurelien 51
	 * @param string $chemin_fichier_principal chemin de base
52
	 */
98 jpm 53
	public static function setChemin($chemin_fichier_principal) {
95 jpm 54
		if (self::$chemin === null) {
55
			if (!file_exists($chemin_fichier_principal)) {
96 jpm 56
				trigger_error("Le fichier indiqué n'existe pas. Utilisez __FILE__ dans la méthode set().", E_USER_ERROR);
95 jpm 57
			} else {
58
				self::$chemin = dirname($chemin_fichier_principal).DS;
186 jpm 59
				self::initialiser();
95 jpm 60
			}
61
		} else {
98 jpm 62
			trigger_error("Le chemin de l'application a déjà été enregistré auprès du Framework", E_USER_WARNING);
95 jpm 63
		}
64
	}
65
 
129 aurelien 66
	/**
67
	 * accesseur pour le chemin
68
	 * @return string le chemin
69
	 */
95 jpm 70
	public static function getChemin() {
71
		return self::$chemin;
72
	}
96 jpm 73
 
98 jpm 74
	/** Le tableau des informations sur l'application possède les clés suivantes :
75
	 * - nom : nom de l'application
76
	 * - abr : abréviation de l'application
77
	 * - encodage : encodage de l'application (ISO-8859-15, UTF-8...)
78
	 *
79
	 * @param array $info tableau fournissant des informations sur l'application
80
	 * @return void
81
	 */
82
	public static function setInfo($info) {
83
		if (self::$info === null) {
84
			self::$info = $info;
85
		} else {
86
			trigger_error("Le informations de l'application ont déjà été enregistrées auprès du Framework", E_USER_WARNING);
87
		}
88
	}
89
 
129 aurelien 90
	/**
91
	 * accesseur pour le tableau d'infos
92
	 * @param string $cle la clé à laquelle on veut accéder
93
	 */
96 jpm 94
	public static function getInfo($cle = null) {
95
		if ($cle !== null) {
96
			if (isset(self::$info[$cle])) {
97
				return self::$info[$cle];
98
			}
99
		} else {
100
			return self::$info;
101
		}
95 jpm 102
	}
103
}