📂 File Browser

AgentAI/vendor/monolog/monolog/src/Monolog/Handler
🌙 Dark Mode
🎯 Quick Launch:

📁 Directories

📁 Curl/ 🔓 Open
📁 FingersCrossed/ 🔓 Open
📁 Slack/ 🔓 Open
📁 SyslogUdp/ 🔓 Open

📄 Files

🐘 AbstractHandler.php
▶ Open 📄 View Source
🐘 AbstractProcessingHandler.php
▶ Open 📄 View Source
🐘 AbstractSyslogHandler.php
▶ Open 📄 View Source
🐘 AmqpHandler.php
▶ Open 📄 View Source
🐘 BrowserConsoleHandler.php
▶ Open 📄 View Source
🐘 BufferHandler.php
▶ Open 📄 View Source
🐘 ChromePHPHandler.php
▶ Open 📄 View Source
🐘 CouchDBHandler.php
▶ Open 📄 View Source
🐘 CubeHandler.php
▶ Open 📄 View Source
🐘 DeduplicationHandler.php
▶ Open 📄 View Source
🐘 DoctrineCouchDBHandler.php
▶ Open 📄 View Source
🐘 DynamoDbHandler.php
▶ Open 📄 View Source
🐘 ElasticaHandler.php
▶ Open 📄 View Source
🐘 ElasticsearchHandler.php
▶ Open 📄 View Source
🐘 ErrorLogHandler.php
▶ Open 📄 View Source
🐘 FallbackGroupHandler.php
▶ Open 📄 View Source
🐘 FilterHandler.php
▶ Open 📄 View Source
🐘 FingersCrossedHandler.php
▶ Open 📄 View Source
🐘 FirePHPHandler.php
▶ Open 📄 View Source
🐘 FleepHookHandler.php
▶ Open 📄 View Source
🐘 FlowdockHandler.php
▶ Open 📄 View Source
🐘 FormattableHandlerInterface.php
▶ Open 📄 View Source
🐘 FormattableHandlerTrait.php
▶ Open 📄 View Source
🐘 GelfHandler.php
▶ Open 📄 View Source
🐘 GroupHandler.php
▶ Open 📄 View Source
🐘 Handler.php
▶ Open 📄 View Source
🐘 HandlerInterface.php
▶ Open 📄 View Source
🐘 HandlerWrapper.php
▶ Open 📄 View Source
🐘 IFTTTHandler.php
▶ Open 📄 View Source
🐘 InsightOpsHandler.php
▶ Open 📄 View Source
🐘 LogEntriesHandler.php
▶ Open 📄 View Source
🐘 LogglyHandler.php
▶ Open 📄 View Source
🐘 LogmaticHandler.php
▶ Open 📄 View Source
🐘 MailHandler.php
▶ Open 📄 View Source
🐘 MandrillHandler.php
▶ Open 📄 View Source
🐘 MissingExtensionException.php
▶ Open 📄 View Source
🐘 MongoDBHandler.php
▶ Open 📄 View Source
🐘 NativeMailerHandler.php
▶ Open 📄 View Source
🐘 NewRelicHandler.php
▶ Open 📄 View Source
🐘 NoopHandler.php
▶ Open 📄 View Source
🐘 NullHandler.php
▶ Open 📄 View Source
🐘 OverflowHandler.php
▶ Open 📄 View Source
🐘 PHPConsoleHandler.php
▶ Open 📄 View Source
🐘 ProcessHandler.php
▶ Open 📄 View Source
🐘 ProcessableHandlerInterface.php
▶ Open 📄 View Source
🐘 ProcessableHandlerTrait.php
▶ Open 📄 View Source
🐘 PsrHandler.php
▶ Open 📄 View Source
🐘 PushoverHandler.php
▶ Open 📄 View Source
🐘 RedisHandler.php
▶ Open 📄 View Source
🐘 RedisPubSubHandler.php
▶ Open 📄 View Source
🐘 RollbarHandler.php
▶ Open 📄 View Source
🐘 RotatingFileHandler.php
▶ Open 📄 View Source
🐘 SamplingHandler.php
▶ Open 📄 View Source
🐘 SendGridHandler.php
▶ Open 📄 View Source
🐘 SlackHandler.php
▶ Open 📄 View Source
🐘 SlackWebhookHandler.php
▶ Open 📄 View Source
🐘 SocketHandler.php
▶ Open 📄 View Source
🐘 SqsHandler.php
▶ Open 📄 View Source
🐘 StreamHandler.php
▶ Open 📄 View Source
🐘 SymfonyMailerHandler.php
▶ Open 📄 View Source
🐘 SyslogHandler.php
▶ Open 📄 View Source
🐘 SyslogUdpHandler.php
▶ Open 📄 View Source
🐘 TelegramBotHandler.php
▶ Open 📄 View Source
🐘 TestHandler.php
▶ Open 📄 View Source
🐘 WebRequestRecognizerTrait.php
▶ Open 📄 View Source
🐘 WhatFailureGroupHandler.php
▶ Open 📄 View Source
🐘 ZendMonitorHandler.php
▶ Open 📄 View Source

