12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 |
- <?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\Handler;
- use Monolog\Handler\AbstractHandler;
- use Monolog\Logger;
- use Symfony\Component\Notifier\Notification\Notification;
- use Symfony\Component\Notifier\Notifier;
- use Symfony\Component\Notifier\NotifierInterface;
- /**
- * Uses Notifier as a log handler.
- *
- * @author Fabien Potencier <fabien@symfony.com>
- */
- class NotifierHandler extends AbstractHandler
- {
- private $notifier;
- /**
- * @param string|int $level The minimum logging level at which this handler will be triggered
- */
- public function __construct(NotifierInterface $notifier, $level = Logger::ERROR, bool $bubble = true)
- {
- $this->notifier = $notifier;
- parent::__construct(Logger::toMonologLevel($level) < Logger::ERROR ? Logger::ERROR : $level, $bubble);
- }
- public function handle(array $record): bool
- {
- if (!$this->isHandling($record)) {
- return false;
- }
- $this->notify([$record]);
- return !$this->bubble;
- }
- public function handleBatch(array $records): void
- {
- if ($records = array_filter($records, [$this, 'isHandling'])) {
- $this->notify($records);
- }
- }
- private function notify(array $records): void
- {
- $record = $this->getHighestRecord($records);
- if (($record['context']['exception'] ?? null) instanceof \Throwable) {
- $notification = Notification::fromThrowable($record['context']['exception']);
- } else {
- $notification = new Notification($record['message']);
- }
- $notification->importanceFromLogLevelName(Logger::getLevelName($record['level']));
- $this->notifier->send($notification, ...$this->notifier->getAdminRecipients());
- }
- private function getHighestRecord(array $records)
- {
- $highestRecord = null;
- foreach ($records as $record) {
- if (null === $highestRecord || $highestRecord['level'] < $record['level']) {
- $highestRecord = $record;
- }
- }
- return $highestRecord;
- }
- }
|