Subversion Repositories eFlore/Applications.coel-consultation

Rev

Rev 181 | Rev 213 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 181 Rev 195
1
<?php
1
<?php
2
// declare(encoding='UTF-8');
2
// declare(encoding='UTF-8');
3
/**
3
/**
4
 * classe Controleur du module Recherche.
4
 * classe Controleur du module Recherche.
5
 *
5
 *
6
 * @package		Collection
6
 * @package		Collection
7
 * @category	Php5
7
 * @category	Php5
8
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
8
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
9
 * @copyright	2010 Tela-Botanica
9
 * @copyright	2010 Tela-Botanica
10
 * @license		http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
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
11
 * @license		http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
12
 * @version		SVN: $Id: Recherche.php 181 2013-12-20 10:53:16Z mathias $
12
 * @version		SVN: $Id: Recherche.php 195 2014-01-22 13:29:20Z aurelien $
13
 */
13
 */
14
class Recherche extends aControleur {
14
class Recherche extends aControleur {
15
	
15
	
16
	//private $chaine_recherche = null;
16
	//private $chaine_recherche = null;
17
	private $masque = null;
17
	private $masque = null;
18
	private static $url_exemple = null;
18
	private static $url_exemple = null;
19
	
19
	
20
	//+----------------------------------------------------------------------------------------------------------------+
20
	//+----------------------------------------------------------------------------------------------------------------+
21
	// Méthodes
21
	// Méthodes
22
	/**
22
	/**
23
	 * Fonction d'affichage par défaut, elle appelle la liste des administrateurs
23
	 * Fonction d'affichage par défaut, elle appelle la liste des administrateurs
24
	 */
24
	 */
25
	public function executerActionParDefaut() {
25
	public function executerActionParDefaut() {
26
		return $this->rechercher();
26
		return $this->rechercher();
27
	}
27
	}
28
	
28
	
29
	/**
29
	/**
30
	 * Charge le moteur de recherche et l'envoie à la vue.
30
	 * Charge le moteur de recherche et l'envoie à la vue.
31
	 */
31
	 */
32
	public function chargerMoteurRecherche() {
32
	public function chargerMoteurRecherche() {
33
		$donnees = array();
33
		$donnees = array();
34
 
34
 
35
		// Gestion des données de la requête
35
		// Gestion des données de la requête
36
		//$donnees['recherche'] = htmlspecialchars($this->obtenirChaineRecherche());
36
		//$donnees['recherche'] = htmlspecialchars($this->obtenirChaineRecherche());
37
		// masque multi-critères
37
		// masque multi-critères
38
		$donnees['masque'] = $this->obtenirMasqueRecherche();
38
		$donnees['masque'] = $this->obtenirMasqueRecherche();
39
 
39
 
40
		// Gestion des urls
40
		// Gestion des urls
41
		$donnees['url_form'] = $this->obtenirUrlRecherche();
41
		$donnees['url_form'] = $this->obtenirUrlRecherche();
42
		$donnees['url_module'] = 'Recherche';
42
		$donnees['url_module'] = 'Recherche';
43
		$donnees['url_action'] = 'rechercher';
43
		$donnees['url_action'] = 'rechercher';
44
		$donnees['url_contexte'] = $this->registre->get('contexte');
44
		$donnees['url_contexte'] = $this->registre->get('contexte');
45
		self::$url_exemple = $this->obtenirUrlRecherche('%s');
45
		self::$url_exemple = $this->obtenirUrlRecherche('%s');
-
 
46
			
-
 
47
		// remplissage de case de tableaux vides pour éviter des warnings
-
 
48
		$donnees['masque'] = $this->initialiserMasquesVides($donnees['masque']);
-
 
49
		//echo '<pre>'.print_r($donnees['masque'],true).'</pre>';exit;
46
		
50
		
47
		// Gestion du squelette et de la sortie
51
		// Gestion du squelette et de la sortie
48
		$this->setSortie(self::RENDU_TETE, $this->getVue('moteur', $donnees));
52
		$this->setSortie(self::RENDU_TETE, $this->getVue('moteur', $donnees));
49
	}
53
	}
50
 
54
 
51
	private function obtenirMasqueRecherche() {
55
	private function obtenirMasqueRecherche() {
52
		$masque = array();
56
		$masque = array();
53
		if (!is_null($this->masque)) {
57
		if (!is_null($this->masque)) {
54
			$masque = $this->masque;
58
			$masque = $this->masque;
55
		} else if (isset($_GET['masque'])) {
59
		} else if (isset($_GET['masque'])) {
56
			$masque = $_GET['masque'];
60
			$masque = $_GET['masque'];
57
			$_SESSION['col']['masque'] = $masque;
61
			$_SESSION['col']['masque'] = $masque;
58
		} else if (isset($_SESSION['col']['masque'])) {
62
		} else if (isset($_SESSION['col']['masque'])) {
59
			$masque = $_SESSION['col']['masque'];
63
			$masque = $_SESSION['col']['masque'];
60
		}
64
		}
61
		$this->masque = $masque;
65
		$this->masque = $masque;
62
		return $masque;
66
		return $masque;
63
	}
67
	}
64
 
68
 
65
	/*private function obtenirChaineRecherche() {
69
	/*private function obtenirChaineRecherche() {
66
		$chaine = '';
70
		$chaine = '';
67
		if (!is_null($this->chaine_recherche)) {
71
		if (!is_null($this->chaine_recherche)) {
68
			$chaine = $this->chaine_recherche;
72
			$chaine = $this->chaine_recherche;
69
		} else if (isset($_GET['recherche'])) {
73
		} else if (isset($_GET['recherche'])) {
70
			// Pré-traitement de la chaine de recherche
74
			// Pré-traitement de la chaine de recherche
71
			$chaine = $_GET['recherche'];
75
			$chaine = $_GET['recherche'];
72
			// Suppression des slash ajouté automatiquement par PHP devant les guillemets
76
			// Suppression des slash ajouté automatiquement par PHP devant les guillemets
73
			$chaine = stripslashes($chaine);
77
			$chaine = stripslashes($chaine);
74
			// Mémorisation de la chaine
78
			// Mémorisation de la chaine
75
			$this->memoriserChaineRecherche($chaine);
79
			$this->memoriserChaineRecherche($chaine);
76
			// Stockage dans la classe pour éviter d'effectuer à nouveau le traitement ci-dessus
80
			// Stockage dans la classe pour éviter d'effectuer à nouveau le traitement ci-dessus
77
			$this->chaine_recherche = $chaine;
81
			$this->chaine_recherche = $chaine;
78
		} else if (isset($_SESSION['col']['recherche'])) {
82
		} else if (isset($_SESSION['col']['recherche'])) {
79
			$chaine = $_SESSION['col']['recherche'];
83
			$chaine = $_SESSION['col']['recherche'];
80
		}
84
		}
81
		return $chaine;
85
		return $chaine;
82
	}*/
86
	}*/
83
 
87
 
84
	/*private function memoriserChaineRecherche($chaine) {
88
	/*private function memoriserChaineRecherche($chaine) {
85
		$_SESSION['col']['recherche'] = $chaine;
89
		$_SESSION['col']['recherche'] = $chaine;
86
	}*/
90
	}*/
