File: CheckPerformance.php

package info (click to toggle)
icingaweb2 2.12.6-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 15,124 kB
  • sloc: php: 73,980; javascript: 5,009; sql: 333; xml: 75; sh: 72; makefile: 5
file content (50 lines) | stat: -rw-r--r-- 1,517 bytes parent folder | download | duplicates (6)
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;
    }
}