mirror of
https://github.com/pandorafms/pandorafms.git
synced 2025-07-31 01:35:36 +02:00
Fixed the module groups in the networkmaps.
This commit is contained in:
parent
008d243f85
commit
676e6d884f
@ -99,6 +99,12 @@ class Networkmap extends Map {
|
|||||||
if (!is_numeric($graphviz_id))
|
if (!is_numeric($graphviz_id))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
$is_node_module_group = false;
|
||||||
|
if ($this->filter['show_module_group']) {
|
||||||
|
if (strstr($chunks[1], 'URL=""') !== false) {
|
||||||
|
$is_node_module_group = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$chunks = explode("ajax.php?", $chunks[1]);
|
$chunks = explode("ajax.php?", $chunks[1]);
|
||||||
|
|
||||||
@ -110,7 +116,18 @@ class Networkmap extends Map {
|
|||||||
$shape = DEFAULT_NODE_SHAPE;
|
$shape = DEFAULT_NODE_SHAPE;
|
||||||
$color = DEFAULT_NODE_COLOR;
|
$color = DEFAULT_NODE_COLOR;
|
||||||
$image = DEFAULT_NODE_IMAGE;
|
$image = DEFAULT_NODE_IMAGE;
|
||||||
if (strstr($chunks[1], "&id_module=") !== false) {
|
|
||||||
|
if ($is_node_module_group) {
|
||||||
|
preg_match("/<TR><TD>(.*)<\/TD><\/TR><\/TABLE>>/", $chunks[0], $matches);
|
||||||
|
$title = $matches[1];
|
||||||
|
$id = db_get_value('id_mg', 'tmodule_group',
|
||||||
|
'name', $title);
|
||||||
|
$type = ITEM_TYPE_MODULEGROUP_NETWORKMAP;
|
||||||
|
preg_match("/data-status=\"([0-9]*)\"/", $chunks[1], $matches);
|
||||||
|
$status = $matches[1];
|
||||||
|
$shape = "rhombus";
|
||||||
|
}
|
||||||
|
elseif (strstr($chunks[1], "&id_module=") !== false) {
|
||||||
// MODULE
|
// MODULE
|
||||||
preg_match("/id_module=([0-9]*)/", $chunks[1], $matches);
|
preg_match("/id_module=([0-9]*)/", $chunks[1], $matches);
|
||||||
$id = $matches[1];
|
$id = $matches[1];
|
||||||
@ -260,7 +277,9 @@ class Networkmap extends Map {
|
|||||||
$return['filter'] = $this->filter['text'];
|
$return['filter'] = $this->filter['text'];
|
||||||
$return['id_tag'] = $this->filter['id_tag'];
|
$return['id_tag'] = $this->filter['id_tag'];
|
||||||
$return['show_modules'] = $this->filter['show_modules'];
|
$return['show_modules'] = $this->filter['show_modules'];
|
||||||
|
$return['only_modules_alerts'] = $this->filter['only_modules_with_alerts'];
|
||||||
|
$return['module_group'] = $this->filter['module_group'];
|
||||||
|
$return['show_modulegroup'] = $this->filter['show_module_group'];
|
||||||
|
|
||||||
return $return;
|
return $return;
|
||||||
}
|
}
|
||||||
@ -298,7 +317,10 @@ class Networkmap extends Map {
|
|||||||
null,
|
null,
|
||||||
$parameters['old_mode'],
|
$parameters['old_mode'],
|
||||||
$parameters['id_tag'],
|
$parameters['id_tag'],
|
||||||
$parameters['show_modules']);
|
$parameters['show_modules'],
|
||||||
|
$parameters['only_modules_alerts'],
|
||||||
|
$parameters['module_group'],
|
||||||
|
$parameters['show_modulegroup']);
|
||||||
|
|
||||||
|
|
||||||
$filename_dot = sys_get_temp_dir() . "/networkmap" . uniqid() . ".dot";
|
$filename_dot = sys_get_temp_dir() . "/networkmap" . uniqid() . ".dot";
|
||||||
|
@ -501,10 +501,11 @@ define("FIT_WIDTH", 3);
|
|||||||
define("FIT_HEIGH", 4);
|
define("FIT_HEIGH", 4);
|
||||||
|
|
||||||
/* Items of maps */
|
/* Items of maps */
|
||||||
define("ITEM_TYPE_AGENT_NETWORKMAP", 0);
|
define("ITEM_TYPE_AGENT_NETWORKMAP", 0);
|
||||||
define("ITEM_TYPE_MODULE_NETWORKMAP", 1);
|
define("ITEM_TYPE_MODULE_NETWORKMAP", 1);
|
||||||
define("ITEM_TYPE_EDGE_NETWORKMAP", 2);
|
define("ITEM_TYPE_EDGE_NETWORKMAP", 2);
|
||||||
define("ITEM_TYPE_FICTIONAL_NODE", 3);
|
define("ITEM_TYPE_FICTIONAL_NODE", 3);
|
||||||
|
define("ITEM_TYPE_MODULEGROUP_NETWORKMAP", 4);
|
||||||
|
|
||||||
/* Another constants new networkmap */
|
/* Another constants new networkmap */
|
||||||
define("DEFAULT_NODE_WIDTH", 30);
|
define("DEFAULT_NODE_WIDTH", 30);
|
||||||
|
@ -232,7 +232,8 @@ function networkmap_generate_dot ($pandora_name, $group = 0,
|
|||||||
$relative = false, $text_filter = '', $l2_network_or_mixed = false,
|
$relative = false, $text_filter = '', $l2_network_or_mixed = false,
|
||||||
$ip_mask = null, $dont_show_subgroups = false, $strict_user = false,
|
$ip_mask = null, $dont_show_subgroups = false, $strict_user = false,
|
||||||
$size_canvas = null, $old_mode = false, $id_tag = 0,
|
$size_canvas = null, $old_mode = false, $id_tag = 0,
|
||||||
$show_all_modules = false) {
|
$show_all_modules = false, $only_modules_alerts = false,
|
||||||
|
$filter_module_group = 0, $show_modulegroup = false) {
|
||||||
|
|
||||||
global $config;
|
global $config;
|
||||||
|
|
||||||
@ -380,6 +381,8 @@ function networkmap_generate_dot ($pandora_name, $group = 0,
|
|||||||
$node_ref = array();
|
$node_ref = array();
|
||||||
$modules_node_ref = array();
|
$modules_node_ref = array();
|
||||||
|
|
||||||
|
$module_groups = array();
|
||||||
|
|
||||||
$node_count = 0;
|
$node_count = 0;
|
||||||
|
|
||||||
foreach ($agents as $agent) {
|
foreach ($agents as $agent) {
|
||||||
@ -402,28 +405,51 @@ function networkmap_generate_dot ($pandora_name, $group = 0,
|
|||||||
$modules = tags_get_agent_modules ($agent['id_agente'], false, $acltags, false, $filter, false);
|
$modules = tags_get_agent_modules ($agent['id_agente'], false, $acltags, false, $filter, false);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
$filter_get_modules = $filter;
|
||||||
|
if ($filter_module_group > 0) {
|
||||||
|
$filter_get_modules['id_module_group'] = $filter_module_group;
|
||||||
|
}
|
||||||
|
|
||||||
$modules = agents_get_modules(
|
$modules = agents_get_modules(
|
||||||
$agent['id_agente'], '*', $filter, true, true);
|
$agent['id_agente'], '*', $filter_get_modules, true, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($modules === false) {
|
if ($modules === false) {
|
||||||
$modules = array();
|
$modules = array();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$module_groups[$agent['id_node']] = array();
|
||||||
|
|
||||||
// Parse modules
|
// Parse modules
|
||||||
foreach ($modules as $key => $module) {
|
foreach ($modules as $key => $module) {
|
||||||
|
|
||||||
if (!$show_all_modules) {
|
if (!$show_all_modules || $show_snmp_modules) {
|
||||||
if ($module['id_tipo_modulo'] != 18 &&
|
if ($module['id_tipo_modulo'] != 18 &&
|
||||||
(!$l2_network || $module['id_tipo_modulo'] != 6)) {
|
(!$l2_network || $module['id_tipo_modulo'] != 6)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$status_module = modules_get_agentmodule_status(
|
||||||
|
$module['id_agente_modulo']);
|
||||||
|
|
||||||
|
if ($only_modules_alerts) {
|
||||||
|
if (($status_module != AGENT_MODULE_STATUS_NORMAL_ALERT) ||
|
||||||
|
($status_module != AGENT_MODULE_STATUS_WARNING_ALERT) ||
|
||||||
|
($status_module != AGENT_MODULE_STATUS_CRITICAL_ALERT)) {
|
||||||
|
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
$node_count ++;
|
$node_count ++;
|
||||||
$modules_node_ref[$module['id_agente_modulo']] = $node_count;
|
$modules_node_ref[$module['id_agente_modulo']] = $node_count;
|
||||||
$module['id_node'] = $node_count;
|
$module['id_node'] = $node_count;
|
||||||
$module['type'] = 'module';
|
$module['type'] = 'module';
|
||||||
|
$module['status'] = $status_module;
|
||||||
|
|
||||||
// Try to get the interface name
|
// Try to get the interface name
|
||||||
if (preg_match ("/_(.+)$/" , (string)$module['nombre'], $matches)) {
|
if (preg_match ("/_(.+)$/" , (string)$module['nombre'], $matches)) {
|
||||||
@ -432,11 +458,110 @@ function networkmap_generate_dot ($pandora_name, $group = 0,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Save node parent information to define edges later
|
|
||||||
$parents[$node_count] = $module['parent'] = $agent['id_node'];
|
|
||||||
|
//// Show module groups
|
||||||
|
if ($show_modulegroup) {
|
||||||
|
|
||||||
|
$id_node_module_group = array_search(
|
||||||
|
$module['id_module_group'],
|
||||||
|
$module_groups[$agent['id_node']]);
|
||||||
|
|
||||||
|
if ($id_node_module_group === false) {
|
||||||
|
$name = db_get_value('name', 'tmodule_group',
|
||||||
|
'id_mg', $module['id_module_group']);
|
||||||
|
|
||||||
|
if (empty($name))
|
||||||
|
$name = _('N/A');
|
||||||
|
|
||||||
|
$node_count ++;
|
||||||
|
|
||||||
|
$module_group = array();
|
||||||
|
$module_group['name'] = $name;
|
||||||
|
$module_group['type'] = "module_group";
|
||||||
|
$module_group['id_server'] = $agent['id_server'];
|
||||||
|
$module_group['id_node'] = $node_count;
|
||||||
|
$module_group['parent'] = $agent['id_node'];
|
||||||
|
$nodes[$node_count] = $module_group;
|
||||||
|
|
||||||
|
$id_node_module_group = $node_count;
|
||||||
|
|
||||||
|
$module_groups[$agent['id_node']][$node_count]
|
||||||
|
= $module['id_module_group'];
|
||||||
|
|
||||||
|
$parents[$id_node_module_group] =
|
||||||
|
$module_group['parent'];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//Change the status to module group to worst
|
||||||
|
//~ $status = modules_get_agentmodule_status(
|
||||||
|
//~ $module['id_agente_modulo'],
|
||||||
|
//~ false, true, $agent['id_server']);
|
||||||
|
|
||||||
|
switch ($module['status']) {
|
||||||
|
case 0: // Normal monitor
|
||||||
|
if (empty(
|
||||||
|
$nodes[$id_node_module_group]['status']))
|
||||||
|
{
|
||||||
|
$nodes[$id_node_module_group]['status'] = 0;
|
||||||
|
}
|
||||||
|
elseif ($nodes[$id_node_module_group]['status']
|
||||||
|
== -1) {
|
||||||
|
$nodes[$id_node_module_group]['status'] = 0;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 1: //Critical monitor
|
||||||
|
$nodes[$id_node_module_group]['status'] = 1;
|
||||||
|
break;
|
||||||
|
case 2: // Warning monitor
|
||||||
|
if (empty(
|
||||||
|
$nodes[$id_node_module_group]['status']))
|
||||||
|
{
|
||||||
|
$nodes[$id_node_module_group]['status'] = 0;
|
||||||
|
}
|
||||||
|
elseif ($nodes[$id_node_module_group]['status']
|
||||||
|
!= 1) {
|
||||||
|
$nodes[$id_node_module_group]['status'] = 2;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 4: // Alert fired
|
||||||
|
if (empty(
|
||||||
|
$nodes[$id_node_module_group]['status']))
|
||||||
|
{
|
||||||
|
$nodes[$id_node_module_group]['status'] = 4;
|
||||||
|
}
|
||||||
|
elseif (($nodes[$id_node_module_group]['status']
|
||||||
|
== 0) ||
|
||||||
|
($nodes[$id_node_module_group]['status']
|
||||||
|
== -1)) {
|
||||||
|
$nodes[$id_node_module_group]['status'] = 4;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
default: // Unknown monitor
|
||||||
|
$nodes[$id_node_module_group]['status'] = -1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
$module['parent'] = $id_node_module_group;
|
||||||
|
|
||||||
|
$parents[$module['id_node']] =
|
||||||
|
$id_node_module_group;
|
||||||
|
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$parents[$module['id_node']] =
|
||||||
|
$module['parent'] =
|
||||||
|
$agent['id_node'];
|
||||||
|
}
|
||||||
|
////////////////////////////////////////////////////////
|
||||||
|
|
||||||
// Add node
|
// Add node
|
||||||
$nodes[$node_count] = $module;
|
$nodes[$module['id_node']] = $module;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -444,7 +569,7 @@ function networkmap_generate_dot ($pandora_name, $group = 0,
|
|||||||
// Drop the modules without a partner if l2_network is true
|
// Drop the modules without a partner if l2_network is true
|
||||||
// and the snmp interfaces token is false
|
// and the snmp interfaces token is false
|
||||||
if ($l2_network_or_mixed === 'mix_l2_l3') {
|
if ($l2_network_or_mixed === 'mix_l2_l3') {
|
||||||
if (!$show_all_modules) {
|
if (!$show_all_modules || $show_snmp_modules) {
|
||||||
foreach ($modules_node_ref as $id_module => $node_count) {
|
foreach ($modules_node_ref as $id_module => $node_count) {
|
||||||
if (! modules_relation_exists($id_module, array_keys($modules_node_ref))) {
|
if (! modules_relation_exists($id_module, array_keys($modules_node_ref))) {
|
||||||
if ($show_snmp_modules) {
|
if ($show_snmp_modules) {
|
||||||
@ -551,6 +676,10 @@ function networkmap_generate_dot ($pandora_name, $group = 0,
|
|||||||
$font_size) . "\n\t\t";
|
$font_size) . "\n\t\t";
|
||||||
$stats['modules'][] = $node['id_agente_modulo'];
|
$stats['modules'][] = $node['id_agente_modulo'];
|
||||||
break;
|
break;
|
||||||
|
case 'module_group':
|
||||||
|
$graph .= networkmap_create_module_group_node ($node , $simple, $font_size, true, $node['id_server']) . "\n\t\t";
|
||||||
|
$stats['module_group'][] = null;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1268,7 +1397,7 @@ function networkmap_create_module_group_node ($module_group, $simple = 0, $font_
|
|||||||
$node = $module_group['id_node'].' [ color="' . $status_color .
|
$node = $module_group['id_node'].' [ color="' . $status_color .
|
||||||
'", fontsize='.$font_size.', style="filled", ' .
|
'", fontsize='.$font_size.', style="filled", ' .
|
||||||
'fixedsize=true, width=0.30, height=0.30, ' .
|
'fixedsize=true, width=0.30, height=0.30, ' .
|
||||||
'label=<<TABLE CELLPADDING="0" CELLSPACING="0" BORDER="0"><TR><TD>' .
|
'label=<<TABLE data-status="' . $module_group['status'] . '" CELLPADDING="0" CELLSPACING="0" BORDER="0"><TR><TD>' .
|
||||||
io_safe_output($module_group['name']) . '</TD></TR></TABLE>>,
|
io_safe_output($module_group['name']) . '</TD></TR></TABLE>>,
|
||||||
shape="square", URL="' . $url . '",
|
shape="square", URL="' . $url . '",
|
||||||
tooltip="' . $url_tooltip . '"];';
|
tooltip="' . $url_tooltip . '"];';
|
||||||
|
Loading…
x
Reference in New Issue
Block a user