1 |
<?php
|
1 |
<?php
|
2 |
|
2 |
|
3 |
/**
|
3 |
/**
|
4 |
* Classe qui remplit un fond cartographique SVG a partir des observations en base de donnees
|
4 |
* Classe qui remplit un fond cartographique SVG a partir des observations en base de donnees
|
5 |
* pour un taxon de plante. Elle verifie dans un premier temps la validite des parametres saisis,
|
5 |
* pour un taxon de plante. Elle verifie dans un premier temps la validite des parametres saisis,
|
6 |
* puis charge le fond cartographique depuis le fichier, recupere dans la base de donnees
|
6 |
* puis charge le fond cartographique depuis le fichier, recupere dans la base de donnees
|
7 |
* les observations sur la France metropolitaine pour le taxon donne et remplit la carte
|
7 |
* les observations sur la France metropolitaine pour le taxon donne et remplit la carte
|
8 |
* en changeant le style CSS des mailles en fonction des coordonnees des points d'observation.
|
8 |
* en changeant le style CSS des mailles en fonction des coordonnees des points d'observation.
|
9 |
* Le format et la taille de la carte renvoyee au client est parametrable.
|
9 |
* Le format et la taille de la carte renvoyee au client est parametrable.
|
10 |
*
|
10 |
*
|
11 |
* Parametres :
|
11 |
* Parametres :
|
12 |
* - referentiel : le referentiel taxonomique a interroger pour verifier le taxon. Pour l'instant,
|
12 |
* - referentiel : le referentiel taxonomique a interroger pour verifier le taxon. Pour l'instant,
|
13 |
* seul bdtfx (Tracheophytes de France metropolirtaine) est utilise par le web service
|
13 |
* seul bdtfx (Tracheophytes de France metropolirtaine) est utilise par le web service
|
14 |
* - num_taxon : le numero taxonomique de la plante dont on veut obtenir la carte de repartition.
|
14 |
* - num_taxon : le numero taxonomique de la plante dont on veut obtenir la carte de repartition.
|
15 |
* Le rang des taxons traites par le web service sont la famille, le genre, l'espece et la sous-espece.
|
15 |
* Le rang des taxons traites par le web service sont la famille, le genre, l'espece et la sous-espece.
|
16 |
* La recherche des observations s'etend en pus sur les sous taxons et les synonymes.
|
16 |
* La recherche des observations s'etend en pus sur les sous taxons et les synonymes.
|
17 |
* - source : une ou plusieurs sources de donnees a interroger. Si le parametre n'est pas indique,
|
17 |
* - source : une ou plusieurs sources de donnees a interroger. Si le parametre n'est pas indique,
|
18 |
* le web service ira rechercher les observatipons dans toutes les sources de donnees.
|
18 |
* le web service ira rechercher les observatipons dans toutes les sources de donnees.
|
19 |
* - format : la largeur de la carte, exprimee dans une valeur entiere en pixels.
|
19 |
* - format : la largeur de la carte, exprimee dans une valeur entiere en pixels.
|
20 |
* Le ratio largeur:hauteur est conserve lors du redimensionnement de la carte pour le retour
|
20 |
* Le ratio largeur:hauteur est conserve lors du redimensionnement de la carte pour le retour
|
21 |
* - retour : le type MIME (ou format de fichier) de retour. Sont acceptes par le web service
|
21 |
* - retour : le type MIME (ou format de fichier) de retour. Sont acceptes par le web service
|
22 |
* le PNG (image/png) et le XML (text/html) pour renvoyer le web service
|
22 |
* le PNG (image/png) et le XML (text/html) pour renvoyer le web service
|
23 |
*
|
23 |
*
|
24 |
* @package framework-0.4
|
24 |
* @package framework-0.4
|
25 |
* @author Alexandre GALIBERT <alexandre.galibert@tela-botanica.org>
|
25 |
* @author Alexandre GALIBERT <alexandre.galibert@tela-botanica.org>
|
26 |
* @license GPL v3 <http://www.gnu.org/licenses/gpl.txt>
|
26 |
* @license GPL v3 <http://www.gnu.org/licenses/gpl.txt>
|
27 |
* @license CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
|
27 |
* @license CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
|
28 |
* @version $Id$
|
28 |
* @version $Id$
|
29 |
* @copyright 2013 Tela Botanica (accueil@tela-botanica.org)
|
29 |
* @copyright 2013 Tela Botanica (accueil@tela-botanica.org)
|
30 |
*
|
30 |
*
|
31 |
*/
|
31 |
*/
|
32 |
|
32 |
|
33 |
class Cartes {
|
33 |
class MoissonnageCartes {
|
34 |
|
34 |
|
35 |
const MIME_MAP = "text/html";
|
35 |
const MIME_MAP = "text/html";
|
36 |
const MIME_PNG = "image/png";
|
36 |
const MIME_PNG = "image/png";
|
37 |
|
37 |
|
38 |
private $ressources;
|
38 |
private $ressources;
|
39 |
private $parametres;
|
39 |
private $parametres;
|
40 |
|
40 |
|
41 |
private $referentiel = '';
|
41 |
private $referentiel = '';
|
42 |
private $taxon = null;
|
42 |
private $taxon = null;
|
43 |
private $sources = array();
|
43 |
private $sources = array();
|
44 |
private $format = 0;
|
44 |
private $format = 0;
|
45 |
private $retour = self::MIME_MAP;
|
45 |
private $retour = self::MIME_MAP;
|
46 |
private $erreurs = array();
|
46 |
private $erreurs = array();
|
47 |
|
47 |
|
48 |
|
48 |
|
49 |
public function consulter($ressources, $parametres) {
|
49 |
public function consulter($ressources, $parametres) {
|
50 |
$this->parametres = $parametres;
|
50 |
$this->parametres = $parametres;
|
51 |
$this->ressources = $ressources;
|
51 |
$this->ressources = $ressources;
|
52 |
$resultat = null;
|
52 |
$resultat = null;
|
53 |
$this->chargerClassesSousDossier();
|
53 |
$this->chargerClassesSousDossier();
|
54 |
if ($this->analyserRessources() == true) {
|
54 |
if ($this->analyserRessources() == true) {
|
55 |
$resultat = $this->formerLegende();
|
55 |
$resultat = $this->formerLegende();
|
56 |
} else {
|
56 |
} else {
|
57 |
$this->traiterParametres();
|
57 |
$this->traiterParametres();
|
58 |
$resultat = $this->formerCarte();
|
58 |
$resultat = $this->formerCarte();
|
59 |
}
|
59 |
}
|
60 |
return $resultat;
|
60 |
return $resultat;
|
61 |
}
|
61 |
}
|
62 |
|
62 |
|
63 |
private function analyserRessources() {
|
63 |
private function analyserRessources() {
|
64 |
$ok = false;
|
64 |
$ok = false;
|
65 |
if (isset($this->ressources[0]) && $this->ressources[0] == 'legende') {
|
65 |
if (isset($this->ressources[0]) && $this->ressources[0] == 'legende') {
|
66 |
$ok = true;
|
66 |
$ok = true;
|
67 |
}
|
67 |
}
|
68 |
return $ok;
|
68 |
return $ok;
|
69 |
}
|
69 |
}
|
70 |
|
70 |
|
71 |
private function formerLegende() {
|
71 |
private function formerLegende() {
|
72 |
$legende = new LegendeCartes();
|
72 |
$legende = new LegendeCartes();
|
73 |
$resultat = $legende->obtenirLegende();
|
73 |
$resultat = $legende->obtenirLegende();
|
74 |
return $resultat;
|
74 |
return $resultat;
|
75 |
}
|
75 |
}
|
76 |
|
76 |
|
77 |
private function chargerClassesSousDossier() {
|
77 |
private function chargerClassesSousDossier() {
|
78 |
$this->verifierExistenceDossier("cartes");
|
78 |
$this->verifierExistenceDossier("cartes");
|
79 |
$nomDossier = dirname(__FILE__).DS."cartes";
|
79 |
$nomDossier = dirname(__FILE__).DS."cartes";
|
80 |
$dossier = opendir($nomDossier);
|
80 |
$dossier = opendir($nomDossier);
|
81 |
$fichiersAInclure = array();
|
81 |
$fichiersAInclure = array();
|
82 |
while ($fichier = readdir($dossier)) {
|
82 |
while ($fichier = readdir($dossier)) {
|
83 |
if (filetype($nomDossier.DS.$fichier) == 'file') {
|
83 |
if (filetype($nomDossier.DS.$fichier) == 'file') {
|
84 |
$fichiersAInclure[] = $nomDossier.DS.$fichier;
|
84 |
$fichiersAInclure[] = $nomDossier.DS.$fichier;
|
85 |
}
|
85 |
}
|
86 |
}
|
86 |
}
|
87 |
$fichiersAInclure = array_reverse($fichiersAInclure);
|
87 |
$fichiersAInclure = array_reverse($fichiersAInclure);
|
88 |
foreach ($fichiersAInclure as $fichier) {
|
88 |
foreach ($fichiersAInclure as $fichier) {
|
89 |
include_once($fichier);
|
89 |
include_once($fichier);
|
90 |
}
|
90 |
}
|
91 |
}
|
91 |
}
|
92 |
|
92 |
|
93 |
private function verifierExistenceDossier($nomDossier) {
|
93 |
private function verifierExistenceDossier($nomDossier) {
|
94 |
$dossier = dirname(__FILE__).DS.$nomDossier;
|
94 |
$dossier = dirname(__FILE__).DS.$nomDossier;
|
95 |
if (!file_exists($dossier) || !is_dir($dossier)) {
|
95 |
if (!file_exists($dossier) || !is_dir($dossier)) {
|
96 |
$message = "Problème rencontré lors de la génération de la carte : des ressources ".
|
96 |
$message = "Problème rencontré lors de la génération de la carte : des ressources ".
|
97 |
"nécessaires au fonctionnement du service n'ont pas été localisées sur le serveur.\n";
|
97 |
"nécessaires au fonctionnement du service n'ont pas été localisées sur le serveur.\n";
|
98 |
throw new Exception($message);
|
98 |
throw new Exception($message);
|
99 |
}
|
99 |
}
|
100 |
}
|
100 |
}
|
101 |
|
101 |
|
102 |
private function verifierExistenceFichier($nomFichier) {
|
102 |
private function verifierExistenceFichier($nomFichier) {
|
103 |
if (!file_exists($nomFichier)) {
|
103 |
if (!file_exists($nomFichier)) {
|
104 |
$message = "Problème rencontré lors de la génération de la carte : des ressources ".
|
104 |
$message = "Problème rencontré lors de la génération de la carte : des ressources ".
|
105 |
"nécessaires au fonctionnement du service n'ont pas été localisées sur le serveur.\n";
|
105 |
"nécessaires au fonctionnement du service n'ont pas été localisées sur le serveur.\n";
|
106 |
throw new Exception($message);
|
106 |
throw new Exception($message);
|
107 |
}
|
107 |
}
|
108 |
}
|
108 |
}
|
109 |
|
109 |
|
110 |
private function traiterParametres() {
|
110 |
private function traiterParametres() {
|
111 |
$this->verifierReferentielEtTaxon();
|
111 |
$this->verifierReferentielEtTaxon();
|
112 |
$this->verifierParametreSource();
|
112 |
$this->verifierParametreSource();
|
113 |
$this->verifierParametreFormat();
|
113 |
$this->verifierParametreFormat();
|
114 |
$this->verifierParametreRetour();
|
114 |
$this->verifierParametreRetour();
|
115 |
if (count($this->erreurs) > 0) {
|
115 |
if (count($this->erreurs) > 0) {
|
116 |
$this->renvoyerErreurs();
|
116 |
$this->renvoyerErreurs();
|
117 |
}
|
117 |
}
|
118 |
}
|
118 |
}
|
119 |
|
119 |
|
120 |
private function verifierParametreFormat() {
|
120 |
private function verifierParametreFormat() {
|
121 |
if (!isset($this->parametres['format'])) {
|
121 |
if (!isset($this->parametres['format'])) {
|
122 |
$this->erreurs[] = "Le paramètre format (dimensions) de l'image n'a pas été indiqué dans l'URL du service.";
|
122 |
$this->erreurs[] = "Le paramètre format (dimensions) de l'image n'a pas été indiqué dans l'URL du service.";
|
123 |
} elseif (preg_match('/^[1-9]\d{2}$/', $this->parametres['format']) != 1) {
|
123 |
} elseif (preg_match('/^[1-9]\d{2}$/', $this->parametres['format']) != 1) {
|
124 |
$this->erreurs[] = "La valeur du paramètre format n'est pas acceptée par le service. ".
|
124 |
$this->erreurs[] = "La valeur du paramètre format n'est pas acceptée par le service. ".
|
125 |
"Une largeur valide doit être un nombre entier compris entre 100 et 999.";
|
125 |
"Une largeur valide doit être un nombre entier compris entre 100 et 999.";
|
126 |
} else {
|
126 |
} else {
|
127 |
$this->format = $this->parametres['format'];
|
127 |
$this->format = $this->parametres['format'];
|
128 |
}
|
128 |
}
|
129 |
}
|
129 |
}
|
130 |
|
130 |
|
131 |
private function verifierParametreRetour() {
|
131 |
private function verifierParametreRetour() {
|
132 |
$typesMime = array(self::MIME_MAP, self::MIME_PNG);
|
132 |
$typesMime = array(self::MIME_MAP, self::MIME_PNG);
|
133 |
if (!isset($this->parametres['retour'])) {
|
133 |
if (!isset($this->parametres['retour'])) {
|
134 |
$this->erreurs[] = "Le paramètre type de retour de l'image n'a pas été indiqué dans l'URL du service.";
|
134 |
$this->erreurs[] = "Le paramètre type de retour de l'image n'a pas été indiqué dans l'URL du service.";
|
135 |
} elseif (!in_array($this->parametres['retour'], $typesMime)) {
|
135 |
} elseif (!in_array($this->parametres['retour'], $typesMime)) {
|
136 |
$this->erreurs[] = "Le format de retour ".$this->parametres['retour']." n'est pas acceptée par le service. ".
|
136 |
$this->erreurs[] = "Le format de retour ".$this->parametres['retour']." n'est pas acceptée par le service. ".
|
137 |
" Seuls les types MIME suivants sont gérés : ".implode(',', $typesMime);
|
137 |
" Seuls les types MIME suivants sont gérés : ".implode(',', $typesMime);
|
138 |
} else {
|
138 |
} else {
|
139 |
$this->retour = $this->parametres['retour'];
|
139 |
$this->retour = $this->parametres['retour'];
|
140 |
}
|
140 |
}
|
141 |
}
|
141 |
}
|
142 |
|
142 |
|
143 |
private function verifierParametreSource() {
|
143 |
private function verifierParametreSource() {
|
144 |
$sourcesDisponibles = explode(',', trim(Config::get('sourcesDonnees')));
|
144 |
$sourcesDisponibles = explode(',', trim(Config::get('sourcesDonnees')));
|
145 |
if (isset($this->parametres['source'])) {
|
145 |
if (isset($this->parametres['source'])) {
|
146 |
$sourcesParametre = explode(',', trim($this->parametres['source']));
|
146 |
$sourcesParametre = explode(',', trim($this->parametres['source']));
|
147 |
foreach ($sourcesParametre as $source) {
|
147 |
foreach ($sourcesParametre as $source) {
|
148 |
if (!in_array($source, $sourcesDisponibles)) {
|
148 |
if (!in_array($source, $sourcesDisponibles)) {
|
149 |
$this->erreurs[] = "La source de données $source n'est pas disponible pour ce service. ".
|
149 |
$this->erreurs[] = "La source de données $source n'est pas disponible pour ce service. ".
|
150 |
"Les sources suivantes sont utilisables : ".implode(',', $sourcesDisponibles).".";
|
150 |
"Les sources suivantes sont utilisables : ".implode(',', $sourcesDisponibles).".";
|
151 |
} else {
|
151 |
} else {
|
152 |
$this->sources[] = $source;
|
152 |
$this->sources[] = $source;
|
153 |
}
|
153 |
}
|
154 |
}
|
154 |
}
|
155 |
} else {
|
155 |
} else {
|
156 |
$this->sources = $sourcesDisponibles;
|
156 |
$this->sources = $sourcesDisponibles;
|
157 |
}
|
157 |
}
|
158 |
}
|
158 |
}
|
159 |
|
159 |
|
160 |
private function verifierReferentielEtTaxon() {
|
160 |
private function verifierReferentielEtTaxon() {
|
161 |
if (!$this->estReferentielDisponible()) {
|
161 |
if (!$this->estReferentielDisponible()) {
|
162 |
$this->erreurs[] = "Le référentiel ".$this->parametres['referentiel']." n'a pas été trouvé. ".
|
162 |
$this->erreurs[] = "Le référentiel ".$this->parametres['referentiel']." n'a pas été trouvé. ".
|
163 |
"La liste des référentiels disponibles pour ce service sont : ".Config::get('referentielsDispo');
|
163 |
"La liste des référentiels disponibles pour ce service sont : ".Config::get('referentielsDispo');
|
164 |
} else {
|
164 |
} else {
|
165 |
$this->referentiel = $this->parametres['referentiel'];
|
165 |
$this->referentiel = $this->parametres['referentiel'];
|
166 |
$taxon = $this->recupererInformationsTaxon();
|
166 |
$taxon = $this->recupererInformationsTaxon();
|
167 |
if (is_null($taxon)) {
|
167 |
if (is_null($taxon)) {
|
168 |
$this->erreurs[] = "Le taxon d'espèce que vous avez demandé n'a pas été trouvé dans le référentiel.";
|
168 |
$this->erreurs[] = "Le taxon d'espèce que vous avez demandé n'a pas été trouvé dans le référentiel.";
|
169 |
} else {
|
169 |
} else {
|
170 |
$this->taxon = $taxon;
|
170 |
$this->taxon = $taxon;
|
171 |
}
|
171 |
}
|
172 |
}
|
172 |
}
|
173 |
}
|
173 |
}
|
174 |
|
174 |
|
175 |
private function renvoyerErreurs() {
|
175 |
private function renvoyerErreurs() {
|
176 |
$message = "Les erreurs suivantes ont été rencontrées : \n".implode('\n', $this->erreurs);
|
176 |
$message = "Les erreurs suivantes ont été rencontrées : \n".implode('\n', $this->erreurs);
|
177 |
throw new Exception($message, RestServeur::HTTP_CODE_MAUVAISE_REQUETE);
|
177 |
throw new Exception($message, RestServeur::HTTP_CODE_MAUVAISE_REQUETE);
|
178 |
}
|
178 |
}
|
179 |
|
179 |
|
180 |
private function estReferentielDisponible() {
|
180 |
private function estReferentielDisponible() {
|
181 |
$referentielsDispo = explode(',', Config::get('referentielsDispo'));
|
181 |
$referentielsDispo = explode(',', Config::get('referentielsDispo'));
|
182 |
$estDisponible = (isset($this->parametres['referentiel'])
|
182 |
$estDisponible = (isset($this->parametres['referentiel'])
|
183 |
&& in_array($this->parametres['referentiel'], $referentielsDispo));
|
183 |
&& in_array($this->parametres['referentiel'], $referentielsDispo));
|
184 |
return $estDisponible;
|
184 |
return $estDisponible;
|
185 |
}
|
185 |
}
|
186 |
|
186 |
|
187 |
private function recupererInformationsTaxon() {
|
187 |
private function recupererInformationsTaxon() {
|
188 |
$taxon = null;
|
188 |
$taxon = null;
|
189 |
if (isset($this->parametres['num_taxon'])) {
|
189 |
if (isset($this->parametres['num_taxon'])) {
|
190 |
$numTaxon = $this->parametres['num_taxon'];
|
190 |
$numTaxon = $this->parametres['num_taxon'];
|
191 |
$nomTable = $this->recupererNomTableReferentiel();
|
191 |
$nomTable = $this->recupererNomTableReferentiel();
|
192 |
$bdd = new Bdd();
|
192 |
$bdd = new Bdd();
|
193 |
$requete = "SELECT num_nom, num_nom_retenu, nom_sci, rang, num_taxonomique FROM {$nomTable} ".
|
193 |
$requete = "SELECT num_nom, num_nom_retenu, nom_sci, rang, num_taxonomique FROM {$nomTable} ".
|
194 |
"WHERE num_taxonomique={$numTaxon} ORDER BY If(num_nom=num_nom_retenu,0,1) LIMIT 0,1";
|
194 |
"WHERE num_taxonomique={$numTaxon} ORDER BY If(num_nom=num_nom_retenu,0,1) LIMIT 0,1";
|
195 |
$taxon = $bdd->recuperer($requete);
|
195 |
$taxon = $bdd->recuperer($requete);
|
196 |
if ($taxon === false) {
|
196 |
if ($taxon === false) {
|
197 |
$taxon = null;
|
197 |
$taxon = null;
|
198 |
}
|
198 |
}
|
199 |
}
|
199 |
}
|
200 |
return $taxon;
|
200 |
return $taxon;
|
201 |
}
|
201 |
}
|
202 |
|
202 |
|
203 |
private function recupererNomTableReferentiel() {
|
203 |
private function recupererNomTableReferentiel() {
|
204 |
$tablesReferentiel = explode(',', Config::get('bdd_table_referentiel'));
|
204 |
$tablesReferentiel = explode(',', Config::get('bdd_table_referentiel'));
|
205 |
$nomTable = '';
|
205 |
$nomTable = '';
|
206 |
foreach ($tablesReferentiel as $table) {
|
206 |
foreach ($tablesReferentiel as $table) {
|
207 |
if (strstr($table, $this->referentiel) !== false) {
|
207 |
if (strstr($table, $this->referentiel) !== false) {
|
208 |
$nomTable = $table;
|
208 |
$nomTable = $table;
|
209 |
}
|
209 |
}
|
210 |
}
|
210 |
}
|
211 |
return $nomTable;
|
211 |
return $nomTable;
|
212 |
}
|
212 |
}
|
213 |
|
213 |
|
214 |
private function formerCarte() {
|
214 |
private function formerCarte() {
|
215 |
$suffixe = 'france_moissonnage';
|
215 |
$suffixe = 'france_moissonnage';
|
216 |
$nomFichierSVG = Config::get('chemin')."{$suffixe}.svg";
|
216 |
$nomFichierSVG = Config::get('chemin')."{$suffixe}.svg";
|
217 |
$this->verifierExistenceFichier($nomFichierSVG);
|
217 |
$this->verifierExistenceFichier($nomFichierSVG);
|
218 |
|
218 |
|
219 |
$formateur = new FormateurSVG($nomFichierSVG, $this->sources, $this->retour, $this->format);
|
219 |
$formateur = new FormateurSVG($nomFichierSVG, $this->sources, $this->retour, $this->format);
|
220 |
$formateur->formaterCarte($this->taxon);
|
220 |
$formateur->formaterCarte($this->taxon);
|
221 |
$resultat = new ResultatService();
|
221 |
$resultat = new ResultatService();
|
222 |
$resultat->corps = $formateur->renvoyerCarte();
|
222 |
$resultat->corps = $formateur->renvoyerCarte();
|
223 |
$resultat->mime = $this->retour;
|
223 |
$resultat->mime = $this->retour;
|
224 |
|
224 |
|
225 |
return $resultat;
|
225 |
return $resultat;
|
226 |
}
|
226 |
}
|
227 |
|
227 |
|
228 |
}
|
228 |
}
|
229 |
|
229 |
|
230 |
?>
|
230 |
?>
|