X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=index.php;h=21d5ed275354a052ed3df81dad4bff1b4b2c706c;hb=542cadd33c0fbf672192ce3e16b69b2a285ea421;hp=812239e3d56931ae2754cccc71bcbd08c1a2baae;hpb=b6cfd2dffeeb733f07818db5f4ce11d4b3d51771;p=quix0rs-gnu-social.git diff --git a/index.php b/index.php index 812239e3d5..21d5ed2753 100644 --- a/index.php +++ b/index.php @@ -1,18 +1,18 @@ . */ @@ -20,18 +20,21 @@ define('INSTALLDIR', dirname(__FILE__)); define('LACONICA', true); -require_once(INSTALLDIR . "/common.php"); +require_once(INSTALLDIR . "/lib/common.php"); $action = $_REQUEST['action']; + +if (!$action || !preg_match('/^[a-zA-Z0-9_-]*$/', $action)) { + common_redirect(common_local_url('public')); +} + $actionfile = INSTALLDIR."/actions/$action.php"; if (file_exists($actionfile)) { - require_once($actionfile); - $action_class = ucfirst($action) . "Action"; - if (function_exists($action_function)) { - call_user_func($action_function); + require_once($actionfile); + $action_class = ucfirst($action)."Action"; + $action_obj = new $action_class(); + call_user_func(array($action_obj, 'handle'), $_REQUEST); } else { - common_user_error(_t('Unknown action')); -} - -?> \ No newline at end of file + common_user_error(_('Unknown action')); +} \ No newline at end of file