87
 
91
 
88
	public static function getUrlExemple($chaine) {
92
	public static function getUrlExemple($chaine) {
89
		$url = '';
93
		$url = '';
90
		if (!is_null(self::$url_exemple)) {
94
		if (!is_null(self::$url_exemple)) {
91
			// L'utilisation d'urlencode nécessiate de pré-encodé la chaine dans le format de sortie si nécessaire
95
			// L'utilisation d'urlencode nécessiate de pré-encodé la chaine dans le format de sortie si nécessaire
92
			if (Config::get('sortie_encodage') != Config::get('appli_encodage')) {
96
			if (Config::get('sortie_encodage') != Config::get('appli_encodage')) {
93
				$chaine = mb_convert_encoding($chaine, Config::get('sortie_encodage'), Config::get('appli_encodage'));
97
				$chaine = mb_convert_encoding($chaine, Config::get('sortie_encodage'), Config::get('appli_encodage'));
94
			}
98
			}
95
			$chaine = urlencode($chaine);
99
			$chaine = urlencode($chaine);
96
			$url = sprintf(self::$url_exemple, $chaine);
100
			$url = sprintf(self::$url_exemple, $chaine);
97
		}
101
		}
98
		return $url;
102
		return $url;
99
	}
103
	}
100
 
104
 
