mirror of
https://github.com/pandorafms/pandorafms.git
synced 2025-09-26 11:29:12 +02:00
* include/functions_ui.php: Added require_css_file(), require_javascript_file() and require_jquery_file() to add CSS, javascript and jQuery files to the header easily without changing config object. A path parameter is addded to allow the use on enterprise code. * include/functions_db.php: Added get_db_value_filter(), get_db_all_rows_filter() and process_sql_delete(). Fixed delete_agent() style and use these functions. Added process_page_head() from functions_ui.php and changed a bit the config javascript object part. * include/functions_custom_graphs.php: Get results indexed by id on get_user_custom_graphs(). * include/functions.php: Moved process_page_head to functions_ui.php. * godmode/agentes/manage_delete.php: New interface to perform massive agents deletion. * godmode/menu.php: Added new option to massive agents deletion. * general/main_menu.php, godmode/agentes/manage_config.php, godmode/agentes/module_manager_editor.php, godmode/agentes/planned_downtime.php, godmode/alerts/alert_compounds.php, godmode/alerts/alert_list.php, godmode/alerts/configure_alert_compound.php, godmode/alerts/configure_alert_template.php, godmode/reporting/map_builder.php, operation/agentes/networkmap.php, operation/reporting/reporting_viewer.php, operation/visual_console/render_view.php: Use new functions in include CSS and javascript files. * index.php: Bit of style when printing the header so the HTML can be readed easily in a editor. * include/javascript/pandora.js: Added a variable to determine the enterprise directory. * include/styles/pandora.css: Added style for manage_delete.php git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1467 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
116 lines
3.5 KiB
PHP
116 lines
3.5 KiB
PHP
<?php
|
|
|
|
// Pandora FMS - the Flexible Monitoring System
|
|
// ============================================
|
|
// Copyright (c) 2008 Artica Soluciones Tecnologicas, http://www.artica.es
|
|
// Please see http://pandora.sourceforge.net for full contribution list
|
|
|
|
// This program is free software; you can redistribute it and/or
|
|
// modify it under the terms of the GNU Lesser General Public License (LGPL)
|
|
// 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.
|
|
// 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.
|
|
|
|
/**
|
|
* Get all the custom graphs a user can see.
|
|
*
|
|
* @param $id_user User id to check.
|
|
* @param $only_names Wheter to return only graphs names in an associative array
|
|
* or all the values.
|
|
*
|
|
* @return Custom graphs of a an user. Empty array if none.
|
|
*/
|
|
function get_user_custom_graphs ($id_user = 0, $only_names = false) {
|
|
global $config;
|
|
|
|
if (!$id_user) {
|
|
$id_user = $config['id_user'];
|
|
}
|
|
|
|
$all_graphs = get_db_all_rows_in_table ('tgraph', 'name');
|
|
if ($all_graphs === false)
|
|
return array ();
|
|
|
|
$graphs = array ();
|
|
foreach ($all_graphs as $graph) {
|
|
if ($graph["id_user"] != $id_user && $graph['private'])
|
|
continue;
|
|
|
|
if ($only_names) {
|
|
$graphs[$graph['id_graph']] = $graph['name'];
|
|
} else {
|
|
$graphs[$graph['id_graph']] = $graph;
|
|
}
|
|
}
|
|
|
|
return $graphs;
|
|
}
|
|
|
|
/**
|
|
* Print a custom graph image.
|
|
*
|
|
* @param $id_graph Graph id to print.
|
|
* @param $height Height of the returning image.
|
|
* @param $width Width of the returning image.
|
|
* @param $period Period of time to get data in seconds.
|
|
* @param $stacked Wheter the graph is stacked or not.
|
|
* @param $return Whether to return an output string or echo now (optional, echo by default).
|
|
*/
|
|
function print_custom_graph ($id_graph, $height, $width, $period, $stacked, $return = false) {
|
|
global $config;
|
|
|
|
$sources = get_db_all_rows_field_filter ('tgraph_source', 'id_graph', $id_graph);
|
|
$modules = array ();
|
|
$weights = array ();
|
|
foreach ($sources as $source) {
|
|
$sql = sprintf ("SELECT id_grupo
|
|
FROM tagente, tagente_modulo
|
|
WHERE tagente_modulo.id_agente_modulo = %d
|
|
AND tagente.id_agente = tagente_modulo.id_agente",
|
|
$source['id_agent_module']);
|
|
$id_group = get_db_sql ($sql);
|
|
if (! give_acl ($config["id_user"], $id_group, 'AR'))
|
|
continue;
|
|
array_push ($modules, $source['id_agent_module']);
|
|
array_push ($weights, $source['weight']);
|
|
}
|
|
$modules = implode (',', $modules);
|
|
$weights = implode (',', $weights);
|
|
|
|
$output = '<img src="reporting/fgraph.php?tipo=combined&height='.$height.'&width='.$width.'&id='.$modules.'&period='.$period.'&weight_l='.$weights.'&stacked='.$stacked.'">';
|
|
|
|
if ($return)
|
|
return $output;
|
|
echo $output;
|
|
}
|
|
|
|
/**
|
|
* Get all the possible periods in a custom graph.
|
|
*
|
|
* @return The possible periods in a custom graph in an associative array.
|
|
*/
|
|
function get_custom_graph_periods () {
|
|
$periods = array ();
|
|
|
|
$periods[1] = __('1 hour');
|
|
$periods[2] = '2 '.__('hours');
|
|
$periods[3] = '3 '.__('hours');
|
|
$periods[6] = '6 '.__('hours');
|
|
$periods[12] = '12 '.__('hours');
|
|
$periods[24] = __('1 day');
|
|
$periods[48] = __('2 days');
|
|
$periods[360] = __('1 week');
|
|
$periods[720] = __('1 month');
|
|
$periods[4320] = __('6 months');
|
|
|
|
return $periods;
|
|
}
|
|
|
|
?>
|