📄 Source: RollbarHandler.php

<?php declare(strict_types=1);

/*
 * This file is part of the Monolog package.
 *
 * (c) Jordi Boggiano <j.boggiano@seld.be>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace Monolog\Handler;

use Monolog\Level;
use Rollbar\RollbarLogger;
use Throwable;
use Monolog\LogRecord;

/**
 * Sends errors to Rollbar
 *
 * If the context data contains a `payload` key, that is used as an array
 * of payload options to RollbarLogger's log method.
 *
 * Rollbar's context info will contain the context + extra keys from the log record
 * merged, and then on top of that a few keys:
 *
 *  - level (rollbar level name)
 *  - monolog_level (monolog level name, raw level, as rollbar only has 5 but monolog 8)
 *  - channel
 *  - datetime (unix timestamp)
 *
 * @author Paul Statezny <paulstatezny@gmail.com>
 */
class RollbarHandler extends AbstractProcessingHandler
{
    protected RollbarLogger $rollbarLogger;

    /**
     * Records whether any log records have been added since the last flush of the rollbar notifier
     */
    private bool $hasRecords = false;

    protected bool $initialized = false;

    /**
     * @param RollbarLogger $rollbarLogger RollbarLogger object constructed with valid token
     */
    public function __construct(RollbarLogger $rollbarLogger, int|string|Level $level = Level::Error, bool $bubble = true)
    {
        $this->rollbarLogger = $rollbarLogger;

        parent::__construct($level, $bubble);
    }

    /**
     * Translates Monolog log levels to Rollbar levels.
     *
     * @return 'debug'|'info'|'warning'|'error'|'critical'
     */
    protected function toRollbarLevel(Level $level): string
    {
        return match ($level) {
            Level::Debug     => 'debug',
            Level::Info      => 'info',
            Level::Notice    => 'info',
            Level::Warning   => 'warning',
            Level::Error     => 'error',
            Level::Critical  => 'critical',
            Level::Alert     => 'critical',
            Level::Emergency => 'critical',
        };
    }

    /**
     * @inheritDoc
     */
    protected function write(LogRecord $record): void
    {
        if (!$this->initialized) {
            // __destructor() doesn't get called on Fatal errors
            register_shutdown_function([$this, 'close']);
            $this->initialized = true;
        }

        $context = $record->context;
        $context = array_merge($context, $record->extra, [
            'level' => $this->toRollbarLevel($record->level),
            'monolog_level' => $record->level->getName(),
            'channel' => $record->channel,
            'datetime' => $record->datetime->format('U'),
        ]);

        if (isset($context['exception']) && $context['exception'] instanceof Throwable) {
            $exception = $context['exception'];
            unset($context['exception']);
            $toLog = $exception;
        } else {
            $toLog = $record->message;
        }

        $this->rollbarLogger->log($context['level'], $toLog, $context);

        $this->hasRecords = true;
    }

    public function flush(): void
    {
        if ($this->hasRecords) {
            $this->rollbarLogger->flush();
            $this->hasRecords = false;
        }
    }

    /**
     * @inheritDoc
     */
    public function close(): void
    {
        $this->flush();
    }

    /**
     * @inheritDoc
     */
    public function reset(): void
    {
        $this->flush();

        parent::reset();
    }
}
← Back