]> git.wh0rd.org - tt-rss.git/blame - include/sanity_check.php
sanitize: move htmlawed rewriting to execute last so that we can keep
[tt-rss.git] / include / sanity_check.php
CommitLineData
1d3a17c7 1<?php
618e2d35
AD
2 // WARNING: Don't ask for help on tt-rss.org forums or the bugtracker if you have
3 // modified this file.
4
5be0ba92 5 function initial_sanity_check($link) {
d8735fc8 6
5be0ba92 7 $errors = array();
d8735fc8 8
5be0ba92
AD
9 if (!file_exists("config.php")) {
10 array_push($errors, "Configuration file not found. Looks like you forgot to copy config.php-dist to config.php and edit it.");
11 } else {
8fc26c41 12
5be0ba92 13 require_once "sanity_config.php";
c798704b 14
72679db8
AD
15 if (strpos(PLUGINS, "auth_") === FALSE) {
16 array_push($errors, "Please enable at least one authentication module via PLUGINS constant in config.php");
17 }
18
5be0ba92
AD
19 if (function_exists('posix_getuid') && posix_getuid() == 0) {
20 array_push($errors, "Please don't run this script as root.");
21 }
ef8be8ea 22
1b113281 23 if (version_compare(PHP_VERSION, '5.3.0', '<')) {
9170056c 24 array_push($errors, "PHP version 5.3.0 or newer required.");
79f946be
AD
25 }
26
5be0ba92 27 if (CONFIG_VERSION != EXPECTED_CONFIG_VERSION) {
545ca067 28 array_push($errors, "Configuration file (config.php) has incorrect version. Update it with new options from config.php-dist and set CONFIG_VERSION to the correct value.");
5be0ba92 29 }
ef8be8ea 30
5be0ba92
AD
31 if (!is_writable(CACHE_DIR . "/images")) {
32 array_push($errors, "Image cache is not writable (chmod -R 777 ".CACHE_DIR."/images)");
33 }
ef8be8ea 34
5be0ba92
AD
35 if (!is_writable(CACHE_DIR . "/export")) {
36 array_push($errors, "Data export cache is not writable (chmod -R 777 ".CACHE_DIR."/export)");
09e8bdfd 37 }
ef8be8ea 38
5be0ba92
AD
39 if (GENERATED_CONFIG_CHECK != EXPECTED_CONFIG_VERSION) {
40 array_push($errors,
41 "Configuration option checker sanity_config.php is outdated, please recreate it using ./utils/regen_config_checks.sh");
42 }
ef8be8ea 43
5be0ba92
AD
44 foreach ($requred_defines as $d) {
45 if (!defined($d)) {
46 array_push($errors,
47 "Required configuration file parameter $d is not defined in config.php. You might need to copy it from config.php-dist.");
48 }
49 }
50
51 if (SESSION_EXPIRE_TIME < 60) {
52 array_push($errors, "SESSION_EXPIRE_TIME set in config.php is too low, please set it to an integer value >= 60");
53 }
333f0b2a 54
5be0ba92
AD
55 if (SESSION_EXPIRE_TIME < SESSION_COOKIE_LIFETIME) {
56 array_push($errors, "SESSION_EXPIRE_TIME set in config.php should be >= to SESSION_COOKIE_LIFETIME");
57 }
50e7dd7d 58
5be0ba92
AD
59 if (SINGLE_USER_MODE) {
60 $link = db_connect(DB_HOST, DB_USER, DB_PASS, DB_NAME);
50e7dd7d 61
5be0ba92
AD
62 if ($link) {
63 $result = db_query($link, "SELECT id FROM ttrss_users WHERE id = 1");
64
65 if (db_num_rows($result) != 1) {
66 array_push($errors, "SINGLE_USER_MODE is enabled in config.php but default admin account is not found.");
67 }
09e8bdfd 68 }
50e7dd7d 69 }
b03b2631 70
5be0ba92
AD
71 if (SELF_URL_PATH == "http://yourserver/tt-rss/") {
72 if ($_SERVER['HTTP_REFERER']) {
73 array_push($errors,
74 "Please set SELF_URL_PATH to the correct value for your server (possible value: <b>" . $_SERVER['HTTP_REFERER'] . "</b>)");
75 } else {
76 array_push($errors, "Please set SELF_URL_PATH to the correct value for your server.");
77 }
09e8bdfd 78 }
17c0eeba 79
5be0ba92
AD
80 if (!is_writable(ICONS_DIR)) {
81 array_push($errors, "ICONS_DIR defined in config.php is not writable (chmod -R 777 ".ICONS_DIR.").\n");
82 }
17c0eeba 83
5be0ba92
AD
84 if (!is_writable(LOCK_DIRECTORY)) {
85 array_push($errors, "LOCK_DIRECTORY defined in config.php is not writable (chmod -R 777 ".LOCK_DIRECTORY.").\n");
86 }
2604ad7d 87
5be0ba92
AD
88 if (ini_get("open_basedir")) {
89 array_push($errors, "PHP configuration option open_basedir is not supported. Please disable this in PHP settings file (php.ini).");
90 }
78a5c296 91
5be0ba92
AD
92 if (!function_exists("curl_init") && !ini_get("allow_url_fopen")) {
93 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.");
94 }
78a5c296 95
5be0ba92
AD
96 if (!function_exists("json_encode")) {
97 array_push($errors, "PHP support for JSON is required, but was not found.");
98 }
edfab7bd 99
5be0ba92
AD
100 if (DB_TYPE == "mysql" && !function_exists("mysql_connect")) {
101 array_push($errors, "PHP support for MySQL is required for configured DB_TYPE in config.php.");
102 }
f6370f36 103
5be0ba92
AD
104 if (DB_TYPE == "pgsql" && !function_exists("pg_connect")) {
105 array_push($errors, "PHP support for PostgreSQL is required for configured DB_TYPE in config.php");
106 }
7bb8d39a 107
5be0ba92
AD
108 if (!function_exists("mb_strlen")) {
109 array_push($errors, "PHP support for mbstring functions is required but was not found.");
110 }
fe2f004c 111
5be0ba92
AD
112 if (!function_exists("hash")) {
113 array_push($errors, "PHP support for hash() function is required but was not found.");
114 }
7bb8d39a 115
5be0ba92
AD
116 if (!function_exists("ctype_lower")) {
117 array_push($errors, "PHP support for ctype functions are required by HTMLPurifier.");
118 }
7bb8d39a 119
5be0ba92
AD
120 if (ini_get("safe_mode")) {
121 array_push($errors, "PHP safe mode setting is not supported.");
122 }
7bb8d39a 123
5be0ba92
AD
124 if ((PUBSUBHUBBUB_HUB || PUBSUBHUBBUB_ENABLED) && !function_exists("curl_init")) {
125 array_push($errors, "PHP support for CURL is required for PubSubHubbub.");
126 }
7bb8d39a 127
5be0ba92
AD
128 if (!class_exists("DOMDocument")) {
129 array_push($errors, "PHP support for DOMDocument is required, but was not found.");
130 }
09e8bdfd 131 }
f5b429ef 132
5be0ba92
AD
133 if (count($errors) > 0 && $_SERVER['REQUEST_URI']) { ?>
134 <html>
135 <head>
136 <title>Startup failed</title>
137 <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
138 <link rel="stylesheet" type="text/css" href="utility.css">
139 </head>
140 <body>
141 <div class="floatingLogo"><img src="images/logo_wide.png"></div>
7bb8d39a 142
5be0ba92 143 <h1>Startup failed</h1>
e2bcd11b 144
5be0ba92
AD
145 <p>Tiny Tiny RSS was unable to start properly. This usually means a misconfiguration or an incomplete upgrade. Please fix
146 errors indicated by the following messages:</p>
76a259c2 147
5be0ba92 148 <?php foreach ($errors as $error) { echo format_error($error); } ?>
e6a63a1c 149
5be0ba92
AD
150 <p>You might want to check tt-rss <a href="http://tt-rss.org/wiki">wiki</a> or the
151 <a href="http://tt-rss.org/forum">forums</a> for more information. Please search the forums before creating new topic
152 for your question.</p>
09e8bdfd
AD
153 </body>
154 </html>
f56c6cd4 155
5be0ba92
AD
156 <?php
157 die;
158 } else if (count($errors) > 0) {
159 echo "Tiny Tiny RSS was unable to start properly. This usually means a misconfiguration or an incomplete upgrade.\n";
160 echo "Please fix errors indicated by the following messages:\n\n";
161
162 foreach ($errors as $error) {
163 echo " * $error\n";
164 }
165
383b0090 166 echo "\nYou might want to check tt-rss wiki or the forums for more information.\n";
5be0ba92
AD
167 echo "Please search the forums before creating new topic for your question.\n";
168
169 exit(-1);
170 }
ef8be8ea
AD
171 }
172
5be0ba92
AD
173 initial_sanity_check($link);
174
66581886 175?>