first commit
This commit is contained in:
38
plugins/system/log/log.xml
Normal file
38
plugins/system/log/log.xml
Normal file
@ -0,0 +1,38 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<extension type="plugin" group="system" method="upgrade">
|
||||
<name>plg_system_log</name>
|
||||
<author>Joomla! Project</author>
|
||||
<creationDate>2007-04</creationDate>
|
||||
<copyright>(C) 2007 Open Source Matters, Inc.</copyright>
|
||||
<license>GNU General Public License version 2 or later; see LICENSE.txt</license>
|
||||
<authorEmail>admin@joomla.org</authorEmail>
|
||||
<authorUrl>www.joomla.org</authorUrl>
|
||||
<version>3.0.0</version>
|
||||
<description>PLG_LOG_XML_DESCRIPTION</description>
|
||||
<namespace path="src">Joomla\Plugin\System\Log</namespace>
|
||||
<files>
|
||||
<folder plugin="log">services</folder>
|
||||
<folder>src</folder>
|
||||
</files>
|
||||
<languages>
|
||||
<language tag="en-GB">language/en-GB/plg_system_log.ini</language>
|
||||
<language tag="en-GB">language/en-GB/plg_system_log.sys.ini</language>
|
||||
</languages>
|
||||
<config>
|
||||
<fields name="params">
|
||||
<fieldset name="basic">
|
||||
<field
|
||||
name="log_username"
|
||||
type="radio"
|
||||
layout="joomla.form.field.radio.switcher"
|
||||
label="PLG_SYSTEM_LOG_FIELD_LOG_USERNAME_LABEL"
|
||||
default="0"
|
||||
filter="integer"
|
||||
>
|
||||
<option value="0">JNO</option>
|
||||
<option value="1">JYES</option>
|
||||
</field>
|
||||
</fieldset>
|
||||
</fields>
|
||||
</config>
|
||||
</extension>
|
||||
46
plugins/system/log/services/provider.php
Normal file
46
plugins/system/log/services/provider.php
Normal file
@ -0,0 +1,46 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* @package Joomla.Plugin
|
||||
* @subpackage System.log
|
||||
*
|
||||
* @copyright (C) 2023 Open Source Matters, Inc. <https://www.joomla.org>
|
||||
* @license GNU General Public License version 2 or later; see LICENSE.txt
|
||||
*/
|
||||
|
||||
\defined('_JEXEC') or die;
|
||||
|
||||
use Joomla\CMS\Extension\PluginInterface;
|
||||
use Joomla\CMS\Factory;
|
||||
use Joomla\CMS\Plugin\PluginHelper;
|
||||
use Joomla\DI\Container;
|
||||
use Joomla\DI\ServiceProviderInterface;
|
||||
use Joomla\Event\DispatcherInterface;
|
||||
use Joomla\Plugin\System\Log\Extension\Log;
|
||||
|
||||
return new class () implements ServiceProviderInterface {
|
||||
/**
|
||||
* Registers the service provider with a DI container.
|
||||
*
|
||||
* @param Container $container The DI container.
|
||||
*
|
||||
* @return void
|
||||
*
|
||||
* @since 4.4.0
|
||||
*/
|
||||
public function register(Container $container): void
|
||||
{
|
||||
$container->set(
|
||||
PluginInterface::class,
|
||||
function (Container $container) {
|
||||
$plugin = new Log(
|
||||
$container->get(DispatcherInterface::class),
|
||||
(array) PluginHelper::getPlugin('system', 'log')
|
||||
);
|
||||
$plugin->setApplication(Factory::getApplication());
|
||||
|
||||
return $plugin;
|
||||
}
|
||||
);
|
||||
}
|
||||
};
|
||||
72
plugins/system/log/src/Extension/Log.php
Normal file
72
plugins/system/log/src/Extension/Log.php
Normal file
@ -0,0 +1,72 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* @package Joomla.Plugin
|
||||
* @subpackage System.log
|
||||
*
|
||||
* @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\Log\Extension;
|
||||
|
||||
use Joomla\CMS\Authentication\Authentication;
|
||||
use Joomla\CMS\Log\Log as Logger;
|
||||
use Joomla\CMS\Plugin\CMSPlugin;
|
||||
|
||||
// phpcs:disable PSR1.Files.SideEffects
|
||||
\defined('_JEXEC') or die;
|
||||
// phpcs:enable PSR1.Files.SideEffects
|
||||
|
||||
/**
|
||||
* Joomla! System Logging Plugin.
|
||||
*
|
||||
* @since 1.5
|
||||
*/
|
||||
final class Log extends CMSPlugin
|
||||
{
|
||||
/**
|
||||
* Called if user fails to be logged in.
|
||||
*
|
||||
* @param array $response Array of response data.
|
||||
*
|
||||
* @return void
|
||||
*
|
||||
* @since 1.5
|
||||
*/
|
||||
public function onUserLoginFailure($response)
|
||||
{
|
||||
$errorlog = [];
|
||||
|
||||
switch ($response['status']) {
|
||||
case Authentication::STATUS_SUCCESS:
|
||||
$errorlog['status'] = $response['type'] . ' CANCELED: ';
|
||||
$errorlog['comment'] = $response['error_message'];
|
||||
break;
|
||||
|
||||
case Authentication::STATUS_FAILURE:
|
||||
$errorlog['status'] = $response['type'] . ' FAILURE: ';
|
||||
|
||||
if ($this->params->get('log_username', 0)) {
|
||||
$errorlog['comment'] = $response['error_message'] . ' ("' . $response['username'] . '")';
|
||||
} else {
|
||||
$errorlog['comment'] = $response['error_message'];
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
$errorlog['status'] = $response['type'] . ' UNKNOWN ERROR: ';
|
||||
$errorlog['comment'] = $response['error_message'];
|
||||
break;
|
||||
}
|
||||
|
||||
Logger::addLogger([], Logger::INFO);
|
||||
|
||||
try {
|
||||
Logger::add($errorlog['comment'], Logger::INFO, $errorlog['status']);
|
||||
} catch (\Exception $e) {
|
||||
// If the log file is unwriteable during login then we should not go to the error page
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user