-
Notifications
You must be signed in to change notification settings - Fork 2
/
zabbix_chart.php
128 lines (108 loc) · 4.72 KB
/
zabbix_chart.php
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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
<?php
/*
** Zabbix
** Copyright (C) 2001-2014 Zabbix SIA
**
** This program is free software; you can redistribute it and/or modify
** it under the terms of the GNU General Public License as published by
** the Free Software Foundation; either version 2 of the License, or
** (at your option) any later version.
**
** This program is distributed in the hope that it will be useful,
** but WITHOUT ANY WARRANTY; without even the implied warranty of
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
** GNU General Public License for more details.
**
** You should have received a copy of the GNU General Public License
** along with this program; if not, write to the Free Software
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
**/
require_once dirname(__FILE__) . '/include/config.inc.php';
require_once dirname(__FILE__) . '/include/graphs.inc.php';
$page['file'] = 'chart2.php';
$page['type'] = PAGE_TYPE_IMAGE;//PAGE_TYPE_IMAGE;
require_once dirname(__FILE__) . '/include/page_header.php';
// VAR TYPE OPTIONAL FLAGS VALIDATION EXCEPTION
$fields = array(
'graphid' => array(T_ZBX_INT, O_MAND, P_SYS, DB_ID, null),
'period' => array(T_ZBX_INT, O_OPT, P_NZERO, BETWEEN(ZBX_MIN_PERIOD, ZBX_MAX_PERIOD), null),
'stime' => array(T_ZBX_STR, O_OPT, P_SYS, null, null),
'profileIdx' => array(T_ZBX_STR, O_OPT, null, null, null),
'profileIdx2' => array(T_ZBX_STR, O_OPT, null, null, null),
'updateProfile' => array(T_ZBX_STR, O_OPT, null, null, null),
'border' => array(T_ZBX_INT, O_OPT, P_NZERO, IN('0,1'), null),
'width' => array(T_ZBX_INT, O_OPT, P_NZERO, '{}>0', null),
'height' => array(T_ZBX_INT, O_OPT, P_NZERO, '{}>0', null)
);
check_fields($fields);
/*
* Permissions
*/
$dbGraph = API::Graph()->get(array(
'graphids' => $_REQUEST['graphid'],
'output' => API_OUTPUT_EXTEND,
'expandName' => 1
));
// _ex($dbGraph,0);
if (!$dbGraph) {
access_deny();
} else {
$dbGraph = reset($dbGraph);
}
$host = API::Host()->get(array(
'nodeids' => get_current_nodeid(true),
'graphids' => $_REQUEST['graphid'],
'output' => API_OUTPUT_EXTEND,
'templated_hosts' => true
));
$host = reset($host);
/*
* Display
*/
$timeline = CScreenBase::calculateTime(array(
'profileIdx' => get_request('profileIdx', 'web.screens'),
'profileIdx2' => get_request('profileIdx2'),
'updateProfile' => get_request('updateProfile', true),
'period' => get_request('period'),
'stime' => get_request('stime')
));
CProfile::update('web.screens.graphid', $_REQUEST['graphid'], PROFILE_TYPE_ID);
$chartHeader = '';
if (id2nodeid($dbGraph['graphid']) != get_current_nodeid()) {
$chartHeader = get_node_name_by_elid($dbGraph['graphid'], true, NAME_DELIMITER);
}
$chartHeader .= $host['name'] . NAME_DELIMITER . $dbGraph['name'];
$graph = new CLineGraphDraw_Zabbix($dbGraph['graphtype']);
$graph->setHeader($chartHeader);
$graph->setPeriod($timeline['period']);
$graph->setSTime($timeline['stime']);
if (isset($_REQUEST['border'])) {
$graph->setBorder(0);
}
$width = get_request('width', 0);
if ($width <= 0) {
$width = $dbGraph['width'];
}
$height = get_request('height', 0);
if ($height <= 0) {
$height = $dbGraph['height'];
}
$graph->showLegend($dbGraph['show_legend']);
$graph->showWorkPeriod($dbGraph['show_work_period']);
$graph->showTriggers($dbGraph['show_triggers']);
$graph->setWidth($width);
$graph->setHeight($height);
$graph->setYMinAxisType($dbGraph['ymin_type']);
$graph->setYMaxAxisType($dbGraph['ymax_type']);
$graph->setYAxisMin($dbGraph['yaxismin']);
$graph->setYAxisMax($dbGraph['yaxismax']);
$graph->setYMinItemId($dbGraph['ymin_itemid']);
$graph->setYMaxItemId($dbGraph['ymax_itemid']);
$graph->setLeftPercentage($dbGraph['percent_left']);
$graph->setRightPercentage($dbGraph['percent_right']);
$dbGraphItems = DBselect('SELECT gi.*' . ' FROM graphs_items gi' . ' WHERE gi.graphid=' . zbx_dbstr($dbGraph['graphid']) . ' ORDER BY gi.sortorder,gi.itemid DESC');
while ($dbGraphItem = DBfetch($dbGraphItems)) {
$graph->addItem($dbGraphItem['itemid'], $dbGraphItem['yaxisside'], $dbGraphItem['calc_fnc'], $dbGraphItem['color'], $dbGraphItem['drawtype'], $dbGraphItem['type']);
}
$graph->draw();
require_once dirname(__FILE__) . '/include/page_footer.php';