Subversion Repositories eFlore/Applications.del

Rev

Rev 1159 | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 1159 Rev 1612
Line 13... Line 13...
13
 * @version	$Id$
13
 * @version	$Id$
14
 * @see http://www.tela-botanica.org/wikini/eflore/wakka.php?wiki=ApiIdentiplante01Images
14
 * @see http://www.tela-botanica.org/wikini/eflore/wakka.php?wiki=ApiIdentiplante01Images
15
 */
15
 */
Line 16... Line 16...
16
 
16
 
17
class ListeMotsCles {
17
class ListeMotsCles {
18
	
18
 
19
	private $conteneur;
19
	private $conteneur;
20
	private $navigation;
20
	private $navigation;
21
	private $masque;
21
	private $masque;
22
	private $gestionBdd;
22
	private $gestionBdd;
23
	private $bdd;
23
	private $bdd;
24
	private $parametres = array();
24
	private $parametres = array();
25
	private $ressources = array();
25
	private $ressources = array();
26
	
26
 
27
	public function __construct(Conteneur $conteneur = null) {
27
	public function __construct(Conteneur $conteneur = null) {
28
		$this->conteneur = $conteneur == null ? new Conteneur() : $conteneur;
28
		$this->conteneur = $conteneur == null ? new Conteneur() : $conteneur;
29
		$this->conteneur->chargerConfiguration('config_mots_cles.ini');
29
		$this->conteneur->chargerConfiguration('config_mots_cles.ini');
30
		$this->conteneur->chargerConfiguration('config_mapping_mots_cles.ini');
30
		$this->conteneur->chargerConfiguration('config_mapping_mots_cles.ini');
31
		$this->navigation = $conteneur->getNavigation();
31
		$this->navigation = $conteneur->getNavigation();
32
		$this->masque = $conteneur->getMasque();
32
		$this->masque = $conteneur->getMasque();
33
		$this->gestionBdd = $conteneur->getGestionBdd();
33
		$this->gestionBdd = $conteneur->getGestionBdd();
34
		$this->bdd = $this->gestionBdd->getBdd();	
34
		$this->bdd = $this->gestionBdd->getBdd();
35
	}
35
	}
36
	
36
 
37
	/**
37
	/**
38
	 * Méthode principale de la classe.
38
	 * Méthode principale de la classe.
39
	 * Lance la récupération des images dans la base et les place dans un objet ResultatService 
39
	 * Lance la récupération des images dans la base et les place dans un objet ResultatService
40
	 * pour l'afficher.
40
	 * pour l'afficher.
41
	 * @param array $ressources les ressources situées après l'url de base (ex : http://url/ressource1/ressource2)
41
	 * @param array $ressources les ressources situées après l'url de base (ex : http://url/ressource1/ressource2)
42
	 * @param array $parametres les paramètres situés après le ? dans l'url
42
	 * @param array $parametres les paramètres situés après le ? dans l'url
43
	 * */
43
	 * */
44
	public function consulter($ressources, $parametres) {
44
	public function consulter($ressources, $parametres) {
45
		$this->initialiserRessourcesEtParametres($ressources, $parametres);
45
		$this->initialiserRessourcesEtParametres($ressources, $parametres);
46
		
46
 
47
		// Gestion des configuration du script
47
		// Gestion des configuration du script
48
		$this->configurer();
48
		$this->configurer();
49
		$this->verifierConfiguration();
49
		$this->verifierConfiguration();
50
		
50
 
51
		// Lancement du service
51
		// Lancement du service
52
		$mots_cles = $this->chargerMotsCles();
52
		$mots_cles = $this->chargerMotsCles();
53
		$mots_cles = $this->formaterMotsCles($mots_cles);
53
		$mots_cles = $this->formaterMotsCles($mots_cles);
54
		$total = $this->compterMotsCles();
54
		$total = $this->compterMotsCles();
Line 55... Line 55...
55
		$this->navigation->setTotal($total);
55
		$this->navigation->setTotal($total);
56
 
56
 
57
		$resultat = new ResultatService();
57
		$resultat = new ResultatService();
58
		
58
 
59
		$resultat->corps = array('entete' => $this->conteneur->getEntete(), 'resultats' => $mots_cles);
59
		$resultat->corps = array('entete' => $this->conteneur->getEntete(), 'resultats' => $mots_cles);
60
		return $resultat;
60
		return $resultat;
61
	}
61
	}
62
	
62
 
63
	private function initialiserRessourcesEtParametres($ressources, $parametres) {
63
	private function initialiserRessourcesEtParametres($ressources, $parametres) {
64
		$this->ressources = $ressources;
64
		$this->ressources = $ressources;
65
		$this->parametres = $parametres;
65
		$this->parametres = $parametres;
66
	}
66
	}
67
	
67
 
68
	/*-------------------------------------------------------------------------------
68
	/*-------------------------------------------------------------------------------
69
	 							CONFIGURATION DU SERVICE
69
	 							CONFIGURATION DU SERVICE
70
	 --------------------------------------------------------------------------------*/
70
	 --------------------------------------------------------------------------------*/
71
	/**
71
	/**
72
	 * Configuration du service en fonction du fichier de config config_del.ini
72
	 * Configuration du service en fonction du fichier de config config_del.ini
73
	 * */
73
	 * */
74
	public function configurer() {
74
	public function configurer() {
75
		$this->mappingMotsCles = $this->conteneur->getParametre('mapping_mots_cles');
75
		$this->mappingMotsCles = $this->conteneur->getParametre('mapping_mots_cles');
76
		$this->mappingFiltre = $this->conteneur->getParametre('mapping_masque');
76
		$this->mappingFiltre = $this->conteneur->getParametre('mapping_masque');
77
	}
77
	}
78
	
78
 
79
	/**
79
	/**
80
	 * Vérifier que le service est bien configuré 
80
	 * Vérifier que le service est bien configuré
Line 81... Line 81...
81
	 * */
81
	 * */
82
	public function verifierConfiguration() {
82
	public function verifierConfiguration() {
83
 
83
 
84
		$erreurs = array();
84
		$erreurs = array();
85
		$tableau_mots_cles = $this->conteneur->getParametre('motscles');
85
		$tableau_mots_cles = $this->conteneur->getParametre('motscles');
86
		if (empty($tableau_mots_cles)) {
86
		if (empty($tableau_mots_cles)) {
87
			$erreurs[] = '- le fichier de configuration ne contient pas le tableau [motscles] ou celui-ci est vide ;'; 
87
			$erreurs[] = '- le fichier de configuration ne contient pas le tableau [motscles] ou celui-ci est vide ;';
88
		} else {
88
		} else {
89
			if ($this->conteneur->getParametre('url_service') == null) {
89
			if ($this->conteneur->getParametre('url_service') == null) {
90
				$erreurs[] = '- paramètre "url_service" manquant ;';
90
				$erreurs[] = '- paramètre "url_service" manquant ;';
91
			}
91
			}
92
		}
92
		}
93
		
93
 
94
		if (empty($this->mappingFiltre)) {
94
		if (empty($this->mappingFiltre)) {
95
			$erreurs[] = '- le fichier de configuration ne contient pas le tableau [mapping_masque] ou celui-ci est vide ;';
95
			$erreurs[] = '- le fichier de configuration ne contient pas le tableau [mapping_masque] ou celui-ci est vide ;';
96
		}
96
		}
97
		
97
 
98
		if (!empty($erreurs)) {
98
		if (!empty($erreurs)) {
99
			$e = 'Erreur lors de la configuration : '."\n";
99
			$e = 'Erreur lors de la configuration : '."\n";
100
			$e .= implode("\n", $erreurs);
100
			$e .= implode("\n", $erreurs);
101
			throw new Exception($e, RestServeur::HTTP_CODE_ERREUR);
101
			throw new Exception($e, RestServeur::HTTP_CODE_ERREUR);
102
		}
102
		}
103
	}
103
	}
104
	
104
 
105
	/**
105
	/**
106
	* Charger la clause WHERE en fonction des paramètres de masque
106
	* Charger la clause WHERE en fonction des paramètres de masque
107
	* */
107
	* */
108
	private function chargerClauseWhere() {
108
	private function chargerClauseWhere() {
109
		$where = array();
109
		$where = array();
110
		$where[] = ' actif = 1 ';
110
		$where[] = ' actif = 1 ';
111
		$tableauMasque = $this->masque->getMasque();
111
		$tableauMasque = $this->masque->getMasque();
112
		if (!empty($tableauMasque)) {
112
		if (!empty($tableauMasque)) {
113
			foreach($tableauMasque as $idMasque => $valeurMasque) {
113
			foreach($tableauMasque as $idMasque => $valeurMasque) {
114
				//TODO: scinder ceci en fonctions réutilisables ? 
114
				//TODO: scinder ceci en fonctions réutilisables ?
115
				// voir si c'est interessant par rapport à la recherche générale	
115
				// voir si c'est interessant par rapport à la recherche générale
116
				$idMasque = str_replace('masque.', '', $idMasque);
116
				$idMasque = str_replace('masque.', '', $idMasque);
117
				switch ($idMasque) {
117
				switch ($idMasque) {
118
					default:
118
					default:
119
						$where[] = ' '.$this->mappingFiltre[$idMasque].' = '.$this->proteger($valeurMasque);
119
						$where[] = ' '.$this->mappingFiltre[$idMasque].' = '.$this->proteger($valeurMasque);
120
					break;
120
					break;
121
				}
121
				}
122
			}	
122
			}
123
		}
123
		}
124
		if (!empty($where)) {
124
		if (!empty($where)) {
125
			return ' WHERE '.implode('AND', $where);
125
			return ' WHERE '.implode('AND', $where);
126
		} else {
126
		} else {
127
			return;
127
			return;
128
		}
128
		}
129
	}
129
	}
130
	
130
 
131
	/*-------------------------------------------------------------------------------
131
	/*-------------------------------------------------------------------------------
132
							   CHARGEMENT DES MOTS CLES 
132
							   CHARGEMENT DES MOTS CLES
133
	--------------------------------------------------------------------------------*/
133
	--------------------------------------------------------------------------------*/
134
	/**
134
	/**
135
	* Chargement depuis la bdd de tous les mots clés
-
 
136
	* */
135
	* Chargement depuis la bdd de tous les mots clés
137
	private function chargerMotsCles() {
-
 
138
	
136
	* */
139
		$requeteLiaisons = 'SELECT DISTINCT SQL_CALC_FOUND_ROWS * '.
137
	private function chargerMotsCles() {
140
						   'FROM '.$this->gestionBdd->formaterTable('del_image_tag', 'dit');
138
		$requeteLiaisons = 'SELECT DISTINCT SQL_CALC_FOUND_ROWS * '.
141
		$requeteLiaisons .= $this->chargerClauseWhere();
139
			'FROM del_image_tag '.$this->chargerClauseWhere();
142
		return $this->bdd->recupererTous($requeteLiaisons);
140
		return $this->bdd->recupererTous($requeteLiaisons);
143
	}
141
	}
144
	
142
 
145
	/**
143
	/**
146
	* Compter le nombre total de mots clés dans la base pour affichage dans en tete.
144
	* Compter le nombre total de mots clés dans la base pour affichage dans en tete.
147
	* */
145
	* */
148
	private function compterMotsCles() {
146
	private function compterMotsCles() {
149
		$requete = 'SELECT FOUND_ROWS() AS nbre ';
147
		$requete = 'SELECT FOUND_ROWS() AS nbre ';
150
		$resultats = $this->bdd->recuperer($requete);
148
		$resultats = $this->bdd->recuperer($requete);
151
		return (int) $resultats['nbre'];
149
		return (int) $resultats['nbre'];
152
	}
150
	}
153
	
151
 
154
	/*-------------------------------------------------------------------------------
152
	/*-------------------------------------------------------------------------------
155
								FORMATER ET METTRE EN FORME
153
								FORMATER ET METTRE EN FORME
156
	--------------------------------------------------------------------------------*/
154
	--------------------------------------------------------------------------------*/
157
	
155
 
158
	/**
156
	/**
159
	*  Formater les mots clés
157
	*  Formater les mots clés
Line 167... Line 165...
167
			foreach ($this->mappingMotsCles as $nomOriginal => $nomFinal) {
165
			foreach ($this->mappingMotsCles as $nomOriginal => $nomFinal) {
168
				$mapping[$nomFinal] = $mot_cle[$nomOriginal];
166
				$mapping[$nomFinal] = $mot_cle[$nomOriginal];
169
			}
167
			}
170
			$retour[$mot_cle['id_tag']] = $mapping;
168
			$retour[$mot_cle['id_tag']] = $mapping;
171
		}
169
		}
172
		
170
 
173
		return $retour;
171
		return $retour;
174
	}
172
	}
175
	
173
 
176
	private function proteger($valeur) {
174
	private function proteger($valeur) {
177
		if (is_array($valeur)) {
175
		if (is_array($valeur)) {
178
			return $this->bdd->protegerTableau($valeur);
176
			return $this->bdd->protegerTableau($valeur);
179
		} else {
177
		} else {
180
			return $this->bdd->proteger($valeur);
178
			return $this->bdd->proteger($valeur);