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); |