X-Git-Url: https://git.wh0rd.org/?a=blobdiff_plain;f=include%2Fsanity_check.php;h=8a38ec5238a552aeb282db334248213be3a69ef1;hb=b2f085806040ee9eb4ea02739c507c20baf8e981;hp=5cb55674663cf5dd447cb3b503dde4a7910c7b05;hpb=ef1162593f6aec45831dd458cec915e35f84bb09;p=tt-rss.git diff --git a/include/sanity_check.php b/include/sanity_check.php old mode 100644 new mode 100755 index 5cb55674..8a38ec52 --- a/include/sanity_check.php +++ b/include/sanity_check.php @@ -1,8 +1,30 @@ = 60"); - } + if (SINGLE_USER_MODE && class_exists("PDO")) { + $pdo = DB::pdo(); - if (SESSION_EXPIRE_TIME < SESSION_COOKIE_LIFETIME) { - array_push($errors, "SESSION_EXPIRE_TIME set in config.php should be >= to SESSION_COOKIE_LIFETIME"); - } + $res = $pdo->query("SELECT id FROM ttrss_users WHERE id = 1"); - if (SINGLE_USER_MODE) { - $link = db_connect(DB_HOST, DB_USER, DB_PASS, DB_NAME); + if (!$res->fetch()) { + array_push($errors, "SINGLE_USER_MODE is enabled in config.php but default admin account is not found."); + } + } - if ($link) { - $result = db_query($link, "SELECT id FROM ttrss_users WHERE id = 1"); + $ref_self_url_path = make_self_url_path(); + $ref_self_url_path = preg_replace("/\w+\.php$/", "", $ref_self_url_path); - if (db_num_rows($result) != 1) { - array_push($errors, "SINGLE_USER_MODE is enabled in config.php but default admin account is not found."); - } - } + if (SELF_URL_PATH == "http://example.org/tt-rss/") { + array_push($errors, + "Please set SELF_URL_PATH to the correct value for your server (possible value: $ref_self_url_path)"); } - if (SELF_URL_PATH == "http://yourserver/tt-rss/") { - if ($_SERVER['HTTP_REFERER']) { - array_push($errors, - "Please set SELF_URL_PATH to the correct value for your server (possible value: " . $_SERVER['HTTP_REFERER'] . ")"); - } else { - array_push($errors, "Please set SELF_URL_PATH to the correct value for your server."); - } + if (isset($_SERVER["HTTP_HOST"]) && + (!defined('_SKIP_SELF_URL_PATH_CHECKS') || !_SKIP_SELF_URL_PATH_CHECKS) && + SELF_URL_PATH != $ref_self_url_path && SELF_URL_PATH != mb_substr($ref_self_url_path, 0, mb_strlen($ref_self_url_path)-1)) { + array_push($errors, + "Please set SELF_URL_PATH to the correct value detected for your server: $ref_self_url_path"); } if (!is_writable(ICONS_DIR)) { @@ -85,10 +115,6 @@ array_push($errors, "LOCK_DIRECTORY defined in config.php is not writable (chmod -R 777 ".LOCK_DIRECTORY.").\n"); } - if (ini_get("open_basedir")) { - array_push($errors, "PHP configuration option open_basedir is not supported. Please disable this in PHP settings file (php.ini)."); - } - if (!function_exists("curl_init") && !ini_get("allow_url_fopen")) { array_push($errors, "PHP configuration option allow_url_fopen is disabled, and CURL functions are not present. Either enable allow_url_fopen or install PHP extension for CURL."); } @@ -97,7 +123,7 @@ array_push($errors, "PHP support for JSON is required, but was not found."); } - if (DB_TYPE == "mysql" && !function_exists("mysql_connect")) { + if (DB_TYPE == "mysql" && !function_exists("mysqli_connect")) { array_push($errors, "PHP support for MySQL is required for configured DB_TYPE in config.php."); } @@ -105,6 +131,10 @@ array_push($errors, "PHP support for PostgreSQL is required for configured DB_TYPE in config.php"); } + if (!class_exists("PDO")) { + array_push($errors, "PHP support for PDO is required but was not found."); + } + if (!function_exists("mb_strlen")) { array_push($errors, "PHP support for mbstring functions is required but was not found."); } @@ -113,21 +143,40 @@ array_push($errors, "PHP support for hash() function is required but was not found."); } - if (!function_exists("ctype_lower")) { - array_push($errors, "PHP support for ctype functions are required by HTMLPurifier."); - } - if (ini_get("safe_mode")) { - array_push($errors, "PHP safe mode setting is not supported."); + array_push($errors, "PHP safe mode setting is obsolete and not supported by tt-rss."); } - if ((PUBSUBHUBBUB_HUB || PUBSUBHUBBUB_ENABLED) && !function_exists("curl_init")) { - array_push($errors, "PHP support for CURL is required for PubSubHubbub."); + if (!function_exists("mime_content_type")) { + array_push($errors, "PHP function mime_content_type() is missing, try enabling fileinfo module."); } if (!class_exists("DOMDocument")) { array_push($errors, "PHP support for DOMDocument is required, but was not found."); } + + if (DB_TYPE == "mysql") { + $bad_tables = check_mysql_tables(); + + if (count($bad_tables) > 0) { + $bad_tables_fmt = []; + + foreach ($bad_tables as $bt) { + array_push($bad_tables_fmt, sprintf("%s (%s)", $bt['table_name'], $bt['engine'])); + } + + $msg = "

The following tables use an unsupported MySQL engine: " . + implode(", ", $bad_tables_fmt) . ".

"; + + $msg .= "

The only supported engine on MySQL is InnoDB. MyISAM lacks functionality to run + tt-rss. + Please backup your data (via OPML) and re-import the schema before continuing.

+

WARNING: importing the schema would mean LOSS OF ALL YOUR DATA.

"; + + + array_push($errors, $msg); + } + } } if (count($errors) > 0 && $_SERVER['REQUEST_URI']) { ?> @@ -135,10 +184,11 @@ Startup failed - + - - + + +

Startup failed

@@ -150,6 +200,8 @@

You might want to check tt-rss wiki or the forums for more information. Please search the forums before creating new topic for your question.

+ +
@@ -170,6 +222,6 @@ } } - initial_sanity_check($link); + initial_sanity_check(); ?>