QueryLogger::addResultsInfo()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 4

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 4
c 0
b 0
f 0
rs 10
cc 1
nc 1
nop 1
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
}