X-Git-Url: https://git.openstreetmap.org./nominatim.git/blobdiff_plain/4429121341de7727be26d56b9a1d7ada84359ea6..2a4198f94d1c52bb7e0042cf1b4074f277538384:/website/search.php diff --git a/website/search.php b/website/search.php old mode 100755 new mode 100644 index 98c878ea..26c10122 --- a/website/search.php +++ b/website/search.php @@ -1,188 +1,85 @@ setLanguagePreference($aLangPrefOrder); - - if (isset($_GET['addressdetails'])) $oGeocode->setIncludeAddressDetails((bool)$_GET['addressdetails']); - if (isset($_GET['bounded'])) $oGeocode->setBounded((bool)$_GET['bounded']); - if (isset($_GET['dedupe'])) $oGeocode->setDedupe((bool)$_GET['dedupe']); - - if (isset($_GET['limit'])) $oGeocode->setLimit((int)$_GET['limit']); - if (isset($_GET['offset'])) $oGeocode->setOffset((int)$_GET['offset']); - - // Format for output - $sOutputFormat = 'html'; - if (isset($_GET['format']) && ($_GET['format'] == 'html' || $_GET['format'] == 'xml' || $_GET['format'] == 'json' || $_GET['format'] == 'jsonv2')) - { - $sOutputFormat = $_GET['format']; - } - - // Show / use polygons - if ($sOutputFormat == 'html') - { - if (isset($_GET['polygon'])) $oGeocode->setIncludePolygonAsPoints((bool)$_GET['polygon']); - } - else - { - $bAsPoints = (boolean)isset($_GET['polygon']) && $_GET['polygon']; - $bAsGeoJSON = (boolean)isset($_GET['polygon_geojson']) && $_GET['polygon_geojson']; - $bAsKML = (boolean)isset($_GET['polygon_kml']) && $_GET['polygon_kml']; - $bAsSVG = (boolean)isset($_GET['polygon_svg']) && $_GET['polygon_svg']; - $bAsText = (boolean)isset($_GET['polygon_text']) && $_GET['polygon_text']; - if ( ( ($bAsGeoJSON?1:0) - + ($bAsKML?1:0) - + ($bAsSVG?1:0) - + ($bAsText?1:0) - + ($bAsPoints?1:0) - ) > CONST_PolygonOutput_MaximumTypes) - { - if (CONST_PolygonOutput_MaximumTypes) - { - userError("Select only ".CONST_PolygonOutput_MaximumTypes." polgyon output option"); - } - else - { - userError("Polygon output is disabled"); - } - exit; - } - $oGeocode->setIncludePolygonAsText($bAsText); - $oGeocode->setIncludePolygonAsGeoJSON($bAsGeoJSON); - $oGeocode->setIncludePolygonAsKML($bAsKML); - $oGeocode->setIncludePolygonAsSVG($bAsSVG); - } - - // List of excluded Place IDs - used for more acurate pageing - if (isset($_GET['exclude_place_ids']) && $_GET['exclude_place_ids']) - { - foreach(explode(',',$_GET['exclude_place_ids']) as $iExcludedPlaceID) - { - $iExcludedPlaceID = (int)$iExcludedPlaceID; - if ($iExcludedPlaceID) $aExcludePlaceIDs[$iExcludedPlaceID] = $iExcludedPlaceID; - } - $oGeocode->setExcludedPlaceIds($aExcludePlaceIDs); - } - - // Only certain ranks of feature - if (isset($_GET['featureType'])) $oGeocode->setFeatureType($_GET['featureType']); - if (isset($_GET['featuretype'])) $oGeocode->setFeatureType($_GET['featuretype']); - - // Country code list - if (isset($_GET['countrycodes'])) - { - $aCountryCodes = array(); - foreach(explode(',',$_GET['countrycodes']) as $sCountryCode) - { - if (preg_match('/^[a-zA-Z][a-zA-Z]$/', $sCountryCode)) - { - $aCountryCodes[] = strtolower($sCountryCode); - } - } - $oGeocode->setCountryCodeList($aCountryCodes); - } - - if (isset($_GET['viewboxlbrt']) && $_GET['viewboxlbrt']) - { - $aCoOrdinatesLBRT = explode(',',$_GET['viewboxlbrt']); - $oGeocode->setViewBox($aCoOrdinatesLBRT[0], $aCoOrdinatesLBRT[1], $aCoOrdinatesLBRT[2], $aCoOrdinatesLBRT[3]); - } - - if (isset($_GET['viewbox']) && $_GET['viewbox']) - { - $aCoOrdinatesLTRB = explode(',',$_GET['viewbox']); - $oGeocode->setViewBox($aCoOrdinatesLTRB[0], $aCoOrdinatesLTRB[3], $aCoOrdinatesLTRB[2], $aCoOrdinatesLTRB[1]); - } - - if (isset($_GET['route']) && $_GET['route'] && isset($_GET['routewidth']) && $_GET['routewidth']) - { - $aPoints = explode(',',$_GET['route']); - if (sizeof($aPoints) % 2 != 0) - { - userError("Uneven number of points"); - exit; - } - $fPrevCoord = false; - $aRoute = array(); - foreach($aPoints as $i => $fPoint) - { - if ($i%2) - { - $aRoute[] = array((float)$fPoint, $fPrevCoord); - } - else - { - $fPrevCoord = (float)$fPoint; - } - } - $oGeocode->setRoute($aRoute); - } - - // Search query - $sQuery = (isset($_GET['q'])?trim($_GET['q']):''); - if (!$sQuery && isset($_SERVER['PATH_INFO']) && $_SERVER['PATH_INFO'][0] == '/') - { - $sQuery = substr($_SERVER['PATH_INFO'], 1); - - // reverse order of '/' separated string - $aPhrases = explode('/', $sQuery); - $aPhrases = array_reverse($aPhrases); - $sQuery = join(', ',$aPhrases); - } - if (!$sQuery) - { - $oGeocode->setStructuredQuery(@$_GET['amenity'], @$_GET['street'], @$_GET['city'], @$_GET['county'], @$_GET['state'], @$_GET['country'], @$_GET['postalcode']); - } - else - { - $oGeocode->setQuery($sQuery); - } - - $hLog = logStart($oDB, 'search', $sQuery, $aLangPrefOrder); - - if (isset($_GET['batch'])) - { - $aBatch = json_decode($_GET['batch'], true); - foreach($aBatch as $aItem) { - var_dump($aItem); - } - exit; - } - - $aSearchResults = $oGeocode->lookup(); - if ($aSearchResults === false) $aSearchResults = array(); - - $sDataDate = $oDB->getOne("select TO_CHAR(lastimportdate - '2 minutes'::interval,'YYYY/MM/DD HH24:MI')||' GMT' from import_status limit 1"); - - logEnd($oDB, $hLog, sizeof($aSearchResults)); - - $bAsText = $oGeocode->getIncludePolygonAsText(); - $sQuery = $oGeocode->getQueryString(); - - $sMoreURL = CONST_Website_BaseURL.'search?format='.urlencode($sOutputFormat).'&exclude_place_ids='.join(',',$oGeocode->getExcludedPlaceIDs()); - if (isset($_SERVER["HTTP_ACCEPT_LANGUAGE"])) $sMoreURL .= '&accept-language='.$_SERVER["HTTP_ACCEPT_LANGUAGE"]; - if ($oGeocode->getIncludePolygonAsPoints()) $sMoreURL .= '&polygon=1'; - if ($oGeocode->getIncludeAddressDetails()) $sMoreURL .= '&addressdetails=1'; - if (isset($_GET['viewbox']) && $_GET['viewbox']) $sMoreURL .= '&viewbox='.urlencode($_GET['viewbox']); - if (isset($_GET['nearlat']) && isset($_GET['nearlon'])) $sMoreURL .= '&nearlat='.(float)$_GET['nearlat'].'&nearlon='.(float)$_GET['nearlon']; - $sMoreURL .= '&q='.urlencode($sQuery); - - if (CONST_Debug) exit; - - include(CONST_BasePath.'/lib/template/search-'.$sOutputFormat.'.php'); + +require_once(CONST_BasePath.'/lib/init-website.php'); +require_once(CONST_BasePath.'/lib/log.php'); +require_once(CONST_BasePath.'/lib/Geocode.php'); +require_once(CONST_BasePath.'/lib/output.php'); +ini_set('memory_limit', '200M'); + +$oDB = new Nominatim\DB(); +$oDB->connect(); +$oParams = new Nominatim\ParameterParser(); + +$oGeocode = new Nominatim\Geocode($oDB); + +$aLangPrefOrder = $oParams->getPreferredLanguages(); +$oGeocode->setLanguagePreference($aLangPrefOrder); + +if (CONST_Search_ReversePlanForAll + || isset($aLangPrefOrder['name:de']) + || isset($aLangPrefOrder['name:ru']) + || isset($aLangPrefOrder['name:ja']) + || isset($aLangPrefOrder['name:pl']) +) { + $oGeocode->setReverseInPlan(true); +} + +// Format for output +$sOutputFormat = $oParams->getSet('format', array('html', 'xml', 'json', 'jsonv2', 'geojson', 'geocodejson'), 'html'); +set_exception_handler_by_format($sOutputFormat); + +$sForcedGeometry = ($sOutputFormat == 'html') ? 'geojson' : null; +$oGeocode->loadParamArray($oParams, $sForcedGeometry); + +if (CONST_Search_BatchMode && isset($_GET['batch'])) { + $aBatch = json_decode($_GET['batch'], true); + $aBatchResults = array(); + foreach ($aBatch as $aBatchParams) { + $oBatchGeocode = clone $oGeocode; + $oBatchParams = new Nominatim\ParameterParser($aBatchParams); + $oBatchGeocode->loadParamArray($oBatchParams); + $oBatchGeocode->setQueryFromParams($oBatchParams); + $aSearchResults = $oBatchGeocode->lookup(); + $aBatchResults[] = $aSearchResults; + } + include(CONST_BasePath.'/lib/template/search-batch-json.php'); + exit; +} + +$oGeocode->setQueryFromParams($oParams); + +if (!$oGeocode->getQueryString() + && isset($_SERVER['PATH_INFO']) + && $_SERVER['PATH_INFO'][0] == '/' +) { + $sQuery = substr(rawurldecode($_SERVER['PATH_INFO']), 1); + + // reverse order of '/' separated string + $aPhrases = explode('/', $sQuery); + $aPhrases = array_reverse($aPhrases); + $sQuery = join(', ', $aPhrases); + $oGeocode->setQuery($sQuery); +} + +$hLog = logStart($oDB, 'search', $oGeocode->getQueryString(), $aLangPrefOrder); + +$aSearchResults = $oGeocode->lookup(); + +if ($sOutputFormat=='html') { + $sDataDate = $oDB->getOne("select TO_CHAR(lastimportdate,'YYYY/MM/DD HH24:MI')||' GMT' from import_status limit 1"); +} +logEnd($oDB, $hLog, count($aSearchResults)); + +$sQuery = $oGeocode->getQueryString(); + +$aMoreParams = $oGeocode->getMoreUrlParams(); +if ($sOutputFormat != 'html') $aMoreParams['format'] = $sOutputFormat; +if (isset($_SERVER['HTTP_ACCEPT_LANGUAGE'])) { + $aMoreParams['accept-language'] = $_SERVER['HTTP_ACCEPT_LANGUAGE']; +} +$sMoreURL = CONST_Website_BaseURL.'search.php?'.http_build_query($aMoreParams); + +if (CONST_Debug) exit; + +$sOutputTemplate = ($sOutputFormat == 'jsonv2') ? 'json' : $sOutputFormat; +include(CONST_BasePath.'/lib/template/search-'.$sOutputTemplate.'.php');