/*
+-------------------------------------------------------------------------+
| Copyright (C) 2004-2017 The Cacti Group |
| |
| 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. |
+-------------------------------------------------------------------------+
| Cacti: The Complete RRDTool-based Graphing Solution |
+-------------------------------------------------------------------------+
| This code is designed, written, and maintained by the Cacti Group. See |
| about.php and/or the AUTHORS file for specific developer information. |
+-------------------------------------------------------------------------+
| http://www.cacti.net/ |
+-------------------------------------------------------------------------+
*/
include('./include/auth.php');
include_once('./lib/vdef.php');
$vdef_actions = array(
'1' => __('Delete'),
'2' => __('Duplicate')
);
set_default_action();
switch (get_request_var('action')) {
case 'save':
vdef_form_save();
break;
case 'actions':
vdef_form_actions();
break;
case 'item_remove_confirm':
vdef_item_remove_confirm();
break;
case 'item_remove':
vdef_item_remove();
break;
case 'item_movedown':
get_filter_request_var('vdef_id');
item_movedown();
header('Location: vdef.php?header=false&action=edit&id=' . get_request_var('vdef_id'));
break;
case 'item_moveup':
get_filter_request_var('vdef_id');
item_moveup();
header('Location: vdef.php?header=false&action=edit&id=' . get_request_var('vdef_id'));
break;
case 'item_edit':
top_header();
vdef_item_edit();
bottom_footer();
break;
case 'edit':
top_header();
vdef_edit();
bottom_footer();
break;
case 'ajax_dnd':
vdef_item_dnd();
break;
default:
top_header();
vdef();
bottom_footer();
break;
}
/* --------------------------
Global Form Functions
-------------------------- */
function draw_vdef_preview($vdef_id) {
?>
vdef=<?php print get_vdef($vdef_id, true);?>
}
/* --------------------------
The Save Function
-------------------------- */
function vdef_form_save() {
if (isset_request_var('save_component_vdef')) {
$save['id'] = get_filter_request_var('id');
$save['hash'] = get_hash_vdef(get_request_var('id'));
$save['name'] = form_input_validate(get_nfilter_request_var('name'), 'name', '', false, 3);
if (!is_error_message()) {
$vdef_id = sql_save($save, 'vdef');
if ($vdef_id) {
raise_message(1);
} else {
raise_message(2);
}
}
header('Location: vdef.php?action=edit&header=false&id=' . (empty($vdef_id) ? get_request_var('id') : $vdef_id));
} elseif (isset_request_var('save_component_item')) {
$sequence = get_sequence(get_filter_request_var('id'), 'sequence', 'vdef_items', 'vdef_id=' . get_filter_request_var('vdef_id'));
$save['id'] = get_filter_request_var('id');
$save['hash'] = get_hash_vdef(get_request_var('id'), 'vdef_item');
$save['vdef_id'] = get_filter_request_var('vdef_id');
$save['sequence'] = $sequence;
$save['type'] = get_nfilter_request_var('type');
$save['value'] = get_nfilter_request_var('value');
if (!is_error_message()) {
$vdef_item_id = sql_save($save, 'vdef_items');
if ($vdef_item_id) {
raise_message(1);
} else {
raise_message(2);
}
}
if (is_error_message()) {
header('Location: vdef.php?action=item_edit&header=false&vdef_id=' . get_request_var('vdef_id') . '&id=' . (empty($vdef_item_id) ? get_request_var('id') : $vdef_item_id));
} else {
header('Location: vdef.php?action=edit&header=false&id=' . get_request_var('vdef_id'));
}
}
}
function duplicate_vdef($_vdef_id, $vdef_title) {
global $fields_vdef_edit;
$vdef = db_fetch_row_prepared('SELECT * FROM vdef WHERE id = ?', array($_vdef_id));
$vdef_items = db_fetch_assoc_prepared('SELECT * FROM vdef_items WHERE vdef_id = ?', array($_vdef_id));
/* substitute the title variable */
$vdef['name'] = str_replace('', $vdef['name'], $vdef_title);
/* create new entry: device_template */
$save['id'] = 0;
$save['hash'] = get_hash_vdef(0);
$fields_vdef_edit = preset_vdef_form_list();
foreach ($fields_vdef_edit as $field => $array) {
if (!preg_match('/^hidden/', $array['method'])) {
$save[$field] = $vdef[$field];
}
}
$vdef_id = sql_save($save, 'vdef');
/* create new entry(s): vdef_items */
if (sizeof($vdef_items) > 0) {
foreach ($vdef_items as $vdef_item) {
unset($save);
$save['id'] = 0;
$save['hash'] = get_hash_vdef(0, 'vdef_item');
$save['vdef_id'] = $vdef_id;
$save['sequence'] = $vdef_item['sequence'];
$save['type'] = $vdef_item['type'];
$save['value'] = $vdef_item['value'];
sql_save($save, 'vdef_items');
}
}
}
/* ------------------------
The 'actions' function
------------------------ */
function vdef_form_actions() {
global $vdef_actions;
/* if we are to save this form, instead of display it */
if (isset_request_var('selected_items')) {
$selected_items = sanitize_unserialize_selected_items(get_nfilter_request_var('selected_items'));
if ($selected_items != false) {
if (get_nfilter_request_var('drp_action') === '1') { // delete
/* do a referential integrity check */
if (sizeof($selected_items)) {
foreach($selected_items as $vdef_id) {
/* ================= input validation ================= */
input_validate_input_number($vdef_id);
/* ==================================================== */
$vdef_ids[] = $vdef_id;
}
}
if (isset($vdef_ids)) {
db_execute('DELETE FROM vdef WHERE ' . array_to_sql_or($vdef_ids, 'id'));
db_execute('DELETE FROM vdef_items WHERE ' . array_to_sql_or($vdef_ids, 'vdef_id'));
}
} elseif (get_nfilter_request_var('drp_action') === '2') { // duplicate
for ($i=0;($i
/* ================= input validation ================= */
input_validate_input_number($selected_items[$i]);
/* ==================================================== */
duplicate_vdef($selected_items[$i], get_nfilter_request_var('title_format'));
}
}
}
header('Location: vdef.php?header=false');
exit;
}
/* setup some variables */
$vdef_list = '';
/* loop through each of the graphs selected on the previous page and get more info about them */
foreach ($_POST as $var => $val) {
if (preg_match('/^chk_([0-9]+)$/', $var, $matches)) {
/* ================= input validation ================= */
input_validate_input_number($matches[1]);
/* ==================================================== */
$vdef_list .= '
' . db_fetch_cell_prepared('SELECT name FROM vdef WHERE id = ?', array($matches[1])) . '';$vdef_array[] = $matches[1];
}
}
top_header();
form_start('vdef.php', 'vdef_actions');
html_start_box($vdef_actions{get_nfilter_request_var('drp_action')}, '60%', '', '3', 'center', '');
if (isset($vdef_array)) {
if (get_nfilter_request_var('drp_action') === '1') { // delete
print "
" . __n('Click \'Continue\' to delete the following VDEF.', 'Click \'Continue\' to delete following VDEFs.', sizeof($vdef_array)) . "
- $vdef_list
$save_html = " ";
} elseif (get_nfilter_request_var('drp_action') === '2') { // duplicate
print "
" . __n('Click \'Continue\' to duplicate the following VDEF. You can optionally change the title format for the new VDEF.', 'Click \'Continue\' to duplicate following VDEFs. You can optionally change the title format for the new VDEFs.', sizeof($vdef_array)) . "
- $vdef_list
" . __('Title Format:') . "
"; form_text_box("title_format", " (1)", "", "255", "30", "text"); print "
$save_html = " ";
}
} else {
print "
" . __('You must select at least one VDEF.') . "\n";$save_html = "";
}
print "
$save_html
\n";html_end_box();
form_end();
bottom_footer();
}
/* --------------------------
VDEF Item Functions
-------------------------- */
function vdef_item_remove_confirm() {
global $vdef_functions, $vdef_item_types, $custom_vdef_data_source_types;
/* ================= input validation ================= */
get_filter_request_var('id');
get_filter_request_var('vdef_id');
/* ==================================================== */
form_start('vdef.php');
html_start_box('', '100%', '', '3', 'center', '');
$vdef = db_fetch_row_prepared('SELECT * FROM vdef WHERE id = ?', array(get_request_var('id')));
$vdef_item = db_fetch_row_prepared('SELECT * FROM vdef_items WHERE id = ?', array(get_request_var('vdef_id')));
?>
VDEF Name: '<?php print $vdef['name'];?>'
<?php $vdef_item_type = $vdef_item['type']; print $vdef_item_types[$vdef_item_type];?>: <?php print get_vdef_item_name($vdef_item['id']);?>
' onClick='$("#cdialog").dialog("close");' name='cancel'>
' name='continue' title='<?php print __esc('Remove VDEF Item');?>'>
html_end_box();
form_end();
?>
$(function() {
$('#cdialog').dialog();
});
$('#continue').click(function(data) {
$.post('vdef.php?action=item_remove', {
__csrf_magic: csrfMagicToken,
vdef_id: <?php print get_request_var('vdef_id');?>,
id: <?php print get_request_var('id');?>
}, function(data) {
$('#cdialog').dialog('close');
loadPageNoHeader('vdef.php?action=edit&header=false&id=<?php print get_request_var('id');?>');
});
});
}
function vdef_item_remove() {
/* ================= input validation ================= */
get_filter_request_var('vdef_id');
/* ==================================================== */
db_execute_prepared('DELETE FROM vdef_items WHERE id = ?', array(get_request_var('vdef_id')));
}
function vdef_item_edit() {
global $vdef_functions, $vdef_item_types, $custom_vdef_data_source_types;
/* ================= input validation ================= */
get_filter_request_var('id');
get_filter_request_var('vdef_id');
get_filter_request_var('type_select');
/* ==================================================== */
if (!isempty_request_var('id')) {
$vdef = db_fetch_row_prepared('SELECT * FROM vdef_items WHERE id = ?', array(get_request_var('id')));
$current_type = $vdef['type'];
$values[$current_type] = $vdef['value'];
}
html_start_box(__('VDEF Preview'), '100%', '', '3', 'center', '');
draw_vdef_preview(get_request_var('vdef_id'));
html_end_box();
if (!isempty_request_var('vdef_id')) {
$header_label = __('VDEF Items [edit: %s]', db_fetch_cell_prepared('SELECT name FROM vdef WHERE id = ?', array(get_request_var('vdef_id'))) );
}else {
$header_label = __('VDEF Items [new]');
}
form_start('vdef.php', 'form_vdef');
html_start_box($header_label, '100%', '', '3', 'center', '');
if (isset_request_var('type_select')) {
$current_type = get_request_var('type_select');
} elseif (isset($vdef['type'])) {
$current_type = $vdef['type'];
} else {
$current_type = CVDEF_ITEM_TYPE_FUNCTION;
}
form_alternate_row();
print '
' . __('VDEF Item Type') . '' . __('Choose what type of VDEF item this is.') .'';
?>
foreach ($vdef_item_types as $var => $val) {
print "$val\n";
}
?>
$(function() {
$('#type_select').change(function() {
loadPageNoHeader('vdef.php?action=item_edit&header=false&vdef_id=<?php print get_request_var('vdef_id');?>&type_select='+$('#type_select').val())
});
});
form_end_row();
form_alternate_row();
print '
' . __('VDEF Item Value') . '' . __('Enter a value for this VDEF item.') . '';
?>
switch ($current_type) {
case '1':
form_dropdown('value', $vdef_functions, '', '', (isset($vdef['value']) ? $vdef['value'] : ''), '', '');
break;
case '4':
form_dropdown('value', $custom_vdef_data_source_types, '', '', (isset($vdef['value']) ? $vdef['value'] : ''), '', '');
break;
case '6':
form_text_box('value', (isset($vdef['value']) ? $vdef['value'] : ''), '', '255', 30, 'text', (isset_request_var('id') ? get_request_var('id') : '0'));
break;
}
?>
form_end_row();
form_hidden_box('id', (isset_request_var('id') ? get_request_var('id') : '0'), '');
form_hidden_box('type', $current_type, '');
form_hidden_box('vdef_id', get_request_var('vdef_id'), '');
form_hidden_box('save_component_item', '1', '');
html_end_box();
form_save_button('vdef.php?action=edit&id=' . get_request_var('vdef_id'));
}
/* ---------------------
VDEF Functions
--------------------- */
function item_movedown() {
/* ================= input validation ================= */
get_filter_request_var('id');
get_filter_request_var('vdef_id');
/* ==================================================== */
move_item_down('vdef_items', get_request_var('id'), 'vdef_id=' . get_request_var('vdef_id'));
}
function item_moveup() {
/* ================= input validation ================= */
get_filter_request_var('id');
get_filter_request_var('vdef_id');
/* ==================================================== */
move_item_up('vdef_items', get_request_var('id'), 'vdef_id=' . get_request_var('vdef_id'));
}
function vdef_item_dnd() {
/* ================= Input validation ================= */
get_filter_request_var('id');
/* ================= Input validation ================= */
if (!isset_request_var('vdef_item') || !is_array(get_nfilter_request_var('vdef_item'))) exit;
/* vdef table contains one row defined as 'nodrag&nodrop' */
unset($_REQUEST['vdef_item'][0]);
/* delivered vdef ids has to be exactly the same like we have stored */
$old_order = array();
foreach(get_nfilter_request_var('vdef_item') as $sequence => $vdef_id) {
if (empty($vdef_id)) continue;
$new_order[$sequence] = str_replace('line', '', $vdef_id);
}
$vdef_items = db_fetch_assoc_prepared('SELECT id, sequence FROM vdef_items WHERE vdef_id = ?', array(get_request_var('id')));
if(sizeof($vdef_items)) {
foreach($vdef_items as $item) {
$old_order[$item['sequence']] = $item['id'];
}
}else {
exit;
}
if (sizeof(array_diff($new_order, $old_order))>0) exit;
/* the set of sequence numbers has to be the same too */
if (sizeof(array_diff_key($new_order, $old_order))>0) exit;
/* ==================================================== */
foreach($new_order as $sequence => $vdef_id) {
input_validate_input_number($sequence);
input_validate_input_number($vdef_id);
db_execute_prepared('UPDATE vdef_items SET sequence = ? WHERE id = ?', array($sequence, $vdef_id));
}
header('Location: vdef.php?action=edit&header=false&id=' . get_request_var('id'));
}
function vdef_edit() {
global $vdef_item_types;
/* ================= input validation ================= */
get_filter_request_var('id');
/* ==================================================== */
if (!isempty_request_var('id')) {
$vdef = db_fetch_row_prepared('SELECT * FROM vdef WHERE id = ?', array(get_request_var('id')));
$header_label = __('VDEFs [edit: %s]', $vdef['name']);
} else {
$header_label = __('VDEFs [new]');
}
form_start('vdef.php', 'vdef_edit');
html_start_box( $header_label, '100%', true, '3', 'center', '');
$preset_vdef_form_list = preset_vdef_form_list();
draw_edit_form(
array(
'config' => array('no_form_tag' => true),
'fields' => inject_form_variables($preset_vdef_form_list, (isset($vdef) ? $vdef : array()))
)
);
html_end_box(true, true);
form_hidden_box('id', (isset($vdef['id']) ? $vdef['id'] : '0'), '');
form_hidden_box('save_component_vdef', '1', '');
if (!isempty_request_var('id')) {
html_start_box('', '100%', '', '3', 'center', '');
draw_vdef_preview(get_request_var('id'));
html_end_box();
html_start_box('VDEF Items', '100%', '', '3', 'center', 'vdef.php?action=item_edit&vdef_id=' . $vdef['id']);
$header_items = array(
array('display' => __('Item'), 'align' => 'left'),
array('display' => __('Item Value'), 'align' => 'left')
);
html_header($header_items, 2);
$vdef_items = db_fetch_assoc_prepared('SELECT * FROM vdef_items WHERE vdef_id = ? ORDER BY sequence', array(get_request_var('id')));
$i = 1;
$total_items = sizeof($vdef_items);
if (sizeof($vdef_items)) {
foreach ($vdef_items as $vdef_item) {
form_alternate_row('line' . $vdef_item['id'], true, true);
?>
'><?php print __('Item #%d', $i);?>
<?php $vdef_item_type = $vdef_item['type']; print $vdef_item_types[$vdef_item_type];?>: <?php print get_vdef_item_name($vdef_item['id']);?>
if (read_config_option('drag_and_drop') == '') {
if ($i < $total_items && $total_items > 1) {
} else {
echo '';
}
if ($i > 1 && $i <= $total_items) {
} else {
echo '';
}
}
?>
' class='delete deleteMarker fa fa-remove' title='<?php print __esc('Delete VDEF Item');?>'>
form_end_row();
$i++;
}
}
html_end_box();
}
form_save_button('vdef.php', 'return');
?>
$(function() {
$('#vdef_edit3').find('.cactiTable').attr('id', 'vdef_item');
$('.cdialog').remove();
$('body').append("
$('#vdef_item').tableDnD({
onDrop: function(table, row) {
loadPageNoHeader('vdef.php?action=ajax_dnd&id=<?php isset_request_var('id') ? print get_request_var('id') : print 0;?>&'+$.tableDnD.serialize());
}
});
$('.delete').click(function (event) {
event.preventDefault();
id = $(this).attr('id').split('_');
request = 'vdef.php?action=item_remove_confirm&id='+id[0]+'&vdef_id='+id[1];
$.get(request, function(data) {
$('#cdialog').html(data);
applySkin();
$('#cdialog').dialog({ title: '<?php print __esc('Delete VDEF Item');?>', minHeight: 80, minWidth: 500 });
});
}).css('cursor', 'pointer');
});
}
function vdef_filter() {
global $item_rows;
html_start_box( __('VDEFs'), '100%', '', '3', 'center', 'vdef.php?action=edit');
?>
'> | ':'>') . __('Default');?> if (sizeof($item_rows)) { foreach ($item_rows as $key => $value) { print "' . $value . "\n"; } } ?> | > | ' id='refresh'> | ' id='clear'> |
'>
function applyFilter() {
strURL = 'vdef.php?filter='+escape($('#filter').val())+'&rows='+$('#rows').val()+'&page='+$('#page').val()+'&has_graphs='+$('#has_graphs').is(':checked')+'&header=false';
loadPageNoHeader(strURL);
}
function clearFilter() {
strURL = 'vdef.php?clear=1&header=false';
loadPageNoHeader(strURL);
}
$(function() {
$('#refresh').click(function() {
applyFilter();
});
$('#has_graphs').click(function() {
applyFilter();
});
$('#clear').click(function() {
clearFilter();
});
$('#form_vdef').submit(function(event) {
event.preventDefault();
applyFilter();
});
});
html_end_box();
}
function get_vdef_records(&$total_rows, &$rows) {
/* form the 'where' clause for our main sql query */
if (get_request_var('filter') != '') {
$sql_where = "WHERE (rs.name LIKE '%" . get_request_var('filter') . "%')";
} else {
$sql_where = '';
}
if (get_request_var('has_graphs') == 'true') {
$sql_having = 'HAVING graphs>0';
} else {
$sql_having = '';
}
$total_rows = db_fetch_cell("SELECT
COUNT(rows)
FROM (
SELECT vd.id AS rows, vd.name,
SUM(CASE WHEN local_graph_id>0 THEN 1 ELSE 0 END) AS graphs
FROM vdef AS vd
LEFT JOIN graph_templates_item AS gti
ON gti.vdef_id=vd.id
GROUP BY vd.id
) AS rs
$sql_where
$sql_having
");
$sql_order = get_order_string();
$sql_limit = ' LIMIT ' . ($rows*(get_request_var('page')-1)) . ',' . $rows;
return db_fetch_assoc("SELECT rs.*,
SUM(CASE WHEN local_graph_id=0 THEN 1 ELSE 0 END) AS templates,
SUM(CASE WHEN local_graph_id>0 THEN 1 ELSE 0 END) AS graphs
FROM (
SELECT vd.*, gti.local_graph_id
FROM vdef AS vd
LEFT JOIN graph_templates_item AS gti
ON gti.vdef_id=vd.id
GROUP BY vd.id, gti.graph_template_id, gti.local_graph_id
) AS rs
$sql_where
GROUP BY rs.id
$sql_having
$sql_order
$sql_limit");
}
function vdef($refresh = true) {
global $vdef_actions;
/* ================= input validation and session storage ================= */
$filters = array(
'rows' => array(
'filter' => FILTER_VALIDATE_INT,
'pageset' => true,
'default' => '-1'
),
'page' => array(
'filter' => FILTER_VALIDATE_INT,
'default' => '1'
),
'filter' => array(
'filter' => FILTER_CALLBACK,
'pageset' => true,
'default' => '',
'options' => array('options' => 'sanitize_search_string')
),
'sort_column' => array(
'filter' => FILTER_CALLBACK,
'default' => 'name',
'options' => array('options' => 'sanitize_search_string')
),
'sort_direction' => array(
'filter' => FILTER_CALLBACK,
'default' => 'ASC',
'options' => array('options' => 'sanitize_search_string')
),
'has_graphs' => array(
'filter' => FILTER_VALIDATE_REGEXP,
'options' => array('options' => array('regexp' => '(true|false)')),
'pageset' => true,
'default' => read_config_option('default_has') == 'on' ? 'true':'false'
)
);
validate_store_request_vars($filters, 'sess_vdef');
/* ================= input validation ================= */
vdef_filter();
$total_rows = 0;
$vdefs = array();
if (get_request_var('rows') == '-1') {
$rows = read_config_option('num_rows_table');
} else {
$rows = get_request_var('rows');
}
$vdefs = get_vdef_records($total_rows, $rows);
$nav = html_nav_bar('vdef.php?filter=' . get_request_var('filter'), MAX_DISPLAY_PAGES, get_request_var('page'), $rows, $total_rows, 5, __('VDEFs'), 'page', 'main');
form_start('vdef.php', 'chk');
print $nav;
html_start_box('', '100%', '', '3', 'center', '');
$display_text = array(
'name' => array('display' => __('VDEF Name'), 'align' => 'left', 'sort' => 'ASC', 'tip' => __esc('The name of this VDEF.') ),
'nosort' => array('display' => __('Deletable'), 'align' => 'right', 'tip' => __esc('VDEFs that are in use cannot be Deleted. In use is defined as being referenced by a Graph or a Graph Template.') ),
'graphs' => array('display' => __('Graphs Using'), 'align' => 'right', 'sort' => 'DESC', 'tip' => __esc('The number of Graphs using this VDEF.') ),
'templates' => array('display' => __('Templates Using'), 'align' => 'right', 'sort' => 'DESC', 'tip' => __esc('The number of Graphs Templates using this VDEF.') )
);
html_header_sort_checkbox($display_text, get_request_var('sort_column'), get_request_var('sort_direction'), false);
$i = 0;
if (sizeof($vdefs)) {
foreach ($vdefs as $vdef) {
if ($vdef['graphs'] == 0 && $vdef['templates'] == 0) {
$disabled = false;
} else {
$disabled = true;
}
form_alternate_row('line' . $vdef['id'], false, $disabled);
form_selectable_cell(filter_value($vdef['name'], get_request_var('filter'), 'vdef.php?action=edit&id=' . $vdef['id']), $vdef['id']);
form_selectable_cell($disabled ? __('No'):__('Yes'), $vdef['id'], '', 'text-align:right');
form_selectable_cell(number_format_i18n($vdef['graphs'], '-1'), $vdef['id'], '', 'text-align:right');
form_selectable_cell(number_format_i18n($vdef['templates'], '-1'), $vdef['id'], '', 'text-align:right');
form_checkbox_cell($vdef['name'], $vdef['id'], $disabled);
form_end_row();
}
} else {
print "
" . __('No VDEFs') . "\n";}
html_end_box(false);
if (sizeof($vdefs)) {
print $nav;
}
/* draw the dropdown containing a list of available actions for this form */
draw_actions_dropdown($vdef_actions);
form_end();
}
一键复制
编辑
Web IDE
原始数据
按行查看
历史