123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443 |
- <?php
- if (!defined('SMF'))
- die('Hacking attempt...');
- function log_error($error_message, $error_type = 'general', $file = null, $line = null)
- {
- global $txt, $modSettings, $sc, $user_info, $smcFunc, $scripturl, $last_error;
- static $tried_hook = false;
-
- if (empty($modSettings['enableErrorLogging']))
- return $error_message;
-
- $error_message = strtr($error_message, array('<' => '<', '>' => '>', '"' => '"'));
- $error_message = strtr($error_message, array('<br />' => '<br />', '<b>' => '<strong>', '</b>' => '</strong>', "\n" => '<br />'));
-
-
- if ($file == null)
- $file = '';
- else
-
- $file = str_replace('\\', '/', $file);
- if ($line == null)
- $line = 0;
- else
- $line = (int) $line;
-
- if (empty($user_info['id']))
- $user_info['id'] = 0;
- if (empty($user_info['ip']))
- $user_info['ip'] = '';
-
- $query_string = empty($_SERVER['QUERY_STRING']) ? (empty($_SERVER['REQUEST_URL']) ? '' : str_replace($scripturl, '', $_SERVER['REQUEST_URL'])) : $_SERVER['QUERY_STRING'];
-
- $query_string = htmlspecialchars((SMF == 'SSI' ? '' : '?') . preg_replace(array('~;sesc=[^&;]+~', '~' . session_name() . '=' . session_id() . '[&;]~'), array(';sesc', ''), $query_string));
-
- if (isset($_POST['board']) && !isset($_GET['board']))
- $query_string .= ($query_string == '' ? 'board=' : ';board=') . $_POST['board'];
-
- $known_error_types = array(
- 'general',
- 'critical',
- 'database',
- 'undefined_vars',
- 'user',
- 'template',
- 'debug',
- );
-
- $other_error_types = array();
- if (empty($tried_hook))
- {
- $tried_hook = true;
- call_integration_hook('integrate_error_types', array(&$other_error_types));
- $known_error_types += $other_error_types;
- }
-
- $error_type = in_array($error_type, $known_error_types) && $error_type !== true ? $error_type : 'general';
-
- $error_info = array($user_info['id'], time(), $user_info['ip'], $query_string, $error_message, (string) $sc, $error_type, $file, $line);
- if (empty($last_error) || $last_error != $error_info)
- {
-
- $smcFunc['db_insert']('',
- '{db_prefix}log_errors',
- array('id_member' => 'int', 'log_time' => 'int', 'ip' => 'string-16', 'url' => 'string-65534', 'message' => 'string-65534', 'session' => 'string', 'error_type' => 'string', 'file' => 'string-255', 'line' => 'int'),
- $error_info,
- array('id_error')
- );
- $last_error = $error_info;
- }
-
- return $error_message;
- }
- function fatal_error($error, $log = 'general')
- {
- global $txt, $context, $modSettings;
-
- if (empty($txt))
- die($error);
- setup_fatal_error_context($log || (!empty($modSettings['enableErrorLogging']) && $modSettings['enableErrorLogging'] == 2) ? log_error($error, $log) : $error, $error);
- }
- function fatal_lang_error($error, $log = 'general', $sprintf = array())
- {
- global $txt, $language, $modSettings, $user_info, $context;
- static $fatal_error_called = false;
-
- if (empty($context['theme_loaded']) && empty($fatal_error_called))
- {
- $fatal_error_called = true;
- loadTheme();
- }
-
- if (empty($context['theme_loaded']))
- die($error);
- $reload_lang_file = true;
-
- if ($log || (!empty($modSettings['enableErrorLogging']) && $modSettings['enableErrorLogging'] == 2))
- {
- loadLanguage('Errors', $language);
- $reload_lang_file = $language != $user_info['language'];
- $error_message = empty($sprintf) ? $txt[$error] : vsprintf($txt[$error], $sprintf);
- log_error($error_message, $log);
- }
-
- if ($reload_lang_file)
- {
- loadLanguage('Errors');
- $error_message = empty($sprintf) ? $txt[$error] : vsprintf($txt[$error], $sprintf);
- }
- setup_fatal_error_context($error_message, $error);
- }
- function error_handler($error_level, $error_string, $file, $line)
- {
- global $settings, $modSettings, $db_show_debug;
-
- if (error_reporting() == 0 || (defined('E_STRICT') && $error_level == E_STRICT && (empty($modSettings['enableErrorLogging']) || $modSettings['enableErrorLogging'] != 2)))
- return;
- if (strpos($file, 'eval()') !== false && !empty($settings['current_include_filename']))
- {
- $array = debug_backtrace();
- for ($i = 0; $i < count($array); $i++)
- {
- if ($array[$i]['function'] != 'loadSubTemplate')
- continue;
-
- if (empty($array[$i]['args']))
- $i++;
- break;
- }
- if (isset($array[$i]) && !empty($array[$i]['args']))
- $file = realpath($settings['current_include_filename']) . ' (' . $array[$i]['args'][0] . ' sub template - eval?)';
- else
- $file = realpath($settings['current_include_filename']) . ' (eval?)';
- }
- if (isset($db_show_debug) && $db_show_debug === true)
- {
-
- if ($error_level % 255 != E_ERROR)
- {
- $temporary = ob_get_contents();
- if (substr($temporary, -2) == '="')
- echo '"';
- }
-
- echo '<br />
- <strong>', $error_level % 255 == E_ERROR ? 'Error' : ($error_level % 255 == E_WARNING ? 'Warning' : 'Notice'), '</strong>: ', $error_string, ' in <strong>', $file, '</strong> on line <strong>', $line, '</strong><br />';
- }
- $error_type = stripos($error_string, 'undefined') !== false ? 'undefined_vars' : 'general';
- $message = log_error($error_level . ': ' . $error_string, $error_type, $file, $line);
-
- call_integration_hook('integrate_output_error', array($message, $error_type, $error_level, $file, $line));
-
- if ($file == 'Unknown')
- return;
-
- if ($error_level % 255 == E_ERROR)
- obExit(false);
- else
- return;
-
- if ($error_level % 255 == E_ERROR || $error_level % 255 == E_WARNING)
- fatal_error(allowedTo('admin_forum') ? $message : $error_string, false);
-
- if ($error_level % 255 == E_ERROR)
- die('Hacking attempt...');
- }
- function setup_fatal_error_context($error_message, $error_code)
- {
- global $context, $txt, $ssi_on_error_method;
- static $level = 0;
-
- ++$level;
- if ($level > 1)
- return false;
-
- if (SMF != 'SSI' && empty($context['theme_loaded']))
- loadTheme();
-
- $context['robot_no_index'] = true;
- if (!isset($context['error_title']))
- $context['error_title'] = $txt['error_occured'];
- $context['error_message'] = isset($context['error_message']) ? $context['error_message'] : $error_message;
- $context['error_code'] = isset($error_code) ? 'id="' . $error_code . '" ' : '';
- if (empty($context['page_title']))
- $context['page_title'] = $context['error_title'];
-
- if (defined('WIRELESS') && WIRELESS)
- $context['sub_template'] = WIRELESS_PROTOCOL . '_error';
-
- else
- {
- loadTemplate('Errors');
- $context['sub_template'] = 'fatal_error';
- }
-
- if (SMF == 'SSI')
- {
- if (!empty($ssi_on_error_method) && $ssi_on_error_method !== true && is_callable($ssi_on_error_method))
- $ssi_on_error_method();
- elseif (empty($ssi_on_error_method) || $ssi_on_error_method !== true)
- loadSubTemplate('fatal_error');
-
- if (empty($ssi_on_error_method) || $ssi_on_error_method !== true)
- exit;
- }
-
- obExit(null, true, false, true);
-
- trigger_error('Hacking attempt...', E_USER_ERROR);
- }
- function display_maintenance_message()
- {
- global $maintenance, $mtitle, $mmessage;
- set_fatal_error_headers();
- if (!empty($maintenance))
- echo '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
- <html xmlns="http://www.w3.org/1999/xhtml">
- <head>
- <meta name="robots" content="noindex" />
- <title>', $mtitle, '</title>
- </head>
- <body>
- <h3>', $mtitle, '</h3>
- ', $mmessage, '
- </body>
- </html>';
- die();
- }
- function display_db_error()
- {
- global $mbname, $modSettings, $maintenance;
- global $db_connection, $webmaster_email, $db_last_error, $db_error_send, $smcFunc;
- set_fatal_error_headers();
-
- $modSettings['cache_enable'] = '1';
- if (($temp = cache_get_data('db_last_error', 600)) !== null)
- $db_last_error = max($db_last_error, $temp);
- if ($db_last_error < time() - 3600 * 24 * 3 && empty($maintenance) && !empty($db_error_send))
- {
-
- cache_put_data('db_last_error', time(), 600);
- if (($temp = cache_get_data('db_last_error', 600)) === null)
- logLastDatabaseError();
-
- $db_error = @$smcFunc['db_error']($db_connection);
- @mail($webmaster_email, $mbname . ': SMF Database Error!', 'There has been a problem with the database!' . ($db_error == '' ? '' : "\n" . $smcFunc['db_title'] . ' reported:' . "\n" . $db_error) . "\n\n" . 'This is a notice email to let you know that SMF could not connect to the database, contact your host if this continues.');
- }
-
- echo '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
- <html xmlns="http://www.w3.org/1999/xhtml">
- <head>
- <meta name="robots" content="noindex" />
- <title>Connection Problems</title>
- </head>
- <body>
- <h3>Connection Problems</h3>
- Sorry, SMF was unable to connect to the database. This may be caused by the server being busy. Please try again later.
- </body>
- </html>';
- die();
- }
- function display_loadavg_error()
- {
-
- set_fatal_error_headers();
- echo '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
- <html xmlns="http://www.w3.org/1999/xhtml">
- <head>
- <meta name="robots" content="noindex" />
- <title>Temporarily Unavailable</title>
- </head>
- <body>
- <h3>Temporarily Unavailable</h3>
- Due to high stress on the server the forum is temporarily unavailable. Please try again later.
- </body>
- </html>';
- die();
- }
- function set_fatal_error_headers()
- {
-
- header('Expires: Mon, 26 Jul 1997 05:00:00 GMT');
- header('Last-Modified: ' . gmdate('D, d M Y H:i:s') . ' GMT');
- header('Cache-Control: no-cache');
-
- header('HTTP/1.1 503 Service Temporarily Unavailable');
- header('Status: 503 Service Temporarily Unavailable');
- header('Retry-After: 3600');
- }
|