加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
cdef.php 28.57 KB
一键复制 编辑 原始数据 按行查看 历史
TheWitness 提交于 2021-02-22 20:02 . Update copyrights
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939
<?php
/*
+-------------------------------------------------------------------------+
| Copyright (C) 2004-2021 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/cdef.php');
$cdef_actions = array(
1 => __('Delete'),
2 => __('Duplicate')
);
/* set default action */
set_default_action();
switch (get_request_var('action')) {
case 'save':
form_save();
break;
case 'actions':
form_actions();
break;
case 'item_remove_confirm':
cdef_item_remove_confirm();
break;
case 'item_remove':
cdef_item_remove();
break;
case 'item_movedown':
get_filter_request_var('cdef_id');
item_movedown();
header('Location: cdef.php?action=edit&id=' . get_request_var('cdef_id'));
break;
case 'item_moveup':
get_filter_request_var('cdef_id');
item_moveup();
header('Location: cdef.php?action=edit&id=' . get_request_var('cdef_id'));
break;
case 'item_remove':
get_filter_request_var('cdef_id');
item_remove();
header('Location: cdef.php?action=edit&id=' . get_request_var('cdef_id'));
break;
case 'item_edit':
top_header();
item_edit();
bottom_footer();
break;
case 'edit':
top_header();
cdef_edit();
bottom_footer();
break;
case 'ajax_dnd':
cdef_item_dnd();
break;
default:
top_header();
cdef();
bottom_footer();
break;
}
/* --------------------------
Global Form Functions
-------------------------- */
function draw_cdef_preview($cdef_id) {
?>
<tr class='even'>
<td style='padding:4px'>
<pre>cdef=<?php print html_escape(get_cdef($cdef_id, true));?></pre>
</td>
</tr>
<?php
}
/* --------------------------
The Save Function
-------------------------- */
function form_save() {
// make sure ids are numeric
if (isset_request_var('id') && ! is_numeric(get_filter_request_var('id'))) {
set_request_var('id', 0);
}
if (isset_request_var('cdef_id') && ! is_numeric(get_filter_request_var('cdef_id'))) {
set_request_var('cdef_id', 0);
}
if (isset_request_var('save_component_cdef')) {
$save['id'] = form_input_validate(get_nfilter_request_var('id'), 'id', '^[0-9]+$', false, 3);
$save['hash'] = get_hash_cdef(get_nfilter_request_var('id'));
$save['name'] = form_input_validate(get_nfilter_request_var('name'), 'name', '', false, 3);
$save['system'] = 0;
if (!is_error_message()) {
$cdef_id = sql_save($save, 'cdef');
if ($cdef_id) {
raise_message(1);
} else {
raise_message(2);
}
}
header('Location: cdef.php?action=edit&id=' . (empty($cdef_id) ? get_nfilter_request_var('id') : $cdef_id));
} elseif (isset_request_var('save_component_item')) {
/* ================= input validation ================= */
get_filter_request_var('id');
get_filter_request_var('cdef_id');
get_filter_request_var('type');
/* ==================================================== */
$sequence = get_sequence(get_nfilter_request_var('id'), 'sequence', 'cdef_items', 'cdef_id=' . get_nfilter_request_var('cdef_id'));
$save['id'] = form_input_validate(get_nfilter_request_var('id'), 'id', '^[0-9]+$', false, 3);
$save['hash'] = get_hash_cdef(get_nfilter_request_var('id'), 'cdef_item');
$save['cdef_id'] = form_input_validate(get_nfilter_request_var('cdef_id'), 'cdef_id', '^[0-9]+$', false, 3);
$save['sequence'] = $sequence;
$save['type'] = form_input_validate(get_nfilter_request_var('type'), 'type', '^[0-9]+$', false, 3);
$save['value'] = form_input_validate(get_nfilter_request_var('value'), 'value', '', false, 3);
if (!is_error_message()) {
$cdef_item_id = sql_save($save, 'cdef_items');
if ($cdef_item_id) {
raise_message(1);
} else {
raise_message(2);
}
}
if (is_error_message()) {
header('Location: cdef.php?action=item_edit&cdef_id=' . get_nfilter_request_var('cdef_id') . '&id=' . (empty($cdef_item_id) ? get_nfilter_request_var('id') : $cdef_item_id));
} else {
header('Location: cdef.php?action=edit&id=' . get_nfilter_request_var('cdef_id'));
}
}
}
function duplicate_cdef($_cdef_id, $cdef_title) {
global $fields_cdef_edit;
$cdef = db_fetch_row_prepared('SELECT * FROM cdef WHERE id = ?', array($_cdef_id));
$cdef_items = db_fetch_assoc_prepared('SELECT * FROM cdef_items WHERE cdef_id = ?', array($_cdef_id));
/* substitute the title variable */
$cdef['name'] = str_replace('<cdef_title>', $cdef['name'], $cdef_title);
/* create new entry: host_template */
$save['id'] = 0;
$save['hash'] = get_hash_cdef(0);
foreach ($fields_cdef_edit as $field => $array) {
if (!preg_match('/^hidden/', $array['method'])) {
$save[$field] = $cdef[$field];
}
}
$cdef_id = sql_save($save, 'cdef');
/* create new entry(s): cdef_items */
if (cacti_sizeof($cdef_items) > 0) {
foreach ($cdef_items as $cdef_item) {
unset($save);
$save['id'] = 0;
$save['hash'] = get_hash_cdef(0, 'cdef_item');
$save['cdef_id'] = $cdef_id;
$save['sequence'] = $cdef_item['sequence'];
$save['type'] = $cdef_item['type'];
$save['value'] = $cdef_item['value'];
sql_save($save, 'cdef_items');
}
}
}
/* ------------------------
The 'actions' function
------------------------ */
function form_actions() {
global $cdef_actions;
/* ================= input validation ================= */
get_filter_request_var('drp_action', FILTER_VALIDATE_REGEXP, array('options' => array('regexp' => '/^([a-zA-Z0-9_]+)$/')));
/* ==================================================== */
/* 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 */
db_execute('DELETE FROM cdef WHERE ' . array_to_sql_or($selected_items, 'id'));
db_execute('DELETE FROM cdef_items WHERE ' . array_to_sql_or($selected_items, 'cdef_id'));
} elseif (get_nfilter_request_var('drp_action') == '2') { /* duplicate */
for ($i=0;($i<cacti_count($selected_items));$i++) {
duplicate_cdef($selected_items[$i], get_nfilter_request_var('title_format'));
}
}
}
header('Location: cdef.php');
exit;
}
/* setup some variables */
$cdef_list = ''; $i = 0;
/* 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]);
/* ==================================================== */
$cdef_list .= '<li>' . html_escape(db_fetch_cell_prepared('SELECT name FROM cdef WHERE id = ?', array($matches[1]))) . '</li>';
$cdef_array[$i] = $matches[1];
$i++;
}
}
top_header();
form_start('cdef.php');
html_start_box($cdef_actions[get_nfilter_request_var('drp_action')], '60%', '', '3', 'center', '');
if (isset($cdef_array) && cacti_sizeof($cdef_array)) {
if (get_nfilter_request_var('drp_action') == '1') { /* delete */
print "<tr>
<td class='textArea'>
<p>" . __n('Click \'Continue\' to delete the following CDEF.', 'Click \'Continue\' to delete all following CDEFs.', cacti_sizeof($cdef_array)) . "</p>
<div class='itemlist'><ul>$cdef_list</ul></div>
</td>
</tr>\n";
$save_html = "<input type='button' class='ui-button ui-corner-all ui-widget' value='" . __esc('Cancel') . "' onClick='cactiReturnTo()'>&nbsp;<input type='submit' class='ui-button ui-corner-all ui-widget' value='" . __esc('Continue') . "' title='" . __n('Delete CDEF', 'Delete CDEFs', cacti_sizeof($cdef_array)) . "'>";
} elseif (get_nfilter_request_var('drp_action') == '2') { /* duplicate */
print "<tr>
<td class='textArea'>
<p>" . __n('Click \'Continue\' to duplicate the following CDEF. You can optionally change the title format for the new CDEF.', 'Click \'Continue\' to duplicate the following CDEFs. You can optionally change the title format for the new CDEFs.', cacti_sizeof($cdef_array)) . "</p>
<div class='itemlist'><ul>$cdef_list</ul></div>
<p>" . __('Title Format:') . '<br>';
form_text_box('title_format', '<cdef_title> (1)', '', '255', '30', 'text'); print "</p>
</td>
</tr>\n";
$save_html = "<input type='button' class='ui-button ui-corner-all ui-widget' value='" . __esc('Cancel') . "' onClick='cactiReturnTo()'>&nbsp;<input type='submit' class='ui-button ui-corner-all ui-widget' value='" . __esc('Continue') . "' title='" . __n('Duplicate CDEF', 'Duplicate CDEFs', cacti_sizeof($cdef_array)) . "'>";
}
} else {
raise_message(40);
header('Location: cdef.php');
exit;
}
print "<tr>
<td class='saveRow'>
<input type='hidden' name='action' value='actions'>
<input type='hidden' name='selected_items' value='" . (isset($cdef_array) ? serialize($cdef_array) : '') . "'>
<input type='hidden' name='drp_action' value='" . html_escape(get_nfilter_request_var('drp_action')) . "'>
$save_html
</td>
</tr>";
html_end_box();
form_end();
bottom_footer();
}
/* --------------------------
CDEF Item Functions
-------------------------- */
function cdef_item_remove_confirm() {
global $cdef_functions, $cdef_item_types, $custom_cdef_data_source_types;
/* ================= input validation ================= */
get_filter_request_var('id');
get_filter_request_var('cdef_id');
/* ==================================================== */
/* sort the cdef functions */
asort($cdef_functions);
form_start('cdef.php');
html_start_box('', '100%', '', '3', 'center', '');
$cdef = db_fetch_row_prepared('SELECT * FROM cdef WHERE id = ?', array(get_request_var('id')));
$cdef_item = db_fetch_row_prepared('SELECT * FROM cdef_items WHERE id = ?', array(get_request_var('cdef_id')));
?>
<tr>
<td class='topBoxAlt'>
<p><?php print __('Click \'Continue\' to delete the following CDEF Item.');?></p>
<p><?php print __esc('CDEF Name: %s', $cdef['name']);?><br>
<em><?php $cdef_item_type = $cdef_item['type']; print $cdef_item_types[$cdef_item_type];?></em>: <strong><?php print html_escape(get_cdef_item_name($cdef_item['id']));?></strong></p>
</td>
</tr>
<tr>
<td class='right'>
<input type='button' class='ui-button ui-corner-all ui-widget' id='cancel' value='<?php print __esc('Cancel');?>' onClick='$("#cdialog").dialog("close");$(".deleteMarker").blur();' name='cancel'>
<input type='button' class='ui-button ui-corner-all ui-widget' id='continue' value='<?php print __esc('Continue');?>' name='continue' title='<?php print __esc('Remove CDEF Item');?>'>
</td>
</tr>
<?php
html_end_box();
form_end();
}
function cdef_item_remove() {
/* ================= input validation ================= */
get_filter_request_var('cdef_id');
/* ==================================================== */
db_execute_prepared('DELETE FROM cdef_items WHERE id = ?', array(get_request_var('cdef_id')));
}
function item_movedown() {
/* ================= input validation ================= */
get_filter_request_var('id');
get_filter_request_var('cdef_id');
/* ==================================================== */
move_item_down('cdef_items', get_request_var('id'), 'cdef_id=' . get_request_var('cdef_id'));
}
function item_moveup() {
/* ================= input validation ================= */
get_filter_request_var('id');
get_filter_request_var('cdef_id');
/* ==================================================== */
move_item_up('cdef_items', get_request_var('id'), 'cdef_id=' . get_request_var('cdef_id'));
}
function item_remove() {
/* ================= input validation ================= */
get_filter_request_var('id');
get_filter_request_var('cdef_id');
/* ==================================================== */
db_execute_prepared('DELETE FROM cdef_items WHERE id = ?', array(get_request_var('id')));
}
function item_edit() {
global $cdef_item_types, $cdef_functions, $cdef_operators, $custom_data_source_types;
/* ================= input validation ================= */
get_filter_request_var('id');
get_filter_request_var('cdef_id');
/* ==================================================== */
/* sort the cdef functions */
asort($cdef_functions);
if (!isempty_request_var('id')) {
$cdef = db_fetch_row_prepared('SELECT *
FROM cdef_items
WHERE id = ?',
array(get_request_var('id')));
if (cacti_sizeof($cdef)) {
$current_type = $cdef['type'];
$values[$current_type] = $cdef['value'];
}
} else {
$cdef = array();
}
html_start_box(__('CDEF Preview'), '100%', '', '3', 'center', '');
draw_cdef_preview(get_request_var('cdef_id'));
html_end_box();
form_start('cdef.php', 'chk');
$cdef_name = db_fetch_cell_prepared('SELECT name
FROM cdef
WHERE id = ?',
array(get_request_var('cdef_id')));
html_start_box(__esc('CDEF Items [edit: %s]', $cdef_name), '100%', '', '3', 'center', '');
if (isset_request_var('type_select')) {
$current_type = get_request_var('type_select');
} elseif (isset($cdef['type'])) {
$current_type = $cdef['type'];
} else {
$current_type = '1';
}
$form_cdef = array(
'type_select' => array(
'method' => 'drop_array',
'friendly_name' => __('CDEF Item Type'),
'description' => __('Choose what type of CDEF item this is.'),
'value' => $current_type,
'array' => $cdef_item_types
),
'value' => array(
'method' => 'drop_array',
'friendly_name' => __('CDEF Item Value'),
'description' => __('Enter a value for this CDEF item.'),
'value' => (isset($cdef['value']) ? $cdef['value']:'')
),
'id' => array(
'method' => 'hidden',
'value' => isset_request_var('id') ? get_request_var('id') : '0',
),
'type' => array(
'method' => 'hidden',
'value' => $current_type
),
'cdef_id' => array(
'method' => 'hidden',
'value' => get_request_var('cdef_id')
),
'save_component_item' => array(
'method' => 'hidden',
'value' => '1'
)
);
switch ($current_type) {
case '1':
$form_cdef['value']['array'] = $cdef_functions;
break;
case '2':
$form_cdef['value']['array'] = $cdef_operators;
break;
case '4':
$form_cdef['value']['array'] = $custom_data_source_types;
break;
case '5':
$form_cdef['value']['method'] = 'drop_sql';
$form_cdef['value']['sql'] = 'SELECT name, id FROM cdef WHERE `system` = 0 ORDER BY name';
break;
case '6':
$form_cdef['value']['method'] = 'textbox';
$form_cdef['value']['max_length'] = '255';
$form_cdef['value']['size'] = '30';
break;
}
draw_edit_form(
array(
'config' => array('no_form_tag' => true),
'fields' => inject_form_variables($form_cdef, $cdef)
)
);
?>
<script type='text/javascript'>
$(function() {
$('#type_select').off('change').on('change', function() {
strURL = 'cdef.php?action=item_edit';
strURL += '&id=' + $('#id').val();
strURL += '&cdef_id=' + $('#cdef_id').val();
strURL += '&type_select=' + $('#type_select').val();
loadUrl({url:strURL})
});
});
</script>
<?php
html_end_box();
form_save_button('cdef.php?action=edit&id=' . get_request_var('cdef_id'));
}
/* ---------------------
CDEF Functions
--------------------- */
function cdef_item_dnd() {
/* ================= Input validation ================= */
get_filter_request_var('id');
/* ================= Input validation ================= */
$continue = true;
if (isset_request_var('cdef_item') && is_array(get_nfilter_request_var('cdef_item'))) {
$cdef_ids = get_nfilter_request_var('cdef_item');
if (cacti_sizeof($cdef_ids)) {
$sequence = 1;
foreach($cdef_ids as $cdef_id) {
$cdef_id = str_replace('line', '', $cdef_id);
input_validate_input_number($cdef_id);
db_execute_prepared('UPDATE cdef_items
SET sequence = ?
WHERE id = ?',
array($sequence, $cdef_id));
$sequence++;
}
}
}
header('Location: cdef.php?action=edit&id=' . get_request_var('id'));
}
function cdef_edit() {
global $cdef_item_types, $fields_cdef_edit;
/* ================= input validation ================= */
get_filter_request_var('id');
/* ==================================================== */
if (!isempty_request_var('id')) {
$cdef = db_fetch_row_prepared('SELECT * FROM cdef WHERE id = ?', array(get_request_var('id')));
$header_label = __esc('CDEF [edit: %s]', $cdef['name']);
} else {
$header_label = __('CDEF [new]');
}
form_start('cdef.php', 'cdef');
html_start_box($header_label, '100%', true, '3', 'center', '');
draw_edit_form(
array(
'config' => array('no_form_tag' => true),
'fields' => inject_form_variables($fields_cdef_edit, (isset($cdef) ? $cdef : array()))
)
);
html_end_box(true, true);
if (!isempty_request_var('id')) {
html_start_box('', '100%', '', '3', 'center', '');
draw_cdef_preview(get_request_var('id'));
html_end_box();
html_start_box(__('CDEF Items'), '100%', '', '3', 'center', 'cdef.php?action=item_edit&cdef_id=' . $cdef['id']);
$display_text = array(
array('display' => __('Item'), 'align' => 'left'),
array('display' => __('Item Value'), 'align' => 'left')
);
html_header($display_text, 2);
$cdef_items = db_fetch_assoc_prepared('SELECT *
FROM cdef_items
WHERE cdef_id = ?
ORDER BY sequence',
array(get_request_var('id')));
$i = 1;
$total_items = cacti_sizeof($cdef_items);
if (cacti_sizeof($cdef_items)) {
foreach ($cdef_items as $cdef_item) {
form_alternate_row('line' . $cdef_item['id'], true, true);?>
<td>
<a class='linkEditMain' href='<?php print html_escape('cdef.php?action=item_edit&id=' . $cdef_item['id'] . '&cdef_id=' . $cdef['id']);?>'><?php print __('Item #%d', $i);?></a>
</td>
<td>
<em><?php $cdef_item_type = $cdef_item['type']; print $cdef_item_types[$cdef_item_type];?></em>: <?php print html_escape(get_cdef_item_name($cdef_item['id']));?>
</td>
<td class='right'>
<?php
if (read_config_option('drag_and_drop') == '') {
if ($i < $total_items && $total_items > 0) {
echo '<a class="pic fa fa-caret-down moveArrow" href="' . html_escape('cdef.php?action=item_movedown&id=' . $cdef_item['id'] . '&cdef_id=' . $cdef_item['cdef_id']) . '" title="' . __esc('Move Down') . '"></a>';
} else {
echo '<span class="moveArrowNone"></span>';
}
if ($i > 1 && $i <= $total_items) {
echo '<a class="pic fa fa-caret-up moveArrow" href="' . html_escape('cdef.php?action=item_moveup&id=' . $cdef_item['id'] . '&cdef_id=' . $cdef_item['cdef_id']) . '" title="' . __esc('Move Up') . '"></a>';
} else {
echo '<span class="moveArrowNone"></span>';
}
}
?>
<a id='<?php print $cdef['id'] . '_' . $cdef_item['id'];?>' class='delete deleteMarker fa fa-times' title='<?php print __esc('Delete');?>' href='#'></a>
</td>
</tr>
<?php
$i++;
}
}
html_end_box();
}
form_save_button('cdef.php', 'return');
?>
<script type='text/javascript'>
$(function() {
$('#cdef_edit3').find('.cactiTable').attr('id', 'cdef_item');
$('.cdialog').remove();
$('#main').append("<div class='cdialog' id='cdialog'></div>");
<?php if (read_config_option('drag_and_drop') == 'on') { ?>
$('#cdef_item').tableDnD({
onDrop: function(table, row) {
loadUrl({url:'cdef.php?action=ajax_dnd&id=<?php isset_request_var('id') ? print get_request_var('id') : print 0;?>&'+$.tableDnD.serialize()})
}
});
<?php } ?>
$('.delete').click(function(event) {
event.preventDefault();
id = $(this).attr('id').split('_');
request = 'cdef.php?action=item_remove_confirm&id='+id[0]+'&cdef_id='+id[1];
$.get(request)
.done(function(data) {
$('#cdialog').html(data);
applySkin();
$('#continue').off('click').on('click', function(data) {
var options = {
url:'cdef.php?action=item_remove',
funcEnd: 'removeCdefItemFinalize'
}
var data = {
__csrf_magic: csrfMagicToken,
cdef_id: id[1],
id: id[0]
}
postUrl(options, data);
});
$('#cdialog').dialog({
title: '<?php print __('Delete CDEF Item');?>',
minHeight: 80,
minWidth: 500
});
})
.fail(function(data) {
getPresentHTTPError(data);
});
});
});
function removeCdefItemFinalize(data) {
$('#cdialog').dialog('close');
$('.deleteMarker').blur();
loadUrl({url:'cdef.php?action=edit&id=<?php print get_request_var('id');?>'})
};
</script>
<?php
}
function cdef() {
global $cdef_actions, $item_rows;
/* ================= 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_DEFAULT,
'pageset' => true,
'default' => ''
),
'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_cdef');
/* ================= input validation ================= */
if (get_request_var('rows') == '-1') {
$rows = read_config_option('num_rows_table');
} else {
$rows = get_request_var('rows');
}
html_start_box(__('CDEFs'), '100%', '', '3', 'center', 'cdef.php?action=edit');
?>
<tr class='even'>
<td>
<form id='form_cdef' action='cdef.php'>
<table class='filterTable'>
<tr>
<td>
<?php print __('Search');?>
</td>
<td>
<input type='text' class='ui-state-default ui-corner-all' id='filter' name='filter' size='25' value='<?php print html_escape_request_var('filter');?>'>
</td>
<td>
<?php print __('CDEFs');?>
</td>
<td>
<select id='rows' name='rows' onChange='applyFilter()'>
<option value='-1'<?php print (get_request_var('rows') == '-1' ? ' selected>':'>') . __('Default');?></option>
<?php
if (cacti_sizeof($item_rows) > 0) {
foreach ($item_rows as $key => $value) {
print "<option value='" . $key . "'"; if (get_request_var('rows') == $key) { print ' selected'; } print '>' . html_escape($value) . "</option>\n";
}
}
?>
</select>
</td>
<td>
<span>
<input type='checkbox' id='has_graphs' <?php print (get_request_var('has_graphs') == 'true' ? 'checked':'');?>>
<label for='has_graphs'><?php print __('Has Graphs');?></label>
</span>
</td>
<td>
<span>
<input type='button' class='ui-button ui-corner-all ui-widget' id='refresh' value='<?php print __esc('Go');?>' title='<?php print __esc('Set/Refresh Filters');?>'>
<input type='button' class='ui-button ui-corner-all ui-widget' id='clear' value='<?php print __esc('Clear');?>' title='<?php print __esc('Clear Filters');?>'>
</span>
</td>
</tr>
</table>
</form>
<script type='text/javascript'>
function applyFilter() {
strURL = 'cdef.php';
strURL += '?filter='+$('#filter').val();
strURL += '&rows='+$('#rows').val();
strURL += '&has_graphs='+$('#has_graphs').is(':checked');
loadUrl({url:strURL})
}
function clearFilter() {
strURL = 'cdef.php?clear=1';
loadUrl({url:strURL})
}
$(function() {
$('#refresh').click(function() {
applyFilter();
});
$('#has_graphs').click(function() {
applyFilter();
});
$('#clear').click(function() {
clearFilter();
});
$('#form_cdef').submit(function(event) {
event.preventDefault();
applyFilter();
});
});
</script>
</td>
</tr>
<?php
html_end_box();
/* form the 'where' clause for our main sql query */
if (get_request_var('filter') != '') {
$sql_where = 'WHERE (name LIKE ' . db_qstr('%' . get_request_var('filter') . '%') . ' AND `system` = 0)';
} else {
$sql_where = 'WHERE `system` = 0';
}
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 cd.id AS `rows`,
SUM(CASE WHEN local_graph_id>0 THEN 1 ELSE 0 END) AS graphs
FROM cdef AS cd
LEFT JOIN (
SELECT DISTINCT cdef_id, local_graph_id, graph_template_id
FROM graph_templates_item
) AS gti
ON gti.cdef_id=cd.id
$sql_where
GROUP BY cd.id
$sql_having
) AS rs");
$sql_order = get_order_string();
$sql_limit = ' LIMIT ' . ($rows*(get_request_var('page')-1)) . ',' . $rows;
$cdef_list = 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 cd.*, gti.local_graph_id
FROM cdef AS cd
LEFT JOIN (
SELECT DISTINCT cdef_id, local_graph_id, graph_template_id
FROM graph_templates_item
) AS gti
ON gti.cdef_id=cd.id
WHERE `system` = 0
GROUP BY cd.id, gti.graph_template_id, gti.local_graph_id
) AS rs
$sql_where
GROUP BY rs.id
$sql_having
$sql_order
$sql_limit");
$nav = html_nav_bar('cdef.php?filter=' . get_request_var('filter'), MAX_DISPLAY_PAGES, get_request_var('page'), $rows, $total_rows, 5, __('CDEFs'), 'page', 'main');
form_start('cdef.php', 'chk');
print $nav;
html_start_box('', '100%', '', '3', 'center', '');
$display_text = array(
'name' => array('display' => __('CDEF Name'), 'align' => 'left', 'sort' => 'ASC', 'tip' => __('The name of this CDEF.')),
'nosort' => array('display' => __('Deletable'), 'align' => 'right', 'tip' => __('CDEFs 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' => __('The number of Graphs using this CDEF.')),
'templates' => array('display' => __('Templates Using'), 'align' => 'right', 'sort' => 'DESC', 'tip' => __('The number of Graphs Templates using this CDEF.')));
html_header_sort_checkbox($display_text, get_request_var('sort_column'), get_request_var('sort_direction'), false);
$i = 0;
if (cacti_sizeof($cdef_list)) {
foreach ($cdef_list as $cdef) {
if ($cdef['graphs'] == 0 && $cdef['templates'] == 0) {
$disabled = false;
} else {
$disabled = true;
}
form_alternate_row('line' . $cdef['id'], false, $disabled);
form_selectable_cell(filter_value($cdef['name'], get_request_var('filter'), 'cdef.php?action=edit&id=' . $cdef['id']), $cdef['id']);
form_selectable_cell($disabled ? __('No'):__('Yes'), $cdef['id'], '', 'right');
form_selectable_cell(number_format_i18n($cdef['graphs'], '-1'), $cdef['id'], '', 'right');
form_selectable_cell(number_format_i18n($cdef['templates'], '-1'), $cdef['id'], '', 'right');
form_checkbox_cell($cdef['name'], $cdef['id'], $disabled);
form_end_row();
}
} else {
print "<tr class='tableRow'><td colspan='" . (cacti_sizeof($display_text)+1) . "'><em>" . __('No CDEFs') . "</em></td></tr>\n";
}
html_end_box(false);
if (cacti_sizeof($cdef_list)) {
print $nav;
}
/* draw the dropdown containing a list of available actions for this form */
draw_actions_dropdown($cdef_actions);
form_end();
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化