primo commit

This commit is contained in:
2024-12-17 17:34:10 +01:00
commit e650f8df99
16435 changed files with 2451012 additions and 0 deletions

View File

@ -0,0 +1,107 @@
<?php
/**
* @package Joomla.Plugin
* @subpackage Task.deleteactionlogs
*
* @copyright (C) 2023 Open Source Matters, Inc. <https://www.joomla.org>
* @license GNU General Public License version 2 or later; see LICENSE.txt
*/
namespace Joomla\Plugin\Task\DeleteActionLogs\Extension;
use Joomla\CMS\Factory;
use Joomla\CMS\Plugin\CMSPlugin;
use Joomla\Component\Scheduler\Administrator\Event\ExecuteTaskEvent;
use Joomla\Component\Scheduler\Administrator\Task\Status;
use Joomla\Component\Scheduler\Administrator\Traits\TaskPluginTrait;
use Joomla\Database\DatabaseAwareTrait;
use Joomla\Event\SubscriberInterface;
// phpcs:disable PSR1.Files.SideEffects
\defined('_JEXEC') or die;
// phpcs:enable PSR1.Files.SideEffects
/**
* A task plugin. For Delete Action Logs after x days
* {@see ExecuteTaskEvent}.
*
* @since 5.0.0
*/
final class DeleteActionLogs extends CMSPlugin implements SubscriberInterface
{
use DatabaseAwareTrait;
use TaskPluginTrait;
/**
* @var string[]
* @since 5.0.0
*/
private const TASKS_MAP = [
'delete.actionlogs' => [
'langConstPrefix' => 'PLG_TASK_DELETEACTIONLOGS_DELETE',
'method' => 'deleteLogs',
'form' => 'deleteForm',
],
];
/**
* @var boolean
* @since 5.0.0
*/
protected $autoloadLanguage = true;
/**
* @inheritDoc
*
* @return string[]
*
* @since 5.0.0
*/
public static function getSubscribedEvents(): array
{
return [
'onTaskOptionsList' => 'advertiseRoutines',
'onExecuteTask' => 'standardRoutineHandler',
'onContentPrepareForm' => 'enhanceTaskItemForm',
];
}
/**
* @param ExecuteTaskEvent $event The `onExecuteTask` event.
*
* @return integer The routine exit code.
*
* @since 5.0.0
* @throws \Exception
*/
private function deleteLogs(ExecuteTaskEvent $event): int
{
$daysToDeleteAfter = (int) $event->getArgument('params')->logDeletePeriod ?? 0;
$this->logTask(\sprintf('Delete Logs after %d days', $daysToDeleteAfter));
$now = Factory::getDate()->toSql();
$db = $this->getDatabase();
$query = $db->getQuery(true);
if ($daysToDeleteAfter > 0) {
$days = -1 * $daysToDeleteAfter;
$query->clear()
->delete($db->quoteName('#__action_logs'))
->where($db->quoteName('log_date') . ' < ' . $query->dateAdd($db->quote($now), $days, 'DAY'));
$db->setQuery($query);
try {
$db->execute();
} catch (\RuntimeException $e) {
// Ignore it
return Status::KNOCKOUT;
}
}
$this->logTask('Delete Logs end');
return Status::OK;
}
}