Viewing file: FlareHandler.php (2.45 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
namespace Facade\Ignition\Logger;
use Facade\FlareClient\Flare; use Facade\FlareClient\Report; use Facade\Ignition\Ignition; use Facade\Ignition\Tabs\Tab; use Monolog\Handler\AbstractProcessingHandler; use Monolog\Logger; use Throwable;
class FlareHandler extends AbstractProcessingHandler { /** @var \Facade\FlareClient\Flare */ protected $flare;
protected $minimumReportLogLevel = Logger::ERROR;
public function __construct(Flare $flare, $level = Logger::DEBUG, $bubble = true) { $this->flare = $flare;
parent::__construct($level, $bubble); }
public function setMinimumReportLogLevel(int $level) { if (! in_array($level, Logger::getLevels())) { throw new \InvalidArgumentException('The given minimum log level is not supported.'); }
$this->minimumReportLogLevel = $level; }
protected function write(array $report): void { if (! $this->shouldReport($report)) { return; }
if ($this->hasException($report)) { /** @var Throwable $throwable */ $throwable = $report['context']['exception'];
collect(Ignition::$tabs) ->each(function (Tab $tab) use ($throwable) { $tab->beforeRenderingErrorPage($this->flare, $throwable); });
$this->flare->report($report['context']['exception']);
return; }
if (config('flare.send_logs_as_events')) { if ($this->hasValidLogLevel($report)) { $this->flare->reportMessage( $report['message'], 'Log ' . Logger::getLevelName($report['level']), function (Report $flareReport) use ($report) { foreach ($report['context'] as $key => $value) { $flareReport->context($key, $value); } } ); } } }
protected function shouldReport(array $report): bool { return $this->hasException($report) || $this->hasValidLogLevel($report); }
protected function hasException(array $report): bool { $context = $report['context'];
return isset($context['exception']) && $context['exception'] instanceof Throwable; }
protected function hasValidLogLevel(array $report): bool { return $report['level'] >= $this->minimumReportLogLevel; } }
|