Subversion Repositories eFlore/Applications.cel

Rev

Rev 2557 | Rev 2914 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 2557 Rev 2564
Line 1... Line 1...
1
<?php
1
<?php
2
// declare(encoding='UTF-8');
2
// declare(encoding='UTF-8');
3
/**
3
/**
4
 * Service recherche de commune par coordonnées et vice versa.
4
 * Service recherche de zone par coordonnées et vice versa.
5
 *
5
 *
6
 * @internal   Mininum PHP version : 5.2
6
 * @internal   Mininum PHP version : 5.2
7
 * @category   CEL
7
 * @category   CEL
8
 * @package    Services
8
 * @package    Services
9
 * @subpackage Cartes
9
 * @subpackage Cartes
Line 15... Line 15...
15
 * @license    CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
15
 * @license    CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
16
 * @copyright  1999-2014 Tela Botanica <accueil@tela-botanica.org>
16
 * @copyright  1999-2014 Tela Botanica <accueil@tela-botanica.org>
17
 */
17
 */
18
class CoordSearch extends Cel {
18
class CoordSearch extends Cel {
Line 19... Line 19...
19
	
19
	
20
	/**
20
	public function getRessource() {
21
	 * Recherche de coordonnées suivant ce qui est fourni
21
		return $this->getElement(array());
22
	 *
-
 
23
	 * $uid[0] = latitude (ou * si recherche coordonnées d'une commune)
-
 
24
	 * $uid[1] = longitude (ou * si recherche coordonnées d'une commune)
-
 
25
	 * $uid[2] = commune (ou * si recherche d'une commune correspondant à des coordonnées)
-
 
26
	 * $uid[3] = code_postal (ou * si recherche d'une commune correspondant à des coordonnées)
-
 
27
	 * $uid[4] = code_pays (ou * si recherche d'une commune correspondant à des coordonnées, par défaut vaut FR)
22
	}
28
	 */
23
	
29
	public function getElement($uid){
24
	public function getElement($uid){
30
		$header = '';
25
		$header = '';
Line 31... Line 26...
31
		$retour = array();
26
		$retour = array();
32
 
27
 
Line 33... Line 28...
33
		$params = $this->traiterParametres($uid);
28
		$params = $this->traiterParametres();
Line 34... Line 29...
34
		$recherche_zones_geo = new RechercheInfosZoneGeo($this->config);
29
		$recherche_zones_geo = new RechercheInfosZoneGeo($this->config);
35
 
30
 
36
		if ($this->estUneRequeteReverseGeocoding($params)) {
31
		if ($this->estUneRequeteReverseGeocoding($params)) {
37
 
32
 
Line 38... Line 33...
38
			$coordonnees = array('latitude' => $params['lat'], 'longitude' => $params['lon']);
33
			$coordonnees = array('latitude' => $params['lat'], 'longitude' => $params['lon']);
Line 39... Line 34...
39
			$informations_communes = $recherche_zones_geo->obtenirInfosPourCoordonnees($coordonnees);
34
			$informations_zones = $recherche_zones_geo->obtenirInfosPourCoordonnees($coordonnees);
40
			$header = 'Content-Type: application/json; charset=UTF-8';
35
			$header = 'Content-Type: application/json; charset=UTF-8';
41
			$retour = json_encode($informations_communes);	
36
			$retour = json_encode($informations_zones);	
Line 42... Line 37...
42
				
37
				
43
		} elseif ($this->estUneRequeteGeocoding($params)) {	
38
		} elseif ($this->estUneRequeteGeocoding($params)) {	
44
				
39
				
45
			$informations_coord = $recherche_zones_geo->obtenirInfosPourNoms($params['commune'], $params['pays'], $params['code']);
40
			$informations_coord = $recherche_zones_geo->obtenirInfosPourNoms($params['zone'], $params['pays'], $params['code']);
Line 46... Line 41...
46
			$header = 'Content-Type: application/json; charset=UTF-8';
41
			$header = 'Content-Type: application/json; charset=UTF-8';
47
			$retour = json_encode($informations_coord);
42
			$retour = json_encode($informations_coord);
48
			
43
			
Line 49... Line 44...
49
		} else {
44
		} else {
50
			$header = 'HTTP/1.0 400 Bad Request';
45
			$header = 'HTTP/1.0 400 Bad Request';
51
			$retour = 'Commune ou Coordonnées non spécifiées';
46
			$retour = 'zone ou Coordonnées non spécifiées';
52
		}
47
		}
53
		
48
		
54
		header($header);
49
		header($header);
55
		echo $retour;
50
		echo $retour;
56
	}
51
	}
57
 
52
 
58
	protected function traiterParametres($params) {
53
	protected function traiterParametres() {
59
		$lat = $this->affecterValeurParametreOuDefaut($params, 0, '*');
54
		$lat = !empty($_GET['lat']) ? $_GET['lat'] : '';
60
		$lng = $this->affecterValeurParametreOuDefaut($params, 1, '*');
55
		$lon = !empty($_GET['lon']) ? $_GET['lon'] : '';
61
		$commune = $this->affecterValeurParametreOuDefaut($params, 2, '*');
-
 
62
		$code_postal = $this->affecterValeurParametreOuDefaut($params, 3, '*');
-
 
63
		$code_pays = $this->affecterValeurParametreOuDefaut($params, 4, '');
-
 
64
		return array(
-
 
65
			'lat' => $lat,
56
		$zone = !empty($_GET['zone']) ? $_GET['zone'] : '';
66
			'lon' => $lng,
57
		$code = !empty($_GET['code']) ? $_GET['code'] : '';
67
			'commune' => $commune,
58
		$pays = !empty($_GET['pays']) ? $_GET['pays'] : '';
68
			'code' => $code_postal,
59
		return array(
69
			'pays' => $code_pays);
60
			'lat' => $lat,
Line 70... Line 61...
70
	}
61
			'lon' => $lon,
71
 
62
			'zone' => $zone,
72
	private function affecterValeurParametreOuDefaut($params, $indice, $valeur_si_non_present) {
63
			'code' => $code,
73
		return isset($params[$indice]) ? str_replace('"','',urldecode($params[$indice])) : $valeur_si_non_present;
64
			'pays' => $pays);
74
	}
65
	}