2008-08-22 20:07:32 +02:00
|
|
|
<?php
|
|
|
|
|
2009-06-08 20:15:58 +02:00
|
|
|
// Pandora FMS - http://pandorafms.com
|
|
|
|
// ==================================================
|
2010-06-02 19:30:11 +02:00
|
|
|
// Copyright (c) 2005-2010 Artica Soluciones Tecnologicas
|
2009-06-08 20:15:58 +02:00
|
|
|
// Please see http://pandorafms.org for full contribution list
|
2006-03-27 05:37:27 +02:00
|
|
|
|
2008-04-01 15:53:11 +02:00
|
|
|
// 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.
|
2009-06-08 20:15:58 +02:00
|
|
|
|
2010-03-02 20:25:51 +01:00
|
|
|
global $config;
|
2008-08-22 20:07:32 +02:00
|
|
|
|
2008-06-19 02:24:05 +02:00
|
|
|
check_login();
|
2006-03-27 05:37:27 +02:00
|
|
|
|
2008-06-19 02:24:05 +02:00
|
|
|
if (isset($_GET["id_agente"])){
|
|
|
|
$id_agente = $_GET["id_agente"];
|
|
|
|
}
|
2006-03-27 05:37:27 +02:00
|
|
|
|
2008-06-19 02:24:05 +02:00
|
|
|
// View last data packet
|
|
|
|
// Get timestamp of last packet
|
2009-03-26 16:55:30 +01:00
|
|
|
$agent = get_db_row ('tagente', 'id_agente', $id_agente,
|
|
|
|
array ('ultimo_contacto_remoto',
|
|
|
|
'ultimo_contacto',
|
|
|
|
'intervalo',
|
|
|
|
'id_grupo'));
|
|
|
|
$timestamp_ref = $agent["ultimo_contacto_remoto"];
|
|
|
|
$timestamp_lof = $agent["ultimo_contacto"];
|
|
|
|
$intervalo_agente = $agent["intervalo"];
|
2006-03-27 05:37:27 +02:00
|
|
|
|
2008-06-19 02:24:05 +02:00
|
|
|
// Get last packet
|
2011-04-11 19:05:20 +02:00
|
|
|
switch ($config["dbtype"]) {
|
|
|
|
case "mysql":
|
|
|
|
case "postgresql":
|
|
|
|
$sql3 = 'SELECT * FROM tagente_modulo, tagente_estado
|
|
|
|
WHERE tagente_modulo.disabled = 0
|
|
|
|
AND tagente_modulo.id_agente = ' . $id_agente.
|
|
|
|
' AND tagente_estado.utimestamp != 0
|
|
|
|
AND tagente_modulo.id_agente_modulo = tagente_estado.id_agente_modulo
|
|
|
|
ORDER BY id_module_group, nombre';
|
|
|
|
break;
|
|
|
|
case "oracle":
|
|
|
|
$sql3 = 'SELECT * FROM tagente_modulo, tagente_estado
|
|
|
|
WHERE tagente_modulo.disabled = 0
|
|
|
|
AND tagente_modulo.id_agente = ' . $id_agente.
|
|
|
|
' AND tagente_estado.utimestamp != 0
|
|
|
|
AND tagente_modulo.id_agente_modulo = tagente_estado.id_agente_modulo
|
|
|
|
ORDER BY id_module_group, dbms_lob.substr(nombre,4000,1)';
|
|
|
|
break;
|
|
|
|
}
|
2008-08-05 13:42:08 +02:00
|
|
|
$label_group = 0;
|
2008-06-19 02:24:05 +02:00
|
|
|
$last_label = "";
|
2008-08-05 13:42:08 +02:00
|
|
|
|
|
|
|
// Title
|
2010-06-02 19:30:11 +02:00
|
|
|
echo "<h3>".__('Display of last data modules received by agent');
|
2011-02-04 14:30:50 +01:00
|
|
|
echo " <a href='index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente=$id_agente&tab=data'>" . print_image('images/refresh.png', true, array("alt" => '')) . "</a>";
|
2010-06-02 19:30:11 +02:00
|
|
|
echo "</h3>";
|
2008-08-05 13:42:08 +02:00
|
|
|
|
2010-07-21 18:56:52 +02:00
|
|
|
$sortField = get_parameter('sort_field');
|
|
|
|
$sort = get_parameter('sort', 'none');
|
|
|
|
$selected = 'border: 1px solid black;';
|
2010-11-11 Raúl Mateos <raulofpandora@gmail.com>
* general/error_install.php, general/error_perms.php, general/header.php,
general/logon_menu.php, general/logon_ok.php, include/functions_menu.php,
include/functions_ui.php, extensions/agents_modules.php,
operation/menu.php, godmode/menu.php, operation/estado_agente.php,
operation/agentes/estado_agente.php, operation/agentes/status_monitor.php,
operation/agentes/estado_monitores.php,
operation/agentes/estado_ultimopaquete.php,
operation/agentes/estado_generalagente.php, pandoradb_data.sql: Closed
some HTML tags, autoclose others, added alt to images, and changed some
& to "&" to help validation for XHTML 1.0 Transitional. Tested and
not error found, but needs more tests...
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@3572 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2010-11-11 12:16:09 +01:00
|
|
|
$url = 'index.php?sec=estado&sec2=operation/agentes/ver_agente&tab=data&id_agente=' . $id_agente;
|
2010-07-21 18:56:52 +02:00
|
|
|
$selectNameUp = '';
|
|
|
|
$selectNameDown = '';
|
|
|
|
$selectTypeUp = '';
|
|
|
|
$selectTypeDown = '';
|
|
|
|
$selectIntervalUp = '';
|
|
|
|
$selectIntervalDown = '';
|
|
|
|
$selectTimestampUp = '';
|
|
|
|
$selectTimestampDown = '';
|
2010-07-21 20:07:21 +02:00
|
|
|
$selectDataUp = '';
|
|
|
|
$selectDataDown = '';
|
2010-07-21 18:56:52 +02:00
|
|
|
|
|
|
|
$order[] = array('field' => 'id_module_group', 'order' => 'ASC');
|
|
|
|
|
|
|
|
switch ($sortField) {
|
|
|
|
case 'name':
|
|
|
|
switch ($sort) {
|
|
|
|
case 'up':
|
|
|
|
$selectNameUp = $selected;
|
2011-04-11 19:05:20 +02:00
|
|
|
switch ($config["dbtype"]) {
|
|
|
|
case "mysql":
|
|
|
|
case "postgresql":
|
|
|
|
$order[] = array('field' => 'tagente_modulo.nombre', 'order' => 'ASC');
|
|
|
|
break;
|
|
|
|
case "oracle":
|
|
|
|
$order[] = array('field' => 'dbms_lob.substr(tagente_modulo.nombre,4000,1)', 'order' => 'ASC');
|
|
|
|
break;
|
|
|
|
}
|
2010-07-21 18:56:52 +02:00
|
|
|
break;
|
|
|
|
case 'down':
|
|
|
|
$selectNameDown = $selected;
|
2011-04-11 19:05:20 +02:00
|
|
|
switch ($config["dbtype"]) {
|
|
|
|
case "mysql":
|
|
|
|
case "postgresql":
|
|
|
|
$order[] = array('field' => 'tagente_modulo.nombre', 'order' => 'DESC');
|
|
|
|
break;
|
|
|
|
case "oracle":
|
|
|
|
$order[] = array('field' => 'dbms_lob.substr(tagente_modulo.nombre,4000,1)', 'order' => 'DESC');
|
|
|
|
break;
|
|
|
|
}
|
2010-07-21 18:56:52 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'type':
|
|
|
|
switch ($sort) {
|
|
|
|
case 'up':
|
|
|
|
$selectTypeUp = $selected;
|
|
|
|
$order[] = array('field' => 'tagente_modulo.id_tipo_modulo', 'order' => 'ASC');
|
|
|
|
break;
|
|
|
|
case 'down':
|
|
|
|
$selectTypeDown = $selected;
|
|
|
|
$order[] = array('field' => 'tagente_modulo.id_tipo_modulo', 'order' => 'DESC');
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'interval':
|
|
|
|
switch ($sort) {
|
|
|
|
case 'up':
|
|
|
|
$selectIntervalUp = $selected;
|
|
|
|
$order[] = array('field' => 'tagente_modulo.module_interval', 'order' => 'ASC');
|
|
|
|
break;
|
|
|
|
case 'down':
|
|
|
|
$selectIntervalDown = $selected;
|
|
|
|
$order[] = array('field' => 'tagente_modulo.module_interval', 'order' => 'DESC');
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'timestamp':
|
|
|
|
switch ($sort) {
|
|
|
|
case 'up':
|
|
|
|
$selectTimestampUp = $selected;
|
|
|
|
$order[] = array('field' => 'tagente_estado.utimestamp', 'order' => 'ASC');
|
|
|
|
break;
|
|
|
|
case 'down':
|
|
|
|
$selectTimestampDown = $selected;
|
|
|
|
$order[] = array('field' => 'tagente_estado.utimestamp', 'order' => 'DESC');
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
break;
|
2010-07-21 20:07:21 +02:00
|
|
|
case 'data':
|
|
|
|
switch ($sort) {
|
|
|
|
case 'up':
|
|
|
|
$selectDataUp = $selected;
|
|
|
|
$order[] = array('field' => 'tagente_estado.datos', 'order' => 'ASC');
|
|
|
|
break;
|
|
|
|
case 'down':
|
|
|
|
$selectDataDown = $selected;
|
|
|
|
$order[] = array('field' => 'tagente_estado.datos', 'order' => 'DESC');
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
break;
|
2010-07-21 18:56:52 +02:00
|
|
|
default:
|
|
|
|
$selectNameUp = $selected;
|
|
|
|
$selectNameDown = '';
|
|
|
|
$selectTypeUp = '';
|
|
|
|
$selectTypeDown = '';
|
|
|
|
$selectIntervalUp = '';
|
|
|
|
$selectIntervalDown = '';
|
|
|
|
$selectTimestampUp = '';
|
|
|
|
$selectTimestampDown = '';
|
2011-04-11 19:05:20 +02:00
|
|
|
switch ($config["dbtype"]) {
|
|
|
|
case "mysql":
|
|
|
|
case "postgresql":
|
|
|
|
$order[] = array('field' => 'tagente_modulo.nombre', 'order' => 'ASC');
|
|
|
|
break;
|
|
|
|
case "oracle":
|
|
|
|
$order[] = array('field' => 'dbms_lob.substr(tagente_modulo.nombre,4000,1)', 'order' => 'ASC');
|
|
|
|
break;
|
|
|
|
}
|
2010-07-21 18:56:52 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2009-03-26 16:55:30 +01:00
|
|
|
$modules = get_db_all_rows_filter ('tagente_modulo, tagente_estado',
|
|
|
|
array ('tagente_modulo.id_agente_modulo = tagente_estado.id_agente_modulo',
|
|
|
|
'disabled' => 0,
|
|
|
|
'tagente_estado.utimestamp != 0',
|
|
|
|
'tagente_modulo.id_agente = '.$id_agente,
|
2010-07-21 18:56:52 +02:00
|
|
|
'order' => $order));
|
2008-08-05 13:42:08 +02:00
|
|
|
|
2009-03-26 16:55:30 +01:00
|
|
|
if ($modules === false) {
|
|
|
|
echo "<div class='nf'>".__('This agent doesn\'t have any module')."</div>";
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2010-10-05 11:33:08 +02:00
|
|
|
$isFunctionPolicies = enterprise_include_once ('include/functions_policies.php');
|
|
|
|
|
2010-07-21 20:07:21 +02:00
|
|
|
echo "<table width='98%' cellpadding='3' cellspacing='3' class='databox'>";
|
2010-10-05 12:53:44 +02:00
|
|
|
echo "<th><span title='" . __('Force execution') . "'>".__('F.')."</span></th>";
|
2010-10-05 11:33:08 +02:00
|
|
|
if ($isFunctionPolicies !== ENTERPRISE_NOT_HOOK) {
|
|
|
|
echo "<th><span title='" . __('Policy') . "'>".__('P.')."</span></th>";
|
|
|
|
}
|
2010-07-21 18:56:52 +02:00
|
|
|
echo "<th>".__('Module name') . ' ' .
|
2011-02-04 14:30:50 +01:00
|
|
|
'<a href="' . $url . '&sort_field=name&sort=up">' . print_image("images/sort_up.png", true, array("style" => $selectNameUp, "alt" => "up")) . '</a>' .
|
|
|
|
'<a href="' . $url . '&sort_field=name&sort=down">' . print_image("images/sort_down.png", true, array("style" => $selectNameDown, "alt" => "down")) . '</a>';
|
2010-07-21 18:56:52 +02:00
|
|
|
echo "</th>";
|
|
|
|
echo "<th>".__('Type') . ' ' .
|
2011-02-04 14:30:50 +01:00
|
|
|
'<a href="' . $url . '&sort_field=type&sort=up">' . print_image("images/sort_up.png", true, array("style" => $selectTypeUp, "alt" => "up")) . '</a>' .
|
|
|
|
'<a href="' . $url . '&sort_field=type&sort=down">' . print_image("images/sort_down.png", true, array("style" => $selectTypeDown, "alt" => "down")) . '</a>';
|
2010-07-21 18:56:52 +02:00
|
|
|
echo "</th>";
|
|
|
|
echo "<th>".__('int') . ' ' .
|
2011-02-04 14:30:50 +01:00
|
|
|
'<a href="' . $url . '&sort_field=interval&sort=up">' . print_image("images/sort_up.png", true, array("style" => $selectIntervalUp, "alt" => "up")) . '</a>' .
|
|
|
|
'<a href="' . $url . '&sort_field=interval&sort=down">' . print_image("images/sort_down.png", true, array("style" => $selectIntervalDown, "alt" => "down")) . '</a>';
|
2010-07-21 18:56:52 +02:00
|
|
|
echo "</th>";
|
|
|
|
echo "<th>".__('Description') . "</th>";
|
2010-07-21 20:07:21 +02:00
|
|
|
echo "<th>".__('Data') . ' ' .
|
2011-02-04 14:30:50 +01:00
|
|
|
'<a href="' . $url . '&sort_field=data&sort=up">' . print_image("images/sort_up.png", true, array("style" => $selectDataUp, "alt" => "up")) . '</a>' .
|
|
|
|
'<a href="' . $url . '&sort_field=data&sort=down">' . print_image("images/sort_down.png", true, array("style" => $selectDataDown, "alt" => "down")) . '</a>';
|
2010-07-21 20:07:21 +02:00
|
|
|
echo "</th>";
|
2009-03-26 16:55:30 +01:00
|
|
|
echo "<th>".__('Graph')."</th>";
|
|
|
|
echo "<th>".__('Raw Data')."</th>";
|
2010-07-21 18:56:52 +02:00
|
|
|
echo "<th>".__('Timestamp') . ' ' .
|
2011-02-04 14:30:50 +01:00
|
|
|
'<a href="' . $url . '&sort_field=timestamp&sort=up">' . print_image("images/sort_up.png", true, array("style" => $selectTimestampUp, "alt" => "up")) . '</a>' .
|
|
|
|
'<a href="' . $url . '&sort_field=timestamp&sort=down">' . print_image("images/sort_down.png", true, array("style" => $selectTimestampDown, "alt" => "down")) . '</a>';
|
2010-07-21 18:56:52 +02:00
|
|
|
echo "</th>";
|
2009-03-26 16:55:30 +01:00
|
|
|
$texto=''; $last_modulegroup = 0;
|
|
|
|
$color = 1;
|
2011-02-27 Miguel de Dios <miguel.dedios@artica.es>
* extensions/users_connected.php: fixed the double negation in the
check_acl.
* include/functions_events.php, include/functions_modules.php,
include/functions_reporting.php, include/functions_filemanager.php,
include/functions_config.php, include/ajax/reporting.ajax.php,
include/ajax/visual_console_builder.ajax.php,
include/ajax/alert_list.ajax.php, include/help/es/modu_group_list.php,
include/fgraph.php, include/functions.php, include/functions_db.php,
include/functions_alerts.php, include/functions_reports.php,
extensions/insert_data.php, extensions/system_info.php,
extensions/pandora_logs.php, extensions/agents_modules.php,
extensions/dbmanager.php, extensions/resource_registration.php,
extensions/update_manager/settings.php, extensions/update_manager/main.php,
extensions/plugin_registration.php, operation/incidents/incident.php,
operation/incidents/incident_detail.php,
operation/incidents/incident_statistics.php, operation/extensions.php,
operation/visual_console/render_view.php,
operation/visual_console/index.php, operation/agentes/status_monitor.php,
operation/agentes/export_csv.php,
operation/agentes/estado_ultimopaquete.php,
operation/agentes/datos_agente.php, operation/agentes/alerts_status.php,
operation/agentes/estado_generalagente.php,
operation/agentes/custom_fields.php, operation/agentes/estado_agente.php,
operation/agentes/networkmap.topology.php,
operation/agentes/networkmap.groups.php, operation/agentes/sla_view.php,
operation/agentes/exportdata.php, operation/agentes/gis_view.php,
operation/agentes/estado_monitores.php, operation/agentes/ver_agente.php,
operation/agentes/graphs.php, operation/agentes/agent_fields.php,
operation/agentes/group_view.php, operation/agentes/networkmap.php,
operation/servers/view_server.php, operation/servers/view_server_detail.php,
operation/menu.php, operation/snmpconsole/snmp_view.php,
operation/users/user_edit.php, operation/events/event_statistics.php,
operation/events/export_csv.php, operation/events/sound_events.php,
operation/events/events_validate.php, operation/events/events_list.php,
operation/events/events_marquee.php, operation/events/events.php,
operation/search_reports.php, operation/reporting/reporting_xml.php,
operation/reporting/reporting_viewer.php,
operation/reporting/graph_viewer.php, operation/search_maps.php,
mobile/operation/agents/monitor_status.php,
mobile/operation/agents/view_agents.php, mobile/index.php,
general/ui/agents_list.php, godmode/groups/modu_group_list.php,
godmode/groups/configure_group.php, godmode/groups/configure_modu_group.php,
godmode/groups/group_list.php, godmode/admin_access_logs.php,
godmode/extensions.php, godmode/db/db_main.php, godmode/db/db_audit.php,
godmode/db/db_sanity.php, godmode/db/db_refine.php, godmode/db/db_info.php,
godmode/db/db_event.php, godmode/db/db_purge.php,
godmode/agentes/fields_manager.php, godmode/agentes/module_manager.php,
godmode/agentes/modificar_agente.php, godmode/agentes/configurar_agente.php,
godmode/agentes/configure_field.php, godmode/agentes/planned_downtime.php,
godmode/agentes/manage_config_remote.php, godmode/servers/recon_script.php,
godmode/servers/plugin.php, godmode/servers/manage_recontask.php,
godmode/servers/modificar_server.php,
godmode/servers/manage_recontask_form.php, godmode/menu.php,
godmode/alerts/alert_list.list.php,
godmode/alerts/configure_alert_compound.php,
godmode/alerts/alert_compounds.php, godmode/alerts/alert_list.php,
godmode/alerts/configure_alert_template.php,
godmode/alerts/alert_templates.php,
godmode/alerts/configure_alert_action.php,
godmode/alerts/configure_alert_command.php,
godmode/alerts/alert_actions.php, godmode/alerts/alert_list.builder.php,
godmode/alerts/alert_commands.php, godmode/snmpconsole/snmp_alert.php,
godmode/snmpconsole/snmp_filters.php, godmode/setup/file_manager.php,
godmode/setup/os.list.php, godmode/setup/news.php,
godmode/setup/gis_step_2.php, godmode/setup/links.php,
godmode/setup/setup.php, godmode/setup/os.php,
godmode/setup/performance.php, godmode/setup/setup_auth.php,
godmode/setup/gis.php, godmode/setup/os.builder.php,
godmode/setup/setup_visuals.php, godmode/users/user_list.php,
godmode/users/configure_user.php, godmode/users/configure_profile.php,
godmode/gis_maps/configure_gis_map.php, godmode/gis_maps/index.php,
godmode/massive/massive_add_alerts.php,
godmode/massive/massive_copy_modules.php,
godmode/massive/massive_delete_agents.php,
godmode/massive/massive_operations.php,
godmode/massive/massive_edit_agents.php,
godmode/massive/massive_delete_action_alerts.php,
godmode/massive/massive_delete_modules.php,
godmode/massive/massive_delete_alerts.php,
godmode/massive/massive_edit_modules.php,
godmode/massive/massive_add_action_alerts.php,
godmode/modules/manage_network_components_form.php,
godmode/modules/manage_nc_groups_form.php,
godmode/modules/manage_network_templates.php,
godmode/modules/module_list.php,
godmode/modules/manage_network_components_form_common.php,
godmode/modules/manage_network_components_form_network.php,
godmode/modules/manage_network_templates_form.php,
godmode/modules/manage_network_components_form_wmi.php,
godmode/modules/manage_network_components.php,
godmode/modules/manage_nc_groups.php,
godmode/reporting/reporting_builder.list_items.php,
godmode/reporting/graph_builder.main.php,
godmode/reporting/visual_console_builder.wizard.php,
godmode/reporting/visual_console_builder.php,
godmode/reporting/reporting_builder.preview.php,
godmode/reporting/reporting_builder.main.php,
godmode/reporting/visual_console_builder.data.php,
godmode/reporting/visual_console_builder.elements.php,
godmode/reporting/graph_builder.php,
godmode/reporting/visual_console_builder.preview.php,
godmode/reporting/graph_builder.graph_editor.php,
godmode/reporting/reporting_builder.php,
godmode/reporting/visual_console_builder.editor.php,
godmode/reporting/reporting_builder.item_editor.php,
godmode/reporting/map_builder.php, godmode/reporting/graphs.php,
godmode/reporting/graph_builder.preview.php: replaced obsolete "give_acl" to
"check_acl" and erased the "give_acl".
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@4025 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2011-02-28 13:02:08 +01:00
|
|
|
$write = check_acl ($config['id_user'], $agent['id_grupo'], "AW");
|
2009-03-26 16:55:30 +01:00
|
|
|
foreach ($modules as $module) {
|
|
|
|
// Calculate table line color
|
|
|
|
if ($color == 1){
|
|
|
|
$tdcolor = "datos";
|
|
|
|
$color = 0;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$tdcolor = "datos2";
|
|
|
|
$color = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($module["id_module_group"] != $last_modulegroup ){
|
2010-06-02 19:30:11 +02:00
|
|
|
// Render module group names (fixed code)
|
2009-03-26 16:55:30 +01:00
|
|
|
$nombre_grupomodulo = get_modulegroup_name ($module["id_module_group"]);
|
|
|
|
$last_modulegroup = $module["id_module_group"];
|
2010-10-05 11:33:08 +02:00
|
|
|
$colspan = 9 + (int)$isFunctionPolicies;
|
|
|
|
echo "<tr><td class='datos3' align='center' colspan='".$colspan."'>
|
2009-03-26 16:55:30 +01:00
|
|
|
<b>".$nombre_grupomodulo."</b></td></tr>";
|
|
|
|
}
|
|
|
|
|
|
|
|
// Begin to render data ...
|
|
|
|
echo "<tr><td class='$tdcolor'>";
|
|
|
|
// Render network exec module button, only when
|
|
|
|
// Agent Write for this module and group, is given
|
|
|
|
// Is a network module
|
|
|
|
// Has flag = 0
|
|
|
|
if ($write && $module["id_modulo"] > 1 && $module["id_tipo_modulo"] < 100) {
|
|
|
|
if ($module["flag"] == 0) {
|
2011-02-04 14:30:50 +01:00
|
|
|
echo "<a href='index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente=".$id_agente."&id_agente_modulo=".$module["id_agente_modulo"]."&flag=1&tab=data&refr=60'>" . print_image('images/target.png', true, array("border" => '0', "alt" => "")) . "</a>";
|
2010-11-30 19:19:53 +01:00
|
|
|
}
|
|
|
|
else {
|
2011-02-04 14:30:50 +01:00
|
|
|
echo "<a href='index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente=".$id_agente."&id_agente_modulo=".$module["id_agente_modulo"]."&tab=data&refr=60'>" . print_image('images/refresh.png', true, array("border" => '0', "alt" => '')) . "</a>";
|
2008-06-19 02:24:05 +02:00
|
|
|
}
|
2009-03-26 16:55:30 +01:00
|
|
|
}
|
|
|
|
echo "</td>";
|
2010-10-05 11:33:08 +02:00
|
|
|
|
|
|
|
if ($isFunctionPolicies !== ENTERPRISE_NOT_HOOK) {
|
|
|
|
if($module["id_policy_module"] != 0) {
|
2010-10-06 14:24:21 +02:00
|
|
|
$linked = isModuleLinked($module['id_agente_modulo']);
|
2010-10-05 11:33:08 +02:00
|
|
|
$id_policy = get_db_value_sql('SELECT id_policy FROM tpolicy_modules WHERE id = '.$module["id_policy_module"]);
|
|
|
|
$name_policy = get_db_value_sql('SELECT name FROM tpolicies WHERE id = '.$id_policy);
|
|
|
|
$policyInfo = infoModulePolicy($module["id_policy_module"]);
|
2010-10-06 14:24:21 +02:00
|
|
|
|
2010-10-14 17:09:29 +02:00
|
|
|
$adopt = false;
|
|
|
|
if (isModuleAdopt($module['id_agente_modulo'])) {
|
|
|
|
$adopt = true;
|
|
|
|
}
|
|
|
|
|
2010-10-06 14:24:21 +02:00
|
|
|
if ($linked) {
|
2010-10-14 17:09:29 +02:00
|
|
|
if ($adopt) {
|
|
|
|
$img = 'images/policies_brick.png';
|
|
|
|
$title = __('(Adopt) ') . $name_policy;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$img = 'images/policies.png';
|
|
|
|
$title = $name_policy;
|
|
|
|
}
|
2010-10-06 14:24:21 +02:00
|
|
|
}
|
|
|
|
else {
|
2010-10-14 17:09:29 +02:00
|
|
|
if ($adopt) {
|
|
|
|
$img = 'images/policies_not_brick.png';
|
|
|
|
$title = __('(Unlinked) (Adopt) ') . $name_policy;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
$img = 'images/unlinkpolicy.png';
|
|
|
|
$title = __('(Unlinked) ') . $name_policy;
|
|
|
|
}
|
2010-10-06 14:24:21 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
echo "<td>";
|
|
|
|
|
2010-11-11 Raúl Mateos <raulofpandora@gmail.com>
* general/error_install.php, general/error_perms.php, general/header.php,
general/logon_menu.php, general/logon_ok.php, include/functions_menu.php,
include/functions_ui.php, extensions/agents_modules.php,
operation/menu.php, godmode/menu.php, operation/estado_agente.php,
operation/agentes/estado_agente.php, operation/agentes/status_monitor.php,
operation/agentes/estado_monitores.php,
operation/agentes/estado_ultimopaquete.php,
operation/agentes/estado_generalagente.php, pandoradb_data.sql: Closed
some HTML tags, autoclose others, added alt to images, and changed some
& to "&" to help validation for XHTML 1.0 Transitional. Tested and
not error found, but needs more tests...
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@3572 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2010-11-11 12:16:09 +01:00
|
|
|
echo'<a href="?sec=gpolicies&sec2=enterprise/godmode/policies/policies&id=' . $id_policy . '">' .
|
2010-10-06 14:24:21 +02:00
|
|
|
print_image($img,true, array('title' => $title)) .
|
2010-10-05 11:33:08 +02:00
|
|
|
'</a>';
|
|
|
|
echo "</td>";
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
echo "<td></td>";
|
|
|
|
}
|
|
|
|
}
|
2009-03-26 16:55:30 +01:00
|
|
|
$nombre_grupomodulo = get_modulegroup_name ($module["id_module_group"]);
|
|
|
|
if ($nombre_grupomodulo != ""){
|
|
|
|
if (($label_group == 0) || ($last_label != $nombre_grupomodulo)){ // Show label module group
|
|
|
|
$label_group = -1;
|
|
|
|
$last_label = $nombre_grupomodulo;
|
|
|
|
$texto = $texto. "
|
|
|
|
<td class='$tdcolor' align='center' colspan='7'>
|
|
|
|
<b>".$nombre_grupomodulo."</b></td>";
|
2008-06-19 02:24:05 +02:00
|
|
|
}
|
2009-03-26 16:55:30 +01:00
|
|
|
}
|
|
|
|
$nombre_tipo_modulo = get_moduletype_name ($module["id_tipo_modulo"]);
|
2009-11-25 10:12:42 +01:00
|
|
|
echo "<td class='".$tdcolor."_id' title='".safe_output($module["nombre"])."'>";
|
2011-04-13 18:11:02 +02:00
|
|
|
ui_print_string_substr ($module["nombre"]);
|
2009-03-26 16:55:30 +01:00
|
|
|
echo "</td><td class='".$tdcolor."'> ";
|
2008-06-19 02:24:05 +02:00
|
|
|
|
2011-04-13 18:11:02 +02:00
|
|
|
ui_print_moduletype_icon ($module["id_tipo_modulo"]);
|
2009-03-26 16:55:30 +01:00
|
|
|
echo "</td><td class='".$tdcolor."'>";
|
2010-03-18 21:01:48 +01:00
|
|
|
|
2009-03-26 16:55:30 +01:00
|
|
|
if ($module["module_interval"] != 0){
|
|
|
|
echo $module["module_interval"];
|
|
|
|
$real_interval = $module["module_interval"];
|
2010-11-30 19:19:53 +01:00
|
|
|
}
|
|
|
|
else {
|
2009-03-26 16:55:30 +01:00
|
|
|
echo $intervalo_agente;
|
|
|
|
$real_interval = $intervalo_agente;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (($module["id_tipo_modulo"] != 3)
|
|
|
|
AND ($module["id_tipo_modulo"] != 10)
|
|
|
|
AND ($module["id_tipo_modulo"] != 17)
|
2010-11-30 19:19:53 +01:00
|
|
|
AND ($module["id_tipo_modulo"] != 23)) {
|
2009-11-25 10:12:42 +01:00
|
|
|
echo "</td><td class='".$tdcolor."f9' title='".safe_output($module["descripcion"])."'>";
|
|
|
|
echo safe_output(substr($module["descripcion"],0,32));
|
2009-03-26 16:55:30 +01:00
|
|
|
if (strlen($module["descripcion"]) > 32){
|
|
|
|
echo "...";
|
2008-06-19 02:24:05 +02:00
|
|
|
}
|
|
|
|
echo "</td>";
|
2010-11-30 19:19:53 +01:00
|
|
|
}
|
2010-02-15 14:07:52 +01:00
|
|
|
|
2010-08-03 13:25:37 +02:00
|
|
|
if ($module["id_tipo_modulo"] == 24) { // Log4x
|
2010-03-18 21:01:48 +01:00
|
|
|
echo "<td class='".$tdcolor."f9' colspan='1'> </td>";
|
|
|
|
echo "<td class='".$tdcolor."f9' colspan='1'> x</td>";
|
2010-08-03 13:25:37 +02:00
|
|
|
|
|
|
|
switch($module["datos"]){
|
|
|
|
case 10: echo "<td class=$tdcolor style='color:darkgreen; font-weight:bold;'>".__('TRACE')."</td>"; break;
|
|
|
|
case 20: echo "<td class=$tdcolor style='color:darkgreen; font-weight:bold;'>".__('DEBUG')."</td>"; break;
|
|
|
|
case 30: echo "<td class=$tdcolor style='color:darkgreen; font-weight:bold;'>".__('INFO')."</td>"; break;
|
|
|
|
case 40: echo "<td class=$tdcolor style='color:darkorange; font-weight:bold;'>".__('WARN')."</td>"; break;
|
|
|
|
case 50: echo "<td class=$tdcolor style='color:red; font-weight:bold;'>".__('ERROR')."</td>"; break;
|
|
|
|
case 60: echo "<td class=$tdcolor style='color:red; font-weight:bold;'>".__('FATAL')."</td>"; break;
|
|
|
|
}
|
2010-02-15 14:07:52 +01:00
|
|
|
|
2010-11-30 19:19:53 +01:00
|
|
|
}
|
|
|
|
else if (($module["id_tipo_modulo"] == 100) OR ($module['history_data'] == 0)) {
|
2009-03-26 16:55:30 +01:00
|
|
|
echo "<td class='".$tdcolor."f9' colspan='2' title='".$module["datos"]."'>";
|
2009-11-25 10:12:42 +01:00
|
|
|
echo substr(safe_output($module["datos"]),0,12);
|
2010-11-30 19:19:53 +01:00
|
|
|
}
|
|
|
|
else {
|
2009-09-14 03:02:44 +02:00
|
|
|
$graph_type = return_graphtype ($module["id_tipo_modulo"]);
|
2010-11-30 19:19:53 +01:00
|
|
|
|
|
|
|
if ((is_numeric($module["datos"])) && ($module["id_tipo_modulo"] != 23)) {
|
2010-08-03 13:25:37 +02:00
|
|
|
echo "<td class=".$tdcolor.">";
|
|
|
|
echo format_for_graph($module["datos"] );
|
2009-09-14 03:02:44 +02:00
|
|
|
}
|
2010-08-03 13:25:37 +02:00
|
|
|
else {
|
2010-11-30 19:19:53 +01:00
|
|
|
|
2010-08-03 13:25:37 +02:00
|
|
|
if (strlen($module["datos"]) > 0 ) $colspan = 2;
|
|
|
|
else $colspan= 1;
|
2010-11-30 19:19:53 +01:00
|
|
|
|
2010-08-03 13:25:37 +02:00
|
|
|
echo "<td class='".$tdcolor."f9' colspan='" . $colspan . "' title='".safe_output($module["datos"])."'>";
|
|
|
|
echo substr(safe_output($module["datos"]),0,42);
|
|
|
|
}
|
|
|
|
echo "</td>";
|
2008-06-19 02:24:05 +02:00
|
|
|
|
2009-03-26 16:55:30 +01:00
|
|
|
$handle = "stat".$nombre_tipo_modulo."_".$module["id_agente_modulo"];
|
2009-06-30 Ramon Novoa <rnovoa@artica.es>
* nclude/FusionCharts,
include/FusionCharts/FCF_Column3D.swf,
include/FusionCharts/FCF_Pie3D.swf,
include/FusionCharts/FusionCharts.js,
include/FusionCharts/FCF_MSLine.swf,
include/FusionCharts/FusionCharts_Gen.php,
include/FusionCharts/FCF_StackedArea2D.swf,
include/FusionCharts/FCF_Area2D.swf,
include/FusionCharts/FCF_MSArea2D.swf,
include/FusionCharts/FusionCharts.php: Added to repository. Fusion
Charts Free.
* include/functions_fsgraph.php: Added to repository. Fusion Charts
chart generation functions for Pandora FMS.
* include/pchart_graph.php, include/pandora_graph.php,
include/fgraph2.php, include/pChart, include/Image,
include/fgraph.php: Moved from reporting to include.
* operation/agentes/stat_win.php: Moved from reporting to
operation/agentes.
* reporting: Deleted from repository.
* general/logon_ok.php, godmode/setup/setup.php,
godmode/admin_access_logs.php, godmode/db/db_main.php,
godmode/db/db_info.php, godmode/db/db_purge.php,
godmode/reporting/graph_builder.php,
operation/reporting/reporting_xml.php,
operation/reporting/reporting_viewer.php,
operation/servers/view_server.php,
operation/servers/view_server_detail.php,
operation/incidents/incident_statistics.php
operation/users/user_statistics.php,
operation/events/event_statistics.php, operation/events/events.php,
operation/agentes/estado_ultimopaquete.php,
operation/agentes/estado_generalagente.php,
operation/agentes/tactical.php, include/functions_config.php,
include/functions_custom_graphs.php,
include/functions_visual_map.php,
include/functions_reporting.php: Added flash charts.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1779 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-06-30 17:08:14 +02:00
|
|
|
$url = 'include/procesos.php?agente='.$module["id_agente_modulo"];
|
2009-03-26 16:55:30 +01:00
|
|
|
$win_handle=dechex(crc32($module["id_agente_modulo"].$module["nombre"]));
|
|
|
|
echo "<td class=".$tdcolor." width='78'>";
|
2011-03-11 13:33:15 +01:00
|
|
|
$graph_label = safe_output($module["nombre"]);
|
2008-06-19 02:24:05 +02:00
|
|
|
|
2011-03-11 13:33:15 +01:00
|
|
|
echo "<a href='javascript:winopeng(\"operation/agentes/stat_win.php?type=$graph_type&period=2419200&id=".$module["id_agente_modulo"]."&label=".base64_encode($graph_label)."&refresh=180000\", \"month_".$win_handle."\")'>" . print_image('images/grafica_m.png' , true, array("border" => '0', "alt" => '')) . "</a> ";
|
2009-01-12 Sancho Lerena <slerena@artica.es>
* pandoradb.sql: Removed fields "timestamp" and "id_agente" (and altered
some indexes) on tagente_datos, tagente_datos_string and
tagente_datos_inc.
tagente_estado table: removed cambio, added status_changes, last_status.
tagente_modulo: added five new fields (warning,critical mgmt., flipflop
detection, history module and delete_pending bit.
* agent_manager.php: Group ALL not shown anymore.
* configurar_agente.php: Support for new options. Delete a module now
mark for deletion the module, not delete data (It's VERY slow!).
* modificar_agente.php: Delete agent now uses the global function,
minor fixes.
* module_manager_editor.php: New fields initializacion.
* module_manager_editor_network.php: At this time, the first module
editor who implements the new fields and improve old ones (tcp data).
* setup.php: Added support for new token: event_view_hr (Filter of max
old (in hr) for the event viewer. Removed old tokens show_unknown and
show_lastalert.
* functions.php: format_for_graph() has an important BUG that makes
all units rendered without the "K" !!!!. Fixed.
* delete_agent.php: Delete remote config (if present). Also mark
for deletion modules instead delete them (and let the data without
being deleted, because it's a HUGE consuming time, and it's left
for the daily db maintance process).
* estado_agente.php: Updated code for view new status.
* estado_generalagente.php: Total packets are removed from this view,
this was a huge time consuming SQL operation that don't give important
infomation. Groupname is now visualized.
* estado_ultimopaquete.php,
* estado_monitores.php,
* estado_grupo.php: Rewritten much code to view new status and other
minor changes.
* ver_agente.php: Data view now works under the tabs and other minor
changes.
* events.php: Support for the new events and status. Added filter for
username and for a max. hours old events. Some boxes are now hidden
by default.
* fgraph.php: Some graphs are now fixed and uses tagente_datos and
tagent_access with utimestamp and without id_agent index. Works faster
* images/*: Updated icons (module types) and two new bulb colors.
git-svn-id: https://svn.code.sf.net/p/pandora/code/trunk@1326 c3f86ba8-e40f-0410-aaad-9ba5e7f4b01f
2009-01-12 04:53:33 +01:00
|
|
|
|
2011-03-11 13:33:15 +01:00
|
|
|
$link ="winopeng('operation/agentes/stat_win.php?type=$graph_type&period=604800&id=".$module["id_agente_modulo"]."&label=".base64_encode($graph_label)."&refresh=6000','week_".$win_handle."')";
|
2011-02-04 14:30:50 +01:00
|
|
|
echo '<a href="javascript:'.$link.'">' . print_image("images/grafica_w.png", true, array("border" => '0', "alt" => '')) . '</a> ';
|
2009-03-26 16:55:30 +01:00
|
|
|
|
2011-03-11 13:33:15 +01:00
|
|
|
$link ="winopeng('operation/agentes/stat_win.php?type=$graph_type&period=86400&id=".$module["id_agente_modulo"]."&label=".base64_encode($graph_label)."&refresh=600','day_".$win_handle."')";
|
2011-02-04 14:30:50 +01:00
|
|
|
echo '<a href="javascript:'.$link.'">' . print_image("images/grafica_d.png", true, array("border" => '0', "alt" => '')) . '</a> ';
|
2009-03-26 16:55:30 +01:00
|
|
|
|
2011-03-11 13:33:15 +01:00
|
|
|
$link ="winopeng('operation/agentes/stat_win.php?type=$graph_type&period=3600&id=".$module["id_agente_modulo"]."&label=".base64_encode($graph_label)."&refresh=60','hour_".$win_handle."')";
|
2011-02-04 14:30:50 +01:00
|
|
|
echo '<a href="javascript:'.$link.'">' . print_image("images/grafica_h.png", true, array("border" => '0', "alt" => "")) . '</a>';
|
2010-03-18 21:01:48 +01:00
|
|
|
|
2009-03-26 16:55:30 +01:00
|
|
|
}
|
|
|
|
|
2008-06-19 02:24:05 +02:00
|
|
|
|
2010-11-30 19:19:53 +01:00
|
|
|
if ($module['history_data'] == 1) {
|
2010-06-02 19:30:11 +02:00
|
|
|
// RAW Table data
|
|
|
|
echo "<td class=".$tdcolor." width=70>";
|
2011-02-04 14:30:50 +01:00
|
|
|
echo "<a href='index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente=$id_agente&tab=data_view&period=2592000&id=".$module["id_agente_modulo"]."'>" . print_image('images/data_m.png', true, array("border" => '0', "alt" => '')) . "</a> ";
|
|
|
|
echo "<a href='index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente=$id_agente&tab=data_view&period=604800&id=".$module["id_agente_modulo"]."'>" . print_image('images/data_w.png', true, array("border" => '0', "alt" => '')) . "</a> ";
|
|
|
|
echo "<a href='index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente=$id_agente&tab=data_view&period=86400&id=".$module["id_agente_modulo"]."'>" . print_image('images/data_d.png', true, array("border" => '0', "alt" => '')) . "</a>";
|
2010-11-30 19:19:53 +01:00
|
|
|
}
|
|
|
|
else {
|
2009-03-26 16:55:30 +01:00
|
|
|
echo "<td class=".$tdcolor."></td>";
|
|
|
|
}
|
2010-06-02 19:30:11 +02:00
|
|
|
|
2009-03-26 16:55:30 +01:00
|
|
|
echo "<td class='".$tdcolor."f9'>";
|
2009-09-14 03:02:44 +02:00
|
|
|
if ($module["utimestamp"] == 0){
|
2009-03-26 16:55:30 +01:00
|
|
|
echo __('Never');
|
2010-11-30 19:19:53 +01:00
|
|
|
}
|
|
|
|
else {
|
2009-09-14 03:02:44 +02:00
|
|
|
$seconds = get_system_time () - $module["utimestamp"];
|
|
|
|
if ($module['id_tipo_modulo'] < 21 && $module["module_interval"] > 0 && $module["utimestamp"] > 0 && $seconds >= ($module["module_interval"] * 2)) {
|
|
|
|
echo '<span class="redb">';
|
2008-06-19 02:24:05 +02:00
|
|
|
} else {
|
2009-09-14 03:02:44 +02:00
|
|
|
echo '<span>';
|
2008-06-19 02:24:05 +02:00
|
|
|
}
|
2009-01-20 17:43:49 +01:00
|
|
|
}
|
2011-04-13 18:11:02 +02:00
|
|
|
ui_print_timestamp ($module["utimestamp"], false);
|
2009-09-14 03:02:44 +02:00
|
|
|
echo '</span>';
|
2009-03-26 16:55:30 +01:00
|
|
|
echo "</td></tr>";
|
2006-03-27 05:37:27 +02:00
|
|
|
}
|
2009-03-26 16:55:30 +01:00
|
|
|
echo '</table>';
|
2008-06-19 02:24:05 +02:00
|
|
|
|
2006-07-09 01:32:38 +02:00
|
|
|
?>
|