primo commit
This commit is contained in:
130
plugins/system/remember/src/Extension/Remember.php
Normal file
130
plugins/system/remember/src/Extension/Remember.php
Normal file
@ -0,0 +1,130 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* @package Joomla.Plugin
|
||||
* @subpackage System.remember
|
||||
*
|
||||
* @copyright (C) 2007 Open Source Matters, Inc. <https://www.joomla.org>
|
||||
* @license GNU General Public License version 2 or later; see LICENSE.txt
|
||||
*/
|
||||
|
||||
namespace Joomla\Plugin\System\Remember\Extension;
|
||||
|
||||
use Joomla\CMS\Log\Log;
|
||||
use Joomla\CMS\Plugin\CMSPlugin;
|
||||
use Joomla\CMS\Plugin\PluginHelper;
|
||||
use Joomla\CMS\User\UserHelper;
|
||||
use Joomla\Database\DatabaseAwareTrait;
|
||||
|
||||
// phpcs:disable PSR1.Files.SideEffects
|
||||
\defined('_JEXEC') or die;
|
||||
// phpcs:enable PSR1.Files.SideEffects
|
||||
|
||||
/**
|
||||
* Joomla! System Remember Me Plugin
|
||||
*
|
||||
* @since 1.5
|
||||
*/
|
||||
final class Remember extends CMSPlugin
|
||||
{
|
||||
use DatabaseAwareTrait;
|
||||
|
||||
/**
|
||||
* Remember me method to run onAfterInitialise
|
||||
* Only purpose is to initialise the login authentication process if a cookie is present
|
||||
*
|
||||
* @return void
|
||||
*
|
||||
* @since 1.5
|
||||
*
|
||||
* @throws \InvalidArgumentException
|
||||
*/
|
||||
public function onAfterInitialise()
|
||||
{
|
||||
// No remember me for admin.
|
||||
if (!$this->getApplication()->isClient('site')) {
|
||||
return;
|
||||
}
|
||||
|
||||
// Check for a cookie if user is not logged in
|
||||
if ($this->getApplication()->getIdentity()->guest) {
|
||||
$cookieName = 'joomla_remember_me_' . UserHelper::getShortHashedUserAgent();
|
||||
|
||||
// Check for the cookie
|
||||
if ($this->getApplication()->getInput()->cookie->get($cookieName)) {
|
||||
$this->getApplication()->login(['username' => ''], ['silent' => true]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Imports the authentication plugin on user logout to make sure that the cookie is destroyed.
|
||||
*
|
||||
* @param array $user Holds the user data.
|
||||
* @param array $options Array holding options (remember, autoregister, group).
|
||||
*
|
||||
* @return boolean
|
||||
*/
|
||||
public function onUserLogout($user, $options)
|
||||
{
|
||||
// No remember me for admin
|
||||
if (!$this->getApplication()->isClient('site')) {
|
||||
return true;
|
||||
}
|
||||
|
||||
$cookieName = 'joomla_remember_me_' . UserHelper::getShortHashedUserAgent();
|
||||
|
||||
// Check for the cookie
|
||||
if ($this->getApplication()->getInput()->cookie->get($cookieName)) {
|
||||
// Make sure authentication group is loaded to process onUserAfterLogout event
|
||||
PluginHelper::importPlugin('authentication');
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Method is called before user data is stored in the database
|
||||
* Invalidate all existing remember-me cookies after a password change
|
||||
*
|
||||
* @param array $user Holds the old user data.
|
||||
* @param boolean $isnew True if a new user is stored.
|
||||
* @param array $data Holds the new user data.
|
||||
*
|
||||
* @return boolean
|
||||
*
|
||||
* @since 3.8.6
|
||||
*/
|
||||
public function onUserBeforeSave($user, $isnew, $data)
|
||||
{
|
||||
// Irrelevant on new users
|
||||
if ($isnew) {
|
||||
return true;
|
||||
}
|
||||
|
||||
// Irrelevant, because password was not changed by user
|
||||
if (empty($data['password_clear'])) {
|
||||
return true;
|
||||
}
|
||||
|
||||
// But now, we need to do something - Delete all tokens for this user!
|
||||
$db = $this->getDatabase();
|
||||
$query = $db->getQuery(true)
|
||||
->delete($db->quoteName('#__user_keys'))
|
||||
->where($db->quoteName('user_id') . ' = :userid')
|
||||
->bind(':userid', $user['username']);
|
||||
|
||||
try {
|
||||
$db->setQuery($query)->execute();
|
||||
} catch (\RuntimeException $e) {
|
||||
// Log an alert for the site admin
|
||||
Log::add(
|
||||
\sprintf('Failed to delete cookie token for user %s with the following error: %s', $user['username'], $e->getMessage()),
|
||||
Log::WARNING,
|
||||
'security'
|
||||
);
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user