]> git.openstreetmap.org Git - nominatim.git/blob - website/reverse.php
correctly handle comma-only exclude_place_ids
[nominatim.git] / website / reverse.php
1 <?php
2         @define('CONST_ConnectionBucket_PageType', 'Reverse');
3
4         require_once(dirname(dirname(__FILE__)).'/lib/init-website.php');
5         require_once(CONST_BasePath.'/lib/log.php');
6         require_once(CONST_BasePath.'/lib/PlaceLookup.php');
7         require_once(CONST_BasePath.'/lib/ReverseGeocode.php');
8
9         if (strpos(CONST_BulkUserIPs, ','.$_SERVER["REMOTE_ADDR"].',') !== false)
10         {
11                 $fLoadAvg = getLoadAverage();
12                 if ($fLoadAvg > 2) sleep(60);
13                 if ($fLoadAvg > 4) sleep(120);
14                 if ($fLoadAvg > 6)
15                 {
16                         echo "Bulk User: Temporary block due to high server load\n";
17                         exit;
18                 }
19         }
20
21         $oDB =& getDB();
22         ini_set('memory_limit', '200M');
23
24         // Format for output
25         $sOutputFormat = 'xml';
26         if (isset($_GET['format']) && ($_GET['format'] == 'xml' || $_GET['format'] == 'json' || $_GET['format'] == 'jsonv2'))
27         {
28                 $sOutputFormat = $_GET['format'];
29         }
30
31         // Show address breakdown
32         $bShowAddressDetails = true;
33         if (isset($_GET['addressdetails'])) $bShowAddressDetails = (bool)$_GET['addressdetails'];
34
35         // Preferred language
36         $aLangPrefOrder = getPreferredLanguages();
37
38         $hLog = logStart($oDB, 'reverse', $_SERVER['QUERY_STRING'], $aLangPrefOrder);
39
40         if (isset($_GET['osm_type']) && isset($_GET['osm_id']) && (int)$_GET['osm_id'] && ($_GET['osm_type'] == 'N' || $_GET['osm_type'] == 'W' || $_GET['osm_type'] == 'R'))
41         {
42                 $oPlaceLookup = new PlaceLookup($oDB);
43                 $oPlaceLookup->setLanguagePreference($aLangPrefOrder);
44                 $oPlaceLookup->setIncludeAddressDetails($bShowAddressDetails);
45                 $oPlaceLookup->setOSMID($_GET['osm_type'], $_GET['osm_id']);
46
47                 $aPlace = $oPlaceLookup->lookup();
48         }
49         else if (isset($_GET['lat']) && isset($_GET['lon']) && preg_match('/^[+-]?[0-9]*\.?[0-9]+$/', $_GET['lat']) && preg_match('/^[+-]?[0-9]*\.?[0-9]+$/', $_GET['lon']))
50         {
51                 $oReverseGeocode = new ReverseGeocode($oDB);
52                 $oReverseGeocode->setLanguagePreference($aLangPrefOrder);
53                 $oReverseGeocode->setIncludeAddressDetails($bShowAddressDetails);
54
55                 $oReverseGeocode->setLatLon($_GET['lat'], $_GET['lon']);
56                 $oReverseGeocode->setZoom(@$_GET['zoom']);
57
58                 $aPlace = $oReverseGeocode->lookup();
59         }
60         else
61         {
62                 $aPlace = null;
63         }
64
65         if (CONST_Debug) exit;
66
67         include(CONST_BasePath.'/lib/template/address-'.$sOutputFormat.'.php');