![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/mautic.corals.io/app/bundles/WebhookBundle/Command/ |
<?php declare(strict_types=1); namespace Mautic\WebhookBundle\Command; use Mautic\CoreBundle\Helper\CoreParametersHelper; use Mautic\WebhookBundle\Model\WebhookModel; use Symfony\Component\Console\Command\Command; use Symfony\Component\Console\Input\InputInterface; use Symfony\Component\Console\Output\OutputInterface; /** * Retains a rolling number of log records. */ class DeleteWebhookLogsCommand extends Command { public const COMMAND_NAME = 'mautic:webhooks:delete_logs'; private \Mautic\WebhookBundle\Entity\LogRepository $logRepository; public function __construct( WebhookModel $webhookModel, private CoreParametersHelper $coreParametersHelper ) { $this->logRepository = $webhookModel->getLogRepository(); parent::__construct(); } protected function configure(): void { $this->setName(static::COMMAND_NAME); } protected function execute(InputInterface $input, OutputInterface $output): int { $logMaxLimit = (int) $this->coreParametersHelper->get('webhook_log_max', WebhookModel::WEBHOOK_LOG_MAX); $webHookIds = $this->logRepository->getWebhooksBasedOnLogLimit($logMaxLimit); $webhookCount = count($webHookIds); $output->writeln("<info>There is {$webhookCount} webhooks with logs more than defined limit.</info>"); foreach ($webHookIds as $webHookId) { $deletedLogCount = $this->logRepository->removeLimitExceedLogs($webHookId, $logMaxLimit); $output->writeln(sprintf('<info>%s logs deleted successfully for webhook id - %s</info>', $deletedLogCount, $webHookId)); } return Command::SUCCESS; } protected static $defaultDescription = 'Retains a rolling number of log records.'; }