61 lines
1.3 KiB
PHP
61 lines
1.3 KiB
PHP
<?php
|
|
|
|
namespace FOS\ElasticaBundle\DataCollector;
|
|
|
|
use FOS\ElasticaBundle\Logger\ElasticaLogger;
|
|
use Symfony\Component\HttpKernel\DataCollector\DataCollector;
|
|
use Symfony\Component\HttpFoundation\Request;
|
|
use Symfony\Component\HttpFoundation\Response;
|
|
|
|
/**
|
|
* Data collector collecting elastica statistics.
|
|
*
|
|
* @author Gordon Franke <info@nevalon.de>
|
|
*/
|
|
class ElasticaDataCollector extends DataCollector
|
|
{
|
|
protected $logger;
|
|
|
|
public function __construct(ElasticaLogger $logger)
|
|
{
|
|
$this->logger = $logger;
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function collect(Request $request, Response $response, \Exception $exception = null)
|
|
{
|
|
$this->data['nb_queries'] = $this->logger->getNbQueries();
|
|
$this->data['queries'] = $this->logger->getQueries();
|
|
}
|
|
|
|
public function getQueryCount()
|
|
{
|
|
return $this->data['nb_queries'];
|
|
}
|
|
|
|
public function getQueries()
|
|
{
|
|
return $this->data['queries'];
|
|
}
|
|
|
|
public function getTime()
|
|
{
|
|
$time = 0;
|
|
foreach ($this->data['queries'] as $query) {
|
|
$time += $query['executionMS'];
|
|
}
|
|
|
|
return $time;
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function getName()
|
|
{
|
|
return 'elastica';
|
|
}
|
|
}
|