2013-08-13 12:29:40 +10:00
# Base collectors
Collectors provided in the `DebugBar\DataCollector` namespace.
## Messages
2013-08-16 00:52:32 +01:00
Provides a way to log messages (compatible with [PSR-3 logger ](https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-3-logger-interface.md )).
2017-07-21 04:35:32 -07:00
You can call the `useHtmlVarDumper()` function to use VarDumper's interactive HTML dumper for
interactively rendering complex variables. If you do that, you must properly render
[inline assets ](rendering.html#assets ) when rendering the debug bar in addition to the normal js/css
static assets.
$c = new DebugBar\DataCollector\MessagesCollector();
$c->useHtmlVarDumper(); // Enables prettier dumps of objects; requires inline assets
$debugbar->addCollector($c);
2013-08-13 12:29:40 +10:00
$debugbar['messages']->info('hello world');
2017-07-21 04:35:32 -07:00
$complicated_variable = array(1, 2, array(3, 4));
$debugbar['messages']->info($complicated_variable); // interactive HTML variable dumping
2013-08-13 12:29:40 +10:00
You can have multiple messages collector by naming them:
$debugbar->addCollector(new MessagesCollector('io_ops'));
$debugbar['io_ops']->info('opening files');
You can aggregate messages collector into other to have a unified view:
$debugbar['messages']->aggregate($debugbar['io_ops']);
If you don't want to create a standalone tab in the debug bar but still be able
to log messages from a different collector, you don't have to add the collector
to the debug bar:
$debugbar['messages']->aggregate(new MessagesCollector('io_ops'));
## TimeData
Provides a way to log total execution time as well as taking "measures" (ie. measure the execution time of a particular operation).
$debugbar->addCollector(new DebugBar\DataCollector\TimeDataCollector());
2014-01-16 21:41:41 +00:00
2013-08-13 12:29:40 +10:00
$debugbar['time']->startMeasure('longop', 'My long operation');
sleep(2);
$debugbar['time']->stopMeasure('longop');
$debugbar['time']->measure('My long operation', function() {
sleep(2);
});
Displays the measures on a timeline
## Exceptions
Display exceptions
$debugbar->addCollector(new DebugBar\DataCollector\ExceptionsCollector());
try {
throw new Exception('foobar');
} catch (Exception $e) {
2019-09-05 15:46:04 +02:00
$debugbar['exceptions']->addThrowable($e);
2013-08-13 12:29:40 +10:00
}
## PDO
2021-06-22 04:12:03 -03:00
Logs SQL queries.
2013-08-13 12:29:40 +10:00
$debugbar->addCollector(new DebugBar\DataCollector\PDO\PDOCollector($pdo));
2013-08-15 08:03:41 -04:00
You can even log queries from multiple `PDO` connections:
$pdoCollector = new DebugBar\DataCollector\PDO\PDOCollector();
$pdoCollector->addConnection($pdoRead, 'read-db');
$pdoCollector->addConnection($pdoWrite, 'write-db');
$debugbar->addCollector($pdoCollector);
2016-11-29 07:59:25 +13:00
If you want to see your PDO requests in the TimeDataCollector, you must add the PDOConnector to the $debugbar _first_
$timeDataCollector = new DebugBar\DataCollector\TimeDataCollector();
$pdoCollector = new DebugBar\DataCollector\PDO\PDOCollector($pdo, $timeDataCollector);
$debugBar->addCollector($pdoCollector);
$debugBar->addCollector($timeDataCollector);
2013-08-15 08:03:41 -04:00
2013-08-13 17:29:44 +10:00
## RequestData
2013-08-13 12:29:40 +10:00
2017-07-21 04:35:58 -07:00
Collects the data of PHP's global variables. You can call the `useHtmlVarDumper()` function to use
VarDumper's interactive HTML dumper for rendering the variables. If you do that, you must properly
render [inline assets ](rendering.html#assets ) when rendering the debug bar in addition to the normal
js/css static assets.
2013-08-13 12:29:40 +10:00
2017-07-21 04:35:58 -07:00
$requestDataCollector = new DebugBar\DataCollector\RequestDataCollector();
$requestDataCollector->useHtmlVarDumper();
$debugbar->addCollector($requestDataCollector);
2013-08-13 12:29:40 +10:00
2013-08-13 17:29:44 +10:00
## Config
2017-07-21 04:35:58 -07:00
Used to display any key/value pairs array. You can call the `useHtmlVarDumper()` function to use
VarDumper's interactive HTML dumper for rendering the variables. If you do that, you must properly
render [inline assets ](rendering.html#assets ) when rendering the debug bar in addition to the normal
js/css static assets.
2013-08-13 17:29:44 +10:00
$data = array('foo' => 'bar');
2017-07-21 04:35:58 -07:00
$configCollector = new DebugBar\DataCollector\ConfigCollector($data);
$configCollector->useHtmlVarDumper();
$debugbar->addCollector($configCollector);
2013-08-13 17:29:44 +10:00
You can provide a different name for this collector in the second argument of the constructor.
2013-08-13 12:29:40 +10:00
## AggregatedCollector
Aggregates multiple collectors. Do not provide any widgets, you have to add your own controls.
$debugbar->addCollector(new DebugBar\DataCollector\AggregatedCollector('all_messages', 'messages', 'time'));
$debugbar['all_messages']->addCollector($debugbar['messages']);
2023-09-19 21:53:10 +02:00
$debugbar['all_messages']->addCollector(new DebugBar\DataCollector\MessagesCollector('mails'));
2013-08-13 12:29:40 +10:00
$debugbar['all_messages']['mails']->addMessage('sending mail');
$renderer = $debugbar->getJavascriptRenderer();
$renderer->addControl('all_messages', array(
'widget' => 'PhpDebugBar.Widgets.MessagesWidget',
'map' => 'all_messages',
2014-05-23 17:36:16 +03:00
'default' => '[]',
2013-08-13 12:29:40 +10:00
));
## Others
Misc collectors which you can just register:
- `MemoryCollector` (*memory*): Display memory usage
- `PhpInfoCollector` (*php*): PHP version number