2014-02-06 20:50:41 +04:00
|
|
|
<?php
|
2021-01-13 19:00:38 +03:00
|
|
|
@define('CONST_LibDir', dirname(dirname(__FILE__)));
|
2014-02-06 20:50:41 +04:00
|
|
|
|
2020-12-15 12:09:55 +03:00
|
|
|
require_once(CONST_LibDir.'/init-cmd.php');
|
2020-12-16 19:20:58 +03:00
|
|
|
require_once(CONST_LibDir.'/log.php');
|
|
|
|
require_once(CONST_LibDir.'/Geocode.php');
|
|
|
|
require_once(CONST_LibDir.'/PlaceLookup.php');
|
|
|
|
require_once(CONST_LibDir.'/ReverseGeocode.php');
|
|
|
|
|
2016-09-04 04:19:48 +03:00
|
|
|
ini_set('memory_limit', '800M');
|
2014-02-06 20:50:41 +04:00
|
|
|
|
2016-09-04 04:19:48 +03:00
|
|
|
$aCMDOptions = array(
|
2017-10-26 22:21:21 +03:00
|
|
|
'Tools to warm nominatim db',
|
2016-09-10 22:10:52 +03:00
|
|
|
array('help', 'h', 0, 1, 0, 0, false, 'Show Help'),
|
|
|
|
array('quiet', 'q', 0, 1, 0, 0, 'bool', 'Quiet output'),
|
|
|
|
array('verbose', 'v', 0, 1, 0, 0, 'bool', 'Verbose output'),
|
|
|
|
array('reverse-only', '', 0, 1, 0, 0, 'bool', 'Warm reverse only'),
|
2017-04-02 18:13:43 +03:00
|
|
|
array('search-only', '', 0, 1, 0, 0, 'bool', 'Warm search only'),
|
2020-12-16 19:20:58 +03:00
|
|
|
array('project-dir', '', 0, 1, 1, 1, 'realpath', 'Base directory of the Nominatim installation (default: .)'),
|
2016-09-10 22:10:52 +03:00
|
|
|
);
|
2016-09-04 04:19:48 +03:00
|
|
|
getCmdOpt($_SERVER['argv'], $aCMDOptions, $aResult, true, true);
|
2014-02-06 20:50:41 +04:00
|
|
|
|
2020-12-16 19:20:58 +03:00
|
|
|
loadSettings($aCMDResult['project-dir'] ?? getcwd());
|
2014-02-06 20:50:41 +04:00
|
|
|
|
2021-01-13 20:12:53 +03:00
|
|
|
@define('CONST_Database_DSN', getSetting('DATABASE_DSN'));
|
|
|
|
@define('CONST_Default_Language', getSetting('DEFAULT_LANGUAGE', false));
|
|
|
|
@define('CONST_Log_DB', getSettingBool('LOG_DB'));
|
|
|
|
@define('CONST_Log_File', getSetting('LOG_FILE', false));
|
|
|
|
@define('CONST_Max_Word_Frequency', getSetting('MAX_WORD_FREQUENCY'));
|
|
|
|
@define('CONST_NoAccessControl', getSettingBool('CORS_NOACCESSCONTROL'));
|
|
|
|
@define('CONST_Places_Max_ID_count', getSetting('LOOKUP_MAX_COUNT'));
|
|
|
|
@define('CONST_PolygonOutput_MaximumTypes', getSetting('POLYGON_OUTPUT_MAX_TYPES'));
|
|
|
|
@define('CONST_Search_BatchMode', getSettingBool('SEARCH_BATCH_MODE'));
|
|
|
|
@define('CONST_Search_NameOnlySearchFrequencyThreshold', getSetting('SEARCH_NAME_ONLY_THRESHOLD'));
|
|
|
|
@define('CONST_Term_Normalization_Rules', getSetting('TERM_NORMALIZATION'));
|
|
|
|
@define('CONST_Use_Aux_Location_data', getSettingBool('USE_AUX_LOCATION_DATA'));
|
|
|
|
@define('CONST_Use_US_Tiger_Data', getSettingBool('USE_US_TIGER_DATA'));
|
|
|
|
@define('CONST_MapIcon_URL', getSetting('MAPICON_URL', false));
|
|
|
|
|
|
|
|
|
2019-02-24 18:14:36 +03:00
|
|
|
$oDB = new Nominatim\DB();
|
|
|
|
$oDB->connect();
|
2014-02-06 20:50:41 +04:00
|
|
|
|
2016-09-04 04:19:48 +03:00
|
|
|
$bVerbose = $aResult['verbose'];
|
2014-02-06 20:50:41 +04:00
|
|
|
|
2020-01-14 20:24:49 +03:00
|
|
|
function print_results($aResults, $bVerbose)
|
|
|
|
{
|
|
|
|
if ($bVerbose) {
|
|
|
|
if ($aResults && count($aResults)) {
|
|
|
|
echo $aResults[0]['langaddress']."\n";
|
|
|
|
} else {
|
|
|
|
echo "<not found>\n";
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
echo '.';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-09-04 04:19:48 +03:00
|
|
|
if (!$aResult['search-only']) {
|
2016-09-16 03:27:36 +03:00
|
|
|
$oReverseGeocode = new Nominatim\ReverseGeocode($oDB);
|
2016-09-04 04:19:48 +03:00
|
|
|
$oReverseGeocode->setZoom(20);
|
2016-09-16 03:27:36 +03:00
|
|
|
$oPlaceLookup = new Nominatim\PlaceLookup($oDB);
|
2016-09-04 04:19:48 +03:00
|
|
|
$oPlaceLookup->setIncludeAddressDetails(true);
|
|
|
|
$oPlaceLookup->setLanguagePreference(array('en'));
|
2014-02-06 20:50:41 +04:00
|
|
|
|
2017-10-26 22:21:21 +03:00
|
|
|
echo 'Warm reverse: ';
|
2016-09-04 04:19:48 +03:00
|
|
|
if ($bVerbose) echo "\n";
|
2016-09-08 04:16:22 +03:00
|
|
|
for ($i = 0; $i < 1000; $i++) {
|
2016-09-04 04:19:48 +03:00
|
|
|
$fLat = rand(-9000, 9000) / 100;
|
|
|
|
$fLon = rand(-18000, 18000) / 100;
|
|
|
|
if ($bVerbose) echo "$fLat, $fLon = ";
|
2020-01-14 20:24:49 +03:00
|
|
|
|
2019-01-09 00:45:21 +03:00
|
|
|
$oLookup = $oReverseGeocode->lookup($fLat, $fLon);
|
2020-01-14 20:24:49 +03:00
|
|
|
$aSearchResults = $oLookup ? $oPlaceLookup->lookup(array($oLookup->iId => $oLookup)) : null;
|
|
|
|
print_results($aSearchResults, $bVerbose);
|
2016-09-04 04:19:48 +03:00
|
|
|
}
|
|
|
|
echo "\n";
|
|
|
|
}
|
2014-02-06 20:50:41 +04:00
|
|
|
|
2016-09-04 04:19:48 +03:00
|
|
|
if (!$aResult['reverse-only']) {
|
2017-04-02 19:03:17 +03:00
|
|
|
$oGeocode = new Nominatim\Geocode($oDB);
|
2014-02-06 20:50:41 +04:00
|
|
|
|
2017-10-26 22:21:21 +03:00
|
|
|
echo 'Warm search: ';
|
2016-09-04 04:19:48 +03:00
|
|
|
if ($bVerbose) echo "\n";
|
2020-01-14 20:24:49 +03:00
|
|
|
$sSQL = 'SELECT word FROM word WHERE word is not null ORDER BY search_name_count DESC LIMIT 1000';
|
2016-09-08 04:16:22 +03:00
|
|
|
foreach ($oDB->getCol($sSQL) as $sWord) {
|
2016-09-04 04:19:48 +03:00
|
|
|
if ($bVerbose) echo "$sWord = ";
|
2020-01-14 20:24:49 +03:00
|
|
|
|
2016-09-04 04:19:48 +03:00
|
|
|
$oGeocode->setLanguagePreference(array('en'));
|
|
|
|
$oGeocode->setQuery($sWord);
|
|
|
|
$aSearchResults = $oGeocode->lookup();
|
2020-01-14 20:24:49 +03:00
|
|
|
print_results($aSearchResults, $bVerbose);
|
2016-09-04 04:19:48 +03:00
|
|
|
}
|
2020-01-14 20:24:49 +03:00
|
|
|
echo "\n";
|
2016-09-04 04:19:48 +03:00
|
|
|
}
|