summaryrefslogtreecommitdiff
path: root/index.php
diff options
context:
space:
mode:
authorSean Murphy <sgmurphy@gmail.com>2009-02-09 17:29:39 -0500
committerSean Murphy <sgmurphy@gmail.com>2009-02-09 17:29:39 -0500
commitbdd9f6ce1d9bafc1c534aec224fa0ad1452779c1 (patch)
tree928e7efa3c382787adacf3e7234d77bce506eb80 /index.php
parentf6705f06c0a8251c0f3eb0fe88532e75645f7705 (diff)
parent32744124bcb8aa0683490a56defd4a79f072d278 (diff)
Merge commit 'upstream/0.7.x' into 0.7.x
Diffstat (limited to 'index.php')
-rw-r--r--index.php41
1 files changed, 29 insertions, 12 deletions
diff --git a/index.php b/index.php
index 387b642e2..e62d9469a 100644
--- a/index.php
+++ b/index.php
@@ -22,6 +22,8 @@ define('LACONICA', true);
require_once INSTALLDIR . '/lib/common.php';
+// XXX: we need a little more structure in this script
+
// get and cache current user
$user = common_current_user();
@@ -45,16 +47,16 @@ if (!$user && common_config('site', 'private') &&
common_redirect(common_local_url('login'));
}
-$actionfile = INSTALLDIR."/actions/$action.php";
-
-if (file_exists($actionfile)) {
-
- include_once $actionfile;
-
- $action_class = ucfirst($action).'Action';
+$action_class = ucfirst($action).'Action';
+if (!class_exists($action_class)) {
+ $cac = new ClientErrorAction(_('Unknown action'), 404);
+ $cac->showPage();
+} else {
$action_obj = new $action_class();
+ // XXX: find somewhere for this little block to live
+
if ($config['db']['mirror'] && $action_obj->isReadOnly()) {
if (is_array($config['db']['mirror'])) {
// "load balancing", ha ha
@@ -66,9 +68,24 @@ if (file_exists($actionfile)) {
}
$config['db']['database'] = $mirror;
}
- if (call_user_func(array($action_obj, 'prepare'), $_REQUEST)) {
- call_user_func(array($action_obj, 'handle'), $_REQUEST);
+
+ try {
+ if ($action_obj->prepare($_REQUEST)) {
+ $action_obj->handle($_REQUEST);
+ }
+ } catch (ClientException $cex) {
+ $cac = new ClientErrorAction($cex->getMessage(), $cex->getCode());
+ $cac->showPage();
+ } catch (ServerException $sex) { // snort snort guffaw
+ $sac = new ServerErrorAction($sex->getMessage(), $sex->getCode());
+ $sac->showPage();
+ } catch (Exception $ex) {
+ $sac = new ServerErrorAction($ex->getMessage());
+ $sac->showPage();
}
-} else {
- common_user_error(_('Unknown action'));
-} \ No newline at end of file
+}
+
+// XXX: cleanup exit() calls or add an exit handler so
+// this always gets called
+
+Event::handle('CleanupPlugin');