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
|
<?php
/*
** ZABBIX
** Copyright (C) 2000-2005 SIA Zabbix
**
** 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., 675 Mass Ave, Cambridge, MA 02139, USA.
**/
?>
<?php
require_once "include/config.inc.php";
$page["title"] = "S_RESOURCE";
$page["file"] = "popup_right.php";
define('ZBX_PAGE_NO_MENU', 1);
include_once "include/page_header.php";
?>
<?php
// VAR TYPE OPTIONAL FLAGS VALIDATION EXCEPTION
$fields=array(
"dstfrm"=> array(T_ZBX_STR, O_MAND,P_SYS, NOT_EMPTY, NULL),
"permission"=> array(T_ZBX_INT, O_MAND,P_SYS, IN(PERM_DENY.','.PERM_READ_ONLY.','.PERM_READ_WRITE), NULL),
'nodeid'=> array(T_ZBX_INT, O_OPT, P_SYS, DB_ID, NULL),
);
check_fields($fields);
$dstfrm = get_request("dstfrm", 0); // destination form
$permission = get_request("permission", PERM_DENY); // right
$nodeid = get_request('nodeid', get_profile('web.popup_right.nodeid.last',get_current_nodeid(false)));
update_profile('web.popup_right.nodeid.last', $nodeid);
?>
<script language="JavaScript" type="text/javascript">
<!--
function add_var_to_opener_obj(obj,name,value){
new_variable = window.opener.document.createElement('input');
new_variable.type = 'hidden';
new_variable.name = name;
new_variable.value = value;
obj.appendChild(new_variable);
}
function add_right(formname,id,permission,name){
var form = window.opener.document.forms[formname];
if(!form){
close_window();
return false;
}
add_var_to_opener_obj(form,'new_right[id]',id);
add_var_to_opener_obj(form,'new_right[permission]',permission);
add_var_to_opener_obj(form,'new_right[name]',name);
form.submit();
close_window();
return true;
}
-->
</script>
<?php
$frmTitle = new CForm();
$frmTitle->AddVar('dstfrm',$dstfrm);
$frmTitle->AddVar('permission', $permission);
if(ZBX_DISTRIBUTED){
$available_nodes = get_accessible_nodes_by_user($USER_DETAILS, PERM_READ_WRITE,PERM_RES_IDS_ARRAY);
$cmbResourceNode = new CComboBox('nodeid',$nodeid,'submit();');
$cmbResourceNode->AddItem(0, S_ALL);
$sql = 'SELECT name,nodeid FROM nodes WHERE '.DBcondition('nodeid',$available_nodes);
$db_nodes = DBselect($sql);
while($node = DBfetch($db_nodes)){
$cmbResourceNode->AddItem($node['nodeid'], $node['name']);
}
$frmTitle->AddItem(array(S_NODE, SPACE, $cmbResourceNode));
}
show_table_header(permission2str($permission),$frmTitle);
$table = new CTableInfo(S_NO_RESOURCES_DEFINED);
$table->SetHeader(array(S_NAME));
$db_resources = null;
$db_resources = DBselect('SELECT n.name as node_name, g.name as name, g.groupid as id'.
' FROM groups g '.
' LEFT JOIN nodes n on '.DBid2nodeid('g.groupid').'=n.nodeid '.
($nodeid?' WHERE nodeid='.$nodeid:'').
' ORDER BY n.name, g.name');
while($db_resource = DBfetch($db_resources)){
if(isset($db_resource['node_name']))
$db_resource['name'] = $db_resource['node_name'].':'.$db_resource['name'];
$name = new CLink($db_resource['name'],'#','action');
$name->SetAction("return add_right('".$dstfrm."','".$db_resource['id']."','".$permission."','".$db_resource['name']."');");
$table->AddRow(array($name));
}
$table->Show();
?>
<?php
include_once "include/page_footer.php";
?>
|