584 |
mathilde |
1 |
<?php
|
|
|
2 |
/**
|
|
|
3 |
*
|
|
|
4 |
* fonctions et paramètres communs aux traitement des syntaxons
|
|
|
5 |
* - traitement de l'ontologie
|
|
|
6 |
* - fonction utiles pour les paramètres de configuration entre autres
|
|
|
7 |
* - traitement des tables et de leur version
|
|
|
8 |
* - traitement de la requête
|
|
|
9 |
*
|
|
|
10 |
* @package eflore-projets
|
|
|
11 |
* @author mathilde Salthun-Lassalle
|
|
|
12 |
* @license GPL v3 <http://www.gnu.org/licenses/gpl.txt>
|
|
|
13 |
* @license CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
|
|
|
14 |
* @version 1.0
|
|
|
15 |
* @copyright 1999-2012 Tela Botanica (accueil@tela-botanica.org)
|
|
|
16 |
*/
|
|
|
17 |
|
|
|
18 |
class SyntaxonsCommun extends Commun {
|
|
|
19 |
|
|
|
20 |
|
|
|
21 |
protected $table = "";
|
|
|
22 |
protected $format_reponse = 'syntaxons';
|
|
|
23 |
protected $serviceNom = 'syntaxons';
|
|
|
24 |
protected $Bdd;
|
|
|
25 |
protected $syn;
|
|
|
26 |
protected $niv;
|
|
|
27 |
protected $limite_requete = array('depart' => 0, 'limite' => 100);
|
|
|
28 |
protected $requete_condition = '';
|
|
|
29 |
protected $total_resultat;
|
|
|
30 |
protected $champs_recherches = ' * ';
|
|
|
31 |
protected $table_version;
|
|
|
32 |
protected $version_projet = '+' ;
|
901 |
raphael |
33 |
protected $cache = array();
|
584 |
mathilde |
34 |
|
|
|
35 |
|
|
|
36 |
public function __construct(Conteneur $conteneur) {
|
|
|
37 |
$this->Bdd = $conteneur->getBdd();
|
|
|
38 |
$this->syn = $this->getParametreTableauSpe('synonymes');
|
|
|
39 |
$this->niv = $this->getParametreTableauSpe('niveaux');
|
|
|
40 |
}
|
|
|
41 |
|
|
|
42 |
|
|
|
43 |
|
|
|
44 |
|
|
|
45 |
|
|
|
46 |
//+---------------------------------------------------outils------------------------------------------------//
|
|
|
47 |
protected function getParametreTableauSpe($cle) {
|
|
|
48 |
$tableau = array();
|
|
|
49 |
$parametre = Config::get($cle);
|
|
|
50 |
if (empty($parametre) === false) {
|
|
|
51 |
$tableauPartiel = explode(',', $parametre);
|
|
|
52 |
$tableauPartiel = array_map('trim', $tableauPartiel);
|
|
|
53 |
foreach ($tableauPartiel as $champ) {
|
|
|
54 |
$tableau[] = trim($champ,"'");// spécificité pour le = ? des synonymes
|
|
|
55 |
}
|
|
|
56 |
}
|
|
|
57 |
return $tableau;
|
|
|
58 |
}
|
|
|
59 |
|
|
|
60 |
//la fonction php array_filters ne marche pas sur le serveur
|
|
|
61 |
protected function enleverValeursVides($tableau) {
|
|
|
62 |
$tab = array();
|
|
|
63 |
foreach ($tableau as $cle => $valeur) {
|
|
|
64 |
if ($valeur != '' && is_int($cle)) {
|
|
|
65 |
$tab[] = $valeur;
|
|
|
66 |
} elseif ($valeur != '' && is_string($cle)) {
|
|
|
67 |
$tab[$cle] = $valeur;
|
|
|
68 |
}
|
|
|
69 |
}
|
|
|
70 |
return $tab;
|
|
|
71 |
}
|
|
|
72 |
|
|
|
73 |
//+++------------------------------traitement des versions----------------------------------------++
|
|
|
74 |
|
|
|
75 |
protected function traiterVersion($valeur) {
|
|
|
76 |
if (preg_match('/^[0-9]+(?:[._][0-9]+)*$/', $valeur) || $valeur == '+' || $valeur == '*') {
|
|
|
77 |
$this->version_projet = $valeur;
|
|
|
78 |
} else {
|
|
|
79 |
$e = "Erreur : La version est inconnue.";
|
|
|
80 |
throw new Exception($e, RestServeur::HTTP_CODE_MAUVAISE_REQUETE);
|
|
|
81 |
}
|
|
|
82 |
}
|
|
|
83 |
|
|
|
84 |
protected function definirTables() {
|
|
|
85 |
$table_num_version = $this->recupererVersionDisponible();
|
|
|
86 |
$prefixe_table = config::get('bdd_table');
|
|
|
87 |
if ( in_array($this->version_projet,$table_num_version) ) {
|
|
|
88 |
$this->table_version[] = $prefixe_table.'_v'.$this->version_projet;
|
|
|
89 |
} elseif ($this->version_projet == '+') {
|
|
|
90 |
$derniere_version = $table_num_version[count($table_num_version) - 1];
|
|
|
91 |
$this->table_version[] = $prefixe_table.'_v'.str_replace('.', '_', $derniere_version);
|
|
|
92 |
} elseif ($this->version_projet == '*') {
|
|
|
93 |
foreach ($table_num_version as $num_version) {
|
|
|
94 |
$this->table_version[] = $prefixe_table.'_v'.str_replace('.', '_', $num_version);
|
|
|
95 |
}
|
|
|
96 |
} else {
|
|
|
97 |
$e = "Erreur : La version est inconnue.";
|
|
|
98 |
throw new Exception($e, RestServeur::HTTP_CODE_MAUVAISE_REQUETE);
|
|
|
99 |
}
|
|
|
100 |
}
|
|
|
101 |
|
|
|
102 |
//+------------------------------------ontologies----------------------------------------------------+
|
|
|
103 |
|
|
|
104 |
protected function recupererOntologiesNiveau($valeur, $code){
|
|
|
105 |
$ontologie = array();
|
|
|
106 |
$url = Config::get('url_service_base').Config::get('nom_projet').
|
|
|
107 |
'/ontologies/'.$code.':'.urlencode(urlencode($valeur));
|
901 |
raphael |
108 |
if(array_key_exists($url, $this->cache)) {
|
|
|
109 |
$val = $this->cache[$url];
|
|
|
110 |
error_log("from cache");
|
|
|
111 |
} else {
|
|
|
112 |
$val = $this->consulterHref($url);
|
|
|
113 |
$this->cache[$url] = $val;
|
|
|
114 |
}
|
584 |
mathilde |
115 |
$ontologie['niveau.code'] = $valeur;
|
|
|
116 |
$ontologie['niveau.libelle'] = $val->nom;
|
|
|
117 |
$ontologie['niveau.href'] = $url;
|
|
|
118 |
return $ontologie;
|
|
|
119 |
}
|
|
|
120 |
|
|
|
121 |
protected function recupererOntologiesNiveauSyn($niveau){
|
|
|
122 |
$ontologie = array();
|
|
|
123 |
$synonymes = explode(' ',$niveau[1]);
|
|
|
124 |
$libelle = array();
|
|
|
125 |
$detail = array();
|
|
|
126 |
foreach ($synonymes as $syn) {
|
|
|
127 |
if ($syn == '=') {
|
|
|
128 |
$syn = 'equi';
|
|
|
129 |
} elseif ($syn == '= ?') {
|
|
|
130 |
$syn = 'prob';
|
|
|
131 |
}
|
|
|
132 |
if ($syn != '' && $syn != '?') {
|
|
|
133 |
$detail[] = $this->recupererOntologiesNiveau($syn, 'syn');
|
|
|
134 |
$dernier = end($detail);
|
|
|
135 |
$libelle[] = $dernier['niveau.libelle'].' ';
|
|
|
136 |
}
|
|
|
137 |
}
|
|
|
138 |
$ontologie['niveau.code'] = $niveau[0];
|
|
|
139 |
$ontologie['niveau.libelle'] = 'synonyme '.implode(' - ',$libelle);
|
|
|
140 |
if ($niveau[2]) {
|
|
|
141 |
$ontologie['niveau.libelle'] .= ' '.$niveau[2];
|
|
|
142 |
}
|
|
|
143 |
$ontologie['niveau.detail'] = $detail;
|
|
|
144 |
return $ontologie;
|
|
|
145 |
}
|
|
|
146 |
|
|
|
147 |
protected function traiterOntologieNiveau($niveau) {
|
|
|
148 |
$ontologie = array();
|
|
|
149 |
|
|
|
150 |
if ( preg_match('/syn {0,1}(['.implode('',$this->syn).']*)( *\[.+\])*/',$niveau,$retour)) {
|
|
|
151 |
|
|
|
152 |
$ontologie = $this->recupererOntologiesNiveauSyn($retour);
|
|
|
153 |
|
|
|
154 |
} else {
|
|
|
155 |
$ontologie = $this->recupererOntologiesNiveau($niveau, 'UP');
|
|
|
156 |
}
|
|
|
157 |
return $ontologie;
|
|
|
158 |
}
|
|
|
159 |
|
|
|
160 |
//+--------------------------FONCTIONS D'ASSEMBLAGE DE LA REQUETE-------------------------------------------+
|
|
|
161 |
|
|
|
162 |
protected function assemblerLaRequete() {
|
|
|
163 |
$requete = ' SELECT '.$this->champs_recherches.' FROM '.$this->table.' '
|
|
|
164 |
.$this->retournerRequeteCondition().' '.$this->delimiterResultatsRequete();
|
|
|
165 |
|
|
|
166 |
return $requete;
|
|
|
167 |
}
|
|
|
168 |
|
|
|
169 |
protected function calculerTotalResultat() {
|
|
|
170 |
$requete = 'SELECT count(*) as nombre FROM '.$this->table.' '.$this->retournerRequeteCondition();
|
|
|
171 |
|
|
|
172 |
$res = $this->getBdd()->recuperer($requete);
|
|
|
173 |
if ($res) {
|
|
|
174 |
$this->total_resultat = $res['nombre'];
|
|
|
175 |
} else {
|
|
|
176 |
$this->total_resultat = 0;
|
|
|
177 |
$e = 'Données introuvables dans la base';
|
|
|
178 |
$this->renvoyerErreur(RestServeur::HTTP_CODE_RESSOURCE_INTROUVABLE, $e);
|
|
|
179 |
}
|
|
|
180 |
}
|
|
|
181 |
|
|
|
182 |
protected function delimiterResultatsRequete() {
|
|
|
183 |
$this->calculerTotalResultat();
|
|
|
184 |
$requete_limite = '';
|
|
|
185 |
if (($this->limite_requete['depart'] <= $this->total_resultat) ){
|
|
|
186 |
if (($this->limite_requete['limite'] + $this->limite_requete['depart'] )
|
|
|
187 |
< $this->total_resultat ){
|
|
|
188 |
$requete_limite = 'LIMIT '.$this->limite_requete['depart'].', '
|
|
|
189 |
.$this->limite_requete['limite'];
|
|
|
190 |
}
|
|
|
191 |
} else {
|
|
|
192 |
$e = "Erreur : la valeur pour le paramètre navigation.départ est supérieure".
|
|
|
193 |
" au nombre total de résultats.";
|
|
|
194 |
throw new Exception($e, RestServeur::HTTP_CODE_RESSOURCE_INTROUVABLE);
|
|
|
195 |
}
|
|
|
196 |
return $requete_limite;
|
|
|
197 |
}
|
|
|
198 |
|
|
|
199 |
|
|
|
200 |
|
|
|
201 |
protected function retournerRequeteCondition() {
|
|
|
202 |
$condition = '';
|
|
|
203 |
if (empty($this->requete_condition) == false) {
|
|
|
204 |
$condition = ' WHERE '.implode(' AND ', $this->requete_condition);
|
|
|
205 |
}
|
|
|
206 |
|
|
|
207 |
return $condition;
|
|
|
208 |
}
|
|
|
209 |
|
|
|
210 |
}
|
|
|
211 |
?>
|