File "GelfHandler.php"
Full Path: /home/jlklyejr/public_html/post-date/wp-content/plugins/flexible-shipping/vendor_prefixed/monolog/monolog/src/Monolog/Handler/GelfHandler.php
File size: 1.52 KB
MIME-type: text/x-php
Charset: utf-8
<?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 FSVendor\Monolog\Handler;
use FSVendor\Gelf\PublisherInterface;
use FSVendor\Monolog\Logger;
use FSVendor\Monolog\Formatter\GelfMessageFormatter;
use FSVendor\Monolog\Formatter\FormatterInterface;
/**
* Handler to send messages to a Graylog2 (http://www.graylog2.org) server
*
* @author Matt Lehner <mlehner@gmail.com>
* @author Benjamin Zikarsky <benjamin@zikarsky.de>
*/
class GelfHandler extends \FSVendor\Monolog\Handler\AbstractProcessingHandler
{
/**
* @var PublisherInterface the publisher object that sends the message to the server
*/
protected $publisher;
/**
* @param PublisherInterface $publisher a gelf publisher object
*/
public function __construct(\FSVendor\Gelf\PublisherInterface $publisher, $level = \FSVendor\Monolog\Logger::DEBUG, bool $bubble = \true)
{
parent::__construct($level, $bubble);
$this->publisher = $publisher;
}
/**
* {@inheritDoc}
*/
protected function write(array $record) : void
{
$this->publisher->publish($record['formatted']);
}
/**
* {@inheritDoc}
*/
protected function getDefaultFormatter() : \FSVendor\Monolog\Formatter\FormatterInterface
{
return new \FSVendor\Monolog\Formatter\GelfMessageFormatter();
}
}