| 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 =
 | 
        
           |  |  | 41 | 		"SELECT num_nom, nom_sci, num_taxonomique FROM bdtfx_v1_01 WHERE hierarchie LIKE '%-{$this->taxon['num_nom']}-%' ".
 | 
        
           |  |  | 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 ".
 | 
        
           |  |  | 102 | 		"FROM {$source}_tapir WHERE ".$this->construireWhereTaxonMoissonnage()." ".
 | 
        
           |  |  | 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']." ".
 | 
        
           |  |  | 105 | 		"AND Length(lieu_commune_code_insee)=5 ORDER BY lieu_commune_code_insee, date";
 | 
        
           |  |  | 106 | 		$stations = $this->bdd->recupererTous($requete);
 | 
        
           |  |  | 107 | 		$this->rechercherInfosCommune($stations);
 | 
        
           |  |  | 108 | 		return $stations;
 | 
        
           |  |  | 109 | 	}
 | 
        
           |  |  | 110 |   | 
        
           |  |  | 111 | 	private function construireWhereTaxonMoissonnage() {
 | 
        
           |  |  | 112 | 		$nomRang = $this->obtenirNomRang();
 | 
        
           |  |  | 113 | 		$criteres = array();
 | 
        
           |  |  | 114 | 		$criteres[] = "nom_scientifique_complet LIKE ".$this->bdd->proteger($this->taxon['nom_sci']."%");
 | 
        
           |  |  | 115 | 		if ($this->nomRang == 'espece' || $this->nomRang == 'sous_espece') {
 | 
        
           |  |  | 116 | 			foreach ($this->taxons as $sousTaxon) {
 | 
        
           |  |  | 117 | 				$criteres[] = "nom_scientifique_complet LIKE ".$this->bdd->proteger($sousTaxon['nom_sci']."%");
 | 
        
           |  |  | 118 | 			}
 | 
        
           |  |  | 119 | 		} elseif ($this->nomRang == 'famille') {
 | 
        
           |  |  | 120 | 			foreach ($this->genres as $genre) {
 | 
        
           |  |  | 121 | 				$criteres[] = "nom_scientifique_complet LIKE ".$this->bdd->proteger($genre['nom_sci']."%");
 | 
        
           |  |  | 122 | 			}
 | 
        
           |  |  | 123 | 		}
 | 
        
           |  |  | 124 | 		return "(".implode(' OR ',array_unique($criteres)).")";
 | 
        
           |  |  | 125 | 	}
 | 
        
           |  |  | 126 |   | 
        
           |  |  | 127 | 	private function rechercherInfosCommune(& $stations) {
 | 
        
           |  |  | 128 | 		$codesInsee = array();
 | 
        
           |  |  | 129 | 		foreach ($stations as $station) {
 | 
        
           |  |  | 130 | 			$codeInsee = $station['lieu_commune_code_insee'];
 | 
        
           |  |  | 131 | 			if (substr($codeInsee, 0, 2) == '20') {
 | 
        
           |  |  | 132 | 				$codeInsee  = '2A'.substr($codeInsee, 2);
 | 
        
           |  |  | 133 | 				$codeInsee2 = '2B'.substr($codeInsee, 2);
 | 
        
           |  |  | 134 | 			}
 | 
        
           |  |  | 135 | 			if (!in_array($codeInsee, $codesInsee)) {
 | 
        
           |  |  | 136 | 				if (substr($codeInsee, 0, 2) == '20') {
 | 
        
           |  |  | 137 | 					$codesInsee[] = "'$codeInsee2'";
 | 
        
           |  |  | 138 | 				}
 | 
        
           |  |  | 139 | 				$codesInsee[] = "'$codeInsee'";
 | 
        
           |  |  | 140 | 			}
 | 
        
           |  |  | 141 | 		}
 | 
        
           | 751 | alex | 142 | 		$nomTableCommunes = Config::get('bdd_table_communes');
 | 
        
           | 860 | aurelien | 143 | 		$communes = array();
 | 
        
           |  |  | 144 | 		if(count($codesInsee) > 0) {
 | 
        
           |  |  | 145 | 			$requete =
 | 
        
           |  |  | 146 | 			"SELECT insee, nom AS commune, Floor(latitude_degre*10)/10 AS lat, Floor(longitude_degre*10)/10 AS lng ".
 | 
        
           |  |  | 147 | 			"FROM $nomTableCommunes WHERE insee IN (".implode(',', array_unique($codesInsee)).") ORDER BY insee";
 | 
        
           |  |  | 148 | 			$communes = $this->bdd->recupererTous($requete);
 | 
        
           |  |  | 149 | 		}
 | 
        
           | 747 | alex | 150 | 		$indexStation = 0;
 | 
        
           |  |  | 151 | 		foreach ($communes as $commune) {
 | 
        
           |  |  | 152 | 			$codeInsee = $commune['insee'];
 | 
        
           |  |  | 153 | 			if (substr($codeInsee, 0, 2) == '2A' || substr($codeInsee, 0, 2) == '2B') {
 | 
        
           |  |  | 154 | 				$codeInsee = '20'.substr($codeInsee, 2);
 | 
        
           |  |  | 155 | 			}
 | 
        
           |  |  | 156 | 			while ($stations[$indexStation]['lieu_commune_code_insee'] < $codeInsee) {
 | 
        
           |  |  | 157 | 				$indexStation ++;
 | 
        
           |  |  | 158 | 			}
 | 
        
           |  |  | 159 | 			if ($stations[$indexStation]['lieu_commune_code_insee'] == $codeInsee) {
 | 
        
           |  |  | 160 | 				$stations[$indexStation]['lat'] = $commune['lat'];
 | 
        
           |  |  | 161 | 				$stations[$indexStation]['lng'] = $commune['lng'];
 | 
        
           |  |  | 162 | 				$stations[$indexStation]['commune'] = $commune['commune'];
 | 
        
           |  |  | 163 | 			}
 | 
        
           |  |  | 164 | 		}
 | 
        
           |  |  | 165 |   | 
        
           |  |  | 166 | 		$lat = array();
 | 
        
           |  |  | 167 | 		$lng = array();
 | 
        
           |  |  | 168 | 		foreach ($stations as $index => $station) {
 | 
        
           |  |  | 169 | 			if (!isset($station['lat'])) {
 | 
        
           |  |  | 170 | 				$station['lat'] = -100;
 | 
        
           |  |  | 171 | 				$station['lng'] = -100;
 | 
        
           |  |  | 172 | 			}
 | 
        
           |  |  | 173 | 			$lat[$index] = $station['lat'];
 | 
        
           |  |  | 174 | 			$lng[$index] = $station['lng'];
 | 
        
           |  |  | 175 | 		}
 | 
        
           |  |  | 176 | 		array_multisort($lat, SORT_DESC, $lng, SORT_ASC, $stations);
 | 
        
           |  |  | 177 | 	}
 | 
        
           |  |  | 178 |   | 
        
           | 727 | alex | 179 | }
 | 
        
           |  |  | 180 |   | 
        
           |  |  | 181 | ?>
 |