mautic / app /bundles /WebhookBundle /Command /DeleteWebhookLogsCommand.php
chrisbryan17's picture
Upload folder using huggingface_hub
d2897cd verified
raw
history blame contribute delete
1.78 kB
<?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.';
}