]> git.openstreetmap.org Git - nominatim.git/blobdiff - lib/template/search-json.php
Try alternative orderings of structured queries that include postal codes
[nominatim.git] / lib / template / search-json.php
index 8950f14cc3f9687c61e66c2543139088d267402a..57586fb9eee3c3adeb24003e225d64fb11480aaf 100644 (file)
@@ -1,65 +1,80 @@
-<?php\r
-       header("Content-Type: application/json; charset=UTF-8");\r
-       header("Access-Control-Allow-Origin: *");\r
-\r
-       $aFilteredPlaces = array();\r
-       foreach($aSearchResults as $iResNum => $aPointDetails)\r
-       {\r
-               $aPlace = array(\r
-                               'place_id'=>$aPointDetails['place_id'],\r
-                               'licence'=>"Data Copyright OpenStreetMap Contributors, Some Rights Reserved. CC-BY-SA 2.0.",\r
-                       );\r
-\r
-               $sOSMType = ($aPointDetails['osm_type'] == 'N'?'node':($aPointDetails['osm_type'] == 'W'?'way':($aPointDetails['osm_type'] == 'R'?'relation':'')));\r
-               if ($sOSMType)\r
-               {\r
-                       $aPlace['osm_type'] = $sOSMType;\r
-                       $aPlace['osm_id'] = $aPointDetails['osm_id'];\r
-               }\r
-\r
-                if (isset($aPointDetails['aBoundingBox']))\r
-                {\r
-                       $aPlace['boundingbox'] = array(\r
-                               $aPointDetails['aBoundingBox'][0],\r
-                               $aPointDetails['aBoundingBox'][1],\r
-                               $aPointDetails['aBoundingBox'][2],\r
-                               $aPointDetails['aBoundingBox'][3]);\r
-\r
-                       if (isset($aPointDetails['aPolyPoints']) && $bShowPolygons)\r
-                       {\r
-                               $aPlace['polygonpoints'] = $aPointDetails['aPolyPoints'];\r
-                       }\r
-                }\r
-\r
-               if (isset($aPointDetails['zoom']))\r
-               {\r
-                       $aPlace['zoom'] = $aPointDetails['zoom'];\r
-               }\r
-\r
-               $aPlace['lat'] = $aPointDetails['lat'];\r
-               $aPlace['lon'] = $aPointDetails['lon'];\r
-               $aPlace['display_name'] = $aPointDetails['name'];\r
-\r
-               $aPlace['class'] = $aPointDetails['class'];\r
-               $aPlace['type'] = $aPointDetails['type'];\r
-               if ($aPointDetails['icon'])\r
-               {\r
-                       $aPlace['icon'] = $aPointDetails['icon'];\r
-               }\r
-\r
-               if (isset($aPointDetails['address']))\r
-               {\r
-                       $aPlace['address'] = $aPointDetails['address'];\r
-                }\r
-\r
-               $aFilteredPlaces[] = $aPlace;\r
-       }\r
-\r
-       if (isset($_GET['json_callback']) && preg_match('/^[-A-Za-z0-9:_.]+$/',$_GET['json_callback']))\r
-       {\r
-               echo $_GET['json_callback'].'('.javascript_renderData($aFilteredPlaces).')';\r
-       }\r
-       else\r
-       {\r
-               echo javascript_renderData($aFilteredPlaces);\r
-       }\r
+<?php
+       header("content-type: application/json; charset=UTF-8");
+
+       $aFilteredPlaces = array();
+       foreach($aSearchResults as $iResNum => $aPointDetails)
+       {
+               $aPlace = array(
+                               'place_id'=>$aPointDetails['place_id'],
+                               'licence'=>"Data © OpenStreetMap contributors, ODbL 1.0. http://www.openstreetmap.org/copyright",
+                       );
+
+               $sOSMType = ($aPointDetails['osm_type'] == 'N'?'node':($aPointDetails['osm_type'] == 'W'?'way':($aPointDetails['osm_type'] == 'R'?'relation':'')));
+               if ($sOSMType)
+               {
+                       $aPlace['osm_type'] = $sOSMType;
+                       $aPlace['osm_id'] = $aPointDetails['osm_id'];
+               }
+
+                if (isset($aPointDetails['aBoundingBox']))
+                {
+                       $aPlace['boundingbox'] = array(
+                               $aPointDetails['aBoundingBox'][0],
+                               $aPointDetails['aBoundingBox'][1],
+                               $aPointDetails['aBoundingBox'][2],
+                               $aPointDetails['aBoundingBox'][3]);
+
+                       if (isset($aPointDetails['aPolyPoints']) && $bShowPolygons)
+                       {
+                               $aPlace['polygonpoints'] = $aPointDetails['aPolyPoints'];
+                       }
+                }
+
+               if (isset($aPointDetails['zoom']))
+               {
+                       $aPlace['zoom'] = $aPointDetails['zoom'];
+               }
+
+               $aPlace['lat'] = $aPointDetails['lat'];
+               $aPlace['lon'] = $aPointDetails['lon'];
+               $aPlace['display_name'] = $aPointDetails['name'];
+
+               $aPlace['class'] = $aPointDetails['class'];
+               $aPlace['type'] = $aPointDetails['type'];
+
+               $aPlace['importance'] = $aPointDetails['importance'];
+
+               if (isset($aPointDetails['icon']) && $aPointDetails['icon'])
+               {
+                       $aPlace['icon'] = $aPointDetails['icon'];
+               }
+
+               if (isset($aPointDetails['address']))
+               {
+                       $aPlace['address'] = $aPointDetails['address'];
+                }
+
+                if (isset($aPointDetails['asgeojson']))
+                {
+                        $aPlace['geojson'] = json_decode($aPointDetails['asgeojson']);
+                }
+
+                if (isset($aPointDetails['assvg']))
+                {
+                        $aPlace['svg'] = $aPointDetails['assvg'];
+                }
+
+                if (isset($aPointDetails['astext']))
+                {
+                        $aPlace['geotext'] = $aPointDetails['astext'];
+                }
+
+               if (isset($aPointDetails['askml']))
+               {
+                       $aPlace['geokml'] = $aPointDetails['askml'];
+               }
+
+               $aFilteredPlaces[] = $aPlace;
+       }
+
+       javascript_renderData($aFilteredPlaces);