Subversion Repositories Sites.obs-saisons.fr

Compare Revisions

Ignore whitespace Rev 296 → Rev 297

/trunk/applications/jrest/services/OdsStation.php
14,20 → 14,14
return;
}
if($param[1] == "*") {
if($param[1] == "*") {
$info = $this->obtenirListeStationPourParticipant($id_participant);
} else if(is_numeric($param[1])) {
$id_station = $param[1];
$info = $this->obtenirInformationsStation($id_station);
}
// Envoi sur la sortie standard
$this->envoyer($info);
}
/**
49,16 → 43,10
}
$id_participant = $params['id_participant'];
$commune = $this->traiterParametreCommune($params);
if(isset($params['station_code_insee']) && trim($params['station_code_insee']) != '') {
$commune = $params['station_code_insee'];
if(strlen($commune) == 4) {
$commune = '0'.$commune;
}
} else {
$commune = $params['station_commune'];
}
// description n'est pas obligatoire, et également pour le moment inutilisé
$params['station_description'] = isset($params['station_description']) ? $params['station_description'] : '';
$requete_creation_station = 'INSERT INTO ods_stations '.
'(os_ce_participant, os_nom, os_ce_commune, os_latitude, os_longitude, os_altitude, os_ce_environnement, os_commentaire) '.
107,18 → 95,10
if(!isset($uid[0])) {
return;
} else {
$id_station = $uid[0];;
$id_station = $uid[0];
}
if(isset($params['station_code_insee']) && trim($params['station_code_insee']) != '') {
$commune = $params['station_code_insee'];
if(strlen($commune) == 4) {
$commune = '0'.$commune;
}
} else {
$commune = $params['station_commune'];
}
$commune = $this->traiterParametreCommune($params);
$requete_modification_station = 'UPDATE ods_stations '.
'SET '.
144,6 → 124,44
 
$this->envoyer($retour);
}
private function traiterParametreCommune($params) {
// Si on a pas de code INSEE on mettra la valeur brute que
// l'utilisateur a saisi afin de ne pas perdre d'infos
$commune = $params['station_commune'];
// Si un code INSEE semble présent
if(isset($params['station_code_insee']) && trim($params['station_code_insee']) != '') {
// Si c'est le cas affectation directe
if($this->estUnCodeInsee($params)) {
$commune = $params['station_code_insee'];
// Cas du code saisi sans le 0 de gauche
$commune = (strlen($commune) == 4) ? '0'.$commune : $commune;
} elseif($this->estUnCommunePlusDepartement($params)) {
// Cas du département sur un ou deux chiffres + une commune
// tentative de retrouve le code INSEE complet
$params['station_code_insee'] = (strlen($params['station_code_insee']) == 1) ? '0'.$params['station_code_insee'] : $params['station_code_insee'];
$infos = $this->obtenirInformationsCommuneParNomEtDepartement($params['station_commune'], $params['station_code_insee']);
$commune = ($infos != null) ? $infos['oc_code_insee'] : $commune;
//TODO: quoi faire si on a 3 chiffres par exemple ou plus de 5 chiffres ?
}
}
 
return $commune;
}
private function estUnCodeInsee($params) {
return is_numeric($params['station_code_insee']) &&
(strlen($params['station_code_insee']) == 5 ||
strlen($params['station_code_insee']) == 4);
}
private function estUnCommunePlusDepartement($params) {
return is_numeric($params['station_code_insee']) &&
(strlen($params['station_code_insee']) == 2 ||
strlen($params['station_code_insee']) == 1) &&
isset($params['station_commune']) &&
trim($params['station_commune']) != "";
}
/**
* Méthode appelée pour supprimer un élément
238,12 → 256,27
$requete_infos_commune = 'SELECT * FROM ods_communes WHERE oc_code_insee = '.$this->proteger($code_insee_commune);
$infos_commune = $this->executerRequete($requete_infos_commune);
//TODO: en attendant de stocker les ids
return $infos_commune[0]['oc_nom'];
//return $infos_commune;
}
private function obtenirInformationsCommuneParNomEtDepartement($nom, $departement) {
// un remplacement par des underscores permet de s'affranchir des problèmes de saisie
// des communes avec des tirets espaces etc...
$nom = str_replace(array("'","-",'"',' ') ,'_', $nom);
$requete_infos_commune = 'SELECT oc_nom, oc_code_insee FROM ods_communes '.
'WHERE oc_code_insee LIKE '.$this->proteger($departement.'%').' AND '.
'oc_nom LIKE '.$this->proteger($nom);
$infos_commune = $this->executerRequete($requete_infos_commune);
$retour = null;
if($infos_commune && isset($infos_commune[0])) {
$retour = $infos_commune[0];
}
 
return $retour;
}
private function obtenirInformationsMilieuParId($id_milieu) {
$informations_milieu = $this->obtenirValeurTripleParId($id_milieu);
/trunk/applications/jrest/services/OdsCommune.php
35,17 → 35,21
return $this->getInformationsPourCoordonnees();
}
private function getInformationsPourCoordonnees($params) {
public function getInformationsPourCoordonnees($params) {
$lat = $_GET['lat'];
$lon = $_GET['lon'];
$infos_altitude_json = file_get_contents('http://maps.googleapis.com/maps/api/elevation/json?sensor=false&locations='.$lat.','.$lon);
$infos_commune_json = file_get_contents("http://api.geonames.org/findNearbyJSON?featureClass=ADM4&lat=".urlencode($lat)."&lng=".urlencode($lon)."&style=full") ;
// les erreurs sont mises sous silence car le cas où file_get_contents ne retourne rien
// correspond à un cas valide où l'on a pas de données sur ses coordonnées
// (ce cas est traité dans formaterTableauInformationsCoordsPourEnvoi)
$url_atitude = "http://api.tela-botanica.org/service:eflore:0.1/nasa-srtm/altitude?lon=".urlencode($lon)."&lat=".urlencode($lat);
$infos_altitude_json = @file_get_contents($url_atitude);
 
// à voir l'utilisation de google places lors de la mise en place d'un compte google premier api
//$infos_commune = file_get_contents('https://maps.googleapis.com/maps/api/place/search/json?sensor=false&locations='.$lat.','.$lon);
$url_commune = "http://api.tela-botanica.org/service:eflore:0.1/osm/nom-commune?lon=".urlencode($lon)."&lat=".urlencode($lat);
$infos_commune_json = @file_get_contents($url_commune);
$infos_localites = $this->formaterTableauInformationsCoordsPourEnvoi($infos_altitude_json, $infos_commune_json);
return $infos_localites;
58,9 → 62,8
$commune = $this->remplacerNomCommunePourRecherche($commune);
$requete_infos_communes = 'SELECT * FROM ods_communes WHERE oc_nom LIKE '.$this->proteger($commune).' ORDER BY oc_nom LIMIT 0,10';
$infos_communes = $this->executerRequete($requete_infos_communes);
 
$infos_communes_formatees = $this->formaterTableauInformationsCommunePourEnvoi($infos_communes);
return $infos_communes_formatees;
114,29 → 117,42
$infos_altitude = json_decode($infos_altitude_json);
$infos_commune = json_decode($infos_commune_json);
$altitude = $infos_altitude->results[0]->elevation;
$altitude = number_format($altitude, 0, '', '');
$lat = $infos_altitude->results[0]->location->lat;
$lon = $infos_altitude->results[0]->location->lng;
$altitude = "";
$dpt = "";
$lat = "";
$lon = "";
$altitude = "";
$code_insee = "";
$commune = "";
$commune_phenoclim = false;
$commune = $infos_commune->geonames[0]->adminName4;
$dpt = $infos_commune->geonames[0]->adminCode2;
$cp_recherche = $dpt;
if(strlen($cp_recherche) == 4) {
$cp_recherche = '0'.$cp_recherche;
}
$commune_phenoclim = $this->estUneCommunePhenoclim(array('code_postal' => $cp_recherche));
 
$cp_recherche = substr($cp_recherche,0,2);
if(is_object($infos_altitude)) {
$altitude = $infos_altitude->altitude;
$altitude = number_format($altitude, 0, '', '');
$lat = $infos_altitude->latitude;
$lon = $infos_altitude->longitude;
}
$code_insee = '';
if($commune != null) {
$code_insee = $this->obtenirCodeInseeCommune($commune, $cp_recherche);
}
if(is_object($infos_commune)) {
$commune = $infos_commune->nom;
$dpt = $infos_commune->codeINSEE;
$cp_recherche = $dpt;
if(strlen($cp_recherche) == 4) {
$cp_recherche = '0'.$cp_recherche;
}
$commune_phenoclim = $this->estUneCommunePhenoclim(array('code_postal' => $cp_recherche));
$cp_recherche = substr($cp_recherche,0,2);
$code_insee = '';
if($commune != null) {
$code_insee = $this->obtenirCodeInseeCommune($commune, $cp_recherche);
}
}
$infos_communes = array(
'commune' => $commune,
182,6 → 198,7
'commune_phenoclim' => $commune_phenoclim
);
}
 
return $infos_formatees;
}