48 lines
1.3 KiB
PHP
48 lines
1.3 KiB
PHP
<?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;
|
|
|
|
/**
|
|
* Encodes message information into JSON in a format compatible with Loggly.
|
|
*
|
|
* @author Adam Pancutt <adam@pancutt.com>
|
|
*/
|
|
class LogglyFormatter extends JsonFormatter
|
|
{
|
|
/**
|
|
* Overrides the default batch mode to new lines for compatibility with the
|
|
* Loggly bulk API.
|
|
*
|
|
* @param int $batchMode
|
|
*/
|
|
public function __construct($batchMode = self::BATCH_MODE_NEWLINES, $appendNewline = false)
|
|
{
|
|
parent::__construct($batchMode, $appendNewline);
|
|
}
|
|
|
|
/**
|
|
* Appends the 'timestamp' parameter for indexing by Loggly.
|
|
*
|
|
* @see https://www.loggly.com/docs/automated-parsing/#json
|
|
* @see \Monolog\Formatter\JsonFormatter::format()
|
|
*/
|
|
public function format(array $record)
|
|
{
|
|
if (isset($record["datetime"]) && ($record["datetime"] instanceof \DateTime)) {
|
|
$record["timestamp"] = $record["datetime"]->format("Y-m-d\TH:i:s.uO");
|
|
// TODO 2.0 unset the 'datetime' parameter, retained for BC
|
|
}
|
|
|
|
return parent::format($record);
|
|
}
|
|
}
|