Subversion Repositories Sites.obs-saisons.fr

Compare Revisions

Ignore whitespace Rev 255 → 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);