summaryrefslogtreecommitdiffstats
path: root/modules/monitoring/application/views/helpers/CheckPerformance.php
blob: feac4d864a8d8e027e930ffbc5fa3fb9407f989a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
<?php
/* Icinga Web 2 | (c) 2013 Icinga Development Team | GPLv2+ */

/**
 * Convert check summary data into a simple usable stdClass
 */
class Zend_View_Helper_CheckPerformance extends Zend_View_Helper_Abstract
{
    /**
     * Create dispatch instance
     *
     * @return $this
     */
    public function checkPerformance()
    {
        return $this;
    }

    /**
     * Create a condensed row of object data
     *
     * @param   array $results      Array of stdClass
     *
     * @return  stdClass            Condensed row
     */
    public function create(array $results)
    {
        $out = new stdClass();
        $out->host_passive_count = 0;
        $out->host_passive_latency_avg = 0;
        $out->host_passive_execution_avg = 0;
        $out->service_passive_count = 0;
        $out->service_passive_latency_avg = 0;
        $out->service_passive_execution_avg = 0;
        $out->service_active_count = 0;
        $out->service_active_latency_avg = 0;
        $out->service_active_execution_avg = 0;
        $out->host_active_count = 0;
        $out->host_active_latency_avg = 0;
        $out->host_active_execution_avg = 0;

        foreach ($results as $row) {
            $key = $row->object_type . '_' . $row->check_type . '_';
            $out->{$key . 'count'} = $row->object_count;
            $out->{$key . 'latency_avg'} = $row->latency / $row->object_count;
            $out->{$key . 'execution_avg'} = $row->execution_time / $row->object_count;
        }
        return $out;
    }
}