Subversion Repositories eFlore/Applications.cel

Rev

Rev 2551 | Rev 2564 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed

<?php
// declare(encoding='UTF-8');
/**
 * Service recherche de commune par coordonnées et vice versa.
 *
 * @internal   Mininum PHP version : 5.2
 * @category   CEL
 * @package    Services
 * @subpackage Cartes
 * @version    0.1
 * @author     Mathias CHOUET <mathias@tela-botanica.org>
 * @author     Jean-Pascal MILCENT <jpm@tela-botanica.org>
 * @author     Aurelien PERONNET <aurelien@tela-botanica.org>
 * @license    GPL v3 <http://www.gnu.org/licenses/gpl.txt>
 * @license    CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
 * @copyright  1999-2014 Tela Botanica <accueil@tela-botanica.org>
 */
class CoordSearch extends Cel {
        
        /**
         * Recherche de coordonnées suivant ce qui est fourni
         *
         * $uid[0] = latitude (ou * si recherche coordonnées d'une commune)
         * $uid[1] = longitude (ou * si recherche coordonnées d'une commune)
         * $uid[2] = commune (ou * si recherche d'une commune correspondant à des coordonnées)
         * $uid[3] = code_postal (ou * si recherche d'une commune correspondant à des coordonnées)
         * $uid[4] = code_pays (ou * si recherche d'une commune correspondant à des coordonnées, par défaut vaut FR)
         */
        public function getElement($uid){
                $header = '';
                $retour = array();

                $params = $this->traiterParametres($uid);
                $recherche_zones_geo = new RechercheInfosZoneGeo($this->config);

                if ($this->estUneRequeteReverseGeocoding($params)) {

                        $coordonnees = array('latitude' => $params['lat'], 'longitude' => $params['lon']);
                        $informations_communes = $recherche_zones_geo->obtenirInfosPourCoordonnees($coordonnees);
                        $header = 'Content-Type: application/json; charset=UTF-8';
                        $retour = json_encode($informations_communes);  
                                
                } elseif ($this->estUneRequeteGeocoding($params)) {     
                                
                        $informations_coord = $recherche_zones_geo->obtenirInfosPourNoms($params['commune'], $params['pays'], $params['code']);
                        $header = 'Content-Type: application/json; charset=UTF-8';
                        $retour = json_encode($informations_coord);
                        
                } else {
                        $header = 'HTTP/1.0 400 Bad Request';
                        $retour = 'Commune ou Coordonnées non spécifiées';
                }
                
                header($header);
                echo $retour;
        }

        protected function traiterParametres($params) {
                $lat = $this->affecterValeurParametreOuDefaut($params, 0, '*');
                $lng = $this->affecterValeurParametreOuDefaut($params, 1, '*');
                $commune = $this->affecterValeurParametreOuDefaut($params, 2, '*');
                $code_postal = $this->affecterValeurParametreOuDefaut($params, 3, '*');
                $code_pays = $this->affecterValeurParametreOuDefaut($params, 4, '');
                return array(
                        'lat' => $lat,
                        'lon' => $lng,
                        'commune' => $commune,
                        'code' => $code_postal,
                        'pays' => $code_pays);
        }

        private function affecterValeurParametreOuDefaut($params, $indice, $valeur_si_non_present) {
                return isset($params[$indice]) ? str_replace('"','',urldecode($params[$indice])) : $valeur_si_non_present;
        }

        private function estUneRequeteReverseGeocoding($params) {
                return ($params['lat'] != '*' && $params['lon'] != '*');
        }

        private function estUneRequeteGeocoding($params) {
                return ($params['commune'] != '*');
        }
}