primo commit
This commit is contained in:
		
							
								
								
									
										107
									
								
								plugins/task/deleteactionlogs/src/Extension/DeleteActionLogs.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										107
									
								
								plugins/task/deleteactionlogs/src/Extension/DeleteActionLogs.php
									
									
									
									
									
										Normal 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; | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user