<?php /** * Reporting graphs. * * @category Reporting * @package Pandora FMS * @subpackage Community * @version 1.0.0 * @license See below * * ______ ___ _______ _______ ________ * | __ \.-----.--.--.--| |.-----.----.-----. | ___| | | __| * | __/| _ | | _ || _ | _| _ | | ___| |__ | * |___| |___._|__|__|_____||_____|__| |___._| |___| |__|_|__|_______| * * ============================================================================ * Copyright (c) 2005-2023 Pandora FMS * Please see https://pandorafms.com/community/ for full contribution list * 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 for version 2. * 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. * ============================================================================ */ // Begin. global $config; require_once 'include/functions_custom_graphs.php'; // Check user credentials check_login(); $report_r = check_acl($config['id_user'], 0, 'RR'); $report_w = check_acl($config['id_user'], 0, 'RW'); $report_m = check_acl($config['id_user'], 0, 'RM'); if (!$report_r && !$report_w && !$report_m) { db_pandora_audit( AUDIT_LOG_ACL_VIOLATION, 'Trying to access Inventory Module Management' ); include 'general/noaccess.php'; return; } $access = ($report_r == true) ? 'RR' : (($report_w == true) ? 'RW' : (($report_m == true) ? 'RM' : 'RR')); $activeTab = get_parameter('tab', 'main'); $enterpriseEnable = false; if (enterprise_include_once('include/functions_reporting.php') !== ENTERPRISE_NOT_HOOK) { $enterpriseEnable = true; } $buttons['graph_list'] = [ 'active' => true, 'text' => '<a href="index.php?sec=reporting&sec2=godmode/reporting/graphs">'.html_print_image( 'images/logs@svg.svg', true, [ 'title' => __('Graph list'), 'class' => 'main_menu_icon invert_filter', ] ).'</a>', ]; if ($enterpriseEnable) { $buttons = reporting_enterprise_add_template_graph_tabs($buttons); } $subsection = ''; switch ($activeTab) { case 'main': $buttons['graph_list']['active'] = true; $subsection = ' » '.__('Graph list'); break; default: $subsection = reporting_enterprise_add_graph_template_subsection($activeTab, $buttons); break; } switch ($activeTab) { case 'main': include_once 'godmode/reporting/graphs.php'; break; default: reporting_enterprise_select_graph_template_tab($activeTab); break; } if ($enterpriseEnable) { $buttons['graph_container'] = [ 'active' => false, 'text' => '<a href="index.php?sec=reporting&sec2=godmode/reporting/graph_container">'.html_print_image( 'images/graph-container@svg.svg', true, [ 'title' => __('Graphs containers'), 'class' => 'invert_filter', ] ).'</a>', ]; } $delete_graph = (bool) get_parameter('delete_graph'); $view_graph = (bool) get_parameter('view_graph'); $id = (int) get_parameter('id'); $multiple_delete = (bool) get_parameter('multiple_delete', 0); // Header. ui_print_standard_header( __('List of custom graphs'), 'images/chart.png', false, '', false, $buttons, [ [ 'link' => '', 'label' => __('Reporting'), ], [ 'link' => '', 'label' => __('Custom graphs'), ], ] ); // Delete module SQL code if ($delete_graph) { $graph_group = db_get_value('id_group', 'tgraph', 'id_graph', $id); if (check_acl_restricted_all($config['id_user'], $graph_group, 'RW') || check_acl_restricted_all($config['id_user'], $graph_group, 'RM') ) { $exist = db_get_value('id_graph', 'tgraph_source', 'id_graph', $id); if ($exist) { $result = db_process_sql_delete('tgraph_source', ['id_graph' => $id]); if ($result) { $result = ui_print_success_message(__('Successfully deleted')); } else { $result = ui_print_error_message(__('Not deleted. Error deleting data')); } } $result = db_process_sql_delete('tgraph', ['id_graph' => $id]); $auditMessage = ($result === true) ? 'Delete graph' : 'Fail try to delete graph'; ui_print_result_message( $result, __('Successfully deleted'), __('Not deleted. Error deleting data') ); db_pandora_audit( AUDIT_LOG_REPORT_MANAGEMENT, sprintf('%s #%s', $auditMessage, $id) ); echo $result; } else { db_pandora_audit( AUDIT_LOG_ACL_VIOLATION, 'Trying to delete a graph from access graph builder' ); include 'general/noaccess.php'; exit; } } if ($multiple_delete) { $ids = (array) get_parameter('delete_multiple', []); foreach ($ids as $id) { $result = db_process_sql_delete( 'tgraph', ['id_graph' => $id] ); if ($result === false) { break; } } if ($result !== false) { $result = true; } else { $result = false; } $auditMessage = ($result === true) ? 'Multiple delete graph' : 'Fail try to delete graphs'; $str_ids = implode(',', $ids); db_pandora_audit( AUDIT_LOG_REPORT_MANAGEMENT, sprintf('%s: %s', $auditMessage, $str_ids) ); ui_print_result_message( $result, __('Successfully deleted'), __('Not deleted. Error deleting data') ); } $id_group = (int) get_parameter('id_group', 0); $search = trim(get_parameter('search', '')); $graphs = custom_graphs_get_user($config['id_user'], false, true, $access); $offset = (int) get_parameter('offset'); $table_aux = new stdClass(); $table_aux->width = '100%'; if (is_metaconsole() === true) { $table_aux->class = 'databox filters'; $table_aux->cellpadding = 0; $table_aux->cellspacing = 0; $table_aux->colspan[0][0] = 4; $table_aux->data[0][0] = '<b>'.__('Group').'</b>'; $table_aux->data[0][1] = html_print_select_groups(false, $access, true, 'id_group', $id_group, '', '', '', true, false, true, '', false, '', false, false, 'id_grupo', $strict_user).'<br>'; $table_aux->data[0][2] = '<b>'.__('Free text for search: ').ui_print_help_tip( __('Search by report name or description, list matches.'), true ).'</b>'; $table_aux->data[0][3] = html_print_input_text('search', $search, '', 30, '', true); $table_aux->data[0][6] = html_print_submit_button(__('Search'), 'search_submit', false, 'class="sub upd"', true); $filter = "<form class ='' action='index.php?sec=reporting&sec2=godmode/reporting/graphs&id_group=$id_group&pure=$pure' method='post'>"; $filter .= html_print_table($table_aux, true); $filter .= '</form>'; ui_toggle($filter, __('Show Option')); } else { $table_aux->class = 'filter-table-adv'; $table_aux->size[0] = '50%'; $table_aux->data[0][0] = html_print_label_input_block( __('Group'), html_print_select_groups( false, $access, true, 'id_group', $id_group, '', '', '', true, false, true, '', false, '', false, false, 'id_grupo', $strict_user ) ); $table_aux->data[0][1] = html_print_label_input_block( __('Free text for search: ').ui_print_help_tip(__('Search by report name or description, list matches.'), true), html_print_input_text('search', $search, '', 30, '', true) ); $searchForm .= '<form action="index.php?sec=reporting&sec2=godmode/reporting/graphs&id_group='.$id_group.'&pure='.$pure.'"method="post">'; $searchForm .= html_print_table($table_aux, true); $searchForm .= html_print_div( [ 'class' => 'action-buttons', 'content' => html_print_submit_button( __('Filter'), 'search_submit', false, [ 'mode' => 'mini', 'icon' => 'search', ], true ), ], true ); $searchForm .= '</form>'; ui_toggle( $searchForm, '<span class="subsection_header_title">'.__('Filters').'</span>', 'filter_form', '', true, false, '', 'white-box-content', 'box-flat white_table_graph fixed_filter_bar' ); } // Show only selected groups. if ($id_group > 0) { $group = ["$id_group" => $id_group]; } else { $group = false; } $own_info = get_user_info($config['id_user']); if ($own_info['is_admin'] || check_acl($config['id_user'], 0, 'RM')) { $return_all_group = true; } else { $return_all_group = false; } if ($search != '') { $filter = [ 'name' => $search_name, 'order' => 'name', ]; } else { $filter = ['order' => 'name']; } // Fix : group filter was not working // Show only selected groups. if ($id_group > 0) { $group = ["$id_group" => $id_group]; $filter['id_group'] = $id_group; } else { $group = false; } // Filter normal and metaconsole reports. if ($config['metaconsole'] == 1 && defined('METACONSOLE')) { $filter['metaconsole'] = 1; } else { $filter['metaconsole'] = 0; } if ($id_group != null || $search != null) { $graphs = custom_graphs_search($id_group, $search); } if (!empty($graphs)) { $table = new stdClass(); $table->width = '100%'; $table->class = 'info_table'; $table->cellpadding = 0; $table->cellspacing = 0; $table->align = []; $table->head = []; $table->head[0] = __('Graph name'); $table->head[1] = __('Description'); $table->head[2] = __('Number of Graphs'); $table->head[3] = __('Group'); $table->size[0] = '30%'; $table->size[2] = '200px'; $table->size[3] = '200px'; $table->align[2] = 'left'; $table->align[3] = 'left'; $op_column = false; if ($report_w || $report_m) { $op_column = true; $table->align[4] = 'left'; $table->head[4] = __('Op.'); $table->size[4] = '90px'; } if ($report_w || $report_m) { $table->align[5] = 'left'; $table->head[5] = html_print_checkbox('all_delete', 0, false, true, false); $table->size[5] = '20px'; } $table->data = []; $result_graphs = array_slice($graphs, $offset, $config['block_size']); foreach ($result_graphs as $graph) { $data = []; $data[0] = '<a href="index.php?sec=reporting&sec2=operation/reporting/graph_viewer&view_graph=1&id='.$graph['id_graph'].'">'.ui_print_truncate_text( $graph['name'], 70 ).'</a>'; $data[1] = ui_print_truncate_text($graph['description'], 70); $data[2] = $graph['graphs_count']; $data[3] = ui_print_group_icon($graph['id_group'], true); $data[4] = ''; $table->cellclass[][4] = 'table_action_buttons'; if (($report_w || $report_m)) { $data[4] = '<a href="index.php?sec=reporting&sec2=godmode/reporting/graph_builder&edit_graph=1&id='.$graph['id_graph'].'">'.html_print_image( 'images/edit.svg', true, ['class' => 'invert_filter main_menu_icon'] ).'</a>'; } $data[5] = ''; if (check_acl_restricted_all($config['id_user'], $graph['id_group'], 'RM')) { $data[4] .= '<a href="index.php?sec=reporting&sec2=godmode/reporting/graphs&delete_graph=1&id='.$graph['id_graph'].'" onClick="if (!confirm(\''.__('Are you sure?').'\')) return false;">'.html_print_image( 'images/delete.svg', true, [ 'alt' => __('Delete'), 'title' => __('Delete'), 'class' => 'invert_filter main_menu_icon', ] ).'</a>'; $data[5] .= html_print_checkbox_extended( 'delete_multiple[]', $graph['id_graph'], false, false, '', [ 'class' => 'check_delete mrgn_lft_2px check_delete', 'form' => 'form_delete', 'data-value' => $graph['id_graph'], ], true ); } array_push($table->data, $data); } if (is_metaconsole() === true) { if (!empty($result_graphs)) { echo "<form method='post' action='index.php?sec=reporting&sec2=godmode/reporting/graphs'>"; html_print_input_hidden('multiple_delete', 1); html_print_table($table); ui_pagination(count($graphs), false, 0, 0, false, 'offset', true, ''); echo "<div class='right'>"; html_print_submit_button(__('Delete'), 'delete_btn', false, 'class="sub delete"'); echo '</form>'; } echo "<div class='right'>"; if ($report_w || $report_m) { echo '<form method="post" class="right" action="index.php?sec=reporting&sec2=godmode/reporting/graph_builder">'; html_print_submit_button(__('Create graph'), 'create', false, 'class="sub next mrgn_right_5px"'); echo '</form>'; } } else { if ($report_w || $report_m) { $ActionButtons[] = '<form method="post" class="right mrgn_lft_10px" action="index.php?sec=reporting&sec2=godmode/reporting/graph_builder">'; $ActionButtons[] = html_print_submit_button( __('Create graph'), 'create', false, [ 'class' => 'sub ok', 'icon' => 'next', ], true ); $ActionButtons[] = '</form>'; } if (!empty($result_graphs)) { $ActionButtons[] = "<form method='post' id='form_delete' action='index.php?sec=reporting&sec2=godmode/reporting/graphs'>"; $ActionButtons[] = html_print_input_hidden('multiple_delete', 1, true); $ActionButtons[] = html_print_submit_button( __('Delete'), 'delete_btn', false, [ 'class' => 'secondary', 'icon' => 'delete', ], true ); $ActionButtons[] = '</form>'; $offset = (int) get_parameter('offset', 0); $block_size = (int) $config['block_size']; $tablePagination = ui_pagination( count($graphs), false, $offset, $block_size, true, 'offset', false ); } // FALTA METER EL PRINT TABLE. html_print_table($table); if (is_metaconsole() === true) { html_print_action_buttons( implode('', $ActionButtons), ['type' => 'form_action'] ); } else { html_print_action_buttons( implode('', $ActionButtons), [ 'type' => 'form_action', 'right_content' => $tablePagination, ] ); } } echo '</div>'; echo '</div>'; } else { include_once $config['homedir'].'/general/first_task/custom_graphs.php'; } ?> <script type="text/javascript"> $( document ).ready(function() { $('[id^=checkbox-delete_multiple]').click(function(){ if($(this).prop("checked") === false ){ $(this).prop("checked", false); } else { $(this).prop("checked", true); } }); $('#checkbox-all_delete').click(function(){ if ($("#checkbox-all_delete").prop("checked") === true) { $("[id^=checkbox-delete_multiple]").prop("checked", true); } else{ $("[id^=checkbox-delete_multiple]").prop("checked", false); } }); }); </script>