X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=actions%2Flogout.php;h=1e0adae57592a536bdaf7b6bbf3eb7ae60959f14;hb=3326b7b850f538f0e3c2c7969c5e566e2a374ffb;hp=3fcfb4f4ef2570352d1c28f888c09329182feced;hpb=3e60160f07f32d109b545db6b73be344b9180de8;p=quix0rs-gnu-social.git diff --git a/actions/logout.php b/actions/logout.php index 3fcfb4f4ef..b9dfe3b811 100644 --- a/actions/logout.php +++ b/actions/logout.php @@ -5,14 +5,14 @@ * PHP version 5 * * @category Action - * @package Laconica - * @author Evan Prodromou - * @author Robin Millette + * @package StatusNet + * @author Evan Prodromou + * @author Robin Millette * @license http://www.fsf.org/licensing/licenses/agpl.html AGPLv3 - * @link http://laconi.ca/ + * @link http://status.net/ * - * Laconica - a distributed open-source microblogging tool - * Copyright (C) 2008, 2009, Control Yourself, Inc. + * StatusNet - the distributed open-source microblogging tool + * Copyright (C) 2008, 2009, StatusNet, Inc. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by @@ -28,31 +28,26 @@ * along with this program. If not, see . */ -if (!defined('LACONICA')) { - exit(1); -} - -require_once INSTALLDIR.'/lib/openid.php'; +if (!defined('GNUSOCIAL')) { exit(1); } /** * Logout action class. * * @category Action - * @package Laconica - * @author Evan Prodromou - * @author Robin Millette + * @package StatusNet + * @author Evan Prodromou + * @author Robin Millette * @license http://www.fsf.org/licensing/licenses/agpl.html AGPLv3 - * @link http://laconi.ca/ + * @link http://status.net/ */ -class LogoutAction extends Action +class LogoutAction extends ManagedAction { - /** * This is read only. * * @return boolean true */ - function isReadOnly($args) + function isReadOnly(array $args=array()) { return false; } @@ -60,30 +55,27 @@ class LogoutAction extends Action /** * 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('top')); } - 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! } - }