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);
 | 
						|
    }
 | 
						|
}
 |