mirror of
https://github.com/osm-search/Nominatim.git
synced 2026-02-26 11:08:13 +00:00
make missing osmosis non-fatal for 'all' option - just skip it
This commit is contained in:
135
utils/setup.php
135
utils/setup.php
@@ -502,75 +502,80 @@
|
|||||||
if (!file_exists(CONST_Osmosis_Binary))
|
if (!file_exists(CONST_Osmosis_Binary))
|
||||||
{
|
{
|
||||||
echo "Please download osmosis.\nIf it is already installed, check the path in your local settings (settings/local.php) file.\n";
|
echo "Please download osmosis.\nIf it is already installed, check the path in your local settings (settings/local.php) file.\n";
|
||||||
fail("osmosis not found in '".CONST_Osmosis_Binary."'");
|
if (!$aCMDResult['all'])
|
||||||
}
|
{
|
||||||
if (file_exists(CONST_BasePath.'/settings/configuration.txt'))
|
fail("osmosis not found in '".CONST_Osmosis_Binary."'");
|
||||||
{
|
}
|
||||||
echo "settings/configuration.txt already exists\n";
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
passthru(CONST_Osmosis_Binary.' --read-replication-interval-init '.CONST_BasePath.'/settings');
|
if (file_exists(CONST_BasePath.'/settings/configuration.txt'))
|
||||||
// update osmosis configuration.txt with our settings
|
{
|
||||||
passthru("sed -i 's!baseUrl=.*!baseUrl=".CONST_Replication_Url."!' ".CONST_BasePath.'/settings/configuration.txt');
|
echo "settings/configuration.txt already exists\n";
|
||||||
passthru("sed -i 's:maxInterval = .*:maxInterval = ".CONST_Replication_MaxInterval.":' ".CONST_BasePath.'/settings/configuration.txt');
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
passthru(CONST_Osmosis_Binary.' --read-replication-interval-init '.CONST_BasePath.'/settings');
|
||||||
|
// update osmosis configuration.txt with our settings
|
||||||
|
passthru("sed -i 's!baseUrl=.*!baseUrl=".CONST_Replication_Url."!' ".CONST_BasePath.'/settings/configuration.txt');
|
||||||
|
passthru("sed -i 's:maxInterval = .*:maxInterval = ".CONST_Replication_MaxInterval.":' ".CONST_BasePath.'/settings/configuration.txt');
|
||||||
|
}
|
||||||
|
|
||||||
|
// Find the last node in the DB
|
||||||
|
$iLastOSMID = $oDB->getOne("select max(id) from planet_osm_nodes");
|
||||||
|
|
||||||
|
// Lookup the timestamp that node was created (less 3 hours for margin for changsets to be closed)
|
||||||
|
$sLastNodeURL = 'http://www.openstreetmap.org/api/0.6/node/'.$iLastOSMID."/1";
|
||||||
|
$sLastNodeXML = file_get_contents($sLastNodeURL);
|
||||||
|
preg_match('#timestamp="(([0-9]{4})-([0-9]{2})-([0-9]{2})T([0-9]{2}):([0-9]{2}):([0-9]{2})Z)"#', $sLastNodeXML, $aLastNodeDate);
|
||||||
|
$iLastNodeTimestamp = strtotime($aLastNodeDate[1]) - (3*60*60);
|
||||||
|
|
||||||
|
// Search for the correct state file - uses file timestamps so need to sort by date descending
|
||||||
|
$sRepURL = CONST_Replication_Url."/";
|
||||||
|
$sRep = file_get_contents($sRepURL."?C=M;O=D");
|
||||||
|
// download.geofabrik.de: <a href="000/">000/</a></td><td align="right">26-Feb-2013 11:53 </td>
|
||||||
|
// planet.openstreetmap.org: <a href="273/">273/</a> 22-Mar-2013 07:41 -
|
||||||
|
preg_match_all('#<a href="[0-9]{3}/">([0-9]{3}/)</a>.*(([0-9]{2})-([A-z]{3})-([0-9]{4}) ([0-9]{2}):([0-9]{2}))#', $sRep, $aRepMatches, PREG_SET_ORDER);
|
||||||
|
$aPrevRepMatch = false;
|
||||||
|
foreach($aRepMatches as $aRepMatch)
|
||||||
|
{
|
||||||
|
if (strtotime($aRepMatch[2]) < $iLastNodeTimestamp) break;
|
||||||
|
$aPrevRepMatch = $aRepMatch;
|
||||||
|
}
|
||||||
|
if ($aPrevRepMatch) $aRepMatch = $aPrevRepMatch;
|
||||||
|
|
||||||
|
$sRepURL .= $aRepMatch[1];
|
||||||
|
$sRep = file_get_contents($sRepURL."?C=M;O=D");
|
||||||
|
preg_match_all('#<a href="[0-9]{3}/">([0-9]{3}/)</a>.*(([0-9]{2})-([A-z]{3})-([0-9]{4}) ([0-9]{2}):([0-9]{2}))#', $sRep, $aRepMatches, PREG_SET_ORDER);
|
||||||
|
$aPrevRepMatch = false;
|
||||||
|
foreach($aRepMatches as $aRepMatch)
|
||||||
|
{
|
||||||
|
if (strtotime($aRepMatch[2]) < $iLastNodeTimestamp) break;
|
||||||
|
$aPrevRepMatch = $aRepMatch;
|
||||||
|
}
|
||||||
|
if ($aPrevRepMatch) $aRepMatch = $aPrevRepMatch;
|
||||||
|
|
||||||
|
$sRepURL .= $aRepMatch[1];
|
||||||
|
$sRep = file_get_contents($sRepURL."?C=M;O=D");
|
||||||
|
preg_match_all('#<a href="[0-9]{3}.state.txt">([0-9]{3}).state.txt</a>.*(([0-9]{2})-([A-z]{3})-([0-9]{4}) ([0-9]{2}):([0-9]{2}))#', $sRep, $aRepMatches, PREG_SET_ORDER);
|
||||||
|
$aPrevRepMatch = false;
|
||||||
|
foreach($aRepMatches as $aRepMatch)
|
||||||
|
{
|
||||||
|
if (strtotime($aRepMatch[2]) < $iLastNodeTimestamp) break;
|
||||||
|
$aPrevRepMatch = $aRepMatch;
|
||||||
|
}
|
||||||
|
if ($aPrevRepMatch) $aRepMatch = $aPrevRepMatch;
|
||||||
|
|
||||||
|
$sRepURL .= $aRepMatch[1].'.state.txt';
|
||||||
|
echo "Getting state file: $sRepURL\n";
|
||||||
|
$sStateFile = file_get_contents($sRepURL);
|
||||||
|
if (!$sStateFile || strlen($sStateFile) > 1000) fail("unable to obtain state file");
|
||||||
|
file_put_contents(CONST_BasePath.'/settings/state.txt', $sStateFile);
|
||||||
|
echo "Updating DB status\n";
|
||||||
|
pg_query($oDB->connection, 'TRUNCATE import_status');
|
||||||
|
$sSQL = "INSERT INTO import_status VALUES('".$aRepMatch[2]."')";
|
||||||
|
pg_query($oDB->connection, $sSQL);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Find the last node in the DB
|
|
||||||
$iLastOSMID = $oDB->getOne("select max(id) from planet_osm_nodes");
|
|
||||||
|
|
||||||
// Lookup the timestamp that node was created (less 3 hours for margin for changsets to be closed)
|
|
||||||
$sLastNodeURL = 'http://www.openstreetmap.org/api/0.6/node/'.$iLastOSMID."/1";
|
|
||||||
$sLastNodeXML = file_get_contents($sLastNodeURL);
|
|
||||||
preg_match('#timestamp="(([0-9]{4})-([0-9]{2})-([0-9]{2})T([0-9]{2}):([0-9]{2}):([0-9]{2})Z)"#', $sLastNodeXML, $aLastNodeDate);
|
|
||||||
$iLastNodeTimestamp = strtotime($aLastNodeDate[1]) - (3*60*60);
|
|
||||||
|
|
||||||
|
|
||||||
// Search for the correct state file - uses file timestamps so need to sort by date descending
|
|
||||||
$sRepURL = CONST_Replication_Url."/";
|
|
||||||
$sRep = file_get_contents($sRepURL."?C=M;O=D");
|
|
||||||
// download.geofabrik.de: <a href="000/">000/</a></td><td align="right">26-Feb-2013 11:53 </td>
|
|
||||||
// planet.openstreetmap.org: <a href="273/">273/</a> 22-Mar-2013 07:41 -
|
|
||||||
preg_match_all('#<a href="[0-9]{3}/">([0-9]{3}/)</a>.*(([0-9]{2})-([A-z]{3})-([0-9]{4}) ([0-9]{2}):([0-9]{2}))#', $sRep, $aRepMatches, PREG_SET_ORDER);
|
|
||||||
$aPrevRepMatch = false;
|
|
||||||
foreach($aRepMatches as $aRepMatch)
|
|
||||||
{
|
|
||||||
if (strtotime($aRepMatch[2]) < $iLastNodeTimestamp) break;
|
|
||||||
$aPrevRepMatch = $aRepMatch;
|
|
||||||
}
|
|
||||||
if ($aPrevRepMatch) $aRepMatch = $aPrevRepMatch;
|
|
||||||
|
|
||||||
$sRepURL .= $aRepMatch[1];
|
|
||||||
$sRep = file_get_contents($sRepURL."?C=M;O=D");
|
|
||||||
preg_match_all('#<a href="[0-9]{3}/">([0-9]{3}/)</a>.*(([0-9]{2})-([A-z]{3})-([0-9]{4}) ([0-9]{2}):([0-9]{2}))#', $sRep, $aRepMatches, PREG_SET_ORDER);
|
|
||||||
$aPrevRepMatch = false;
|
|
||||||
foreach($aRepMatches as $aRepMatch)
|
|
||||||
{
|
|
||||||
if (strtotime($aRepMatch[2]) < $iLastNodeTimestamp) break;
|
|
||||||
$aPrevRepMatch = $aRepMatch;
|
|
||||||
}
|
|
||||||
if ($aPrevRepMatch) $aRepMatch = $aPrevRepMatch;
|
|
||||||
|
|
||||||
$sRepURL .= $aRepMatch[1];
|
|
||||||
$sRep = file_get_contents($sRepURL."?C=M;O=D");
|
|
||||||
preg_match_all('#<a href="[0-9]{3}.state.txt">([0-9]{3}).state.txt</a>.*(([0-9]{2})-([A-z]{3})-([0-9]{4}) ([0-9]{2}):([0-9]{2}))#', $sRep, $aRepMatches, PREG_SET_ORDER);
|
|
||||||
$aPrevRepMatch = false;
|
|
||||||
foreach($aRepMatches as $aRepMatch)
|
|
||||||
{
|
|
||||||
if (strtotime($aRepMatch[2]) < $iLastNodeTimestamp) break;
|
|
||||||
$aPrevRepMatch = $aRepMatch;
|
|
||||||
}
|
|
||||||
if ($aPrevRepMatch) $aRepMatch = $aPrevRepMatch;
|
|
||||||
|
|
||||||
$sRepURL .= $aRepMatch[1].'.state.txt';
|
|
||||||
echo "Getting state file: $sRepURL\n";
|
|
||||||
$sStateFile = file_get_contents($sRepURL);
|
|
||||||
if (!$sStateFile || strlen($sStateFile) > 1000) fail("unable to obtain state file");
|
|
||||||
file_put_contents(CONST_BasePath.'/settings/state.txt', $sStateFile);
|
|
||||||
echo "Updating DB status\n";
|
|
||||||
pg_query($oDB->connection, 'TRUNCATE import_status');
|
|
||||||
$sSQL = "INSERT INTO import_status VALUES('".$aRepMatch[2]."')";
|
|
||||||
pg_query($oDB->connection, $sSQL);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($aCMDResult['index'] || $aCMDResult['all'])
|
if ($aCMDResult['index'] || $aCMDResult['all'])
|
||||||
|
|||||||
Reference in New Issue
Block a user