Subversion Repositories eFlore/Applications.del

Rev

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

Rev Author Line No. Line
716 gduche 1
<?php
2
/**
723 gduche 3
 * Le conteneur encapsule les classe Masque, Navigation et GestionBdd
4
 * Il gère leur instanciation, ainsi que la récupération des paramètres depuis l'url ou
5
 * les fichiers de configuration
716 gduche 6
 *
723 gduche 7
 * @category php 5.2
8
 * @package del
9
 * @author Grégoire Duché <gregoire@tela-botanica.org>
10
 * @copyright Copyright (c) 2012, Tela Botanica (accueil@tela-botanica.org)
11
 * @license	http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
12
 * @license	http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
13
 * @version	$Id: Bdd.php 403 2012-02-22 14:35:20Z gduche $
14
 */
716 gduche 15
class Conteneur {
16
 
723 gduche 17
	protected $parametres;
18
	protected $navigation;
19
	protected $masque;
20
	protected $gestionBdd;
935 gduche 21
	protected $sansLimite = false;
723 gduche 22
 
23
	//TODO : initialiser tous les objets dans le conteneur
24
	//TODO : créer un tableau de partage
25
 
26
	/**
27
	 * Constructeur de la classe
28
	 * @param Array $parametres (optionnel) les paramètres additionnels à ajouter à ceux des fichiers de config
29
	 * */
716 gduche 30
	public function __construct(array $parametres = null) {
31
		$this->parametres = is_null($parametres) ? array() : $parametres;
32
	}
33
 
723 gduche 34
	/**
35
	 * Charger la configuration depuis le fichier
36
	 * @param String $chemin le chemin relatif depuis le dossier configurations du fichier
37
	 * */
716 gduche 38
	public function chargerConfiguration($chemin) {
39
		$cheminConfigurations = Config::get('chemin_configurations');
723 gduche 40
		if ($cheminConfigurations == null || $cheminConfigurations == '') {
41
			$message = 'Le chemin vers le répertoire Configurations n\'est pas renseigné';
42
			$code = RestServeur::HTTP_CODE_ERREUR;
43
			throw new Exception($message, $code);
44
		}
716 gduche 45
		Config::charger($cheminConfigurations.DS.$chemin);
46
 
723 gduche 47
		if ($this->masque = $this->creerMasque()) {
48
			$this->masque->chargerMasque();
49
		} else {
50
			$message = 'Erreur lors de la création du Masque';
51
			$code = RestServeur::HTTP_CODE_ERREUR;
52
			throw new Exception($message, $code);
716 gduche 53
		}
54
 
723 gduche 55
		if ($this->navigation = $this->creerNavigation()) {
56
			$this->navigation->chargerUrl();
716 gduche 57
		} else {
723 gduche 58
			$message = 'Erreur lors de la création de la Navigation';
59
			$code = RestServeur::HTTP_CODE_ERREUR;
60
			throw new Exception($message, $code);
716 gduche 61
		}
723 gduche 62
 
63
		$this->creerGestionBdd($this->navigation, Config::get('schemaBdd'));
716 gduche 64
	}
65
 
66
	/**
723 gduche 67
	 * Créer l'objet Masque en fonction des configurations
68
	 * */
69
	private function creerMasque() {
70
		$this->masque = new Masque(Config::get('masques_possibles'), $this->parametres);
71
		return $this->masque;
716 gduche 72
 
73
	}
74
 
723 gduche 75
	/**
76
	 * Créer l'objet navigation avec les paramètres
77
	 * */
78
	private function creerNavigation() {
79
		return ($this->navigation = new Navigation($this->parametres));
716 gduche 80
	}
81
 
723 gduche 82
	/**
83
	 * Créer l'objet Gestion BDD
84
	 * */
85
	private function creerGestionBdd($navigation, $schemaBdd) {
86
		$this->gestionBdd = new GestionBdd($navigation, $schemaBdd);
716 gduche 87
	}
723 gduche 88
 
716 gduche 89
	/**
723 gduche 90
	 * Récupérer l'objet GestionBdd
91
	 * */
92
	public function getGestionBdd() {
93
		return $this->gestionBdd;
94
	}
95
 
96
	/**
97
	 * Récupérer l'objet Navigation
98
	 * */
99
	public function getNavigation() {
100
		return $this->navigation;
101
	}
102
 
103
	/**
935 gduche 104
	 * Changer la valeur de sans limite pour ne pas l'afficher dans l'entete
105
	 * */
106
	public function setSansLimite() {
107
		$this->sansLimite = true;
108
	}
109
 
110
	/**
716 gduche 111
	* Créer l'entête en fonction des paramètres donnés
112
	* */
113
	public function getEntete() {
114
		$entete = array();
723 gduche 115
		$entete['masque'] = $this->masque->getChaineMasque();
935 gduche 116
 
936 gduche 117
		$entete['total'] = $this->navigation->getTotal();
118
 
935 gduche 119
		if ($this->sansLimite = false) {
120
			$entete['depart'] = $this->navigation->getDepart();
121
			$entete['limite'] = $this->navigation->getLimite();
122
 
936 gduche 123
			$lienPrecedent = $this->navigation->recupererHrefPrecedent();
716 gduche 124
 
936 gduche 125
			if ($lienPrecedent != null) {
126
				$entete['href.precedent'] = $lienPrecedent;
127
			}
716 gduche 128
 
936 gduche 129
			$lienSuivant = $this->navigation->recupererHrefSuivant();
130
			if ($lienSuivant) {
131
				$entete['href.suivant'] = $lienSuivant;
132
			}
716 gduche 133
		}
936 gduche 134
 
716 gduche 135
		return $entete;
136
	}
137
 
138
	/**
723 gduche 139
	 * Récupérer l'objet Masque
140
	 * */
141
	public function getMasque() {
142
		return $this->masque;
716 gduche 143
	}
144
 
145
	/**
723 gduche 146
	 * Obtenir un paramètre depuis le tableau de paramètres ou depuis le fichier de config
147
	 * @param String $cle le nom du paramètre
148
	 * @return la valeur du paramètre
716 gduche 149
	 * */
150
	public function getParametre($cle) {
151
		$valeur = isset($this->parametres[$cle]) ? $this->parametres[$cle] : Config::get($cle);
152
		return $valeur;
153
	}
723 gduche 154
 
155
	/**
156
	 * Enregistrer la valeur d'un paramètre
157
	 * */
716 gduche 158
	public function setParametre($cle, $valeur) {
159
		$this->parametres[$cle] = $valeur;
160
	}
161
}
162
?>