QueryLogger   A
last analyzed

Complexity

Total Complexity 8

Size/Duplication

Total Lines 63
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 1

Importance

Changes 0
Metric Value
wmc 8
lcom 1
cbo 1
dl 0
loc 63
c 0
b 0
f 0
rs 10

4 Methods

Rating   Name   Duplication   Size   Complexity  
A addResultsInfo() 0 4 1
A getQueriesNumber() 0 13 4
A getInvalidQueriesNumber() 0 4 1
A getTotalTime() 0 11 2
1
<?php
2
3
namespace Kaliop\EzFindSearchEngineBundle\DataCollector\Logger;
4
5
use ezfSearchResultInfo;
6
7
class QueryLogger
8
{
9
    /**
10
     * @var ezfSearchResultInfo[]
11
     */
12
    protected $resultsInfo = [];
13
14
    /**
15
     * Add new eZSearchResultInfo into query logger to gather extra data.
16
     *
17
     * @param ezfSearchResultInfo $resultInfo
18
     */
19
    public function addResultsInfo(ezfSearchResultInfo $resultInfo)
20
    {
21
        $this->resultsInfo[] = $resultInfo;
22
    }
23
24
    /**
25
     * Get number of successful SOLR queries.
26
     *
27
     * @return int
28
     */
29
    public function getQueriesNumber()
30
    {
31
        $validCalls = 0;
32
33
        foreach ($this->resultsInfo as $resultInfo) {
34
            $responseHeader = $resultInfo->attribute('responseHeader');
35
            if (isset($responseHeader['status']) && $responseHeader['status'] == 0) {
36
                $validCalls++;
37
            }
38
39
        }
40
        return $validCalls;
41
    }
42
43
    /**
44
     * Get number of invalid SOLR queries.
45
     *
46
     * @return int
47
     */
48
    public function getInvalidQueriesNumber()
49
    {
50
        return (count($this->resultsInfo) - $this->getQueriesNumber());
51
    }
52
53
    /**
54
     * Get total time in milliseconds of all SOLR queries made.
55
     *
56
     * @return int
57
     */
58
    public function getTotalTime()
59
    {
60
        $totalTime = 0;
61
62
        foreach ($this->resultsInfo as $resultInfo) {
63
            $responseHeader = $resultInfo->attribute('responseHeader');
64
            $totalTime += intval($responseHeader['QTime']);
65
        }
66
67
        return $totalTime;
68
    }
69
}