X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;ds=sidebyside;f=actions%2Flogout.php;h=60aec3c83a48d37a21bf435fff4d0da2aa513424;hb=0deaf6c50c0a02dd307b797729adbaf2a973db07;hp=eda5cefe5bf15eae09c327cfd55b5e09c2c4d1b2;hpb=be5d113fc684fcbe41b8374c62bfeb0f267216b7;p=quix0rs-gnu-social.git diff --git a/actions/logout.php b/actions/logout.php index eda5cefe5b..60aec3c83a 100644 --- a/actions/logout.php +++ b/actions/logout.php @@ -28,11 +28,7 @@ * along with this program. If not, see . */ -if (!defined('STATUSNET')) { - exit(1); -} - -require_once INSTALLDIR.'/lib/openid.php'; +if (!defined('GNUSOCIAL')) { exit(1); } /** * Logout action class. @@ -44,9 +40,8 @@ require_once INSTALLDIR.'/lib/openid.php'; * @license http://www.fsf.org/licensing/licenses/agpl.html AGPLv3 * @link http://status.net/ */ -class LogoutAction extends Action +class LogoutAction extends ManagedAction { - /** * This is read only. * @@ -57,33 +52,25 @@ class LogoutAction extends Action return false; } - /** - * Class handler. - * - * @param array $args array of arguments - * - * @return nothing - */ - function handle($args) + protected function doPreparation() { - parent::handle($args); if (!common_logged_in()) { - $this->clientError(_('Not logged in.')); - } else { - if (Event::handle('StartLogout', array($this))) { - $this->logout(); - } - Event::handle('EndLogout', array($this)); - - common_redirect(common_local_url('public'), 303); + // TRANS: Error message displayed when trying to logout even though you are not logged in. + throw new AlreadyFulfilledException(_('Cannot log you out if you are not logged in.')); + } + if (Event::handle('StartLogout', array($this))) { + $this->logout(); } + Event::handle('EndLogout', array($this)); + + common_redirect(common_local_url('startpage')); } - function logout() + // Accessed through the action on events + public function logout() { common_set_user(null); common_real_login(false); // not logged in common_forgetme(); // don't log back in! } - }