101
	// recherche des collections ou des personnes, dépendemment de la cible
105
	// recherche des collections ou des personnes, dépendemment de la cible
102
	public function rechercher() {
106
	public function rechercher() {
103
		// un seul pour les collections ou les personnes, on ne cherche pas 2 choses à la fois !
107
		// un seul pour les collections ou les personnes, on ne cherche pas 2 choses à la fois !
104
		$masque = $this->obtenirMasqueRecherche();
108
		$masque = $this->obtenirMasqueRecherche();
105
 
109
 
106
		$donnees = array();
110
		$donnees = array();
107
		$donnees['masque'] = $masque;
111
		$donnees['masque'] = $masque;
108
		$rechercheDao =  new RechercheDao();
112
		$rechercheDao =  new RechercheDao();
109
		$parametres = array('mots' => '*');
113
		$parametres = array('mots' => '*');
110
		
114
		
111
		// Récupération des paramêtres de l'url
115
		// Récupération des paramêtres de l'url
112
		/*$chaine_de_recherche = $this->obtenirChaineRecherche();
116
		/*$chaine_de_recherche = $this->obtenirChaineRecherche();
113
		echo "CH RECH: $chaine_de_recherche<br/>"; 
117
		echo "CH RECH: $chaine_de_recherche<br/>"; 
114
		if (!empty($chaine_de_recherche)) {
118
		if (!empty($chaine_de_recherche)) {
115
			$this->url->setVariableRequete('recherche', $chaine_de_recherche);
119
			$this->url->setVariableRequete('recherche', $chaine_de_recherche);
116
		}
120
		}
117
		$parametres = $this->parserChaineDeRecherche($chaine_de_recherche);*/
121
		$parametres = $this->parserChaineDeRecherche($chaine_de_recherche);*/
118
 
122
 
119
		// Récupération des paramètres depuis le masque
123
		// Récupération des paramètres depuis le masque
120
		$parametres = $masque;
124
		$parametres = $masque;
121
 
-
 
122
		$parametres = $this->limiterParProjets($parametres);
125
 
123
		$this->remplacerAbreviationParId($parametres);
126
		$this->remplacerAbreviationParId($parametres);
124
		//echo "PARAM 2: <pre>" . print_r($parametres, true) . "</pre><br/>";
127
		//echo "PARAM 2: <pre>" . print_r($parametres, true) . "</pre><br/>";
125
		
128
		
126
		// Gestion du nombre de résultats
129
		// Gestion du nombre de résultats
127
		switch ($masque['cible']) {
130
		switch ($masque['cible']) {
128
			case 'collections':
131
			case 'collections':
129
				$donnees_total = $rechercheDao->chercherCollectionsNbre($parametres);
132
				$donnees_total = $rechercheDao->chercherCollectionsNbre($parametres);
130
				break;
133
				break;
131
			case 'personnes':
134
			case 'personnes':
132
				$donnees_total = $rechercheDao->chercherPersonnesNbre($parametres);
135
				$donnees_total = $rechercheDao->chercherPersonnesNbre($parametres);
133
				break;
136
				break;
134
			default:
137
			default:
135
				// @TODO qu'est-ce qui se passe ?
138
				// @TODO qu'est-ce qui se passe ?
136
		}
139
		}
137
 
140
 
138
		// Gestion du fragmenteur
141
		// Gestion du fragmenteur
139
		$options = array(
142
		$options = array(
140
			'url' => $this->url, 
143
			'url' => $this->url, 
141
			'donnees_total' => $donnees_total,
144
			'donnees_total' => $donnees_total,
142
			'donnees_par_page' => Config::get('resultat_par_page_defaut'),
145
			'donnees_par_page' => Config::get('resultat_par_page_defaut'),
143
			'donnees_par_page_choix' => Config::get('resultat_par_page_choix'),
146
			'donnees_par_page_choix' => Config::get('resultat_par_page_choix'),
144
		);
147
		);
145
		$fragmenteur = Composant::fabrique('fragmenteur', $options);
148
		$fragmenteur = Composant::fabrique('fragmenteur', $options);
146
		$donnees['fragmenteur'] = $fragmenteur->executer();
149
		$donnees['fragmenteur'] = $fragmenteur->executer();
147
		list($de, $a) = $fragmenteur->getDeplacementParPageId();
150
		list($de, $a) = $fragmenteur->getDeplacementParPageId();
148
		$this->url->unsetVariablesRequete(array('recherche', 'page'));
151
		$this->url->unsetVariablesRequete(array('recherche', 'page'));
149
 
152
 
150
		// Gestion de l'accès aux données
153
		// Gestion de l'accès aux données
151
		$rechercheDao->setLimitation(($de - 1), $fragmenteur->getDonneesParPage());
154
		$rechercheDao->setLimitation(($de - 1), $fragmenteur->getDonneesParPage());
152
		$rechercheDao->setDistinction(1);
155
		$rechercheDao->setDistinction(1);
153
		
156
		
154
		// Récupération des résultats
157
		// Récupération des résultats
155
		switch ($masque['cible']) {
158
		switch ($masque['cible']) {
156
			case 'collections':
159
			case 'collections':
157
				$resultats = $rechercheDao->chercherCollections($parametres);
160
				$resultats = $rechercheDao->chercherCollections($parametres);
158
				break;
161
				break;
159
			case 'personnes':
162
			case 'personnes':
160
				$resultats = $rechercheDao->chercherPersonnes($parametres);
163
				$resultats = $rechercheDao->chercherPersonnes($parametres);
161
				break;
164
				break;
162
			default:
165
			default:
163
		}
166
		}
164
 
167
 
165
		// Affichage de la liste de résultats
168
		// Affichage de la liste de résultats
166
		switch ($masque['cible']) {
169
		switch ($masque['cible']) {
167
			case 'collections':
170
			case 'collections':
168
				foreach ($resultats as $resultat) {
171
				foreach ($resultats as $resultat) {
169
					// Ajout des données concernant la structure si ce n'est pas déjà fait
172
					// Ajout des données concernant la structure si ce n'est pas déjà fait
170
					$structure_id = $resultat['cs_id_structure'];
173
					$structure_id = $resultat['cs_id_structure'];
171
					if (!isset($donnees['infos'][$structure_id])) {
174
					if (!isset($donnees['infos'][$structure_id])) {
172
						$structure = array(
175
						$structure = array(
173
							'nom' => $resultat['cs_nom'],
176
							'nom' => $resultat['cs_nom'],
174
							'ville' => $resultat['cs_ville'],
177
							'ville' => $resultat['cs_ville'],
175
							'url' => $this->obtenirUrlFicheStructure($resultat['cs_id_structure'])
178
							'url' => $this->obtenirUrlFicheStructure($resultat['cs_id_structure'])
176
						);
179
						);
177
						$donnees['infos'][$structure_id]['structure'] = $structure;
180
						$donnees['infos'][$structure_id]['structure'] = $structure;
178
					}
181
					}
179
					
182
					
180
					// Si la structure possède des collections
183
					// Si la structure possède des collections
181
					if (!empty($resultat['cc_id_collection'])) {
184
					if (!empty($resultat['cc_id_collection'])) {
182
						$collection = array(
185
						$collection = array(
183
							'nom' => $resultat['cc_nom'],
186
							'nom' => $resultat['cc_nom'],
184
							'url' => $this->obtenirUrlFicheCollection($resultat['cc_id_collection'])
187
							'url' => $this->obtenirUrlFicheCollection($resultat['cc_id_collection'])
185
						);
188
						);
186
						$donnees['infos'][$structure_id]['collections'][] = $collection;
189
						$donnees['infos'][$structure_id]['collections'][] = $collection;
187
					}
190
					}
188
				}
191
				}
189
			break;
192
			break;
190
 
193
 
191
			case 'personnes':
194
			case 'personnes':
192
				foreach ($resultats as $resultat) {
195
				foreach ($resultats as $resultat) {
193
					//echo "<pre>".print_r($resultat,true)."</pre>";
196
					//echo "<pre>".print_r($resultat,true)."</pre>";
194
					if (!empty($resultat['cp_id_personne'])) {
197
					if (!empty($resultat['cp_id_personne'])) {
195
						$personne = array(
198
						$personne = array(
196
							'nomcomplet' => $resultat['cp_fmt_nom_complet'],
199
							'nomcomplet' => $resultat['cp_fmt_nom_complet'],
197
							'nom' => $resultat['cp_nom'],
200
							'nom' => $resultat['cp_nom'],
198
							'prenom' => $resultat['cp_prenom'],
201
							'prenom' => $resultat['cp_prenom'],
199
							'url' => $this->obtenirUrlFichePersonne($resultat['cp_id_personne'])
202
							'url' => $this->obtenirUrlFichePersonne($resultat['cp_id_personne'])
200
						);
203
						);
201
						$donnees['infos']['personnes'][] = $personne;
204
						$donnees['infos']['personnes'][] = $personne;
202
					}
205
					}
203
				}
206
				}
204
			break;
207
			break;
205
 
208
 
206
			default:
209
			default:
207
		}
210
		}
208
 
211
 
209
		// Post-traitement des résultats pour l'affichage
212
		// Post-traitement des résultats pour l'affichage
210
		$this->postraiterDonnees($donnees['infos']);
213
		$this->postraiterDonnees($donnees['infos']);
211
		
214
		
212
		// Gestion des squelettes
215
		// Gestion des squelettes
213
		$this->chargerMoteurRecherche();
216
		$this->chargerMoteurRecherche();
214
		$resultat = $this->getVue('resultat', $donnees);
217
		$resultat = $this->getVue('resultat', $donnees);
215
		$this->setSortie(self::RENDU_CORPS, $resultat);
218
		$this->setSortie(self::RENDU_CORPS, $resultat);
216
		$this->chargerPiedDePage();
219
		$this->chargerPiedDePage();
217
	}
220
	}
