event for determining if an action is a login action

This commit is contained in:
Evan Prodromou 2009-08-04 11:13:47 -04:00
parent c378cc976f
commit abffaebebd
2 changed files with 18 additions and 2 deletions

View File

@ -142,3 +142,6 @@ SensitiveAction: determines if an action is 'sensitive' and should use SSL
- $action: name of the action, like 'login'
- $sensitive: flag for whether this is a sensitive action
LoginAction: determines if an action is a 'login' action (OK for public view in private mode)
- $action: name of the action, like 'register'
- $login: flag for whether this is a login action

View File

@ -105,6 +105,20 @@ function checkMirror($action_obj)
}
}
function isLoginAction($action)
{
static $loginActions = array('login', 'openidlogin', 'finishopenidlogin',
'recoverpassword', 'api', 'doc', 'register');
$login = null;
if (Event::handle('LoginAction', array($action, &$login))) {
$login = in_array($action, $loginActions);
}
return $login;
}
function main()
{
// quick check for fancy URL auto-detection support in installer.
@ -164,8 +178,7 @@ function main()
// parts of the site, redirect to login
if (!$user && common_config('site', 'private') &&
!in_array($action, array('login', 'openidlogin', 'finishopenidlogin',
'recoverpassword', 'api', 'doc', 'register')) &&
!isLoginAction($action) &&
!preg_match('/rss$/', $action)) {
common_redirect(common_local_url('login'));
return;