3 * con.php: Generic setup file.
5 * Contains user authentication, database connection and other exciting stuff.
6 * Everything else depends on this file. Don't touch it unless you know what
7 * you're doing, all the config is done in other places (mostly mysql.php).
9 * @author Anthony Parsons (xmpp:ant@specialops.ath.cx)
10 * @license file://COPYING
14 // Numbers that go in the footer
15 define('SO2VER', '$Rev$');
16 define('CLOCK', microtime(1));
20 error_reporting(E_ALL|E_STRICT
);
23 // SO2 loses its magic on anything less than PHP 5.1
24 if ( version_compare(PHP_VERSION
, '5.1', '<') ) {
25 include 'res/server-error.inc';
26 throw new Exception('PHP 5.1 or higher is required to run SO2.');
31 require 'lib/class.Page.php';
32 require 'lib/class.so2mysqli.php';
33 require 'lib/class.User_Anonymous.php';
34 class InvalidInputException
extends Exception
{}
35 class DatabaseException
extends Exception
{}
36 class RateLimitException
extends Exception
{}
37 function __autoload($classname)
39 require 'lib/class.'.$classname.'.php';
44 if ( $_SERVER['REMOTE_ADDR'] === $_SERVER['SERVER_ADDR'] ) {
45 define('DEVELOPER', 1);
49 // Create page object, contains the error handler stuff.
53 // Set up exception handler and database connection here
54 if ( defined('DEVELOPER') ) {
57 function e_handler($exception)
59 header('HTTP/1.1 500 Internal Server Error');
60 header('Content-Type: text/html; charset=UTF-8');
61 echo '<pre class="error">',$exception,'</pre>';
66 $dbtype = 'debugmysqli';
68 function e_handler($exception)
70 if ( !headers_sent() ) {
71 header('HTTP/1.1 500 Internal Server Error');
72 header('Content-Type: text/html; charset=UTF-8');
75 $GLOBALS['page']->errorfooter('runtime');
78 $dbtype = 'so2mysqli';
81 set_exception_handler('e_handler');
84 if ( mysqli_connect_errno() ) {
85 include 'res/server-error.inc';
86 throw new Exception('No database connection.');
90 // On-Login cookie setting hack
91 if ( isset($_POST['login'], $_POST['u'], $_POST['p']) ) {
92 list($_COOKIE['u'], $_COOKIE['p']) = array($_POST['u'], $_POST['p']);
95 // Destroy user cookie details on logout
96 if ( isset($_POST['logout']) ) {
97 setcookie('u', null, 1, '/');
98 setcookie('p', null, 1, '/');
103 if ( isset($_COOKIE['u'], $_COOKIE['p']) ) {
104 /* Try to get the user ID from the DB, and shove it into a MySQL var. */
105 $q = $DB->query('SELECT @userid := `userid` FROM `users`
106 WHERE `alias` = '.$DB->string($_COOKIE['u']).'
107 AND (`password` = AES_ENCRYPT('.$DB->string($_COOKIE['p']).', `reg_ip`)
108 OR `password` IS NULL)');
111 if ( 1 === $q->num_rows
) {
112 // Keep login cookie valid
113 setcookie('u', $_COOKIE['u'], time()+
86400, '/');
114 setcookie('p', $_COOKIE['p'], time()+
86400, '/');
116 $user = new User_Authenticated(isset($prefetch) ?
$prefetch : null);
118 // Wipe cookies if bad login
119 setcookie('u', null, 1, '/');
120 setcookie('p', null, 1, '/');
123 $user = new User_Anonymous
;
126 $user = new User_Anonymous
;