-
 
221
	
-
 
222
	private function initialiserMasquesVides($masque) {
-
 
223
		$masques_possibles = array('lieu-stockage',
-
 
224
		'veg','zg','bot','p','pr','nom-famille','date-vivant','date-deces','adresse');
-
 
225
		foreach($masques_possibles as $masque_possible) {
-
 
226
			if(!isset($masque[$masque_possible])) {
-
 
227
				$masque[$masque_possible] = '';
-
 
228
			}
-
 
229
		}
-
 
230
		return $masque;
-
 
231
	}
218
	
232
	
219
	/*private function parserChaineDeRecherche($chaine) {		
233
	/*private function parserChaineDeRecherche($chaine) {		
220
		$mots = preg_split('/ /i', $chaine, -1, PREG_SPLIT_NO_EMPTY);
234
		$mots = preg_split('/ /i', $chaine, -1, PREG_SPLIT_NO_EMPTY);
221
		$parametres = array('mots' => '');
235
		$parametres = array('mots' => '');
222
		$cle_precedente = null;
236
		$cle_precedente = null;
223
		foreach ($mots as $mot) {
237
		foreach ($mots as $mot) {
224
			if (preg_match('/^(sci|veg|bot|zg|p|pr|str-d):(.*)$/', $mot, $match)) {
238
			if (preg_match('/^(sci|veg|bot|zg|p|pr|str-d):(.*)$/', $mot, $match)) {
225
				$cle = $match[1];
239
				$cle = $match[1];
226
				$cle_precedente = $cle;
240
				$cle_precedente = $cle;
227
				$valeur = $match[2];
241
				$valeur = $match[2];
228
				$parametres[$cle] = $valeur;
242
				$parametres[$cle] = $valeur;
229
			} else if (!is_null($cle_precedente)) {
243
			} else if (!is_null($cle_precedente)) {
230
				$parametres[$cle_precedente] .= ' '.$mot;
244
				$parametres[$cle_precedente] .= ' '.$mot;
231
			} else if (is_null($cle_precedente)) {
245
			} else if (is_null($cle_precedente)) {
232
				if (empty($parametres['mots'])) {
246
				if (empty($parametres['mots'])) {
233
					$parametres['mots'] = $mot;
247
					$parametres['mots'] = $mot;
234
				} else {
248
				} else {
235
					$parametres['mots'] .= ' '.$mot;
249
					$parametres['mots'] .= ' '.$mot;
236
				}
250
				}
237
			}
251
			}
238
		}
252
		}
239
		$this->remplacerAbreviationParId($parametres);
253
		$this->remplacerAbreviationParId($parametres);
240
		
254
		
241
		return $parametres;
255
		return $parametres;
242
	}*/
