forked from hans/Nominatim
CONST_BasePath is split into separate configuration variables for binaries, libraries and data. These variables as well as the installation path are now set in the executable directly and no longer configurable via project settings. This is the first step towards an installable software. The executables should know per installation where to find their necessary data to execute. Project configuration needs to be restricted to settings that really concern the specific Nominatim installation.
188 lines
4.5 KiB
PHP
Executable File
188 lines
4.5 KiB
PHP
Executable File
<?php
|
|
|
|
require_once(CONST_LibDir.'/init-cmd.php');
|
|
|
|
$term_colors = array(
|
|
'green' => "\033[92m",
|
|
'red' => "\x1B[31m",
|
|
'normal' => "\033[0m"
|
|
);
|
|
|
|
$print_success = function ($message = 'OK') use ($term_colors) {
|
|
echo $term_colors['green'].$message.$term_colors['normal']."\n";
|
|
};
|
|
|
|
$print_fail = function ($message = 'Failed') use ($term_colors) {
|
|
echo $term_colors['red'].$message.$term_colors['normal']."\n";
|
|
};
|
|
|
|
|
|
$oDB = new Nominatim\DB;
|
|
|
|
|
|
function isReverseOnlyInstallation()
|
|
{
|
|
global $oDB;
|
|
return !$oDB->tableExists('search_name');
|
|
}
|
|
|
|
|
|
echo 'Checking database got created ... ';
|
|
if ($oDB->checkConnection()) {
|
|
$print_success();
|
|
} else {
|
|
$print_fail();
|
|
echo <<< END
|
|
Hints:
|
|
* Is the database server started?
|
|
* Check the CONST_Database_DSN variable in build/settings/local.php
|
|
* Try connecting to the database with the same settings
|
|
|
|
END;
|
|
exit(1);
|
|
}
|
|
|
|
|
|
echo 'Checking nominatim.so module installed ... ';
|
|
$sStandardWord = $oDB->getOne("SELECT make_standard_name('a')");
|
|
if ($sStandardWord === 'a') {
|
|
$print_success();
|
|
} else {
|
|
$print_fail();
|
|
echo <<< END
|
|
The Postgresql extension nominatim.so was not found in the database.
|
|
Hints:
|
|
* Check the output of the CMmake/make installation step
|
|
* Does nominatim.so exist?
|
|
* Does nominatim.so exist on the database server?
|
|
* Can nominatim.so be accessed by the database user?
|
|
|
|
END;
|
|
exit(1);
|
|
}
|
|
|
|
echo 'Checking place table ... ';
|
|
if ($oDB->tableExists('place')) {
|
|
$print_success();
|
|
} else {
|
|
$print_fail();
|
|
echo <<< END
|
|
* The import didn't finish.
|
|
Hints:
|
|
* Check the output of the utils/setup.php you ran.
|
|
Usually the osm2pgsql step failed. Check for errors related to
|
|
* the file you imported not containing any places
|
|
* harddrive full
|
|
* out of memory (RAM)
|
|
* osm2pgsql killed by other scripts, for consuming to much memory
|
|
|
|
END;
|
|
exit(1);
|
|
}
|
|
|
|
|
|
|
|
echo 'Checking indexing status ... ';
|
|
$iUnindexed = $oDB->getOne('SELECT count(*) FROM placex WHERE indexed_status > 0');
|
|
if ($iUnindexed == 0) {
|
|
$print_success();
|
|
} else {
|
|
$print_fail();
|
|
echo <<< END
|
|
The indexing didn't finish. There is still $iUnindexed places. See the
|
|
question 'Can a stopped/killed import process be resumed?' in the
|
|
troubleshooting guide.
|
|
|
|
END;
|
|
exit(1);
|
|
}
|
|
|
|
echo "Search index creation\n";
|
|
$aExpectedIndices = array(
|
|
// sql/indices.src.sql
|
|
'idx_word_word_id',
|
|
'idx_place_addressline_address_place_id',
|
|
'idx_placex_rank_search',
|
|
'idx_placex_rank_address',
|
|
'idx_placex_pendingsector',
|
|
'idx_placex_parent_place_id',
|
|
'idx_placex_geometry_reverse_lookuppolygon',
|
|
'idx_placex_geometry_reverse_placenode',
|
|
'idx_location_area_country_place_id',
|
|
'idx_osmline_parent_place_id',
|
|
'idx_osmline_parent_osm_id',
|
|
'idx_place_osm_unique',
|
|
'idx_postcode_id',
|
|
'idx_postcode_postcode'
|
|
);
|
|
if (!isReverseOnlyInstallation()) {
|
|
$aExpectedIndices = array_merge($aExpectedIndices, array(
|
|
// sql/indices_search.src.sql
|
|
'idx_search_name_nameaddress_vector',
|
|
'idx_search_name_name_vector',
|
|
'idx_search_name_centroid'
|
|
));
|
|
}
|
|
|
|
foreach ($aExpectedIndices as $sExpectedIndex) {
|
|
echo "Checking index $sExpectedIndex ... ";
|
|
if ($oDB->indexExists($sExpectedIndex)) {
|
|
$print_success();
|
|
} else {
|
|
$print_fail();
|
|
echo <<< END
|
|
Hints:
|
|
* Run './utils/setup.php --create-search-indices --ignore-errors' to
|
|
create missing indices.
|
|
|
|
END;
|
|
exit(1);
|
|
}
|
|
}
|
|
|
|
echo 'Checking search indices are valid ... ';
|
|
$sSQL = <<< END
|
|
SELECT relname
|
|
FROM pg_class, pg_index
|
|
WHERE pg_index.indisvalid = false
|
|
AND pg_index.indexrelid = pg_class.oid;
|
|
END;
|
|
$aInvalid = $oDB->getCol($sSQL);
|
|
if (empty($aInvalid)) {
|
|
$print_success();
|
|
} else {
|
|
$print_fail();
|
|
echo <<< END
|
|
At least one index is invalid. That can happen, e.g. when index creation was
|
|
disrupted and later restarted. You should delete the affected indices and
|
|
run the index stage of setup again.
|
|
See the question 'Can a stopped/killed import process be resumed?' in the
|
|
troubleshooting guide.
|
|
Affected indices:
|
|
END;
|
|
echo join(', ', $aInvalid) . "\n";
|
|
exit(1);
|
|
}
|
|
|
|
|
|
|
|
if (CONST_Use_US_Tiger_Data) {
|
|
echo 'Checking TIGER table exists ... ';
|
|
if ($oDB->tableExists('location_property_tiger')) {
|
|
$print_success();
|
|
} else {
|
|
$print_fail();
|
|
echo <<< END
|
|
Table 'location_property_tiger' does not exist. Run the TIGER data
|
|
import again.
|
|
|
|
END;
|
|
exit(1);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
exit(0);
|