Files
CloudOps/docker-compose/mautic-setup/mautic-backup-files/docroot/app/bundles/WebhookBundle/Command/DeleteWebhookLogsCommand.php

51 lines
1.7 KiB
PHP
Executable File

<?php
declare(strict_types=1);
namespace Mautic\WebhookBundle\Command;
use Mautic\CoreBundle\Helper\CoreParametersHelper;
use Mautic\WebhookBundle\Model\WebhookModel;
use Symfony\Component\Console\Attribute\AsCommand;
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.
*/
#[AsCommand(
name: DeleteWebhookLogsCommand::COMMAND_NAME,
description: '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 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;
}
}