Add a new tab with php errors and warnings to the debug bar
This commit is contained in:
parent
9f6b78b053
commit
39863897b7
168
htdocs/debugbar/class/DataCollector/DolPhpCollector.php
Normal file
168
htdocs/debugbar/class/DataCollector/DolPhpCollector.php
Normal file
@ -0,0 +1,168 @@
|
||||
<?php
|
||||
|
||||
use DebugBar\DataCollector\DataCollector;
|
||||
use DebugBar\DataCollector\Renderable;
|
||||
|
||||
/**
|
||||
* Class PhpCollector
|
||||
*
|
||||
* This class collects all PHP errors, notice, advices, trigger_error,...
|
||||
* Supports 15 different types included.
|
||||
*/
|
||||
class PhpCollector extends DataCollector implements Renderable
|
||||
{
|
||||
/**
|
||||
* Collector name.
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
protected $name;
|
||||
|
||||
/**
|
||||
* List of messages. Each item includes:
|
||||
* 'message', 'message_html', 'is_string', 'label', 'time'.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
protected $messages = [];
|
||||
|
||||
/**
|
||||
* PHPCollector constructor.
|
||||
*
|
||||
* @param string $name The name used by this collector widget.
|
||||
*/
|
||||
public function __construct($name = 'Error handler')
|
||||
{
|
||||
$this->name = $name;
|
||||
set_error_handler([$this, 'errorHandler'], E_ALL);
|
||||
}
|
||||
|
||||
/**
|
||||
* Called by the DebugBar when data needs to be collected.
|
||||
*
|
||||
* @return array Collected data.
|
||||
*/
|
||||
public function collect()
|
||||
{
|
||||
$messages = $this->getMessages();
|
||||
return [
|
||||
'count' => count($messages),
|
||||
'messages' => $messages,
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns a list of messages ordered by their timestamp.
|
||||
*
|
||||
* @return array A list of messages ordered by time.
|
||||
*/
|
||||
public function getMessages()
|
||||
{
|
||||
$messages = $this->messages;
|
||||
|
||||
usort($messages, function ($itemA, $itemB) {
|
||||
if ($itemA['time'] === $itemB['time']) {
|
||||
return 0;
|
||||
}
|
||||
return $itemA['time'] < $itemB['time'] ? -1 : 1;
|
||||
});
|
||||
|
||||
return $messages;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns a hash where keys are control names and their values an array of options as defined in
|
||||
* {@see DebugBar\JavascriptRenderer::addControl()}
|
||||
*
|
||||
* @return array Needed details to render the widget.
|
||||
*/
|
||||
public function getWidgets()
|
||||
{
|
||||
$name = $this->getName();
|
||||
return [
|
||||
$name => [
|
||||
'icon' => 'list',
|
||||
'widget' => 'PhpDebugBar.Widgets.MessagesWidget',
|
||||
'map' => "$name.messages",
|
||||
'default' => '[]',
|
||||
],
|
||||
"$name:badge" => [
|
||||
'map' => "$name.count",
|
||||
'default' => 'null',
|
||||
],
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the unique name of the collector.
|
||||
*
|
||||
* @return string The widget name.
|
||||
*/
|
||||
public function getName()
|
||||
{
|
||||
return $this->name;
|
||||
}
|
||||
|
||||
/**
|
||||
* Exception error handler. Called from constructor with set_error_handler to add all details.
|
||||
*
|
||||
* @param int $severity Error type.
|
||||
* @param string $message Message of error.
|
||||
* @param string $fileName File where error is generated.
|
||||
* @param int $line Line number where error is generated.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function errorHandler($severity, $message, $fileName, $line)
|
||||
{
|
||||
for ($i = 0; $i < 15; $i++) {
|
||||
if ($type = $severity & (2 ** $i)) {
|
||||
$label = $this->friendlyErrorType($type);
|
||||
$this->messages[] = [
|
||||
'message' => $message . ' (' . $fileName . ':' . $line . ')',
|
||||
'message_html' => null,
|
||||
'is_string' => true,
|
||||
'label' => $label,
|
||||
'time' => microtime(true),
|
||||
];
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Return error name from error code.
|
||||
*
|
||||
* @info http://php.net/manual/es/errorfunc.constants.php
|
||||
*
|
||||
* @param int $type Error code.
|
||||
*
|
||||
* @return string Error name.
|
||||
*/
|
||||
private function friendlyErrorType($type)
|
||||
{
|
||||
$errors = [
|
||||
E_ERROR => 'ERROR',
|
||||
E_WARNING => 'WARNING',
|
||||
E_PARSE => 'PARSE',
|
||||
E_NOTICE => 'NOTICE',
|
||||
E_CORE_ERROR => 'CORE_ERROR',
|
||||
E_CORE_WARNING => 'CORE_WARNING',
|
||||
E_COMPILE_ERROR => 'COMPILE_ERROR',
|
||||
E_COMPILE_WARNING => 'COMPILE_WARNING',
|
||||
E_USER_ERROR => 'USER_ERROR',
|
||||
E_USER_WARNING => 'USER_WARNING',
|
||||
E_USER_NOTICE => 'USER_NOTICE',
|
||||
E_STRICT => 'STRICT',
|
||||
E_RECOVERABLE_ERROR => 'RECOVERABLE_ERROR',
|
||||
E_DEPRECATED => 'DEPRECATED',
|
||||
E_USER_DEPRECATED => 'USER_DEPRECATED',
|
||||
];
|
||||
|
||||
$result = '';
|
||||
if (isset($errors[$type])) {
|
||||
$result = $errors[$type];
|
||||
}
|
||||
|
||||
return $result;
|
||||
}
|
||||
}
|
||||
@ -10,6 +10,7 @@ dol_include_once('/debugbar/class/DataCollector/DolRequestDataCollector.php');
|
||||
dol_include_once('/debugbar/class/DataCollector/DolConfigCollector.php');
|
||||
dol_include_once('/debugbar/class/DataCollector/DolTimeDataCollector.php');
|
||||
dol_include_once('/debugbar/class/DataCollector/DolMemoryCollector.php');
|
||||
dol_include_once('/debugbar/class/DataCollector/DolPhpCollector.php');
|
||||
dol_include_once('/debugbar/class/DataCollector/DolExceptionsCollector.php');
|
||||
dol_include_once('/debugbar/class/DataCollector/DolQueryCollector.php');
|
||||
dol_include_once('/debugbar/class/DataCollector/DolibarrCollector.php');
|
||||
@ -36,6 +37,7 @@ class DolibarrDebugBar extends DebugBar
|
||||
$this->addCollector(new DolRequestDataCollector());
|
||||
//$this->addCollector(new DolConfigCollector()); // Disabled for security purpose
|
||||
$this->addCollector(new DolTimeDataCollector());
|
||||
$this->addCollector(new PhpCollector());
|
||||
$this->addCollector(new DolMemoryCollector());
|
||||
//$this->addCollector(new DolExceptionsCollector());
|
||||
$this->addCollector(new DolQueryCollector());
|
||||
|
||||
Loading…
Reference in New Issue
Block a user