X-Git-Url: https://git.openstreetmap.org./nominatim.git/blobdiff_plain/6a3c6c43ea7133c934834ce1face9212f4e3d239..b1e5f3cbed17d862fda8f6a238aa1d69fe8786c0:/website/status.php diff --git a/website/status.php b/website/status.php index 124dc507..0d483544 100644 --- a/website/status.php +++ b/website/status.php @@ -1,37 +1,47 @@ getSet('format', array('text', 'json'), 'text'); -function statusError($sMsg) -{ - header('HTTP/1.0 500 Internal Server Error'); - echo 'ERROR: '.$sMsg; - exit; -} +$oDB = new Nominatim\DB(); -$oDB =& DB::connect(CONST_Database_DSN, false); -if (!$oDB || PEAR::isError($oDB)) { - statusError('No database'); +if ($sOutputFormat == 'json') { + header('content-type: application/json; charset=UTF-8'); } -$sStandardWord = $oDB->getOne("select make_standard_name('a')"); -if (PEAR::isError($sStandardWord)) { - statusError('Module failed'); -} -if ($sStandardWord != 'a') { - statusError('Module call failed'); -} -$iWordID = $oDB->getOne("select word_id,word_token, word, class, type, country_code, operator, search_name_count from word where word_token in (' a')"); -if (PEAR::isError($iWordID)) { - statusError('Query failed'); +try { + $oStatus = new Nominatim\Status($oDB); + $oStatus->status(); +} catch (Exception $oErr) { + if ($sOutputFormat == 'json') { + $aResponse = array( + 'status' => $oErr->getCode(), + 'message' => $oErr->getMessage() + ); + javascript_renderData($aResponse); + } else { + header('HTTP/1.0 500 Internal Server Error'); + echo 'ERROR: '.$oErr->getMessage(); + } + exit; } -if (!$iWordID) { - statusError('No value'); + + +if ($sOutputFormat == 'json') { + $epoch = $oStatus->dataDate(); + $aResponse = array( + 'status' => 0, + 'message' => 'OK', + 'data_updated' => (new DateTime('@'.$epoch))->format(DateTime::RFC3339) + ); + javascript_renderData($aResponse); +} else { + echo 'OK'; } -echo 'OK'; exit;