256
	}*/
243
 
257
 
244
	private function remplacerAbreviationParId(&$parametres) {
258
	private function remplacerAbreviationParId(&$parametres) {
245
		// liste 27 : Liste des relations entre une collection et une personne (id:1030)
259
		// liste 27 : Liste des relations entre une collection et une personne (id:1030)
246
		// liste 80 : Liste des types de collection botanique (id:1083)
260
		// liste 80 : Liste des types de collection botanique (id:1083)
247
		$params_a_remplacer = array('veg' => 1043, 'bot' => 1083, 'pr' => 1030);
261
		$params_a_remplacer = array('veg' => 1043, 'bot' => 1083, 'pr' => 1030);
248
		foreach ($params_a_remplacer as $param => $id_liste) {
262
		foreach ($params_a_remplacer as $param => $id_liste) {
249
			if (isset($parametres[$param])) {
263
			if (isset($parametres[$param])) {
250
				// Si plusieurs valeurs séparées par des virgules
264
				// Si plusieurs valeurs séparées par des virgules
251
				$valeurs = explode(',', $parametres[$param]);
265
				$valeurs = explode(',', $parametres[$param]);
252
				$valeurs_nbre = count($valeurs);
266
				$valeurs_nbre = count($valeurs);
253
				$liste = Ontologie::getListeTrieeParAbreviation($id_liste); 
267
				$liste = Ontologie::getListeTrieeParAbreviation($id_liste); 
254
				foreach ($valeurs as $valeur) {
268
				foreach ($valeurs as $valeur) {
255
					$cle = strtoupper($valeur);
269
					$cle = strtoupper($valeur);
256
					if (isset($liste[$cle])) {
270
					if (isset($liste[$cle])) {
257
						if ($valeurs_nbre == 1) {
271
						if ($valeurs_nbre == 1) {
258
							$parametres[$param] = $liste[$cle]['id'];
272
							$parametres[$param] = $liste[$cle]['id'];
259
						} else if ($valeurs_nbre > 1) {
273
						} else if ($valeurs_nbre > 1) {
260
							$valeur = preg_quote($valeur, '/');
274
							$valeur = preg_quote($valeur, '/');
261
							$parametres[$param] = preg_replace("/$valeur/", $liste[$cle]['id'], $parametres[$param]);								
275
							$parametres[$param] = preg_replace("/$valeur/", $liste[$cle]['id'], $parametres[$param]);								
262
						}
276
						}
263
					}
277
					}
264
				}
278
				}
265
			}
279
			}
266
		}
280
		}
267
	}
281
	}
268
 
-
 
269
	private function limiterParProjets($parametres) {
-
 
270
		if (Config::get('projets') != '') {
-
 
271
			$parametres['projets'] = Config::get('projets');
-
 
272
		} else {
-
 
273
			$parametres['projets'] = '*';
-
 
274
		}
-
 
275
		return $parametres;
-
 
276
	}
-
 
277
}
282
}
278
283