123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103 |
- <?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 $records = [];
- private $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) : '';
- $this->records[$hash][] = [
- 'timestamp' => $record['datetime'] instanceof \DateTimeInterface ? $record['datetime']->getTimestamp() : strtotime($record['datetime']),
- '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)
- {
- 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)
- {
- 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();
- }
- }
|