mirror of
https://github.com/Seldaek/monolog.git
synced 2025-08-10 23:24:02 +02:00
Added FirePHPHandler using a WildfireFormatter
This commit is contained in:
72
src/Monolog/Formatter/WildfireFormatter.php
Normal file
72
src/Monolog/Formatter/WildfireFormatter.php
Normal file
@@ -0,0 +1,72 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/*
|
||||||
|
* 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\Formatter;
|
||||||
|
|
||||||
|
use Monolog\Logger;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Serializes a log message according to Wildfire's header requirements
|
||||||
|
*
|
||||||
|
* @author Eric Clemmons (@ericclemmons) <eric@uxdriven.com>
|
||||||
|
*/
|
||||||
|
class WildfireFormatter extends LineFormatter implements FormatterInterface
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Similar to LineFormatter::SIMPLE_FORMAT, except without the "[%datetime%]"
|
||||||
|
*/
|
||||||
|
const SIMPLE_FORMAT = "%channel%: %message% %extra%";
|
||||||
|
|
||||||
|
// Convert Logger's error levels to Wildfire's
|
||||||
|
const DEBUG = 'LOG';
|
||||||
|
const INFO = 'INFO';
|
||||||
|
const WARNING = 'WARN';
|
||||||
|
const ERROR = 'ERROR';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function __construct($format = null, $dateFormat = null)
|
||||||
|
{
|
||||||
|
$this->format = $format ?: self::SIMPLE_FORMAT;
|
||||||
|
$this->dateFormat = $dateFormat ?: self::SIMPLE_DATE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritdoc}
|
||||||
|
*/
|
||||||
|
public function format(Array $record)
|
||||||
|
{
|
||||||
|
// Format record according with LineFormatter
|
||||||
|
$formatted = parent::format($record);
|
||||||
|
|
||||||
|
// Create JSON object describing the appearance of the message in the console
|
||||||
|
$json = json_encode(array(
|
||||||
|
array(
|
||||||
|
'Type' => constant('self::' . $record['level_name']),
|
||||||
|
'File' => '',
|
||||||
|
'Line' => '',
|
||||||
|
),
|
||||||
|
$formatted['message'],
|
||||||
|
));
|
||||||
|
|
||||||
|
// The message itself is a serialization of the above JSON object + it's length
|
||||||
|
$formatted['message'] = sprintf(
|
||||||
|
'%s|%s|',
|
||||||
|
strlen($json),
|
||||||
|
$json
|
||||||
|
);
|
||||||
|
|
||||||
|
return $formatted;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
95
src/Monolog/Handler/FirePHPHandler.php
Normal file
95
src/Monolog/Handler/FirePHPHandler.php
Normal file
@@ -0,0 +1,95 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/*
|
||||||
|
* 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\Logger;
|
||||||
|
use Monolog\Formatter\WildfireFormatter;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Simple FirePHP Handler (http://www.firephp.org/), which uses the Wildfire protocol.
|
||||||
|
*
|
||||||
|
* @author Eric Clemmons (@ericclemmons) <eric@uxdriven.com>
|
||||||
|
*/
|
||||||
|
class FirePHPHandler extends AbstractHandler
|
||||||
|
{
|
||||||
|
|
||||||
|
const PROTOCOL_URI = 'http://meta.wildfirehq.org/Protocol/JsonStream/0.2';
|
||||||
|
|
||||||
|
const STRUCTURE_URI = 'http://meta.firephp.org/Wildfire/Structure/FirePHP/FirebugConsole/0.1';
|
||||||
|
|
||||||
|
const PLUGIN_URI = 'http://meta.firephp.org/Wildfire/Plugin/ZendFramework/FirePHP/1.6.2';
|
||||||
|
|
||||||
|
private $prefix = 'X-Wf';
|
||||||
|
|
||||||
|
private $records = array();
|
||||||
|
|
||||||
|
protected function createHeader(Array $meta, $message)
|
||||||
|
{
|
||||||
|
return sprintf(
|
||||||
|
'%s-%s: %s',
|
||||||
|
$this->prefix,
|
||||||
|
join('-', $meta),
|
||||||
|
$message
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function write(Array $record)
|
||||||
|
{
|
||||||
|
$this->records[] = $record;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function close()
|
||||||
|
{
|
||||||
|
if (headers_sent()) {
|
||||||
|
return false;
|
||||||
|
} else {
|
||||||
|
foreach ($this->getHeaders() as $header) {
|
||||||
|
header($header);
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getHeaders()
|
||||||
|
{
|
||||||
|
// Wildfire is extensible to support multiple protocols & plugins in a single request,
|
||||||
|
// but we're not taking advantage of that (yet) for simplicity's sake.
|
||||||
|
// (It does help understanding header formatting, though!)
|
||||||
|
$protocolIndex = 1;
|
||||||
|
$structureIndex = 1;
|
||||||
|
$pluginIndex = 1;
|
||||||
|
$messageIndex = 1;
|
||||||
|
|
||||||
|
// Initial payload consists of required headers for Wildfire
|
||||||
|
$headers = array(
|
||||||
|
$this->createHeader(array('Protocol', $protocolIndex), self::PROTOCOL_URI),
|
||||||
|
$this->createHeader(array($protocolIndex, 'Structure', $structureIndex), self::STRUCTURE_URI),
|
||||||
|
$this->createHeader(array($protocolIndex, 'Plugin', $pluginIndex), self::PLUGIN_URI),
|
||||||
|
);
|
||||||
|
|
||||||
|
foreach ($this->records as $record) {
|
||||||
|
$headers[] = $this->createHeader(
|
||||||
|
array($protocolIndex, $structureIndex, $pluginIndex, $messageIndex++),
|
||||||
|
$record['message']
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $headers;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function getDefaultFormatter()
|
||||||
|
{
|
||||||
|
return new WildfireFormatter();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Reference in New Issue
Block a user