X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=index.php;h=3cecb5c8b6c3825d5e2e116ba05a2574191231ba;hb=02877224b20f87af304553f739b69544d7ac4cfa;hp=35168621b90515365e25be1df38e53f8c1507a8b;hpb=749178f34371aabb8a22166fe64920a42679dcc5;p=quix0rs-gnu-social.git diff --git a/index.php b/index.php index 35168621b9..3cecb5c8b6 100644 --- a/index.php +++ b/index.php @@ -1,18 +1,18 @@ . */ @@ -20,21 +20,55 @@ define('INSTALLDIR', dirname(__FILE__)); define('LACONICA', true); -require_once(INSTALLDIR . "/lib/common.php"); +require_once INSTALLDIR . '/lib/common.php'; + +// get and cache current user + +$user = common_current_user(); + +// initialize language env + +common_init_language(); $action = $_REQUEST['action']; -if (!$action) { - common_redirect(common_local_url('public')); +if (!$action || !preg_match('/^[a-zA-Z0-9_-]*$/', $action)) { + common_redirect(common_local_url('public')); +} + +// If the site is private, and they're not on one of the "public" +// parts of the site, redirect to login + +if (!$user && common_config('site', 'private') && + !in_array($action, array('login', 'openidlogin', 'finishopenidlogin', + 'recoverpassword', 'api', 'doc', 'register'))) { + common_redirect(common_local_url('login')); } $actionfile = INSTALLDIR."/actions/$action.php"; if (file_exists($actionfile)) { - require_once($actionfile); - $action_class = ucfirst($action)."Action"; - $action_obj = new $action_class(); - call_user_func(array($action_obj, 'handle'), $_REQUEST); + + include_once $actionfile; + + $action_class = ucfirst($action).'Action'; + + $action_obj = new $action_class(); + + if ($config['db']['mirror'] && $action_obj->is_readonly()) { + if (is_array($config['db']['mirror'])) { + // "load balancing", ha ha + $k = array_rand($config['db']['mirror']); + + $mirror = $config['db']['mirror'][$k]; + } else { + $mirror = $config['db']['mirror']; + } + $config['db']['database'] = $mirror; + } + if (call_user_func(array($action_obj, 'prepare'), $_REQUEST)) { + call_user_func(array($action_obj, 'handle'), $_REQUEST); + } } else { - common_user_error(_t('Unknown action')); + common_user_error(_('Unknown action')); } \ No newline at end of file