113 lines
3.0 KiB
PHP
113 lines
3.0 KiB
PHP
|
<?php
|
||
|
|
||
|
/*
|
||
|
* This file is part of the Symfony package.
|
||
|
*
|
||
|
* (c) Fabien Potencier <fabien@symfony.com>
|
||
|
*
|
||
|
* For the full copyright and license information, please view the LICENSE
|
||
|
* file that was distributed with this source code.
|
||
|
*/
|
||
|
|
||
|
namespace Symfony\Bridge\Monolog\Processor;
|
||
|
|
||
|
use Monolog\Logger;
|
||
|
use Symfony\Component\HttpFoundation\Request;
|
||
|
use Symfony\Component\HttpFoundation\RequestStack;
|
||
|
use Symfony\Component\HttpKernel\Log\DebugLoggerInterface;
|
||
|
use Symfony\Contracts\Service\ResetInterface;
|
||
|
|
||
|
class DebugProcessor implements DebugLoggerInterface, ResetInterface
|
||
|
{
|
||
|
private array $records = [];
|
||
|
private array $errorCount = [];
|
||
|
private $requestStack;
|
||
|
|
||
|
public function __construct(RequestStack $requestStack = null)
|
||
|
{
|
||
|
$this->requestStack = $requestStack;
|
||
|
}
|
||
|
|
||
|
public function __invoke(array $record)
|
||
|
{
|
||
|
$hash = $this->requestStack && ($request = $this->requestStack->getCurrentRequest()) ? spl_object_hash($request) : '';
|
||
|
|
||
|
$timestamp = $timestampRfc3339 = false;
|
||
|
if ($record['datetime'] instanceof \DateTimeInterface) {
|
||
|
$timestamp = $record['datetime']->getTimestamp();
|
||
|
$timestampRfc3339 = $record['datetime']->format(\DateTimeInterface::RFC3339_EXTENDED);
|
||
|
} elseif (false !== $timestamp = strtotime($record['datetime'])) {
|
||
|
$timestampRfc3339 = (new \DateTimeImmutable($record['datetime']))->format(\DateTimeInterface::RFC3339_EXTENDED);
|
||
|
}
|
||
|
|
||
|
$this->records[$hash][] = [
|
||
|
'timestamp' => $timestamp,
|
||
|
'timestamp_rfc3339' => $timestampRfc3339,
|
||
|
'message' => $record['message'],
|
||
|
'priority' => $record['level'],
|
||
|
'priorityName' => $record['level_name'],
|
||
|
'context' => $record['context'],
|
||
|
'channel' => $record['channel'] ?? '',
|
||
|
];
|
||
|
|
||
|
if (!isset($this->errorCount[$hash])) {
|
||
|
$this->errorCount[$hash] = 0;
|
||
|
}
|
||
|
|
||
|
switch ($record['level']) {
|
||
|
case Logger::ERROR:
|
||
|
case Logger::CRITICAL:
|
||
|
case Logger::ALERT:
|
||
|
case Logger::EMERGENCY:
|
||
|
++$this->errorCount[$hash];
|
||
|
}
|
||
|
|
||
|
return $record;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* {@inheritdoc}
|
||
|
*/
|
||
|
public function getLogs(Request $request = null): array
|
||
|
{
|
||
|
if (null !== $request) {
|
||
|
return $this->records[spl_object_hash($request)] ?? [];
|
||
|
}
|
||
|
|
||
|
if (0 === \count($this->records)) {
|
||
|
return [];
|
||
|
}
|
||
|
|
||
|
return array_merge(...array_values($this->records));
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* {@inheritdoc}
|
||
|
*/
|
||
|
public function countErrors(Request $request = null): int
|
||
|
{
|
||
|
if (null !== $request) {
|
||
|
return $this->errorCount[spl_object_hash($request)] ?? 0;
|
||
|
}
|
||
|
|
||
|
return array_sum($this->errorCount);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* {@inheritdoc}
|
||
|
*/
|
||
|
public function clear()
|
||
|
{
|
||
|
$this->records = [];
|
||
|
$this->errorCount = [];
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* {@inheritdoc}
|
||
|
*/
|
||
|
public function reset()
|
||
|
{
|
||
|
$this->clear();
|
||
|
}
|
||
|
}
|