]> git.openstreetmap.org Git - nominatim.git/blobdiff - website/status.php
Merge pull request #1233 from mtmail/better-gbpostcode-setup-warning
[nominatim.git] / website / status.php
index 0caa92a0add83cfaa19f7de8839db22c6d5e8a73..c0c379d0a983e6dd6d331d5a0089a75866570952 100644 (file)
@@ -1,26 +1,51 @@
 <?php
 <?php
-        @define('CONST_ConnectionBucket_PageType', 'Status');
-
-        require_once(dirname(dirname(__FILE__)).'/lib/init-website.php');
-
-        $oDB =& getDB();
-       if (!$oDB || PEAR::isError($oDB))
-       {
-               echo "ERROR: No database";
-               exit;
-       }
-
-       $iWordID = $oDB->getOne("select word_id,word_token, word, class, type, location, country_code, operator, search_name_count from word where word_token in (' a')");
-       if (PEAR::isError($iWordID))
-       {
-               echo "ERROR: Query failed";
-               exit;
-       }
-       if (!$iWordID)
-       {
-               echo "ERROR: No value";
-               exit;
-       }
-       echo "OK";
-       exit;
 
 
+@define('CONST_ConnectionBucket_PageType', 'Status');
+
+require_once(dirname(dirname(__FILE__)).'/settings/settings.php');
+require_once(CONST_BasePath.'/lib/init-website.php');
+require_once(CONST_BasePath.'/lib/ParameterParser.php');
+require_once(CONST_BasePath.'/lib/Status.php');
+
+$oParams = new Nominatim\ParameterParser();
+$sOutputFormat = $oParams->getSet('format', array('text', 'json'), 'text');
+
+$oDB = DB::connect(CONST_Database_DSN, false);
+$oStatus = new Nominatim\Status($oDB);
+
+
+if ($sOutputFormat == 'json') {
+    header('content-type: application/json; charset=UTF-8');
+}
+
+
+try {
+    $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 ($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';
+}
+
+exit;