2009-03-25 Esteban Sanchez <estebans@artica.es>
* include/functions_alerts.php: Finished the alerts API by removing useless and focus of problems clean_*(). All the functions now uses process_sql_*(). * godmode/alerts/alert_actions.php, godmode/alerts/alert_commands.php: Adapted to changes in functions_alerts.php. * godmode/alerts/configure_alert_template.php: Fixed default action updating when it's set to None. Fixed textarea height. * include/functions_reports.php: Added to repository. API to manage user reports. * include/functions_db.php: Moved get_reports() to functions_reports.php. Escape ` on get_db_value(). Use format_array_to_update_sql() on process_sql_update(). * godmode/reporting/reporting_builder.php: Use functions from reports API. git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1560 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
This commit is contained in:
parent
d0d1a5d028
commit
d9445f0b91
|
@ -1,3 +1,26 @@
|
|||
2009-03-25 Esteban Sanchez <estebans@artica.es>
|
||||
|
||||
* include/functions_alerts.php: Finished the alerts API by removing
|
||||
useless and focus of problems clean_*(). All the functions now uses
|
||||
process_sql_*().
|
||||
|
||||
* godmode/alerts/alert_actions.php,
|
||||
godmode/alerts/alert_commands.php: Adapted to changes in
|
||||
functions_alerts.php.
|
||||
|
||||
* godmode/alerts/configure_alert_template.php: Fixed default action
|
||||
updating when it's set to None. Fixed textarea height.
|
||||
|
||||
* include/functions_reports.php: Added to repository. API to manage
|
||||
user reports.
|
||||
|
||||
* include/functions_db.php: Moved get_reports() to
|
||||
functions_reports.php. Escape ` on get_db_value(). Use
|
||||
format_array_to_update_sql() on process_sql_update().
|
||||
|
||||
* godmode/reporting/reporting_builder.php: Use functions from reports
|
||||
API.
|
||||
|
||||
2009-03-25 Esteban Sanchez <estebans@artica.es>
|
||||
|
||||
* include/auth/mysql.php: Fixed an error on get_user_id() which was
|
||||
|
|
|
@ -71,10 +71,13 @@ if ($update_action) {
|
|||
$field2 = (string) get_parameter ('field2');
|
||||
$field3 = (string) get_parameter ('field3');
|
||||
|
||||
$result = update_alert_action ($id, $id_alert_command, $name,
|
||||
array ('field1' => $field1,
|
||||
'field2' => $field2,
|
||||
'field3' => $field3));
|
||||
$values = array ();
|
||||
$values['name'] = $name;
|
||||
$values['id_alert_command'] = $id_alert_command;
|
||||
$values['field1'] = $field1;
|
||||
$values['field2'] = $field2;
|
||||
$values['field3'] = $field3;
|
||||
$result = update_alert_action ($id, $values);
|
||||
|
||||
print_error_message ($result, __('Successfully updated'),
|
||||
__('Could not be updated'));
|
||||
|
|
|
@ -68,8 +68,11 @@ if ($update_command) {
|
|||
$command = (string) get_parameter ('command');
|
||||
$description = (string) get_parameter ('description');
|
||||
|
||||
$result = update_alert_command ($id, $name, $command,
|
||||
array ('description' => $description));
|
||||
$values = array ();
|
||||
$values['name'] = $name;
|
||||
$values['command'] = $command;
|
||||
$values['description'] = $description;
|
||||
$result = update_alert_command ($id, $values);
|
||||
|
||||
print_error_message ($result, __('Successfully updated'),
|
||||
__('Could not be updated'));
|
||||
|
|
|
@ -163,7 +163,7 @@ function update_template ($step) {
|
|||
'time_from' => $time_from,
|
||||
'time_to' => $time_to,
|
||||
'time_threshold' => $threshold,
|
||||
'default_action' => $default_action,
|
||||
'id_alert_action' => $default_action,
|
||||
'field1' => $field1,
|
||||
'field2' => $field2,
|
||||
'field3' => $field3,
|
||||
|
@ -171,10 +171,6 @@ function update_template ($step) {
|
|||
'min_alerts' => $min_alerts
|
||||
);
|
||||
|
||||
if ($default_action) {
|
||||
$values['id_alert_action'] = $default_action;
|
||||
}
|
||||
|
||||
$result = update_alert_template ($id, $values);
|
||||
} elseif ($step == 3) {
|
||||
$recovery_notify = (bool) get_parameter ('recovery_notify');
|
||||
|
@ -300,8 +296,8 @@ print_alert_template_steps ($step, $id);
|
|||
$table->id = 'template';
|
||||
$table->width = '90%';
|
||||
$table->style = array ();
|
||||
$table->style[0] = 'font-weight: bold';
|
||||
$table->style[2] = 'font-weight: bold';
|
||||
$table->style[0] = 'font-weight: bold; vertical-align: top';
|
||||
$table->style[2] = 'font-weight: bold; vertical-align: top';
|
||||
$table->size = array ();
|
||||
$table->size[0] = '20%';
|
||||
$table->size[2] = '20%';
|
||||
|
@ -370,7 +366,7 @@ if ($step == 2) {
|
|||
$table->data['field2'][1] = print_input_text ('field2', $field2, '', 35, 255, true);
|
||||
|
||||
$table->data['field3'][0] = __('Field 3');
|
||||
$table->data['field3'][1] = print_textarea ('field3', 30, 30, $field3, '', true);
|
||||
$table->data['field3'][1] = print_textarea ('field3', 10, 30, $field3, '', true);
|
||||
|
||||
$table->data[4][0] = __('Default action');
|
||||
$table->data[4][1] = print_select_from_sql ('SELECT id, name FROM talert_actions ORDER BY name',
|
||||
|
|
|
@ -23,11 +23,13 @@ check_login ();
|
|||
|
||||
if (! give_acl ($config['id_user'], 0, "AW")) {
|
||||
audit_db ($config['id_user'], $REMOTE_ADDR, "ACL Violation",
|
||||
"Trying to access graph builder");
|
||||
"Trying to access report builder");
|
||||
require ("general/noaccess.php");
|
||||
exit;
|
||||
}
|
||||
|
||||
require_once ("include/functions_reports.php");
|
||||
|
||||
if (is_ajax ()) {
|
||||
$get_report_type_data_source = (bool) get_parameter ('get_report_type_data_source');
|
||||
|
||||
|
@ -57,72 +59,34 @@ $edit_sla_report_content = (bool) get_parameter ('edit_sla_report_content');
|
|||
$content_up = (bool) get_parameter ('content_up');
|
||||
$content_down = (bool) get_parameter ('content_down');
|
||||
|
||||
if (isset($_GET["get_agent"])) {
|
||||
$id_agent = $_POST["id_agent"];
|
||||
}
|
||||
|
||||
// Delete module SQL code
|
||||
if ($delete_report_content) {
|
||||
$id_report_content = (int) get_parameter ('id_report_content');
|
||||
$sql = sprintf ('SELECT `order`
|
||||
FROM treport_content
|
||||
WHERE id_rc = %d',
|
||||
$id_report_content);
|
||||
$order = get_db_sql ($sql);
|
||||
$sql = sprintf ('UPDATE treport_content
|
||||
SET `order` = `order` -1
|
||||
WHERE id_report = %d AND `order` > %d',
|
||||
$id_report, $order);
|
||||
process_sql ($sql);
|
||||
$sql = sprintf ('DELETE FROM treport_content WHERE id_rc = %d', $id_report_content);
|
||||
$result = process_sql ($sql);
|
||||
if ($result !== false) {
|
||||
echo "<h3 class='suc'>".__('Deleted successfully')."</h3>";
|
||||
} else {
|
||||
echo "<h3 class='error'>".__('Not deleted. Error deleting data')."</h3>";
|
||||
}
|
||||
|
||||
$result = delete_report_content ($id_report_content);
|
||||
print_error_message ($result,
|
||||
__('Successfully deleted'),
|
||||
__('Could not be deleted'));
|
||||
}
|
||||
|
||||
// Move content up
|
||||
if ($content_up) {
|
||||
$id_report_content = (int) get_parameter ('id_report_content');
|
||||
$order = get_db_value ('`order`', 'treport_content', 'id_rc', $id_report_content);
|
||||
/* Set the previous element order to the current of the content we want to change */
|
||||
$sql = sprintf ('UPDATE treport_content
|
||||
SET `order` = `order` + 1
|
||||
WHERE id_report = %d
|
||||
AND `order` = %d',
|
||||
$id_report, $order - 1);
|
||||
$result = process_sql ($sql);
|
||||
$sql = sprintf ('UPDATE treport_content
|
||||
SET `order` = `order` - 1
|
||||
WHERE id_rc = %d',
|
||||
$id_report_content);
|
||||
$result = process_sql ($sql);
|
||||
move_report_content_up ($id_report_content, $id_report);
|
||||
}
|
||||
|
||||
// Move content down
|
||||
if ($content_down) {
|
||||
$id_report_content = (int) get_parameter ('id_report_content');
|
||||
$order = get_db_value ('`order`', 'treport_content', 'id_rc', $id_report_content);
|
||||
/* Set the previous element order to the current of the content we want to change */
|
||||
$sql = sprintf ('UPDATE treport_content SET `order` = `order` - 1 WHERE id_report = %d AND `order` = %d',
|
||||
$id_report, $order + 1);
|
||||
$result = process_sql ($sql);
|
||||
$sql = sprintf ('UPDATE treport_content SET `order` = `order` + 1 WHERE id_rc = %d', $id_report_content);
|
||||
$result = process_sql ($sql);
|
||||
move_report_content_down ($id_report_content, $id_report);
|
||||
}
|
||||
|
||||
// Delete report SQL code
|
||||
if ($delete_report) {
|
||||
$sql = sprintf ('DELETE FROM treport_content WHERE id_report = %d', $id_report);
|
||||
$sql2 = sprintf ('DELETE FROM treport WHERE id_report = %d', $id_report);
|
||||
$res = process_sql ($sql);
|
||||
$res2 = process_sql ($sql2);
|
||||
if ($res && $res2)
|
||||
echo "<h3 class=suc>".__('Reporting successfully deleted')."</h3>";
|
||||
else
|
||||
echo "<h3 class=error>".__('There was a problem deleting reporting')."</h3>";
|
||||
$result = delete_report ($id_report);
|
||||
print_error_message ($result,
|
||||
__('Successfully deleted'),
|
||||
__('Could not be deleted'));
|
||||
$id_report = 0;
|
||||
}
|
||||
|
||||
|
@ -136,20 +100,19 @@ if ($add_content) {
|
|||
$id_agent_module = (int) get_parameter ('id_module');
|
||||
$period = (int) get_parameter ('period');
|
||||
$type = (string) get_parameter ('type');
|
||||
$id_agent = (int) get_parameter ('id_agent',0);
|
||||
$id_agent = (int) get_parameter ('id_agent');
|
||||
$id_custom_graph = (int) get_parameter ('id_custom_graph');
|
||||
$module_description = (string) get_parameter ('module_description', '');
|
||||
$module_description = (string) get_parameter ('module_description');
|
||||
|
||||
$order = (int) get_db_value ('COUNT(*)', 'treport_content', 'id_report', $id_report);
|
||||
|
||||
$sql = sprintf ('INSERT INTO treport_content (id_report, id_gs, id_agent_module,
|
||||
`order`, type, period, description, id_agent)
|
||||
VALUES (%d, %s, %s, %d, "%s", %d, "%s", %d)',
|
||||
$id_report, $id_custom_graph ? $id_custom_graph : "NULL",
|
||||
$id_agent_module ? $id_agent_module : "NULL",
|
||||
$order, $type, $period * 3600, $module_description, $id_agent);
|
||||
$result = process_sql ($sql);
|
||||
|
||||
$values = array ();
|
||||
$values['id_custom_graph'] = $id_custom_graph ? $id_custom_graph : NULL;
|
||||
$values['id_agent_module'] = $id_agent_module ? $id_agent_module : NULL;
|
||||
$values['type'] = $type;
|
||||
$values['period'] = $period * 3600;
|
||||
$values['description'] = $module_description;
|
||||
$values['id_agent'] = $id_agent;
|
||||
|
||||
$result = create_report_content ($id_report, $values);
|
||||
if ($result !== false) {
|
||||
echo '<h3 class="suc">'.__('Reporting successfully created').'</h3>';
|
||||
$id_agent = 0;
|
||||
|
@ -170,34 +133,31 @@ if ($add_content) {
|
|||
|
||||
// Create report
|
||||
if ($create_report) {
|
||||
$sql = sprintf ('INSERT INTO treport (name, description, id_user, private, id_group)
|
||||
VALUES ("%s", "%s", "%s", %d, %d)',
|
||||
$report_name, $report_description, $config['id_user'], $report_private, $report_id_group);
|
||||
$id_report = process_sql ($sql, "insert_id");
|
||||
if ($id_report !== false) {
|
||||
echo "<h3 class=suc>".__('Reporting successfully created')."</h3>";
|
||||
} else {
|
||||
echo "<h3 class=error>".__('There was a problem creating reporting')."</h3>";
|
||||
}
|
||||
$values = array ();
|
||||
$values['description'] = $report_description;
|
||||
$values['private'] = $report_private;
|
||||
$id_report = create_report ($name, $id_group, $values);
|
||||
print_error_message ($id_report,
|
||||
__('Successfully created'),
|
||||
__('Could not be created'));
|
||||
}
|
||||
|
||||
// Update report
|
||||
if ($update_report) {
|
||||
$sql = sprintf ('UPDATE treport SET name = "%s",
|
||||
description = "%s", private = %d
|
||||
WHERE id_report = %d',
|
||||
$report_name, $report_description,
|
||||
$report_private, $id_report);
|
||||
$result = process_sql ($sql);
|
||||
if ($result) {
|
||||
echo "<h3 class=suc>".__('Updated successfully')."</h3>";
|
||||
} else {
|
||||
echo "<h3 class=error>".__('Not updated. Error updating data')."</h3>";
|
||||
}
|
||||
$values = array ();
|
||||
$values['name'] = $report_name;
|
||||
$values['description'] = $report_description;
|
||||
$values['private'] = $report_private;
|
||||
$result = update_report ($id_report, $values);
|
||||
print_error_message ($result,
|
||||
__('Successfully updated'),
|
||||
__('Could not be updated'));
|
||||
}
|
||||
|
||||
if ($id_report) {
|
||||
$report = get_db_row ('treport', 'id_report', (int) $id_report);
|
||||
$report = get_report ($id_report);
|
||||
if ($report === false)
|
||||
require ("general/noaccess.php");
|
||||
$report_name = $report["name"];
|
||||
$report_description = $report["description"];
|
||||
$report_private = $report["private"];
|
||||
|
@ -367,7 +327,7 @@ if ($edit_sla_report_content) {
|
|||
if ($id_report) {
|
||||
print_input_hidden ('id_report', $id_report);
|
||||
print_input_hidden ('update_report', 1);
|
||||
print_submit_button (__('Update'), 'submit', false, 'class="sub next"');
|
||||
print_submit_button (__('Update'), 'submit', false, 'class="sub upd"');
|
||||
} else {
|
||||
print_input_hidden ('create_report', 1);
|
||||
print_submit_button (__('Create'), 'submit', false, 'class="sub wand"');
|
||||
|
@ -415,14 +375,15 @@ if ($edit_sla_report_content) {
|
|||
$table->data[3][0] = __('Module');
|
||||
$modules = array ();
|
||||
if ($id_agent) {
|
||||
$sql = sprintf ('SELECT id_agente_modulo, LOWER(nombre) FROM tagente_modulo WHERE id_agente = %d ORDER BY nombre', $id_agent);
|
||||
$modules = get_db_all_rows_sql ($sql);
|
||||
$modules = get_db_all_rows_filter ('tagente_modulo',
|
||||
array ('id_agente' => $id_agent, 'order' => 'nombre');
|
||||
array ('id_agente_modulo', 'nombre'));
|
||||
}
|
||||
$table->data[3][1] = print_select ($modules, 'id_module', 0, '', '--', 0, true);
|
||||
|
||||
$table->data[4][0] = __('Custom graph name');
|
||||
$table->data[4][1] = print_select_from_sql ('SELECT id_graph, name FROM tgraph',
|
||||
'id_custom_graph', 0, '', '--', 0, true);
|
||||
'id_custom_graph', 0, '', '--', 0, true);
|
||||
|
||||
$module_description = "";
|
||||
$table->data[5][0] = __('Description');
|
||||
|
@ -459,8 +420,8 @@ if ($edit_sla_report_content) {
|
|||
$table->head[6] = __('Delete');
|
||||
}
|
||||
|
||||
$sql = sprintf ('SELECT * FROM treport_content WHERE id_report = %d ORDER BY `order`', $id_report);
|
||||
$report_contents = get_db_all_rows_sql ($sql);
|
||||
$report_contents = get_report_contents ($id_report);
|
||||
|
||||
if (sizeof ($report_contents)) {
|
||||
$first_id = $report_contents[0]['id_rc'];
|
||||
$last_id = $report_contents[sizeof ($report_contents) - 1]['id_rc'];
|
||||
|
@ -470,14 +431,24 @@ if ($edit_sla_report_content) {
|
|||
$data = array ();
|
||||
$data[0] = '';
|
||||
if ($first_id != $report_content['id_rc']) {
|
||||
$data[0] .= '<a href="index.php?sec=greporting&sec2=godmode/reporting/reporting_builder&edit_report=1&id_report='.
|
||||
$id_report.'&content_up=1&id_report_content='.$report_content['id_rc'].
|
||||
'"><img src="images/up.png" title="'.__('Up').'"></a>';
|
||||
$data[0] .= '<form method="post" style="display:inline">';
|
||||
$data[0] .= print_input_hidden ('edit_report', 1, true);
|
||||
$data[0] .= print_input_hidden ('id_report', $id_report, true);
|
||||
$data[0] .= print_input_hidden ('content_up', 1, true);
|
||||
$data[0] .= print_input_hidden ('id_report_content', $report_content['id_rc'], true);
|
||||
$data[0] .= print_input_image ('up', 'images/up.png', 1, '',
|
||||
true, array ('title' => __('Up')));
|
||||
$data[0] .= '</form>';
|
||||
}
|
||||
if ($last_id != $report_content['id_rc']) {
|
||||
$data[0] .= '<a href="index.php?sec=greporting&sec2=godmode/reporting/reporting_builder&edit_report=1&id_report='.
|
||||
$id_report.'&content_down=1&id_report_content='.$report_content['id_rc'].
|
||||
'"><img src="images/down.png" title="'.__('Down').'"></a>';
|
||||
$data[0] .= '<form method="post" style="display:inline">';
|
||||
$data[0] .= print_input_hidden ('edit_report', 1, true);
|
||||
$data[0] .= print_input_hidden ('id_report', $id_report, true);
|
||||
$data[0] .= print_input_hidden ('content_down', 1, true);
|
||||
$data[0] .= print_input_hidden ('id_report_content', $report_content['id_rc'], true);
|
||||
$data[0] .= print_input_image ('down', 'images/down.png', 1, '',
|
||||
true, array ('title' => __('Down')));
|
||||
$data[0] .= '</form>';
|
||||
}
|
||||
$data[1] = get_report_name ($report_content['type']);
|
||||
$data[2] = get_agent_name ($report_content['id_agent']);
|
||||
|
@ -492,8 +463,15 @@ if ($edit_sla_report_content) {
|
|||
if ($report_content['type'] == 'SLA') {
|
||||
$data[5] = '<a href="index.php?sec=greporting&sec2=godmode/reporting/reporting_builder&id_report='.$id_report.'&edit_sla_report_content=1&id_report_content='.$report_content['id_rc'].'"><img src="images/setup.png"></a>';
|
||||
}
|
||||
if ($report_id_user == $config['id_user']) {
|
||||
$data[6] = '<a href="index.php?sec=greporting&sec2=godmode/reporting/reporting_builder&id_report='.$id_report.'&delete_report_content=1&id_report_content='.$report_content['id_rc'].'"><img src="images/cross.png"></a>';
|
||||
if ($report_id_user == $config['id_user'] || is_user_admin ($config['id_user'])) {
|
||||
$data[6] = '<form method="post" style="display:inline" onsubmit="if (!confirm (\''.__('Are you sure?').'\')) return false">';
|
||||
$data[6] .= print_input_hidden ('edit_report', 1, true);
|
||||
$data[6] .= print_input_hidden ('id_report', $id_report, true);
|
||||
$data[6] .= print_input_hidden ('delete_report_content', 1, true);
|
||||
$data[6] .= print_input_hidden ('id_report_content', $report_content['id_rc'], true);
|
||||
$data[6] .= print_input_image ('delete', 'images/cross.png', 1, '',
|
||||
true, array ('title' => __('Delete')));
|
||||
$data[6] .= '</form>';
|
||||
}
|
||||
|
||||
array_push ($table->data, $data);
|
||||
|
@ -506,9 +484,10 @@ if ($edit_sla_report_content) {
|
|||
echo "<h2>".__('Reporting')." > ";
|
||||
echo __('Custom reporting')."</h2>";
|
||||
|
||||
$reports = get_db_all_rows_in_table ('treport', 'name');
|
||||
$reports = get_reports (array ('order' => 'name'),
|
||||
array ('name', 'id_report', 'description'));
|
||||
$table->width = '0px';
|
||||
if ($reports !== false) {
|
||||
if (sizeof ($reports)) {
|
||||
$table->id = 'report_list';
|
||||
$table->width = '600px';
|
||||
$table->head = array ();
|
||||
|
@ -520,15 +499,17 @@ if ($edit_sla_report_content) {
|
|||
$table->head[2] = __('Delete');
|
||||
|
||||
foreach ($reports as $report) {
|
||||
if ($report["private"] || $report["id_user"] != $config['id_user'])
|
||||
continue;
|
||||
$data = array ();
|
||||
$data[0] = '<a href="index.php?sec=greporting&sec2=godmode/reporting/reporting_builder&edit_report=1&id_report='.
|
||||
$report['id_report'].'">'.$report['name'].'</a>';
|
||||
$data[1] = $report['description'];
|
||||
$data[2] = '<a href="index.php?sec=greporting&sec2=godmode/reporting/reporting_builder&delete_report=1&id_report='.
|
||||
$report['id_report'].'"><img src="images/cross.png"></a>';
|
||||
|
||||
$data[2] = '<form method="post" style="display:inline" onsubmit="if (!confirm (\''.__('Are you sure?').'\')) return false">';
|
||||
$data[2] .= print_input_hidden ('id_report', $report['id_report'], true);
|
||||
$data[2] .= print_input_hidden ('delete_report', 1, true);
|
||||
$data[2] .= print_input_image ('delete', 'images/cross.png', 1, '',
|
||||
true, array ('title' => __('Delete')));
|
||||
$data[2] .= '</form>';
|
||||
|
||||
array_push ($table->data, $data);
|
||||
|
||||
}
|
||||
|
|
|
@ -17,51 +17,29 @@
|
|||
// along with this program; if not, write to the Free Software
|
||||
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||
|
||||
function clean_alert_command_values ($values, $set_empty = true) {
|
||||
$retvalues = array ();
|
||||
|
||||
if ($set_empty) {
|
||||
$retvalues['description'] = '';
|
||||
}
|
||||
|
||||
if (empty ($values))
|
||||
return $retvalues;
|
||||
|
||||
if (isset ($values['description']))
|
||||
$retvalues['description'] = (string) $values['description'];
|
||||
|
||||
return $retvalues;
|
||||
}
|
||||
|
||||
function create_alert_command ($name, $command, $values = false) {
|
||||
if (empty ($name))
|
||||
return false;
|
||||
if (empty ($command))
|
||||
return false;
|
||||
if (! is_array ($values))
|
||||
$values = array ();
|
||||
$values['name'] = $name;
|
||||
$values['description'] = $description;
|
||||
|
||||
$values = clean_alert_command_values ($values);
|
||||
|
||||
$sql = sprintf ('INSERT talert_commands (name, command, description)
|
||||
VALUES ("%s", "%s", "%s")',
|
||||
$name, $command, $values['description']);
|
||||
return @process_sql ($sql, 'insert_id');
|
||||
return @process_sql_insert ('talert_commands', $values);
|
||||
}
|
||||
|
||||
function update_alert_command ($id_alert_command, $name, $command, $description = '', $values = false) {
|
||||
function update_alert_command ($id_alert_command, $values) {
|
||||
$id_alert_command = safe_int ($id_alert_command, 1);
|
||||
if (empty ($id_alert_command))
|
||||
return false;
|
||||
if (empty ($name))
|
||||
return false;
|
||||
if (empty ($command))
|
||||
if (! is_array ($values))
|
||||
return false;
|
||||
|
||||
$values = clean_alert_command_values ($values);
|
||||
|
||||
$sql = sprintf ('UPDATE talert_commands SET name = "%s", command = "%s",
|
||||
description = "%s" WHERE id = %d',
|
||||
$name, $command, $values['description'], $id_alert_command);
|
||||
return @process_sql ($sql) !== false;
|
||||
return (@process_sql_update ('talert_commands',
|
||||
$values,
|
||||
array ('id' => $id_alert_command))) !== false;
|
||||
}
|
||||
|
||||
function delete_alert_command ($id_alert_command) {
|
||||
|
@ -69,9 +47,8 @@ function delete_alert_command ($id_alert_command) {
|
|||
if (empty ($id_alert_command))
|
||||
return false;
|
||||
|
||||
$sql = sprintf ('DELETE FROM talert_commands WHERE id = %d',
|
||||
$id_alert_command);
|
||||
return @process_sql ($sql);
|
||||
return (@proces_sql_delete ('talert_commands',
|
||||
array ('id' => $id_alert_command))) !== false;
|
||||
}
|
||||
|
||||
function get_alert_command ($id_alert_command) {
|
||||
|
@ -114,28 +91,6 @@ function get_alert_command_description ($id_alert_command) {
|
|||
return get_db_value ('description', 'talert_commands', 'id', $id_alert_command);
|
||||
}
|
||||
|
||||
function clean_alert_action_values ($values, $set_empty = true) {
|
||||
$retvalues = array ();
|
||||
|
||||
if ($set_empty) {
|
||||
$retvalues['field1'] = '';
|
||||
$retvalues['field2'] = '';
|
||||
$retvalues['field3'] = '';
|
||||
}
|
||||
|
||||
if (empty ($values))
|
||||
return $retvalues;
|
||||
|
||||
if (isset ($values['field1']))
|
||||
$retvalues['field1'] = (string) $values['field1'];
|
||||
if (isset ($values['field2']))
|
||||
$retvalues['field2'] = (string) $values['field2'];
|
||||
if (isset ($values['field3']))
|
||||
$retvalues['field3'] = (string) $values['field3'];
|
||||
|
||||
return $retvalues;
|
||||
}
|
||||
|
||||
function create_alert_action ($name, $id_alert_command, $values = false) {
|
||||
$id_alert_command = safe_int ($id_alert_command, 1);
|
||||
if (empty ($id_alert_command))
|
||||
|
@ -143,35 +98,24 @@ function create_alert_action ($name, $id_alert_command, $values = false) {
|
|||
if (empty ($name))
|
||||
return false;
|
||||
|
||||
$values = clean_alert_action_values ($values);
|
||||
if (! is_array ($values))
|
||||
$values = array ();
|
||||
$values['name'] = $name;
|
||||
$values['id_alert_command'] = $id_alert_command;
|
||||
|
||||
$sql = sprintf ('INSERT talert_actions (name, id_alert_command, field1, field2, field3)
|
||||
VALUES ("%s", %d, "%s", "%s", "%s")',
|
||||
$name, $id_alert_command, $values['field1'], $values['field2'],
|
||||
$values['field3']);
|
||||
|
||||
return @process_sql ($sql, 'insert_id');
|
||||
return @proces_sql_insert ('talert_actions', $values);
|
||||
}
|
||||
|
||||
function update_alert_action ($id_alert_action, $id_alert_command, $name, $values = false) {
|
||||
function update_alert_action ($id_alert_action, $values) {
|
||||
$id_alert_action = safe_int ($id_alert_action, 1);
|
||||
if (empty ($id_alert_action))
|
||||
return false;
|
||||
$id_alert_command = safe_int ($id_alert_command, 1);
|
||||
if (empty ($id_alert_command))
|
||||
return false;
|
||||
if (empty ($name))
|
||||
if (! is_array ($values))
|
||||
return false;
|
||||
|
||||
$values = clean_alert_action_values ($values);
|
||||
|
||||
$sql = sprintf ('UPDATE talert_actions SET name = "%s",
|
||||
id_alert_command = %d, field1 = "%s",
|
||||
field2 = "%s", field3 = "%s" WHERE id = %d',
|
||||
$name, $id_alert_command, $values['field1'], $values['field2'],
|
||||
$values['field3'], $id_alert_action);
|
||||
|
||||
return @process_sql ($sql) !== false;
|
||||
return (@proces_sql_update ('talert_actions',
|
||||
$values,
|
||||
array ('id' => $id_alert_action))) !== false;
|
||||
}
|
||||
|
||||
function delete_alert_action ($id_alert_action) {
|
||||
|
@ -179,9 +123,8 @@ function delete_alert_action ($id_alert_action) {
|
|||
if (empty ($id_alert_action))
|
||||
return false;
|
||||
|
||||
$sql = sprintf ('DELETE FROM talert_actions WHERE id = %d',
|
||||
$id_alert_action);
|
||||
return @process_sql ($sql);
|
||||
return (@proces_sql_delete ('talert_actions',
|
||||
array ('id' => $id_alert_action))) !== false;
|
||||
}
|
||||
|
||||
function get_alert_actions ($only_names = true) {
|
||||
|
@ -254,113 +197,14 @@ function get_alert_templates_type_name ($type) {
|
|||
return $types[$type];
|
||||
}
|
||||
|
||||
function clean_alert_template_values ($values, $set_empty = true) {
|
||||
$retvalues = array ();
|
||||
|
||||
if ($set_empty) {
|
||||
$retvalues['type'] = 'equal';
|
||||
$retvalues['description'] = '';
|
||||
$retvalues['id_alert_action'] = NULL;
|
||||
$retvalues['field1'] = '';
|
||||
$retvalues['field2'] = '';
|
||||
$retvalues['field3'] = '';
|
||||
$retvalues['value'] = '';
|
||||
$retvalues['max_value'] = 0;
|
||||
$retvalues['min_value'] = 0;
|
||||
$retvalues['time_threshold'] = 0;
|
||||
$retvalues['max_alerts'] = 0;
|
||||
$retvalues['min_alerts'] = 0;
|
||||
$retvalues['monday'] = 0;
|
||||
$retvalues['tuesday'] = 0;
|
||||
$retvalues['wednesday'] = 0;
|
||||
$retvalues['thursday'] = 0;
|
||||
$retvalues['friday'] = 0;
|
||||
$retvalues['saturday'] = 0;
|
||||
$retvalues['sunday'] = 0;
|
||||
$retvalues['time_from'] = '00:00';
|
||||
$retvalues['time_to'] = '00:00';
|
||||
$retvalues['time_threshold'] = '300';
|
||||
$retvalues['recovery_notify'] = '';
|
||||
$retvalues['field2_recovery'] = '';
|
||||
$retvalues['field2_recovery'] = '';
|
||||
$retvalues['matches_value'] = true;
|
||||
}
|
||||
|
||||
if (empty ($values))
|
||||
return $retvalues;
|
||||
|
||||
if (isset ($values['name']))
|
||||
$retvalues['name'] = (string) $values['name'];
|
||||
if (isset ($values['type']))
|
||||
$retvalues['type'] = (string) $values['type'];
|
||||
if (isset ($values['description']))
|
||||
$retvalues['description'] = (string) $values['description'];
|
||||
if (isset ($values['id_alert_action']))
|
||||
$retvalues['id_alert_action'] = (int) $values['id_alert_action'];
|
||||
if (isset ($values['field1']))
|
||||
$retvalues['field1'] = (string) $values['field1'];
|
||||
if (isset ($values['field2']))
|
||||
$retvalues['field2'] = (string) $values['field2'];
|
||||
if (isset ($values['field3']))
|
||||
$retvalues['field3'] = (string) $values['field3'];
|
||||
if (isset ($values['value']))
|
||||
$retvalues['value'] = (string) $values['value'];
|
||||
if (isset ($values['matches_value']))
|
||||
$retvalues['matches_value'] = (bool) $values['matches_value'];
|
||||
if (isset ($values['max_value']))
|
||||
$retvalues['max_value'] = (float) $values['max_value'];
|
||||
if (isset ($values['min_value']))
|
||||
$retvalues['min_value'] = (float) $values['min_value'];
|
||||
if (isset ($values['time_threshold']))
|
||||
$retvalues['time_threshold'] = (int) $values['time_threshold'];
|
||||
if (isset ($values['max_alerts']))
|
||||
$retvalues['max_alerts'] = (int) $values['max_alerts'];
|
||||
if (isset ($values['min_alerts']))
|
||||
$retvalues['min_alerts'] = (int) $values['min_alerts'];
|
||||
/* Ensure max an min orders */
|
||||
if (isset ($values['min_alerts']) && isset ($values['max_alerts'])) {
|
||||
$max = max ($retvalues['max_alerts'], $retvalues['min_alerts']);
|
||||
$min = min ($retvalues['max_alerts'], $retvalues['min_alerts']);
|
||||
$retvalues['max_alerts'] = $max;
|
||||
$retvalues['min_alerts'] = $min;
|
||||
}
|
||||
if (isset ($values['monday']))
|
||||
$retvalues['monday'] = (bool) $values['monday'];
|
||||
if (isset ($values['tuesday']))
|
||||
$retvalues['tuesday'] = (bool) $values['tuesday'];
|
||||
if (isset ($values['wednesday']))
|
||||
$retvalues['wednesday'] = (bool) $values['wednesday'];
|
||||
if (isset ($values['thursday']))
|
||||
$retvalues['thursday'] = (bool) $values['thursday'];
|
||||
if (isset ($values['friday']))
|
||||
$retvalues['friday'] = (bool) $values['friday'];
|
||||
if (isset ($values['saturday']))
|
||||
$retvalues['saturday'] = (bool) $values['saturday'];
|
||||
if (isset ($values['sunday']))
|
||||
$retvalues['sunday'] = (bool) $values['sunday'];
|
||||
if (isset ($values['time_from']))
|
||||
$retvalues['time_from'] = (string) $values['time_from'];
|
||||
if (isset ($values['time_to']))
|
||||
$retvalues['time_to'] = (string) $values['time_to'];
|
||||
if (isset ($values['time_threshold']))
|
||||
$retvalues['time_threshold'] = (int) $values['time_threshold'];
|
||||
if (isset ($values['recovery_notify']))
|
||||
$retvalues['recovery_notify'] = (bool) $values['recovery_notify'];
|
||||
if (isset ($values['field2_recovery']))
|
||||
$retvalues['field2_recovery'] = (string) $values['field2_recovery'];
|
||||
if (isset ($values['field3_recovery']))
|
||||
$retvalues['field3_recovery'] = (string) $values['field3_recovery'];
|
||||
|
||||
return $retvalues;
|
||||
}
|
||||
|
||||
function create_alert_template ($name, $type, $values = false) {
|
||||
if (empty ($name))
|
||||
return false;
|
||||
if (empty ($type))
|
||||
return false;
|
||||
|
||||
$values = clean_alert_template_values ($values);
|
||||
if (! is_array ($values))
|
||||
$values = array ();
|
||||
$values['name'] = $name;
|
||||
$values['type'] = $type;
|
||||
|
||||
|
@ -371,12 +215,12 @@ function create_alert_template ($name, $type, $values = false) {
|
|||
return @process_sql_insert ('talert_templates', $values);
|
||||
}
|
||||
|
||||
function update_alert_template ($id_alert_template, $values = false) {
|
||||
function update_alert_template ($id_alert_template, $values) {
|
||||
$id_alert_template = safe_int ($id_alert_template, 1);
|
||||
if (empty ($id_alert_template))
|
||||
return false;
|
||||
|
||||
$values = clean_alert_template_values ($values, false);
|
||||
if (! is_array ($values))
|
||||
return false;
|
||||
|
||||
return (@process_sql_update ('talert_templates',
|
||||
$values,
|
||||
|
@ -530,58 +374,25 @@ function duplicate_alert_template ($id_alert_template) {
|
|||
return create_alert_template ($name, $type, $template);
|
||||
}
|
||||
|
||||
function clean_alert_agent_module_values ($values, $set_empty = true) {
|
||||
$retvalues = array ();
|
||||
|
||||
if ($set_empty) {
|
||||
$retvalues['internal_counter'] = 0;
|
||||
$retvalues['last_fired'] = 0;
|
||||
$retvalues['times_fired'] = 0;
|
||||
$retvalues['disabled'] = 0;
|
||||
$retvalues['priority'] = 0;
|
||||
$retvalues['force_execution'] = 0;
|
||||
}
|
||||
|
||||
if (empty ($values))
|
||||
return $retvalues;
|
||||
|
||||
if (isset ($values['internal_counter']))
|
||||
$retvalues['internal_counter'] = (int) $values['internal_counter'];
|
||||
if (isset ($values['last_fired']))
|
||||
$retvalues['last_fired'] = (int) $values['last_fired'];
|
||||
if (isset ($values['times_fired']))
|
||||
$retvalues['times_fired'] = (int) $values['times_fired'];
|
||||
if (isset ($values['disabled']))
|
||||
$retvalues['disabled'] = (int) $values['disabled'];
|
||||
if (isset ($values['priority']))
|
||||
$retvalues['priority'] = (int) $values['priority'];
|
||||
if (isset ($values['force_execution']))
|
||||
$retvalues['force_execution'] = (int) $values['force_execution'];
|
||||
|
||||
return $retvalues;
|
||||
}
|
||||
|
||||
function create_alert_agent_module ($id_agent_module, $id_alert_template, $values = false) {
|
||||
if (empty ($id_agent_module))
|
||||
return false;
|
||||
if (empty ($id_alert_template))
|
||||
return false;
|
||||
|
||||
$values = clean_alert_agent_module_values ($values);
|
||||
if (! is_array ($values))
|
||||
$values = array ();
|
||||
$values['id_agent_module'] = $id_agent_module;
|
||||
$values['id_alert_template'] = $id_alert_template;
|
||||
return @process_sql_insert ('talert_template_modules',
|
||||
$values,
|
||||
array ('id' => $id_alert_template));
|
||||
|
||||
return @process_sql_insert ('talert_template_modules', $values);
|
||||
}
|
||||
|
||||
function update_alert_agent_module ($id_alert_agent_module, $values = false) {
|
||||
function update_alert_agent_module ($id_alert_agent_module, $values) {
|
||||
if (empty ($id_agent_module))
|
||||
return false;
|
||||
|
||||
$values = clean_alert_agent_module_values ($values, false);
|
||||
if ($empty ($values))
|
||||
return true;
|
||||
if (! is_array ($values))
|
||||
return false;
|
||||
|
||||
return (@process_sql_update ('talert_template_modules',
|
||||
$values,
|
||||
|
@ -810,97 +621,23 @@ function get_alert_compound_operations () {
|
|||
return $operations;
|
||||
}
|
||||
|
||||
function clean_alert_compound_values ($values, $set_empty = true) {
|
||||
$retvalues = array ();
|
||||
|
||||
if ($set_empty) {
|
||||
$retvalues['description'] = '';
|
||||
$retvalues['time_threshold'] = 0;
|
||||
$retvalues['max_alerts'] = 0;
|
||||
$retvalues['min_alerts'] = 0;
|
||||
$retvalues['monday'] = 0;
|
||||
$retvalues['tuesday'] = 0;
|
||||
$retvalues['wednesday'] = 0;
|
||||
$retvalues['thursday'] = 0;
|
||||
$retvalues['friday'] = 0;
|
||||
$retvalues['saturday'] = 0;
|
||||
$retvalues['sunday'] = 0;
|
||||
$retvalues['time_from'] = '00:00';
|
||||
$retvalues['time_to'] = '00:00';
|
||||
$retvalues['time_threshold'] = '300';
|
||||
$retvalues['recovery_notify'] = '';
|
||||
$retvalues['field2_recovery'] = '';
|
||||
$retvalues['field2_recovery'] = '';
|
||||
}
|
||||
|
||||
if (empty ($values))
|
||||
return $retvalues;
|
||||
|
||||
if (isset ($values['name']))
|
||||
$retvalues['name'] = (string) $values['name'];
|
||||
if (isset ($values['description']))
|
||||
$retvalues['description'] = (string) $values['description'];
|
||||
if (isset ($values['id_agent']))
|
||||
$retvalues['id_agent'] = (int) $values['id_agent'];
|
||||
if (isset ($values['time_threshold']))
|
||||
$retvalues['time_threshold'] = (int) $values['time_threshold'];
|
||||
if (isset ($values['max_alerts']))
|
||||
$retvalues['max_alerts'] = (int) $values['max_alerts'];
|
||||
if (isset ($values['min_alerts']))
|
||||
$retvalues['min_alerts'] = (int) $values['min_alerts'];
|
||||
/* Ensure max an min orders */
|
||||
if (isset ($values['min_alerts']) && isset ($values['max_alerts'])) {
|
||||
$max = max ($retvalues['max_alerts'], $retvalues['min_alerts']);
|
||||
$min = min ($retvalues['max_alerts'], $retvalues['min_alerts']);
|
||||
$retvalues['max_alerts'] = $max;
|
||||
$retvalues['min_alerts'] = $min;
|
||||
}
|
||||
if (isset ($values['monday']))
|
||||
$retvalues['monday'] = (bool) $values['monday'];
|
||||
if (isset ($values['tuesday']))
|
||||
$retvalues['tuesday'] = (bool) $values['tuesday'];
|
||||
if (isset ($values['wednesday']))
|
||||
$retvalues['wednesday'] = (bool) $values['wednesday'];
|
||||
if (isset ($values['thursday']))
|
||||
$retvalues['thursday'] = (bool) $values['thursday'];
|
||||
if (isset ($values['friday']))
|
||||
$retvalues['friday'] = (bool) $values['friday'];
|
||||
if (isset ($values['saturday']))
|
||||
$retvalues['saturday'] = (bool) $values['saturday'];
|
||||
if (isset ($values['sunday']))
|
||||
$retvalues['sunday'] = (bool) $values['sunday'];
|
||||
if (isset ($values['time_from']))
|
||||
$retvalues['time_from'] = (string) $values['time_from'];
|
||||
if (isset ($values['time_to']))
|
||||
$retvalues['time_to'] = (string) $values['time_to'];
|
||||
if (isset ($values['time_threshold']))
|
||||
$retvalues['time_threshold'] = (int) $values['time_threshold'];
|
||||
if (isset ($values['recovery_notify']))
|
||||
$retvalues['recovery_notify'] = (bool) $values['recovery_notify'];
|
||||
if (isset ($values['field2_recovery']))
|
||||
$retvalues['field2_recovery'] = (string) $values['field2_recovery'];
|
||||
if (isset ($values['field3_recovery']))
|
||||
$retvalues['field3_recovery'] = (string) $values['field3_recovery'];
|
||||
|
||||
return $retvalues;
|
||||
}
|
||||
|
||||
function create_alert_compound ($name, $id_agent, $values = false) {
|
||||
if (empty ($name))
|
||||
return false;
|
||||
|
||||
$values = clean_alert_compound_values ($values);
|
||||
if (! is_array ($values))
|
||||
$values = array ();
|
||||
$values['name'] = $name;
|
||||
$values['id_agent'] = $id_agent;
|
||||
|
||||
return @process_sql_insert ('talert_compound', $values);
|
||||
}
|
||||
|
||||
function update_alert_compound ($id_alert_compound, $values = false) {
|
||||
function update_alert_compound ($id_alert_compound, $values) {
|
||||
$id_alert_compound = safe_int ($id_alert_compound);
|
||||
if (empty ($id_alert_compound))
|
||||
return false;
|
||||
$values = clean_alert_compound_values ($values, false);
|
||||
if (! is_array ($values))
|
||||
return false;
|
||||
|
||||
return (@process_sql_update ('talert_compound', $values,
|
||||
array ('id' => $id_alert_compound))) !== false;
|
||||
|
|
|
@ -432,36 +432,6 @@ function get_agent_modules_count ($id_agent = 0) {
|
|||
return (int) get_db_sql ("SELECT COUNT(*) FROM tagente_modulo".$filter);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get a list of the reports the user can view.
|
||||
*
|
||||
* A user can view a report by two ways:
|
||||
* - The user created the report (id_user field in treport)
|
||||
* - The report is not private and the user has reading privileges on
|
||||
* the group associated to the report
|
||||
*
|
||||
* @param string $id_user User id
|
||||
*
|
||||
* @return array An array with all the reports the user can view.
|
||||
*/
|
||||
function get_reports ($id_user) {
|
||||
$user_reports = array ();
|
||||
$all_reports = get_db_all_rows_in_table ('treport', 'name');
|
||||
if ($all_reports === false) {
|
||||
return $user_reports;
|
||||
}
|
||||
foreach ($all_reports as $report) {
|
||||
/* The report is private and it does not belong to the user */
|
||||
if ($report['private'] && $report['id_user'] != $id_user)
|
||||
continue;
|
||||
/* Check ACL privileges on report group */
|
||||
if (! give_acl ($id_user, $report['id_group'], 'AR'))
|
||||
continue;
|
||||
array_push ($user_reports, $report);
|
||||
}
|
||||
return $user_reports;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get group icon from group.
|
||||
*
|
||||
|
@ -1430,7 +1400,8 @@ function get_db_value ($field, $table, $field_search = 1, $condition = 1) {
|
|||
|
||||
if ($result === false)
|
||||
return false;
|
||||
|
||||
if ($field[0] == '`')
|
||||
$field = str_replace ('`', '', $field);
|
||||
return $result[0][$field];
|
||||
}
|
||||
|
||||
|
@ -1861,9 +1832,9 @@ function get_db_all_fields_in_table ($table, $field = '', $condition = '', $orde
|
|||
echo $sql;
|
||||
</code>
|
||||
* Will return:
|
||||
* <code>
|
||||
* UPDATE table SET `name` = "Name", `description` = "Long description" WHERE id=1
|
||||
* </code>
|
||||
<code>
|
||||
UPDATE table SET `name` = "Name", `description` = "Long description" WHERE id=1
|
||||
</code>
|
||||
*
|
||||
* @param array Values to be formatted in an array indexed by the field name.
|
||||
*
|
||||
|
@ -1874,8 +1845,10 @@ function format_array_to_update_sql ($values) {
|
|||
$fields = array ();
|
||||
|
||||
foreach ($values as $field => $value) {
|
||||
if (! is_string ($field))
|
||||
if (is_numeric ($field)) {
|
||||
array_push ($fields, $value);
|
||||
continue;
|
||||
}
|
||||
|
||||
if ($value === NULL) {
|
||||
$sql = sprintf ("`%s` = NULL", $field);
|
||||
|
@ -1884,7 +1857,12 @@ function format_array_to_update_sql ($values) {
|
|||
} elseif (is_float ($value) || is_double ($value)) {
|
||||
$sql = sprintf ("`%s` = %f", $field, $value);
|
||||
} else {
|
||||
$sql = sprintf ("`%s` = '%s'", $field, $value);
|
||||
/* String */
|
||||
if (isset ($value[0]) && $value[0] == '`')
|
||||
/* Don't round with quotes if it references a field */
|
||||
$sql = sprintf ("`%s` = %s", $field, $value);
|
||||
else
|
||||
$sql = sprintf ("`%s` = '%s'", $field, $value);
|
||||
}
|
||||
array_push ($fields, $sql);
|
||||
}
|
||||
|
@ -1990,7 +1968,7 @@ function format_array_to_where_clause_sql ($values, $join = 'AND', $prefix = fal
|
|||
$i = 1;
|
||||
$max = count ($values);
|
||||
foreach ($values as $field => $value) {
|
||||
if (is_numeric ($field)) {
|
||||
if (is_numeric ($field)) {
|
||||
/* User provide the exact operation to do */
|
||||
$query .= $value;
|
||||
|
||||
|
@ -2890,30 +2868,9 @@ process_sql_update ('table', array ('field' => 2), 'id in (1, 2, 3) OR id > 10')
|
|||
* @return mixed False in case of error or invalid values passed. Affected rows otherwise
|
||||
*/
|
||||
function process_sql_update ($table, $values, $where = false, $where_join = 'AND') {
|
||||
$query = sprintf ("UPDATE `%s` SET ", $table);
|
||||
|
||||
$i = 1;
|
||||
$max = count ($values);
|
||||
foreach ($values as $field => $value) {
|
||||
if ($field[0] != "`") {
|
||||
$field = "`".$field."`";
|
||||
}
|
||||
|
||||
if (is_null ($value)) {
|
||||
$query .= sprintf ("%s = NULL", $field);
|
||||
} elseif (is_int ($value) || is_bool ($value)) {
|
||||
$query .= sprintf ("%s = %d", $field, $value);
|
||||
} else if (is_float ($value) || is_double ($value)) {
|
||||
$query .= sprintf ("%s = %f", $field, $value);
|
||||
} else {
|
||||
$query .= sprintf ("%s = '%s'", $field, $value);
|
||||
}
|
||||
|
||||
if ($i < $max) {
|
||||
$query .= ",";
|
||||
}
|
||||
$i++;
|
||||
}
|
||||
$query = sprintf ("UPDATE `%s` SET %s",
|
||||
$table,
|
||||
format_array_to_update_sql ($values));
|
||||
|
||||
if ($where) {
|
||||
if (is_string ($where)) {
|
||||
|
|
|
@ -0,0 +1,294 @@
|
|||
<?php
|
||||
|
||||
// Pandora FMS - the Flexible Monitoring System
|
||||
// ============================================
|
||||
// Copyright (c) 2009 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 a custom user report.
|
||||
*
|
||||
* @param int Report id to get.
|
||||
* @param array Extra filter.
|
||||
* @param array Fields to get.
|
||||
*
|
||||
* @return Report with the given id. False if not available or readable.
|
||||
*/
|
||||
function get_report ($id_report, $filter = false, $fields = false) {
|
||||
global $config;
|
||||
|
||||
$id_report = safe_int ($id_report);
|
||||
if (empty ($id_report))
|
||||
return false;
|
||||
if (! is_array ($filter))
|
||||
$filter = array ();
|
||||
$filter['id_report'] = $id_report;
|
||||
$filter[] = sprintf ('private = 0 OR (private = 1 AND id_user = "%s")', $config['id_user']);
|
||||
if (is_array ($fields))
|
||||
$fields[] = 'id_group';
|
||||
|
||||
$report = get_db_row_filter ('treport', $filter, $fields);
|
||||
if (! give_acl ($config['id_user'], $report['id_group'], 'AR'))
|
||||
return false;
|
||||
return $report;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get a list of the reports the user can view.
|
||||
*
|
||||
* A user can view a report by two ways:
|
||||
* - The user created the report (id_user field in treport)
|
||||
* - The report is not private and the user has reading privileges on
|
||||
* the group associated to the report
|
||||
*
|
||||
* @param string $id_user User id
|
||||
*
|
||||
* @return array An array with all the reports the user can view.
|
||||
*/
|
||||
function get_reports ($filter = false, $fields = false) {
|
||||
global $config;
|
||||
|
||||
if (! is_array ($filter))
|
||||
$filter = array ();
|
||||
$filter[] = sprintf ('private = 0 OR (private = 1 AND id_user = "%s")', $config['id_user']);
|
||||
if (is_array ($fields)) {
|
||||
$fields[] = 'id_group';
|
||||
$fields[] = 'id_user';
|
||||
}
|
||||
|
||||
$reports = array ();
|
||||
$all_reports = get_db_all_rows_filter ('treport', $filter, $fields);
|
||||
foreach ($all_reports as $report){
|
||||
if ($config['id_user'] != $report['id_user'] && ! give_acl ($config['id_user'], $report['id_group'], 'AR'))
|
||||
continue;
|
||||
array_push ($reports, $report);
|
||||
}
|
||||
|
||||
return $reports;
|
||||
}
|
||||
|
||||
/**
|
||||
* Creates a report.
|
||||
*
|
||||
* @param string Report name.
|
||||
* @param int Group where the report will operate.
|
||||
* @param array Extra values to be set. Notice that id_user is automatically
|
||||
* set to the logged user.
|
||||
*
|
||||
* @return mixed New report id if created. False if it could not be created.
|
||||
*/
|
||||
function create_report ($name, $id_group, $values = false) {
|
||||
global $config;
|
||||
|
||||
if (! is_array ($values))
|
||||
$values = array ();
|
||||
$values['name'] = $name;
|
||||
$values['id_group'] = $id_group;
|
||||
$values['id_user'] = $config['id_user'];
|
||||
|
||||
return @process_sql_insert ('treport', $values);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Updates a report.
|
||||
*
|
||||
* @param int Report id.
|
||||
* @param array Extra values to be set.
|
||||
*
|
||||
* @return bool True if the report was updated. False otherwise.
|
||||
*/
|
||||
function update_report ($id_report, $values) {
|
||||
$report = get_report ($id_report);
|
||||
if ($report === false)
|
||||
return false;
|
||||
return (@process_sql_update ('treport',
|
||||
$values,
|
||||
array ('id_report' => $id_report))) !== false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Deletes a report.
|
||||
*
|
||||
* @param int Report id to be deleted.
|
||||
*
|
||||
* @return bool True if deleted, false otherwise.
|
||||
*/
|
||||
function delete_report ($id_report) {
|
||||
$id_report = safe_int ($id_report);
|
||||
if (empty ($id_report))
|
||||
return false;
|
||||
$report = get_report ($id_report);
|
||||
if ($report === false)
|
||||
return false;
|
||||
$res1 = @process_sql_delete ('treport_content', array ('id_report' => $id_report));
|
||||
$res2 = @process_sql_delete ('treport', array ('id_report' => $id_report));
|
||||
|
||||
return $res1 && $res2;
|
||||
}
|
||||
|
||||
/**
|
||||
* Deletes a content from a report.
|
||||
*
|
||||
* @param int Report content id to be deleted.
|
||||
*
|
||||
* @return bool True if deleted, false otherwise.
|
||||
*/
|
||||
function get_report_content ($id_report_content, $filter = false, $fields = false) {
|
||||
$id_report_content = safe_int ($id_report_content);
|
||||
if (empty ($id_report_content))
|
||||
return false;
|
||||
if (! is_array ($filter))
|
||||
$filter = array ();
|
||||
if (is_array ($fields))
|
||||
$fields[] = 'id_report';
|
||||
$filter['id_rc'] = $id_report_content;
|
||||
|
||||
$content = @get_db_row_filter ('treport_content', $filter, $fields);
|
||||
if ($content === false)
|
||||
return false;
|
||||
$report = get_report ($content['id_report']);
|
||||
if ($report === false)
|
||||
return false;
|
||||
return $content;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get all the contents of a report.
|
||||
*
|
||||
* @param int Report id to get contents.
|
||||
* @param array Extra filters for the contents.
|
||||
* @param array Fields to be fetched. All fields by default
|
||||
*
|
||||
* @return array All the contents of a report.
|
||||
*/
|
||||
function create_report_content ($id_report, $values) {
|
||||
$id_report = safe_int ($id_report);
|
||||
if (empty ($id_report))
|
||||
return false;
|
||||
$report = get_report ($id_report);
|
||||
if ($report === false)
|
||||
return false;
|
||||
if (! is_array ($values))
|
||||
return false;
|
||||
$values['id_report'] = $id_report;
|
||||
unset ($values['`order`']);
|
||||
$order = (int) get_db_value ('MAX(`order`)', 'treport_content', 'id_report', $id_report);
|
||||
$values['`order`'] = $order + 1;
|
||||
|
||||
return @process_sql_insert ('treport_content', $values);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get all the contents of a report.
|
||||
*
|
||||
* @param int Report id to get contents.
|
||||
* @param array Extra filters for the contents.
|
||||
* @param array Fields to be fetched. All fields by default
|
||||
*
|
||||
* @return array All the contents of a report.
|
||||
*/
|
||||
function get_report_contents ($id_report, $filter = false, $fields = false) {
|
||||
$id_report = safe_int ($id_report);
|
||||
if (empty ($id_report))
|
||||
return array ();
|
||||
|
||||
$report = get_report ($id_report);
|
||||
if ($report === false)
|
||||
return array ();
|
||||
if (! is_array ($filter))
|
||||
$filter = array ();
|
||||
$filter['id_report'] = $id_report;
|
||||
$filter['order'] = '`order`';
|
||||
|
||||
$contents = get_db_all_rows_filter ('treport_content', $filter, $fields);
|
||||
if ($contents === false)
|
||||
return array ();
|
||||
return $contents;
|
||||
}
|
||||
|
||||
/**
|
||||
* Moves a content from a report up.
|
||||
*
|
||||
* @param int Report content id to be moved.
|
||||
*
|
||||
* @return bool True if moved, false otherwise.
|
||||
*/
|
||||
function move_report_content_up ($id_report_content) {
|
||||
if (empty ($id_report_content))
|
||||
return false;
|
||||
|
||||
$content = get_report_content ($id_report_content);
|
||||
if ($content === false)
|
||||
return false;
|
||||
$order = get_db_value ('`order`', 'treport_content', 'id_rc', $id_report_content);
|
||||
/* Set the previous element order to the current of the content we want to change */
|
||||
process_sql_update ('treport_content',
|
||||
array ('`order` = `order` + 1'),
|
||||
array ('id_report' => $content['id_report'],
|
||||
'`order` = '.($order - 1)));
|
||||
return (@process_sql_update ('treport_content',
|
||||
array ('`order` = `order` - 1'),
|
||||
array ('id_rc' => $id_report_content))) !== false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Moves a content from a report up.
|
||||
*
|
||||
* @param int Report content id to be moved.
|
||||
*
|
||||
* @return bool True if moved, false otherwise.
|
||||
*/
|
||||
function move_report_content_down ($id_report_content) {
|
||||
if (empty ($id_report_content))
|
||||
return false;
|
||||
|
||||
$content = get_report_content ($id_report_content);
|
||||
if ($content === false)
|
||||
return false;
|
||||
$order = get_db_value ('`order`', 'treport_content', 'id_rc', $id_report_content);
|
||||
/* Set the previous element order to the current of the content we want to change */
|
||||
process_sql_update ('treport_content',
|
||||
array ('`order` = `order` - 1'),
|
||||
array ('id_report' => (int) $content['id_report'],
|
||||
'`order` = '.($order + 1)));
|
||||
return (@process_sql_update ('treport_content',
|
||||
array ('`order` = `order` + 1'),
|
||||
array ('id_rc' => $id_report_content))) !== false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Deletes a content from a report.
|
||||
*
|
||||
* @param int Report content id to be deleted.
|
||||
*
|
||||
* @return bool True if deleted, false otherwise.
|
||||
*/
|
||||
function delete_report_content ($id_report_content) {
|
||||
if (empty ($id_report_content))
|
||||
return false;
|
||||
|
||||
$content = get_report_content ($id_report_content);
|
||||
if ($content === false)
|
||||
return false;
|
||||
$order = get_db_value ('`order`', 'treport_content', 'id_rc', $id_report_content);
|
||||
process_sql_update ('treport_content',
|
||||
array ('`order` = `order` - 1'),
|
||||
array ('id_report' => (int) $content['id_report'],
|
||||
'`order` > '.$order));
|
||||
return (@process_sql_delete ('treport_content',
|
||||
array ('id_rc' => $id_report_content))) !== false;
|
||||
}
|
||||
?>
|
|
@ -19,13 +19,15 @@
|
|||
// Login check
|
||||
check_login ();
|
||||
|
||||
require_once ('include/functions_reports.php');
|
||||
|
||||
// Load enterprise extensions
|
||||
enterprise_include ('operation/reporting/custom_reporting.php');
|
||||
|
||||
echo "<h2>".__('Reporting')." > ";
|
||||
echo __('Custom reporting')."</h2>";
|
||||
|
||||
$reports = get_reports ($config['id_user']);
|
||||
$reports = get_reports ();
|
||||
|
||||
if (sizeof ($reports) == 0) {
|
||||
echo "<div class='nf'>".__('There are no defined reportings')."</div>";
|
||||
|
|
Loading…
Reference in New Issue