727 |
alex |
1 |
<?php
|
|
|
2 |
|
747 |
alex |
3 |
class SourceDonnees {
|
727 |
alex |
4 |
|
747 |
alex |
5 |
private $bdd = null;
|
|
|
6 |
private $limitesCarte = '';
|
|
|
7 |
private $taxon = array();
|
727 |
alex |
8 |
|
747 |
alex |
9 |
private $nomRang = '';
|
|
|
10 |
private $taxons = array();
|
|
|
11 |
private $genres = array();
|
878 |
aurelien |
12 |
private $utilisateurs = null;
|
727 |
alex |
13 |
|
747 |
alex |
14 |
|
|
|
15 |
public function __construct($limitesCarte, $taxon) {
|
727 |
alex |
16 |
$this->limitesCarte = $limitesCarte;
|
|
|
17 |
foreach ($this->limitesCarte as $bord => $valeur) {
|
|
|
18 |
$this->limitesCarte[$bord] = str_replace(",", ".", round($valeur, 6));
|
|
|
19 |
}
|
|
|
20 |
$this->bdd = new Bdd();
|
|
|
21 |
$this->taxon = $taxon;
|
747 |
alex |
22 |
$this->nomRang = $this->obtenirNomRang();
|
|
|
23 |
if ($this->nomRang == 'espece' || $this->nomRang == 'sous_espece') {
|
|
|
24 |
$this->taxons = $this->recupererSynonymesEtSousEspeces();
|
|
|
25 |
} elseif ($this->nomRang == 'famille') {
|
|
|
26 |
$this->genres = $this->recupererGenres();
|
|
|
27 |
}
|
878 |
aurelien |
28 |
$this->utilisateurs = new Utilisateurs();
|
727 |
alex |
29 |
}
|
|
|
30 |
|
747 |
alex |
31 |
private function obtenirNomRang() {
|
727 |
alex |
32 |
$nomsRangs = array('famille', 'genre', 'espece', 'sous_espece');
|
|
|
33 |
$rangs = explode(',', Config::get('rangs'));
|
|
|
34 |
for ($index = 0; $index < count($nomsRangs) && $rangs[$index] != $this->taxon['rang']; $index ++);
|
|
|
35 |
$position = $index == count($nomsRangs) ? count($nomsRangs)-1 : $index;
|
|
|
36 |
return $nomsRangs[$position];
|
|
|
37 |
}
|
|
|
38 |
|
|
|
39 |
protected function recupererSynonymesEtSousEspeces() {
|
|
|
40 |
$requete =
|
970 |
delphine |
41 |
"SELECT num_nom, nom_sci, nom_complet, num_taxonomique FROM bdtfx_v1_01 WHERE hierarchie LIKE '%-{$this->taxon['num_nom']}-%' ".
|
727 |
alex |
42 |
"OR num_taxonomique = {$this->taxon['num_taxonomique']}";
|
|
|
43 |
return $this->bdd->recupererTous($requete);
|
|
|
44 |
}
|
|
|
45 |
|
|
|
46 |
protected function recupererGenres() {
|
|
|
47 |
$this->bdd->requeter("USE ".Config::get('bdd_nom'));
|
|
|
48 |
$requete =
|
|
|
49 |
"SELECT num_nom, nom_sci, num_taxonomique FROM bdtfx_v1_01 WHERE rang=220 AND num_tax_sup={$this->taxon['num_nom']}";
|
|
|
50 |
return $this->bdd->recupererTous($requete);
|
|
|
51 |
}
|
|
|
52 |
|
747 |
alex |
53 |
public function recupererStationsFloradata() {
|
|
|
54 |
$this->bdd->requeter("USE ".Config::get('bdd_nom_floradata'));
|
|
|
55 |
$requete =
|
|
|
56 |
"SELECT DISTINCTROW zone_geo AS commune, Date(date_observation) AS date, Floor(wgs84_latitude*10)/10 AS lat, ".
|
|
|
57 |
"Floor(wgs84_longitude*10)/10 AS lng, courriel_utilisateur AS auteur ".
|
|
|
58 |
"FROM cel_obs LEFT JOIN cel_zones_geo cz ON ce_zone_geo=id_zone_geo ".
|
|
|
59 |
"WHERE ".$this->construireWhereTaxonFloradata()." AND transmission=1 AND ".
|
|
|
60 |
"wgs84_longitude BETWEEN ".$this->limitesCarte['ouest']." AND ".$this->limitesCarte['est']." ".
|
|
|
61 |
"AND wgs84_latitude BETWEEN ".$this->limitesCarte['sud']." AND ".$this->limitesCarte['nord']." ".
|
|
|
62 |
"AND date_observation<>'0000-00-00 00-00-00' ORDER BY lat DESC, lng ASC, commune, date";
|
878 |
aurelien |
63 |
$stations = $this->bdd->recupererTous($requete);
|
|
|
64 |
|
|
|
65 |
$this->extraireIdentitesAuteurs($stations);
|
|
|
66 |
foreach($stations as &$station) {
|
|
|
67 |
$station['auteur'] = $this->utilisateurs->getIntitule($station['auteur']);
|
|
|
68 |
}
|
|
|
69 |
return $stations;
|
747 |
alex |
70 |
}
|
|
|
71 |
|
878 |
aurelien |
72 |
private function extraireIdentitesAuteurs($stations) {
|
|
|
73 |
$courriels = array();
|
|
|
74 |
foreach ($stations as &$station) {
|
|
|
75 |
$courriels[] = $station['auteur'];
|
|
|
76 |
}
|
|
|
77 |
$this->utilisateurs->setCourriels($courriels);
|
|
|
78 |
$this->utilisateurs->chargerIdentites();
|
|
|
79 |
}
|
|
|
80 |
|
747 |
alex |
81 |
private function construireWhereTaxonFloradata() {
|
|
|
82 |
$criteres = array();
|
|
|
83 |
$nomRang = $this->obtenirNomRang($this->taxon);
|
|
|
84 |
if ($this->nomRang == 'famille') {
|
|
|
85 |
$criteres[] = "famille=".$this->bdd->proteger($this->taxon['nom_sci']);
|
|
|
86 |
} elseif ($this->nomRang == 'genre') {
|
|
|
87 |
$criteres[] = "nom_sel LIKE ".$this->bdd->proteger($this->taxon['nom_sci'].'%');
|
|
|
88 |
} else {
|
|
|
89 |
$taxons = array($this->taxon['num_taxonomique']);
|
|
|
90 |
foreach ($this->taxons as $sousTaxon) {
|
|
|
91 |
$taxons[] = $sousTaxon['num_taxonomique'];
|
|
|
92 |
}
|
|
|
93 |
$criteres[] = "nt IN (".implode(',', array_unique($taxons)) .")";
|
|
|
94 |
}
|
|
|
95 |
return "(".implode(' OR ',array_unique($criteres)).")";
|
|
|
96 |
}
|
|
|
97 |
|
|
|
98 |
public function recupererStationsMoissonnage($source) {
|
|
|
99 |
$this->bdd->requeter("USE ".Config::get('bdd_nom'));
|
|
|
100 |
$requete =
|
|
|
101 |
"SELECT DISTINCTROW lieu_commune_code_insee, observation_date AS date, observateur_nom_complet AS auteur ".
|
970 |
delphine |
102 |
"FROM {$source}_tapir WHERE ".$this->construireWhereTaxonMoissonnage($source)." ".
|
747 |
alex |
103 |
"AND lieu_station_longitude BETWEEN ".$this->limitesCarte['ouest']." AND ".$this->limitesCarte['est']." ".
|
|
|
104 |
"AND lieu_station_latitude BETWEEN ".$this->limitesCarte['sud']." AND ".$this->limitesCarte['nord']." ".
|
949 |
raphael |
105 |
"AND Length(lieu_commune_code_insee)=5 ORDER BY lieu_commune_code_insee, date"." -- " . __FILE__ . ":" . __LINE__." ". @$_SERVER['REQUEST_URI'];
|
747 |
alex |
106 |
$stations = $this->bdd->recupererTous($requete);
|
|
|
107 |
$this->rechercherInfosCommune($stations);
|
|
|
108 |
return $stations;
|
|
|
109 |
}
|
|
|
110 |
|
970 |
delphine |
111 |
private function construireWhereTaxonMoissonnage($source) {
|
747 |
alex |
112 |
$nomRang = $this->obtenirNomRang();
|
|
|
113 |
$criteres = array();
|
970 |
delphine |
114 |
|
|
|
115 |
$nom = ($source == "baznat") ? implode('%',explode(' ',$this->taxon['nom_complet'] )) : $this->taxon['nom_sci'] ;
|
|
|
116 |
$criteres[] = "nom_scientifique_complet LIKE ".$this->bdd->proteger($nom);
|
747 |
alex |
117 |
if ($this->nomRang == 'espece' || $this->nomRang == 'sous_espece') {
|
|
|
118 |
foreach ($this->taxons as $sousTaxon) {
|
970 |
delphine |
119 |
$nom = ($source == "baznat") ? implode('%',explode(' ',$sousTaxon['nom_complet'] )) : $sousTaxon['nom_sci'];
|
|
|
120 |
$criteres[] = "nom_scientifique_complet LIKE ".$this->bdd->proteger($nom);
|
747 |
alex |
121 |
}
|
|
|
122 |
} elseif ($this->nomRang == 'famille') {
|
|
|
123 |
foreach ($this->genres as $genre) {
|
|
|
124 |
$criteres[] = "nom_scientifique_complet LIKE ".$this->bdd->proteger($genre['nom_sci']."%");
|
|
|
125 |
}
|
|
|
126 |
}
|
|
|
127 |
return "(".implode(' OR ',array_unique($criteres)).")";
|
|
|
128 |
}
|
|
|
129 |
|
|
|
130 |
private function rechercherInfosCommune(& $stations) {
|
|
|
131 |
$codesInsee = array();
|
|
|
132 |
foreach ($stations as $station) {
|
|
|
133 |
$codeInsee = $station['lieu_commune_code_insee'];
|
|
|
134 |
if (substr($codeInsee, 0, 2) == '20') {
|
|
|
135 |
$codeInsee = '2A'.substr($codeInsee, 2);
|
|
|
136 |
$codeInsee2 = '2B'.substr($codeInsee, 2);
|
|
|
137 |
}
|
|
|
138 |
if (!in_array($codeInsee, $codesInsee)) {
|
|
|
139 |
if (substr($codeInsee, 0, 2) == '20') {
|
|
|
140 |
$codesInsee[] = "'$codeInsee2'";
|
|
|
141 |
}
|
|
|
142 |
$codesInsee[] = "'$codeInsee'";
|
|
|
143 |
}
|
|
|
144 |
}
|
751 |
alex |
145 |
$nomTableCommunes = Config::get('bdd_table_communes');
|
860 |
aurelien |
146 |
$communes = array();
|
|
|
147 |
if(count($codesInsee) > 0) {
|
|
|
148 |
$requete =
|
|
|
149 |
"SELECT insee, nom AS commune, Floor(latitude_degre*10)/10 AS lat, Floor(longitude_degre*10)/10 AS lng ".
|
|
|
150 |
"FROM $nomTableCommunes WHERE insee IN (".implode(',', array_unique($codesInsee)).") ORDER BY insee";
|
|
|
151 |
$communes = $this->bdd->recupererTous($requete);
|
|
|
152 |
}
|
747 |
alex |
153 |
$indexStation = 0;
|
|
|
154 |
foreach ($communes as $commune) {
|
|
|
155 |
$codeInsee = $commune['insee'];
|
|
|
156 |
if (substr($codeInsee, 0, 2) == '2A' || substr($codeInsee, 0, 2) == '2B') {
|
|
|
157 |
$codeInsee = '20'.substr($codeInsee, 2);
|
|
|
158 |
}
|
|
|
159 |
while ($stations[$indexStation]['lieu_commune_code_insee'] < $codeInsee) {
|
|
|
160 |
$indexStation ++;
|
|
|
161 |
}
|
|
|
162 |
if ($stations[$indexStation]['lieu_commune_code_insee'] == $codeInsee) {
|
|
|
163 |
$stations[$indexStation]['lat'] = $commune['lat'];
|
|
|
164 |
$stations[$indexStation]['lng'] = $commune['lng'];
|
|
|
165 |
$stations[$indexStation]['commune'] = $commune['commune'];
|
|
|
166 |
}
|
|
|
167 |
}
|
|
|
168 |
|
|
|
169 |
$lat = array();
|
|
|
170 |
$lng = array();
|
|
|
171 |
foreach ($stations as $index => $station) {
|
|
|
172 |
if (!isset($station['lat'])) {
|
|
|
173 |
$station['lat'] = -100;
|
|
|
174 |
$station['lng'] = -100;
|
|
|
175 |
}
|
|
|
176 |
$lat[$index] = $station['lat'];
|
|
|
177 |
$lng[$index] = $station['lng'];
|
|
|
178 |
}
|
|
|
179 |
array_multisort($lat, SORT_DESC, $lng, SORT_ASC, $stations);
|
|
|
180 |
}
|
|
|
181 |
|
727 |
alex |
182 |
}
|
|
|
183 |
|
|
|
184 |
?>
|