83 lines
2.3 KiB
PHP
83 lines
2.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\Handler;
|
|
|
|
use Monolog\Formatter\LineFormatter;
|
|
use Monolog\Logger;
|
|
|
|
/**
|
|
* Stores to PHP error_log() handler.
|
|
*
|
|
* @author Elan Ruusamäe <glen@delfi.ee>
|
|
*/
|
|
class ErrorLogHandler extends AbstractProcessingHandler
|
|
{
|
|
const OPERATING_SYSTEM = 0;
|
|
const SAPI = 4;
|
|
|
|
protected $messageType;
|
|
protected $expandNewlines;
|
|
|
|
/**
|
|
* @param int $messageType Says where the error should go.
|
|
* @param int $level The minimum logging level at which this handler will be triggered
|
|
* @param bool $bubble Whether the messages that are handled can bubble up the stack or not
|
|
* @param bool $expandNewlines If set to true, newlines in the message will be expanded to be take multiple log entries
|
|
*/
|
|
public function __construct($messageType = self::OPERATING_SYSTEM, $level = Logger::DEBUG, $bubble = true, $expandNewlines = false)
|
|
{
|
|
parent::__construct($level, $bubble);
|
|
|
|
if (false === in_array($messageType, self::getAvailableTypes())) {
|
|
$message = sprintf('The given message type "%s" is not supported', print_r($messageType, true));
|
|
throw new \InvalidArgumentException($message);
|
|
}
|
|
|
|
$this->messageType = $messageType;
|
|
$this->expandNewlines = $expandNewlines;
|
|
}
|
|
|
|
/**
|
|
* @return array With all available types
|
|
*/
|
|
public static function getAvailableTypes()
|
|
{
|
|
return array(
|
|
self::OPERATING_SYSTEM,
|
|
self::SAPI,
|
|
);
|
|
}
|
|
|
|
/**
|
|
* {@inheritDoc}
|
|
*/
|
|
protected function getDefaultFormatter()
|
|
{
|
|
return new LineFormatter('[%datetime%] %channel%.%level_name%: %message% %context% %extra%');
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
protected function write(array $record)
|
|
{
|
|
if ($this->expandNewlines) {
|
|
$lines = preg_split('{[\r\n]+}', (string) $record['formatted']);
|
|
foreach ($lines as $line) {
|
|
error_log($line, $this->messageType);
|
|
}
|
|
} else {
|
|
error_log((string) $record['formatted'], $this->messageType);
|
|
}
|
|
}
|
|
}
|