📂 File Browser

AgentAI/vendor/monolog/monolog/src/Monolog/Handler
☀️ Light 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: AmqpHandler.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 Gelf\Message as GelfMessage;
use Monolog\Level;
use Monolog\Formatter\FormatterInterface;
use Monolog\Formatter\JsonFormatter;
use PhpAmqpLib\Message\AMQPMessage;
use PhpAmqpLib\Channel\AMQPChannel;
use AMQPExchange;
use Monolog\LogRecord;

class AmqpHandler extends AbstractProcessingHandler
{
    protected AMQPExchange|AMQPChannel $exchange;

    /** @var array<string, mixed> */
    private array $extraAttributes = [];

    protected string $exchangeName;

    /**
     * @param AMQPExchange|AMQPChannel $exchange     AMQPExchange (php AMQP ext) or PHP AMQP lib channel, ready for use
     * @param string|null              $exchangeName Optional exchange name, for AMQPChannel (PhpAmqpLib) only
     */
    public function __construct(AMQPExchange|AMQPChannel $exchange, ?string $exchangeName = null, int|string|Level $level = Level::Debug, bool $bubble = true)
    {
        if ($exchange instanceof AMQPChannel) {
            $this->exchangeName = (string) $exchangeName;
        } elseif ($exchangeName !== null) {
            @trigger_error('The $exchangeName parameter can only be passed when using PhpAmqpLib, if using an AMQPExchange instance configure it beforehand', E_USER_DEPRECATED);
        }
        $this->exchange = $exchange;

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

    /**
     * @return array<string, mixed>
     */
    public function getExtraAttributes(): array
    {
        return $this->extraAttributes;
    }

    /**
     * Configure extra attributes to pass to the AMQPExchange (if you are using the amqp extension)
     *
     * @param  array<string, mixed> $extraAttributes One of content_type, content_encoding,
     *                                               message_id, user_id, app_id, delivery_mode,
     *                                               priority, timestamp, expiration, type
     *                                               or reply_to, headers.
     * @return $this
     */
    public function setExtraAttributes(array $extraAttributes): self
    {
        $this->extraAttributes = $extraAttributes;

        return $this;
    }

    /**
     * @inheritDoc
     */
    protected function write(LogRecord $record): void
    {
        $data = $record->formatted;
        $routingKey = $this->getRoutingKey($record);

        if($data instanceof GelfMessage) {
            $data = json_encode($data->toArray());
        }

        if ($this->exchange instanceof AMQPExchange) {
            $attributes = [
                'delivery_mode' => 2,
                'content_type'  => 'application/json',
            ];
            if (\count($this->extraAttributes) > 0) {
                $attributes = array_merge($attributes, $this->extraAttributes);
            }
            $this->exchange->publish(
                $data,
                $routingKey,
                0,
                $attributes
            );
        } else {
            $this->exchange->basic_publish(
                $this->createAmqpMessage($data),
                $this->exchangeName,
                $routingKey
            );
        }
    }

    /**
     * @inheritDoc
     */
    public function handleBatch(array $records): void
    {
        if ($this->exchange instanceof AMQPExchange) {
            parent::handleBatch($records);

            return;
        }

        foreach ($records as $record) {
            if (!$this->isHandling($record)) {
                continue;
            }

            $record = $this->processRecord($record);
            $data = $this->getFormatter()->format($record);

            if($data instanceof GelfMessage) {
                $data = json_encode($data->toArray());
            }

            $this->exchange->batch_basic_publish(
                $this->createAmqpMessage($data),
                $this->exchangeName,
                $this->getRoutingKey($record)
            );
        }

        $this->exchange->publish_batch();
    }

    /**
     * Gets the routing key for the AMQP exchange
     */
    protected function getRoutingKey(LogRecord $record): string
    {
        $routingKey = sprintf('%s.%s', $record->level->name, $record->channel);

        return strtolower($routingKey);
    }

    private function createAmqpMessage(string $data): AMQPMessage
    {
        $attributes = [
            'delivery_mode' => 2,
            'content_type' => 'application/json',
        ];
        if (\count($this->extraAttributes) > 0) {
            $attributes = array_merge($attributes, $this->extraAttributes);
        }

        return new AMQPMessage($data, $attributes);
    }

    /**
     * @inheritDoc
     */
    protected function getDefaultFormatter(): FormatterInterface
    {
        return new JsonFormatter(JsonFormatter::BATCH_MODE_JSON, false);
    }
}
← Back