Use 'StartpageAction' to determine what to show on /
This commit is contained in:
parent
a5d27d9ce7
commit
4daa2e4644
@ -28,9 +28,7 @@
|
|||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (!defined('STATUSNET') && !defined('LACONICA')) {
|
if (!defined('GNUSOCIAL')) { exit(1); }
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Logout action class.
|
* Logout action class.
|
||||||
@ -42,7 +40,7 @@ if (!defined('STATUSNET') && !defined('LACONICA')) {
|
|||||||
* @license http://www.fsf.org/licensing/licenses/agpl.html AGPLv3
|
* @license http://www.fsf.org/licensing/licenses/agpl.html AGPLv3
|
||||||
* @link http://status.net/
|
* @link http://status.net/
|
||||||
*/
|
*/
|
||||||
class LogoutAction extends Action
|
class LogoutAction extends ManagedAction
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* This is read only.
|
* This is read only.
|
||||||
@ -54,36 +52,22 @@ class LogoutAction extends Action
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
protected function doPreparation()
|
||||||
* Class handler.
|
|
||||||
*
|
|
||||||
* @param array $args array of arguments
|
|
||||||
*
|
|
||||||
* @return nothing
|
|
||||||
*/
|
|
||||||
function handle($args)
|
|
||||||
{
|
{
|
||||||
parent::handle($args);
|
|
||||||
if (!common_logged_in()) {
|
if (!common_logged_in()) {
|
||||||
// TRANS: Error message displayed when trying to perform an action that requires a logged in user.
|
// TRANS: Error message displayed when trying to logout even though you are not logged in.
|
||||||
$this->clientError(_('Not logged in.'));
|
throw new AlreadyFulfilledException(_('Cannot log you out if you are not logged in.'));
|
||||||
} else {
|
|
||||||
if (Event::handle('StartLogout', array($this))) {
|
|
||||||
$this->logout();
|
|
||||||
}
|
|
||||||
Event::handle('EndLogout', array($this));
|
|
||||||
|
|
||||||
if (common_config('singleuser', 'enabled')) {
|
|
||||||
$user = User::singleUser();
|
|
||||||
common_redirect(common_local_url('showstream',
|
|
||||||
array('nickname' => $user->nickname)));
|
|
||||||
} else {
|
|
||||||
common_redirect(common_local_url('public'), 303);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
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_set_user(null);
|
||||||
common_real_login(false); // not logged in
|
common_real_login(false); // not logged in
|
||||||
|
26
actions/startpage.php
Normal file
26
actions/startpage.php
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Startpage action. Decides what to show on the first page.
|
||||||
|
*/
|
||||||
|
|
||||||
|
if (!defined('GNUSOCIAL')) { exit(1); }
|
||||||
|
|
||||||
|
class StartpageAction extends ManagedAction
|
||||||
|
{
|
||||||
|
function isReadOnly($args)
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
function showPage()
|
||||||
|
{
|
||||||
|
if (common_config('singleuser', 'enabled')) {
|
||||||
|
$user = User::singleUser();
|
||||||
|
common_redirect(common_local_url('showstream', array('nickname' => $user->nickname)), 303);
|
||||||
|
} elseif (common_config('public', 'localonly')) {
|
||||||
|
common_redirect(common_local_url('public'), 303);
|
||||||
|
} else {
|
||||||
|
common_redirect(common_local_url('networkpublic'), 303);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -894,8 +894,7 @@ class Router
|
|||||||
'nickname' => $nickname));
|
'nickname' => $nickname));
|
||||||
|
|
||||||
$m->connect('',
|
$m->connect('',
|
||||||
array('action' => 'showstream',
|
array('action' => 'startpage'));
|
||||||
'nickname' => $nickname));
|
|
||||||
|
|
||||||
// peopletags
|
// peopletags
|
||||||
|
|
||||||
@ -948,13 +947,9 @@ class Router
|
|||||||
array('tag' => self::REGEX_TAG));
|
array('tag' => self::REGEX_TAG));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
$m->connect('', array('action' => 'startpage'));
|
||||||
$m->connect('main/public', array('action' => 'public'));
|
$m->connect('main/public', array('action' => 'public'));
|
||||||
$m->connect('main/all', array('action' => 'networkpublic'));
|
$m->connect('main/all', array('action' => 'networkpublic'));
|
||||||
if (common_config('site', 'localonly')) {
|
|
||||||
$m->connect('', array('action' => 'public'));
|
|
||||||
} else {
|
|
||||||
$m->connect('', array('action' => 'networkpublic'));
|
|
||||||
}
|
|
||||||
$m->connect('rss', array('action' => 'publicrss'));
|
$m->connect('rss', array('action' => 'publicrss'));
|
||||||
$m->connect('featuredrss', array('action' => 'featuredrss'));
|
$m->connect('featuredrss', array('action' => 'featuredrss'));
|
||||||
$m->connect('featured/', array('action' => 'featured'));
|
$m->connect('featured/', array('action' => 'featured'));
|
||||||
|
Loading…
Reference in New Issue
Block a user