2014-03-17 19:10:47 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace PHPCI\Logging;
|
|
|
|
|
|
|
|
use Psr\Log\LoggerInterface;
|
|
|
|
|
|
|
|
class Handler
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $levels = array(
|
|
|
|
E_WARNING => 'Warning',
|
|
|
|
E_NOTICE => 'Notice',
|
|
|
|
E_USER_ERROR => 'User Error',
|
|
|
|
E_USER_WARNING => 'User Warning',
|
|
|
|
E_USER_NOTICE => 'User Notice',
|
|
|
|
E_STRICT => 'Runtime Notice',
|
|
|
|
E_RECOVERABLE_ERROR => 'Catchable Fatal Error',
|
|
|
|
E_DEPRECATED => 'Deprecated',
|
|
|
|
E_USER_DEPRECATED => 'User Deprecated',
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var LoggerInterface
|
|
|
|
*/
|
|
|
|
protected $logger;
|
|
|
|
|
2014-05-01 17:53:29 +02:00
|
|
|
public function __construct(LoggerInterface $logger = null)
|
2014-03-17 19:10:47 +01:00
|
|
|
{
|
|
|
|
$this->logger = $logger;
|
|
|
|
}
|
|
|
|
|
2014-05-01 17:53:29 +02:00
|
|
|
public static function register(LoggerInterface $logger = null)
|
2014-03-17 19:10:47 +01:00
|
|
|
{
|
|
|
|
$handler = new static($logger);
|
|
|
|
|
|
|
|
set_error_handler(array($handler, 'handleError'));
|
|
|
|
register_shutdown_function(array($handler, 'handleFatalError'));
|
|
|
|
|
|
|
|
set_exception_handler(array($handler, 'handleException'));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param integer $level
|
|
|
|
* @param string $message
|
|
|
|
* @param string $file
|
|
|
|
* @param integer $line
|
|
|
|
*
|
|
|
|
* @throws \ErrorException
|
|
|
|
*/
|
|
|
|
public function handleError($level, $message, $file, $line)
|
|
|
|
{
|
|
|
|
if (error_reporting() & $level) {
|
|
|
|
|
|
|
|
$exception_level = isset($this->levels[$level]) ? $this->levels[$level] : $level;
|
|
|
|
|
|
|
|
throw new \ErrorException(
|
|
|
|
sprintf('%s: %s in %s line %d', $exception_level, $message, $file, $line),
|
2014-05-01 17:53:29 +02:00
|
|
|
0,
|
|
|
|
$level,
|
|
|
|
$file,
|
|
|
|
$line
|
2014-03-17 19:10:47 +01:00
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @throws \ErrorException
|
|
|
|
*/
|
|
|
|
public function handleFatalError()
|
|
|
|
{
|
|
|
|
$fatal_error = error_get_last();
|
|
|
|
|
2014-03-20 16:17:54 +01:00
|
|
|
try {
|
|
|
|
if (($e = error_get_last()) !== null) {
|
|
|
|
$e = new \ErrorException(
|
2014-05-01 17:53:29 +02:00
|
|
|
sprintf(
|
|
|
|
'%s: %s in %s line %d',
|
|
|
|
$fatal_error['type'],
|
|
|
|
$fatal_error['message'],
|
|
|
|
$fatal_error['file'],
|
|
|
|
$fatal_error['line']
|
|
|
|
),
|
|
|
|
0,
|
|
|
|
$fatal_error['type'],
|
|
|
|
$fatal_error['file'],
|
|
|
|
$fatal_error['line']
|
2014-03-20 16:17:54 +01:00
|
|
|
);
|
|
|
|
$this->log($e);
|
|
|
|
}
|
|
|
|
}
|
2014-05-01 17:53:29 +02:00
|
|
|
catch (\Exception $e) {
|
2014-03-17 19:10:47 +01:00
|
|
|
$e = new \ErrorException(
|
2014-05-01 17:53:29 +02:00
|
|
|
sprintf(
|
|
|
|
'%s: %s in %s line %d',
|
|
|
|
$fatal_error['type'],
|
|
|
|
$fatal_error['message'],
|
|
|
|
$fatal_error['file'],
|
|
|
|
$fatal_error['line']
|
|
|
|
),
|
|
|
|
0,
|
|
|
|
$fatal_error['type'],
|
|
|
|
$fatal_error['file'],
|
|
|
|
$fatal_error['line']
|
2014-03-17 19:10:47 +01:00
|
|
|
);
|
|
|
|
$this->log($e);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param \Exception $exception
|
|
|
|
*/
|
|
|
|
public function handleException(\Exception $exception)
|
|
|
|
{
|
|
|
|
$this->log($exception);
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function log(\Exception $exception)
|
|
|
|
{
|
|
|
|
if (null !== $this->logger) {
|
|
|
|
|
|
|
|
$message = sprintf(
|
2014-05-01 17:53:29 +02:00
|
|
|
'%s: %s (uncaught exception) at %s line %s',
|
|
|
|
get_class($exception),
|
|
|
|
$exception->getMessage(),
|
|
|
|
$exception->getFile(),
|
|
|
|
$exception->getLine()
|
2014-03-17 19:10:47 +01:00
|
|
|
);
|
2014-05-01 17:53:29 +02:00
|
|
|
|
2014-03-24 17:43:20 +01:00
|
|
|
$this->logger->error($message, array('exception' => $exception));
|
2014-03-17 19:10:47 +01:00
|
|
|
}
|
|
|
|
}
|
2014-05-01 17:53:29 +02:00
|
|
|
}
|