]> git.openstreetmap.org Git - nominatim.git/blob - website/search.php
Merge pull request #1548 from mtmail/centos7-postgresql-11
[nominatim.git] / website / search.php
1 <?php
2
3 require_once(CONST_BasePath.'/lib/init-website.php');
4 require_once(CONST_BasePath.'/lib/log.php');
5 require_once(CONST_BasePath.'/lib/Geocode.php');
6 require_once(CONST_BasePath.'/lib/output.php');
7 ini_set('memory_limit', '200M');
8
9 $oDB = new Nominatim\DB();
10 $oDB->connect();
11 $oParams = new Nominatim\ParameterParser();
12
13 $oGeocode = new Nominatim\Geocode($oDB);
14
15 $aLangPrefOrder = $oParams->getPreferredLanguages();
16 $oGeocode->setLanguagePreference($aLangPrefOrder);
17
18 if (CONST_Search_ReversePlanForAll
19     || isset($aLangPrefOrder['name:de'])
20     || isset($aLangPrefOrder['name:ru'])
21     || isset($aLangPrefOrder['name:ja'])
22     || isset($aLangPrefOrder['name:pl'])
23 ) {
24     $oGeocode->setReverseInPlan(true);
25 }
26
27 // Format for output
28 $sOutputFormat = $oParams->getSet('format', array('html', 'xml', 'json', 'jsonv2', 'geojson', 'geocodejson'), 'html');
29 set_exception_handler_by_format($sOutputFormat);
30
31 $sForcedGeometry = ($sOutputFormat == 'html') ? 'geojson' : null;
32 $oGeocode->loadParamArray($oParams, $sForcedGeometry);
33
34 if (CONST_Search_BatchMode && isset($_GET['batch'])) {
35     $aBatch = json_decode($_GET['batch'], true);
36     $aBatchResults = array();
37     foreach ($aBatch as $aBatchParams) {
38         $oBatchGeocode = clone $oGeocode;
39         $oBatchParams = new Nominatim\ParameterParser($aBatchParams);
40         $oBatchGeocode->loadParamArray($oBatchParams);
41         $oBatchGeocode->setQueryFromParams($oBatchParams);
42         $aSearchResults = $oBatchGeocode->lookup();
43         $aBatchResults[] = $aSearchResults;
44     }
45     include(CONST_BasePath.'/lib/template/search-batch-json.php');
46     exit;
47 }
48
49 $oGeocode->setQueryFromParams($oParams);
50
51 if (!$oGeocode->getQueryString()
52     && isset($_SERVER['PATH_INFO'])
53     && strlen($_SERVER['PATH_INFO']) > 0
54     && $_SERVER['PATH_INFO'][0] == '/'
55 ) {
56     $sQuery = substr(rawurldecode($_SERVER['PATH_INFO']), 1);
57
58     // reverse order of '/' separated string
59     $aPhrases = explode('/', $sQuery);
60     $aPhrases = array_reverse($aPhrases);
61     $sQuery = join(', ', $aPhrases);
62     $oGeocode->setQuery($sQuery);
63 }
64
65 $hLog = logStart($oDB, 'search', $oGeocode->getQueryString(), $aLangPrefOrder);
66
67 $aSearchResults = $oGeocode->lookup();
68
69 if ($sOutputFormat=='html') {
70     $sDataDate = $oDB->getOne("select TO_CHAR(lastimportdate,'YYYY/MM/DD HH24:MI')||' GMT' from import_status limit 1");
71 }
72 logEnd($oDB, $hLog, count($aSearchResults));
73
74 $sQuery = $oGeocode->getQueryString();
75
76 $aMoreParams = $oGeocode->getMoreUrlParams();
77 if ($sOutputFormat != 'html') $aMoreParams['format'] = $sOutputFormat;
78 if (isset($_SERVER['HTTP_ACCEPT_LANGUAGE'])) {
79     $aMoreParams['accept-language'] = $_SERVER['HTTP_ACCEPT_LANGUAGE'];
80 }
81 $sMoreURL = CONST_Website_BaseURL.'search.php?'.http_build_query($aMoreParams);
82
83 if (CONST_Debug) exit;
84
85 $sOutputTemplate = ($sOutputFormat == 'jsonv2') ? 'json' : $sOutputFormat;
86 include(CONST_BasePath.'/lib/template/search-'.$sOutputTemplate.'.php');