mirror of
https://github.com/osm-search/Nominatim.git
synced 2024-12-18 18:41:51 +03:00
9712decefe
Use https for all openstreetmap addresses, remove defunct mapquest link and redirect documentation links to nominatim.org.
138 lines
3.8 KiB
PHP
Executable File
138 lines
3.8 KiB
PHP
Executable File
<?php
|
|
|
|
require_once(dirname(dirname(__FILE__)).'/settings/settings.php');
|
|
require_once(CONST_BasePath.'/lib/init-website.php');
|
|
require_once(CONST_BasePath.'/lib/log.php');
|
|
require_once(CONST_BasePath.'/lib/output.php');
|
|
ini_set('memory_limit', '200M');
|
|
|
|
$oParams = new Nominatim\ParameterParser();
|
|
|
|
$sOutputFormat = 'html';
|
|
$iDays = $oParams->getInt('days', false);
|
|
$bReduced = $oParams->getBool('reduced', false);
|
|
$sClass = $oParams->getString('class', false);
|
|
|
|
$oDB =& getDB();
|
|
|
|
$iTotalBroken = (int) chksql($oDB->getOne('select count(*) from import_polygon_error'));
|
|
|
|
$aPolygons = array();
|
|
while ($iTotalBroken && !sizeof($aPolygons)) {
|
|
$sSQL = 'select osm_type as "type",osm_id as "id",class as "key",type as "value",name->\'name\' as "name",';
|
|
$sSQL .= 'country_code as "country",errormessage as "error message",updated';
|
|
$sSQL .= ' from import_polygon_error';
|
|
|
|
$aWhere = array();
|
|
if ($iDays) {
|
|
$aWhere[] = "updated > 'now'::timestamp - '".$iDays." day'::interval";
|
|
$iDays++;
|
|
}
|
|
|
|
if ($bReduced) $aWhere[] = "errormessage like 'Area reduced%'";
|
|
if ($sClass) $sWhere[] = "class = '".pg_escape_string($sClass)."'";
|
|
|
|
if (sizeof($aWhere)) {
|
|
$sSQL .= ' where '.join(' and ', $aWhere);
|
|
}
|
|
|
|
$sSQL .= ' order by updated desc limit 1000';
|
|
$aPolygons = chksql($oDB->getAll($sSQL));
|
|
}
|
|
|
|
if (CONST_Debug) {
|
|
var_dump($aPolygons);
|
|
exit;
|
|
}
|
|
|
|
?>
|
|
<!DOCTYPE html>
|
|
<html>
|
|
<head>
|
|
<meta charset="utf-8"/>
|
|
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" >
|
|
|
|
<title>Nominatim Broken Polygon Data</title>
|
|
|
|
<meta name="description" content="List of broken OSM polygon data by date" lang="en-US" />
|
|
|
|
</head>
|
|
|
|
<body>
|
|
<style type="text/css">
|
|
table {
|
|
border-width: 1px;
|
|
border-spacing: 0px;
|
|
border-style: solid;
|
|
border-color: gray;
|
|
border-collapse: collapse;
|
|
background-color: white;
|
|
margin: 10px;
|
|
}
|
|
table th {
|
|
border-width: 1px;
|
|
padding: 2px;
|
|
border-style: inset;
|
|
border-color: gray;
|
|
border-left-color: #ddd;
|
|
border-right-color: #ddd;
|
|
background-color: #eee;
|
|
-moz-border-radius: 0px 0px 0px 0px;
|
|
}
|
|
table td {
|
|
border-width: 1px;
|
|
padding: 2px;
|
|
border-style: inset;
|
|
border-color: gray;
|
|
border-left-color: #ddd;
|
|
border-right-color: #ddd;
|
|
background-color: white;
|
|
-moz-border-radius: 0px 0px 0px 0px;
|
|
}
|
|
</style>
|
|
|
|
<?php
|
|
|
|
echo "<p>Total number of broken polygons: $iTotalBroken</p>";
|
|
if (!$aPolygons) exit;
|
|
echo '<table>';
|
|
echo '<tr>';
|
|
//var_dump($aPolygons[0]);
|
|
foreach ($aPolygons[0] as $sCol => $sVal) {
|
|
echo '<th>'.$sCol.'</th>';
|
|
}
|
|
echo '<th> </th>';
|
|
echo '</tr>';
|
|
$aSeen = array();
|
|
foreach ($aPolygons as $aRow) {
|
|
if (isset($aSeen[$aRow['type'].$aRow['id']])) continue;
|
|
$aSeen[$aRow['type'].$aRow['id']] = 1;
|
|
echo '<tr>';
|
|
foreach ($aRow as $sCol => $sVal) {
|
|
switch ($sCol) {
|
|
case 'error message':
|
|
if (preg_match('/Self-intersection\\[([0-9.\\-]+) ([0-9.\\-]+)\\]/', $sVal, $aMatch)) {
|
|
$aRow['lat'] = $aMatch[2];
|
|
$aRow['lon'] = $aMatch[1];
|
|
echo '<td><a href="https://www.openstreetmap.org/?lat='.$aMatch[2].'&lon='.$aMatch[1].'&zoom=18&layers=M&'.$sOSMType.'='.$aRow['id'].'">'.($sVal?$sVal:' ').'</a></td>';
|
|
} else {
|
|
echo '<td>'.($sVal?$sVal:' ').'</td>';
|
|
}
|
|
break;
|
|
case 'id':
|
|
echo '<td>'.osmLink($aRow).'</td>';
|
|
break;
|
|
default:
|
|
echo '<td>'.($sVal?$sVal:' ').'</td>';
|
|
break;
|
|
}
|
|
}
|
|
echo '<td><a href="http://localhost:8111/import?url=https://www.openstreetmap.org/api/0.6/'.$sOSMType.'/'.$aRow['id'].'/full" target="josm">josm</a></td>';
|
|
echo '</tr>';
|
|
}
|
|
echo '</table>';
|
|
|
|
?>
|
|
</body>
|
|
</html>
|