"; if (empty($graph)) { echo "var graph = null;\n"; return; } else { echo "var graph = \n"; } } echo "{\n"; echo "'nodes' : \n"; echo "[\n"; $first = true; foreach ($graph['nodes'] as $id => $node) { if ($first === false) { echo ",\n"; } $first = false; echo "{ 'id' : ".$id.", 'name' : '".$node['label']."', 'url' : '".$node['url']."', 'tooltip' : '".$node['tooltip']."', 'default_tooltip' : 1, 'tooltip_content' : ' ".html_print_image('images/spinner.gif', true)."', 'color' : '".$node['color']."'}\n"; } echo "],\n"; echo "'links' : \n"; echo "[\n"; $first = true; foreach ($graph['lines'] as $line) { if ($first === false) { echo ",\n"; } $first = false; echo "{ 'source' : ".$line['source'].", 'target' : ".$line['target']."}\n"; } echo "]\n"; echo "}\n"; if ($js_tags === true) { echo ";\n"; echo ''; } } function networkmap_generate_hash( $pandora_name, $group=0, $simple=0, $font_size=12, $layout='radial', $nooverlap=0, $zoom=1, $ranksep=2.5, $center=0, $regen=1, $pure=0, $id_networkmap=0, $show_snmp_modules=0, $cut_names=true, $relative=false, $text_filter='' ) { $graph = networkmap_generate_dot( $pandora_name, $group, $simple, $font_size, $layout, $nooverlap, $zoom, $ranksep, $center, $regen, $pure, $id_networkmap, $show_snmp_modules, $cut_names, $relative, $text_filter, false, null, false ); $return = []; if (empty($graph) === false) { $graph = str_replace("\r", "\n", $graph); $graph = str_replace("\n", ' ', $graph); // Removed the head. preg_match('/graph networkmap {(.*)}/', $graph, $matches); $graph = $matches[1]; // Get the lines and nodes. $tokens = preg_split('/; /', $graph); foreach ($tokens as $token) { if (empty($token)) { continue; } // Ignore the head rests. if (preg_match('/(.+)\s*\[(.*)\]/', $token) != 0) { $items[] = $token; } } $lines = []; $nodes = []; foreach ($items as $item) { $matches = null; preg_match('/(.+)\s*\[(.*)\]/', $item, $matches); if (empty($matches) === true) { continue; } $id_item = trim($matches[1]); $content_item = trim($matches[2]); // Check if is a edge or node. if (strstr($id_item, '--') !== false) { // Edge. $lines[$id_item] = $content_item; } else { // Node. $id_item = (int) $id_item; $nodes[$id_item] = $content_item; } } foreach ($nodes as $key => $node) { if ($key != 0) { // Get label. $matches = null; preg_match('/label=(.*),/', $node, $matches); $label = $matches[1]; $matches = null; preg_match( '/\\(.*?)\<\/TD\>\<\/TR\>/', $label, $matches ); $label = str_replace($matches[0], '', $label); $matches = null; preg_match( '/\\(.*?)\<\/TD\>\<\/TR\>/', $label, $matches ); $label = $matches[1]; // Get color. $matches = null; preg_match('/color="([^"]*)/', $node, $matches); $color = $matches[1]; // Get tooltip. $matches = null; preg_match('/tooltip="([^"]*)/', $node, $matches); $tooltip = $matches[1]; // Get URL. $matches = null; preg_match('/URL="([^"]*)/', $node, $matches); $url = $matches[1]; $return['nodes'][$key]['label'] = $label; $return['nodes'][$key]['color'] = $color; $return['nodes'][$key]['tooltip'] = $tooltip; $return['nodes'][$key]['url'] = $url; } else { // Get tooltip. $matches = null; preg_match('/tooltip="([^"]*)/', $node, $matches); $tooltip = $matches[1]; // Get URL. $matches = null; preg_match('/URL="([^"]*)/', $node, $matches); $url = $matches[1]; $return['nodes'][$key]['label'] = 'Pandora FMS'; $return['nodes'][$key]['color'] = '#7EBE3F'; $return['nodes'][$key]['tooltip'] = $tooltip; $return['nodes'][$key]['url'] = $url; } } ksort($return['nodes']); foreach ($lines as $key => $line) { $data = []; $points = explode(' -- ', $key); $data['source'] = (int) $points[0]; $data['target'] = (int) $points[1]; $return['lines'][] = $data; } } return $return; } function networkmap_generate_dot( $pandora_name, $group=0, $simple=0, $font_size=12, $layout='radial', $nooverlap=0, $zoom=1, $ranksep=2.5, $center=0, $regen=1, $pure=0, $id_networkmap=0, $show_snmp_modules=0, $cut_names=true, $relative=false, $text_filter='', $ip_mask=null, $dont_show_subgroups=false, $strict_user=false, $size_canvas=null, $old_mode=false, $map_filter=[] ) { global $config; $nooverlap = 1; $parents = []; $orphans = []; $filter = []; $filter['disabled'] = 0; if (empty($text_filter) === false) { $filter[] = '(nombre LIKE "%'.$text_filter.'%")'; } /* * Select data origin. * group * discovery task * - Cloud * - Application * - Standar or custom * network/mask */ if ($group >= 0 && empty($ip_mask)) { if ($dont_show_subgroups) { $filter['id_grupo'] = $group; } else { $childrens = groups_get_children($group, null, true); if (empty($childrens) === false) { $childrens = array_keys($childrens); $filter['id_grupo'] = $childrens; $filter['id_grupo'][] = $group; } else { $filter['id_grupo'] = $group; } } // Order by id_parent ascendant for to avoid the bugs // because the first agents to process in the next // foreach loop are without parent (id_parent = 0) // Get agents data. $agents = agents_get_agents( $filter, [ 'id_grupo', 'nombre', 'id_os', 'id_parent', 'id_agente', 'normal_count', 'warning_count', 'critical_count', 'unknown_count', 'total_count', 'notinit_count', ], 'AR', [ 'field' => 'id_parent', 'order' => 'ASC', ] ); } else if ($group == -666) { $agents = false; } else if (empty($ip_mask) === false) { $agents = networkmap_get_nodes_from_ip_mask( $ip_mask ); } else { $agents = agents_get_agents( $filter, [ 'id_grupo', 'nombre', 'id_os', 'id_parent', 'id_agente', 'normal_count', 'warning_count', 'critical_count', 'unknown_count', 'total_count', 'notinit_count', ], 'AR', [ 'field' => 'id_parent', 'order' => 'ASC', ] ); } if ($agents === false) { $agents = []; } // Open Graph. $graph = networkmap_open_graph( $layout, $nooverlap, $pure, $zoom, $ranksep, $font_size, $size_canvas, $map_filter ); // Parse agents. $nodes = []; // Add node refs. $node_ref = []; $modules_node_ref = []; $node_count = 0; foreach ($agents as $agent) { $node_count++; $node_ref[$agent['id_agente']] = $node_count; $agent['id_node'] = $node_count; $agent['type'] = 'agent'; // Add node. $nodes[$node_count] = $agent; $filter = []; $filter['disabled'] = 0; // Get agent modules data. $modules = agents_get_modules($agent['id_agente'], '*', $filter, true, true); if ($modules === false) { $modules = []; } // Parse modules. foreach ($modules as $key => $module) { $node_count++; $modules_node_ref[$module['id_agente_modulo']] = $node_count; $module['id_node'] = $node_count; $module['type'] = 'module'; // Try to get the interface name. if (preg_match('/(.+)_ifOperStatus$/', (string) $module['nombre'], $matches)) { if ($matches[1]) { $module['nombre'] = $matches[1]; // Save node parent information to define edges later. $parents[$node_count] = $module['parent'] = $agent['id_node']; // Add node. $nodes[$node_count] = $module; } } else { $sql_a = sprintf( 'SELECT id FROM tmodule_relationship WHERE module_a = %d AND type = "direct"', $module['id_agente_modulo'] ); $sql_b = sprintf( 'SELECT id FROM tmodule_relationship WHERE module_b = %d AND type = "direct"', $module['id_agente_modulo'] ); $have_relations_a = db_get_value_sql($sql_a); $have_relations_b = db_get_value_sql($sql_b); if ($have_relations_a || $have_relations_b) { // Save node parent information to define edges later. $parents[$node_count] = $module['parent'] = $agent['id_node']; // Add node. $nodes[$node_count] = $module; } } } } foreach ($modules_node_ref as $id_module => $node_count) { $module_type = modules_get_agentmodule_type($id_module); } // Addded the relationship of parents of agents. foreach ($agents as $agent) { if ($agent['id_parent'] != '0' && array_key_exists($agent['id_parent'], $node_ref)) { $parents[$node_ref[$agent['id_agente']]] = $node_ref[$agent['id_parent']]; } else { $orphans[$node_ref[$agent['id_agente']]] = 1; } } // Create a central node if orphan nodes exist. if (count($orphans) > 0 || empty($nodes) === true) { $graph .= networkmap_create_pandora_node($pandora_name, $font_size, $simple); } // Define edges for orphan nodes. foreach (array_keys($orphans) as $node) { $graph .= networkmap_create_edge('0', $node, $layout, $nooverlap, $pure, $zoom, $ranksep, $simple, $regen, $font_size, $group, 'operation/agentes/networkmap', 'topology', $id_networkmap); } // Create void statistics array. $stats = []; // Create nodes. foreach ($nodes as $node_id => $node) { if ($center > 0 && networkmap_is_descendant($node_id, $center, $parents) === false) { unset($parents[$node_id]); unset($orphans[$node_id]); unset($nodes[$node_id]); continue; } switch ($node['type']) { case 'agent': $graph .= networkmap_create_agent_node( $node, $simple, $font_size, $cut_names, $relative )."\n\t\t"; $stats['agents'][] = $node['id_agente']; break; case 'module': $graph .= networkmap_create_module_node( $node, $simple, $font_size )."\n\t\t"; $stats['modules'][] = $node['id_agente_modulo']; break; default: // Do none. break; } } // Define edges. foreach ($parents as $node => $parent_id) { // Verify that the parent is in the graph. if (isset($nodes[$parent_id]) === true) { $graph .= networkmap_create_edge( $parent_id, $node, $layout, $nooverlap, $pure, $zoom, $ranksep, $simple, $regen, $font_size, $group, 'operation/agentes/networkmap', 'topology', $id_networkmap ); } else { $orphans[$node] = 1; } } // Define edges for the module interfaces relations // Get the remote_snmp_proc relations. $relations = modules_get_relations(); if ($relations === false) { $relations = []; } foreach ($relations as $relation) { $module_a = $relation['module_a']; $agent_a = modules_get_agentmodule_agent($module_a); $module_b = $relation['module_b']; $agent_b = modules_get_agentmodule_agent($module_b); if (isset($modules_node_ref[$module_a]) === true && isset($modules_node_ref[$module_b]) === true) { $graph .= networkmap_create_edge( $modules_node_ref[$module_a], $modules_node_ref[$module_b], $layout, $nooverlap, $pure, $zoom, $ranksep, $simple, $regen, $font_size, $group, 'operation/agentes/networkmap', 'topology', $id_networkmap ); } else if (isset($node_ref[$agent_a]) === true && isset($modules_node_ref[$module_b]) === true) { $graph .= networkmap_create_edge( $node_ref[$agent_a], $modules_node_ref[$module_b], $layout, $nooverlap, $pure, $zoom, $ranksep, $simple, $regen, $font_size, $group, 'operation/agentes/networkmap', 'topology', $id_networkmap ); } else if (isset($node_ref[$agent_b]) === true && isset($modules_node_ref[$module_a]) === true) { $graph .= networkmap_create_edge( $node_ref[$agent_b], $modules_node_ref[$module_a], $layout, $nooverlap, $pure, $zoom, $ranksep, $simple, $regen, $font_size, $group, 'operation/agentes/networkmap', 'topology', $id_networkmap ); } else if (isset($node_ref[$agent_a]) === true && isset($node_ref[$agent_b]) === true) { $graph .= networkmap_create_edge( $node_ref[$agent_a], $node_ref[$agent_b], $layout, $nooverlap, $pure, $zoom, $ranksep, $simple, $regen, $font_size, $group, 'operation/agentes/networkmap', 'topology', $id_networkmap ); } } // Close graph. $graph .= networkmap_close_graph(); return $graph; } /** * Returns an edge definition. * * @param mixed $head Head. * @param mixed $tail Tail. * @param string $layout Layout. * @param string $nooverlap Nooverlap. * @param integer $pure Pure. * @param float $zoom Zoom. * @param float $ranksep Ranksep. * @param integer $simple Simple. * @param integer $regen Regen. * @param integer $font_size Font_size. * @param integer $group Group. * @param string $sec2 Sec2. * @param string $tab Tab. * @param integer $id_networkmap Id_networkmap. * * @return string Dot string. */ function networkmap_create_edge( $head, $tail, $layout, $nooverlap, $pure, $zoom, $ranksep, $simple, $regen, $font_size, $group, $sec2='operation/agentes/networkmap', $tab='topology', $id_networkmap=0 ) { if (is_metaconsole() === true) { $url = ''; } else { $url = 'index.php?sec=estado&sec2='.$sec2.'&tab='.$tab.'&'; $url .= 'recenter_networkmap=1¢er='.$head.'&'; $url .= 'layout='.$layout.'&nooverlap='.$nooverlap.'&'; $url .= 'pure='.$pure.'&zoom='.$zoom.'&ranksep='.$ranksep.'&'; $url .= 'simple='.$simple.'®en=1&font_size='.$font_size.'&'; $url .= 'group='.$group.'&id_networkmap='.$id_networkmap; } // Option edgeURL allows node navigation. $edge = "\n".$head.' -- '.$tail; $edge .= '[len='.$ranksep.', color="#BDBDBD", headclip=false, tailclip=false, edgeURL="'.$url.'"];'; $edge .= "\n"; return $edge; } /** * Returns a node definition. * * @param boolean $agent Id Agent. * @param integer $simple Iapa. * @param integer $font_size Iapa. * @param boolean $cut_names Iapa. * @param boolean $relative Iapa. * @param boolean $metaconsole Iapa. * @param integer $id_server Iapa. * @param boolean $strict_user Iapa. * * @return string */ function networkmap_create_agent_node( $agent, $simple=0, $font_size=10, $cut_names=true, $relative=false, $metaconsole=false, $id_server=null, $strict_user=false ) { global $config; global $hack_networkmap_mobile; if ($strict_user === true) { include_once $config['homedir'].'/include/functions_tags.php'; $acltags = tags_get_user_groups_and_tags($config['id_user'], 'AR', $strict_user); $agent_filter = ['id' => $agent['id_agente']]; $strict_data['normal_count'] = (int) groups_get_normal_monitors($agent['id_grupo'], $agent_filter, [], $strict_user, $acltags); $strict_data['warning_count'] = (int) groups_get_warning_monitors($agent['id_grupo'], $agent_filter, [], $strict_user, $acltags); $strict_data['critical_count'] = (int) groups_get_critical_monitors($agent['id_grupo'], $agent_filter, [], $strict_user, $acltags); $strict_data['unknown_count'] = (int) groups_get_unknown_monitors($agent['id_grupo'], $agent_filter, [], $strict_user, $acltags); $strict_data['notinit_count'] = (int) groups_get_not_init_monitors($agent['id_grupo'], $agent_filter, [], $strict_user, $acltags); $strict_data['total_count'] = (int) groups_get_total_monitors($agent['id_grupo'], $agent_filter, [], $strict_user, $acltags); $status = agents_get_status_from_counts($strict_data); } else { $status = agents_get_status_from_counts($agent); } if (is_metaconsole() === true) { $server_data = db_get_row( 'tmetaconsole_setup', 'id', $agent['id_server'] ); } if (empty($server_data) === true) { $server_name = ''; $server_id = ''; $console_url = ''; } else { $server_name = $server_data['server_name']; $server_id = $server_data['id']; $console_url = $server_data['server_url'].'/'; } // Set node status. switch ($status) { case AGENT_STATUS_NORMAL: $status_color = COL_NORMAL; break; case AGENT_STATUS_CRITICAL: $status_color = COL_CRITICAL; break; case AGENT_STATUS_WARNING: $status_color = COL_WARNING; break; case AGENT_STATUS_ALERT_FIRED: $status_color = COL_ALERTFIRED; break; case AGENT_STATUS_NOT_INIT: $status_color = COL_NOTINIT; break; default: $status_color = COL_UNKNOWN; break; } // Short name. $name = io_safe_output($agent['nombre']); if ((strlen($name) > 16) && ($cut_names)) { $name = ui_print_truncate_text($name, 16, false, true, false); } if ((int) $simple === 0) { if ($hack_networkmap_mobile) { $img_node = ui_print_os_icon($agent['id_os'], false, true, true, true, true, true); $img_node = $config['homedir'].'/'.$img_node; $img_node = ''; } else { // Set node icon. $img_node = ui_print_os_icon($agent['id_os'], false, true, true, true, true, $relative); $img_node = str_replace($config['homeurl'].'/', '', $img_node); $img_node = str_replace($config['homeurl'], '', $img_node); if (is_metaconsole() === true) { $img_node = str_replace('../../', '', $img_node); } if ($relative === true) { $img_node = html_print_image($img_node, true, false, false, true); } else { $img_node = html_print_image($img_node, true, false, false, false); } } if (is_metaconsole() === true) { if (can_user_access_node()) { $url = ui_meta_get_url_console_child( $id_server, 'estado', 'operation/agentes/ver_agente&id_agente='.$agent['id_agente'] ); } else { $url = ''; } $url_tooltip = '../../ajax.php?page=operation/agentes/ver_agente&get_agent_status_tooltip=1&id_agent='.$agent['id_agente'].'&metaconsole=1&id_server='.$agent['id_server']; } else { $url = 'index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente='.$agent['id_agente']; $url_tooltip = 'ajax.php?page=operation/agentes/ver_agente&get_agent_status_tooltip=1&id_agent='.$agent['id_agente']; } $node = "\n".$agent['id_node'].' [ parent="'.$agent['id_parent'].'", color="'.$status_color.'", fontsize='.$font_size.', style="filled", fixedsize=true, width=0.40, height=0.40, label=<
'.$img_node.'
'.io_safe_input($name).'
>, shape="doublecircle", URL="'.$url.'", tooltip="'.$url_tooltip.'"];'."\n"; } else { $ajax_prefix = ''; $meta_params = ''; if (is_metaconsole() === true) { $ajax_prefix = '../../'; $meta_params = '&metaconsole=1&id_server='.$id_server; } if (can_user_access_node()) { $url_node_link = ', URL="'.$console_url.'index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente='.$agent['id_agente'].'"'; } else { $url_node_link = ''; } $node = $agent['id_node'].' [ parent="'.$agent['id_parent'].'", color="'.$status_color.'", fontsize='.$font_size.', shape="doublecircle"'.$url_node_link.', style="filled", fixedsize=true, width=0.20, height=0.20, label="", tooltip="'.$ajax_prefix.'ajax.php?page=operation/agentes/ver_agente&get_agent_status_tooltip=1&id_agent='.$agent['id_agente'].$meta_params.'"];'."\n"; } return $node; } /** * Returns a module node definition. * * @param array $module Module definition. * @param integer $simple Simple. * @param integer $font_size Font size. * @param boolean $metaconsole Metaconsole. * @param integer $id_server Id server. * * @return string */ function networkmap_create_module_node( $module, $simple=0, $font_size=10, $metaconsole=false, $id_server=null ) { global $config; global $hack_networkmap_mobile; if (isset($module['status']) === true) { $status = $module['status']; } else { $status = modules_get_agentmodule_status( $module['id_agente_modulo'], false, $metaconsole, $id_server ); } // Set node status. switch ($status) { case AGENT_MODULE_STATUS_NORMAL: // Normal monitor. $status_color = COL_NORMAL; break; case AGENT_MODULE_STATUS_CRITICAL_BAD: // Critical monitor. $status_color = COL_CRITICAL; break; case AGENT_MODULE_STATUS_WARNING: // Warning monitor. $status_color = COL_WARNING; break; case AGENT_STATUS_ALERT_FIRED: // Alert fired. $status_color = COL_ALERTFIRED; break; default: // Unknown monitor. $status_color = COL_UNKNOWN; break; } if ($hack_networkmap_mobile) { $img_node = ui_print_moduletype_icon($module['id_tipo_modulo'], true, true, false, true); $img_node = $config['homedir'].'/'.$img_node; $img_node = ''; } else { $img_node = ui_print_moduletype_icon($module['id_tipo_modulo'], true, true, false); } if ($simple == 0) { if (is_metaconsole() === true) { $url = ''; $url_tooltip = '../../ajax.php?page=operation/agentes/ver_agente&get_agentmodule_status_tooltip=1&id_module='.$module['id_agente_modulo'].'&metaconsole=1&id_server='.$module['id_server']; } else { $url = 'index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente='.$module['id_agente']; $url_tooltip = 'ajax.php?page=operation/agentes/ver_agente&get_agentmodule_status_tooltip=1&id_module='.$module['id_agente_modulo']; } $node = $module['id_node'].' [ id_agent="'.$module['id_agente'].'", color="'.$status_color.'", fontsize='.$font_size.', style="filled", fixedsize=true, width=0.30, height=0.30, label=<
'.$img_node.'
'.io_safe_output($module['nombre']).'
>, shape="circle", URL="'.$url.'", tooltip="'.$url_tooltip.'"];'; } else { if (is_metaconsole() === true) { $url = 'TODO'; $url_tooltip = '../../ajax.php?page=operation/agentes/ver_agente&get_agentmodule_status_tooltip=1&id_module='.$module['id_agente_modulo'].'&metaconsole=1&id_server='.$module['id_server']; } else { $url = 'index.php?sec=estado&sec2=operation/agentes/ver_agente&id_agente='.$module['id_agente']; $url_tooltip = 'ajax.php?page=operation/agentes/ver_agente&get_agentmodule_status_tooltip=1&id_module='.$module['id_agente_modulo']; } $node = $module['id_node'].' [ id_agent="'.$module['id_agente'].'", color="'.$status_color.'", fontsize='.$font_size.', shape="circle", URL="'.$url.'", style="filled", fixedsize=true, width=0.20, height=0.20, label="", tooltip="'.$url_tooltip.'"];'; } return $node; } /** * Returns the definition of the central module. * * @param string $name Name. * @param integer $font_size Font size. * @param integer $simple Simple. * @param array $stats Stats. * * @return string */ function networkmap_create_pandora_node( $name, $font_size=10, $simple=0, $stats=[] ) { global $hack_networkmap_mobile; global $config; $summary = []; if (isset($stats['policies'])) { $summary['policies'] = count($stats['policies']); } if (isset($stats['groups']) === true) { // TODO: GET STATUS OF THE GROUPS AND ADD IT TO SUMMARY. $summary['groups'] = count($stats['groups']); } if (isset($stats['agents']) === true) { // TODO: GET STATUS OF THE AGENTS AND ADD IT TO SUMMARY. $summary['agents'] = count($stats['agents']); } if (isset($stats['modules']) === true) { // TODO: GET STATUS OF THE MODULES AND ADD IT TO SUMMARY. $summary['modules'] = count($stats['modules']); } $stats_json = base64_encode(json_encode($summary)); $img_src = ui_get_logo_to_center_networkmap(); if (is_metaconsole() === true) { $url_tooltip = '../../ajax.php?page=include/ajax/networkmap.ajax&action=get_networkmap_summary&stats='.$stats_json.'&metaconsole=1'; $url = ''; $color = '#052938'; } else { $url_tooltip = 'ajax.php?page=include/ajax/networkmap.ajax&action=get_networkmap_summary&stats='.$stats_json.'", URL="index.php?sec=estado&sec2=operation/agentes/group_view'; $url = 'index.php?sec=estado&sec2=operation/agentes/group_view'; $color = '#373737'; } if ($hack_networkmap_mobile) { $img = ''."".''; } else { $image = html_print_image(ui_get_logo_to_center_networkmap(), true, false, false, true); $img = ''.$image.''; } $name = "".$name.''; $label = "".$img.$name.'
'; if ($simple == 1) { $label = ''; } $node = '0 [ color="'.$color.'", fontsize='.$font_size.', style="filled", fixedsize=true, width=0.8, height=0.6, label=<'.$label.'>, shape="ellipse", tooltip="'.$url_tooltip.'", URL="'.$url.'" ];'; return $node; } // Opens a graph definition. function networkmap_open_graph( $layout, $nooverlap, $pure, $zoom, $rank_sep, $font_size, $size_canvas, $map_filter=[] ) { global $config; if (isset($config['networkmap_max_width']) === true) { $size_x = ($config['networkmap_max_width'] / 100); $size_y = ($size_x * 0.8); } else { $size_x = 8; $size_y = 5.4; $size = ''; } if ($zoom > 0) { $size_x *= $zoom; $size_y *= $zoom; } $size = $size_x.','.$size_y; if (empty($size_canvas) === false) { $size = ($size_canvas['x'] / 100).','.($size_canvas['y'] / 100); } // Graphviz custom values. if (isset($map_filter['node_sep']) === true) { $node_sep = $map_filter['node_sep']; } else { $node_sep = 0.1; } if (isset($map_filter['rank_sep']) === true) { $rank_sep = $map_filter['rank_sep']; } else { if ($layout === 'radial') { $rank_sep = 1.0; } else { $rank_sep = 0.5; } } if (isset($map_filter['mindist']) === true) { $mindist = $map_filter['mindist']; } else { $mindist = 1.0; } if (isset($map_filter['kval']) === true) { $kval = $map_filter['kval']; } else { $kval = 0.1; } // BEWARE: graphwiz DONT use single ('), you need double ("). $head = 'graph networkmap { dpi=100; bgcolor="transparent"; labeljust=l; margin=0; pad="0.75,0.75";'; if (empty($nooverlap) === false) { $head .= 'overlap="false";'; $head .= 'outputorder=first;'; } if ($layout === 'flat' || $layout === 'spring1' || $layout === 'spring2') { if (empty($nooverlap) === false) { $head .= 'overlap="scalexy";'; } if ($layout == 'spring1' || $layout == 'spring2') { $head .= 'sep="'.$node_sep.'";'; } if ($layout === 'flat') { $head .= 'ranksep="'.$rank_sep.'";'; } else if ($layout === 'spring2') { $head .= 'K="'.$kval.'";'; } } else if ($layout === 'radial') { $head .= 'ranksep="'.$rank_sep.'";'; } else if ($layout === 'circular') { $head .= 'mindist="'.$mindist.'";'; } $head .= 'ratio="fill";'; $head .= 'root=0;'; $head .= 'nodesep="'.$node_sep.'";'; $head .= 'size="'.$size.'";'; $head .= "\n"; return $head; } /** * Closes a graph definition * * @return string */ function networkmap_close_graph() { return '}'; } /** * Returns the filter used to achieve the desired layout * * @param string $layout Layout. * * @return string Formatted layout. */ function networkmap_get_filter($layout) { switch ($layout) { case 'flat': $output = 'dot'; break; case 'circular': $output = 'circo'; break; case 'spring1': $output = 'neato'; break; case 'spring2': $output = 'fdp'; break; case 'radial': default: $output = 'twopi'; break; } return $output; } /** * Get a user networkmaps. * * @param integer $id_user Networkmap id to get. * @param integer $type Type. * @param boolean $optgrouped Grouped. * @param boolean $return_all_group Return all groups. * * @return array Networkmap with the given id. False if not available or readable. */ function networkmap_get_networkmaps( $id_user=null, $type=null, $optgrouped=true, $return_all_group=true ) { global $config; if (empty($id_user) === true) { $id_user = $config['id_user']; } // Configure filters. $where = []; $where['type'] = MAP_TYPE_NETWORKMAP; $where['id_group'] = array_keys( users_get_groups( $id_user, 'AR', $return_all_group ) ); if (empty($type) === false) { $where['subtype'] = $type; } $where['order'][0]['field'] = 'type'; $where['order'][0]['order'] = 'DESC'; $where['order'][1]['field'] = 'name'; $where['order'][1]['order'] = 'ASC'; if ((bool) is_metaconsole() === true) { $servers = metaconsole_get_connection_names(); foreach ($servers as $server) { $connection = metaconsole_get_connection($server); if (metaconsole_connect($connection) != NOERR) { continue; } $tmp_maps = db_get_all_rows_filter('tmap', $where); if ($tmp_maps !== false) { foreach ($tmp_maps as $g) { $g['id_t'] = $g['id']; $g['id'] = $connection['id'].'_'.$g['id']; $g['name'] = $g['name'].' ('.$connection['server_name'].')'; $networkmaps_raw[] = $g; } } metaconsole_restore_db(); } } else { $networkmaps_raw = db_get_all_rows_filter('tmap', $where); } if (empty($networkmaps_raw) === true) { return []; } $networkmaps = []; foreach ($networkmaps_raw as $networkmapitem) { if ($optgrouped === true) { $networkmaps[$networkmapitem['id']] = [ 'name' => $networkmapitem['name'], 'optgroup' => networkmap_type_to_str_type($networkmapitem['subtype']), ]; } else { $networkmaps[$networkmapitem['id']] = $networkmapitem['name']; } } return $networkmaps; } /** * Covert Networkmap type to string type * * @param integer $type Type of network map. * * @return string */ function networkmap_type_to_str_type($type) { switch ($type) { case MAP_SUBTYPE_GROUPS: $output = __('Groups'); break; case MAP_SUBTYPE_POLICIES: $output = __('Policies'); break; case MAP_SUBTYPE_RADIAL_DYNAMIC: $output = __('Radial dynamic'); break; case MAP_SUBTYPE_TOPOLOGY: $output = __('Topology'); break; default: $output = ''; break; } return $output; } /** * Get different networkmaps types for creation. * * @param boolean $strict_user Defines strict user. * * @return array Networkmap diferent types. */ function networkmap_get_types($strict_user=false) { $networkmap_types = []; $is_enterprise = enterprise_include_once('include/functions_policies.php'); $networkmap_types['topology'] = __('Create a new topology map'); $networkmap_types['groups'] = __('Create a new group map'); $networkmap_types['dynamic'] = __('Create a new dynamic map'); if ($strict_user === false) { $networkmap_types['radial_dynamic'] = __('Create a new radial dynamic map'); } if (($is_enterprise !== ENTERPRISE_NOT_HOOK) && ($strict_user === false)) { $enterprise_types = enterprise_hook('policies_get_networkmap_types'); $networkmap_types = array_merge($networkmap_types, $enterprise_types); } return $networkmap_types; } /** * Retrieve agent list matching desired network. * * @param string $ip_mask Networks. * @param boolean $return_ids_only Retrieve only ids. * * @return array Of agents. */ function networkmap_get_nodes_from_ip_mask( $ip_mask, $return_ids_only=false, $separator=',', ) { $list_ip_masks = explode($separator, $ip_mask); if (empty($list_ip_masks) === true) { return []; } $agents = []; foreach ($list_ip_masks as $subnet) { $net = explode('/', $subnet); // Calculate real network address. Avoid user bad input. $mask = ~((1 << (32 - $net[1])) - 1); $network = long2ip(ip2long($net[0]) & $mask); $sql = sprintf( 'SELECT * FROM `tagente` INNER JOIN (SELECT DISTINCT `id_agent` FROM (SELECT `id_agente` AS "id_agent", `direccion` AS "ip" FROM `tagente` UNION SELECT ag.`id_agent`, a.`ip` FROM `taddress_agent` ag INNER JOIN `taddress` a ON ag.id_a=a.id_a ) t_tmp WHERE (-1 << %d) & INET_ATON(t_tmp.ip) = INET_ATON("%s") ) t_res ON t_res.`id_agent` = `tagente`.`id_agente`', (32 - $net[1]), $network ); $subnet_agents = db_get_all_rows_sql($sql); if ($subnet_agents !== false) { $agents = array_merge($agents, $subnet_agents); } } if ($return_ids_only === false) { $agents = array_reduce( $agents, function ($carry, $item) { $carry[$item['id_agente']] = $item; return $carry; }, [] ); } else { $agents = array_reduce( $agents, function ($carry, $item) { $carry[$item['id_agente']] = $item['id_agente']; return $carry; }, [] ); } return $agents; } /** * Get all interfaces from modules * * @param integer $id_agent Id agent. * * @return array */ function modules_get_all_interfaces($id_agent) { $return = []; $modules = db_get_all_rows_filter( 'tagente_modulo', ['id_agente' => $id_agent] ); if (empty($modules) === false) { foreach ($modules as $module) { if (preg_match('/(.+)_ifOperStatus$/', (string) $module['nombre'], $matches)) { if ($matches[1]) { $return[] = $module; } } } } return $return; } /** * Delete network map. * * @param integer $id Id. * * @return integer Number of rows affected */ function networkmap_delete_networkmap($id=0) { // Relations. $result = delete_relations($id); // Nodes. $result = delete_nodes($id); // Map. $result = db_process_sql_delete('tmap', ['id' => $id]); return $result; } /** * Delete nodes * * @param integer $id_map Id Map. * * @return mixed */ function networkmap_delete_nodes($id_map) { return db_process_sql_delete('titem', ['id_map' => $id_map]); } /** * Delete relations given id_map * * @param integer $id_map Id map. * * @return integer result */ function networkmap_delete_relations($id_map) { $result = db_process_sql_delete('trel_item', ['id_map' => $id_map]); return $result; } function get_networkmaps($id) { $groups = array_keys(users_get_groups(null, 'MW')); $filter = []; $filter['id_group'] = $groups; $filter['id'] = '<>'.$id; $networkmaps = db_get_all_rows_filter('tmap', $filter); if ($networkmaps === false) { $networkmaps = []; } $return = []; $return[0] = __('None'); foreach ($networkmaps as $networkmap) { $return[$networkmap['id']] = $networkmap['name']; } return $return; } /** * Translates node (nodes_and_relations) into JS node. * * @param array $node Node. * @param integer $count Count. * @param integer $count_item_holding_area Count_item_holding_area. * @param boolean $simulated Simulated. * * @return array JS nodes. */ function networkmap_db_node_to_js_node( $node, &$count, &$count_item_holding_area, $simulated=false ) { global $config; $networkmap = db_get_row('tmap', 'id', $node['id_map']); $networkmap['filter'] = json_decode($networkmap['filter'], true); // Hardcoded. $networkmap['filter']['holding_area'] = [ 500, 500, ]; // 40 = DEFAULT NODE RADIUS // 30 = for to align $holding_area_max_y = ($networkmap['height'] + 30 + 40 * 2 - $networkmap['filter']['holding_area'][1] + 10 * 40); $item = []; $item['id'] = $count; $item['id_db'] = ($simulated === true) ? (int) $node['id'] : (int) $node['id_in_db']; if ((int) $node['type'] === 0) { $item['type'] = 0; $item['id_agent'] = (int) $node['source_data']; $item['id_module'] = ''; } else if ((int) $node['type'] === 1) { $item['type'] = 1; $item['id_agent'] = (int) $node['style']['id_agent']; $item['id_module'] = (int) $node['source_data']; } else { $item['type'] = 3; } $item['fixed'] = true; $item['x'] = (int) $node['x']; $item['y'] = (int) $node['y']; $item['px'] = (int) $node['x']; $item['py'] = (int) $node['y']; $item['z'] = (int) $node['z']; $item['state'] = $node['state']; $item['deleted'] = $node['deleted']; if ($item['state'] === 'holding_area') { // 40 = DEFAULT NODE RADIUS // 30 = for to align $holding_area_x = ($networkmap['width'] + 30 + 40 * 2 - $networkmap['filter']['holding_area'][0] + ($count_item_holding_area % 11) * 40); $holding_area_y = ($networkmap['height'] + 30 + 40 * 2 - $networkmap['filter']['holding_area'][1] + (int) (($count_item_holding_area / 11)) * 40); if ($holding_area_max_y <= $holding_area_y) { $holding_area_y = $holding_area_max_y; } $item['x'] = $holding_area_x; $item['y'] = $holding_area_y; // Increment for the next node in holding area. $count_item_holding_area++; } $item['image_url'] = ''; $item['image_width'] = 0; $item['image_height'] = 0; if (!empty($node['style']['image'])) { $item['image_url'] = html_print_image( $node['style']['image'], true, false, true ); $image_size = getimagesize( $config['homedir'].'/'.$node['style']['image'] ); $item['image_width'] = (int) $image_size[0]; $item['image_height'] = (int) $image_size[1]; } $item['raw_text'] = $node['style']['label']; $item['text'] = io_safe_output($node['style']['label']); $item['shape'] = $node['style']['shape']; switch ($node['type']) { case 0: $color = get_status_color_networkmap($node['source_data']); break; default: // Old code. if ($node['source_data'] == -1) { $color = '#364D1F'; } else if ($node['source_data'] == -2) { $color = '#364D1F'; } else { $color = get_status_color_networkmap($node['source_data']); } break; } $item['color'] = $color; $item['map_id'] = 0; if (isset($node['id_map']) === true) { $item['map_id'] = $node['id_map']; } if (!isset($node['style']['id_networkmap']) || $node['style']['id_networkmap'] == '' || $node['style']['id_networkmap'] == 0) { $item['networkmap_id'] = 0; } else { $item['networkmap_id'] = $node['style']['id_networkmap']; } $count++; return $item; } /** * Get Status color * * @param integer $id Id Agent. * @param boolean $color If want to be coloured. * * @return string */ function get_status_color_networkmap($id, $color=true) { $agent_data = db_get_row_sql('SELECT * FROM tagente WHERE id_agente = '.$id); if ($agent_data === false) { return COL_UNKNOWN; } $status = agents_get_status_from_counts($agent_data); if ($color === false) { return $status; } if ($agent_data['fired_count'] > 0) { return COL_ALERTFIRED; } $output = ''; // Select node color by checking status. switch ($status) { case AGENT_MODULE_STATUS_NORMAL: $output = COL_NORMAL; break; case AGENT_MODULE_STATUS_NOT_INIT: $output = COL_NOTINIT; break; case AGENT_MODULE_STATUS_CRITICAL_BAD: $output = COL_CRITICAL; break; case AGENT_MODULE_STATUS_WARNING: $output = COL_WARNING; break; case AGENT_MODULE_STATUS_UNKNOWN: default: $output = COL_UNKNOWN; break; } return $output; } function networkmap_clean_relations_for_js(&$relations) { do { $cleaned = true; foreach ($relations as $key => $relation) { if ($relation['id_parent_source_data'] == $relation['id_child_source_data']) { if (($relation['child_type'] != 3) && $relation['parent_type'] != 3) { $cleaned = false; if ($relation['parent_type'] == 1) { $to_find = $relation['id_parent_source_data']; $to_replace = $relation['id_child_source_data']; } else if ($relation['child_type'] == 1) { $to_find = $relation['id_child_source_data']; $to_replace = $relation['id_parent_source_data']; } // Replace and erase the links. foreach ($relations as $key2 => $relation2) { if ($relation2['id_parent_source_data'] == $to_find) { $relations[$key2]['id_parent_source_data'] = $to_replace; } else if ($relation2['id_child_source_data'] == $to_find) { $relations[$key2]['id_child_source_data'] = $to_replace; } } unset($relations[$key]); break; } } } } while ($cleaned === false); } /** * Transform networkmap relations into js links. * * @param array $relations Relations. * @param array $nodes_graph Nodes_graph. * @param boolean $simulated Simulated. * * @return array JS relations. */ function networkmap_links_to_js_links( $relations, $nodes_graph, $simulated=false ) { $return = []; $count = 0; foreach ($relations as $key => $relation) { if (($relation['parent_type'] == NODE_MODULE) && ($relation['child_type'] == NODE_MODULE) ) { $id_target_agent = agents_get_agent_id_by_module_id( $relation['id_parent_source_data'] ); $id_source_agent = agents_get_agent_id_by_module_id( $relation['id_child_source_data'] ); $id_target_module = $relation['id_parent_source_data']; $id_source_module = $relation['id_child_source_data']; } else if (($relation['parent_type'] == NODE_MODULE) && ($relation['child_type'] == NODE_AGENT) ) { $id_target_agent = agents_get_agent_id_by_module_id( $relation['id_parent_source_data'] ); $id_target_module = $relation['id_parent_source_data']; $id_source_agent = $relation['id_child_source_data']; } else if (($relation['parent_type'] == NODE_AGENT) && ($relation['child_type'] == NODE_MODULE) ) { $id_target_agent = $relation['id_parent_source_data']; $id_source_module = $relation['id_child_source_data']; $id_source_agent = agents_get_agent_id_by_module_id( $relation['id_child_source_data'] ); } else { $id_target_agent = $relation['id_parent_source_data']; $id_source_agent = $relation['id_child_source_data']; } $item = []; $item['id'] = $count; $count++; $item['id_db'] = ($simulated === true) ? $key : get_relation_id($relation); $item['arrow_start'] = ''; $item['arrow_end'] = ''; $item['status_start'] = ''; $item['status_end'] = ''; $item['id_module_start'] = 0; $item['id_agent_start'] = (int) $id_source_agent; $item['id_module_end'] = 0; $item['id_agent_end'] = (int) $id_target_agent; $item['link_color'] = '#999'; $item['target'] = -1; $item['source'] = -1; $item['deleted'] = $relation['deleted']; if ($simulated === false) { $target_and_source = []; $target_and_source = get_id_target_and_source_in_db($relation); $item['target_id_db'] = (int) $target_and_source['target']; $item['source_id_db'] = (int) $target_and_source['source']; } else { if (($relation['parent_type'] == NODE_MODULE) && ($relation['child_type'] == NODE_MODULE)) { $item['target_id_db'] = $id_target_agent; $item['source_id_db'] = $id_source_agent; } else if (($relation['parent_type'] == NODE_AGENT) && ($relation['child_type'] == NODE_AGENT)) { $item['target_id_db'] = (int) $relation['id_parent_source_data']; $item['source_id_db'] = $id_source_agent; } else { $item['target_id_db'] = (int) $relation['id_parent_source_data']; $item['source_id_db'] = (int) $relation['id_child_source_data']; } } $item['text_end'] = ''; $item['text_start'] = ''; if ($relation['parent_type'] == 1) { $item['arrow_end'] = 'module'; $item['status_end'] = modules_get_agentmodule_status((int) $id_target_module, false, false, null); $item['id_module_end'] = (int) $id_target_module; $text_end = modules_get_agentmodule_name((int) $id_target_module); if (preg_match('/(.+)_ifOperStatus$/', (string) $text_end, $matches)) { if ($matches[1]) { // It's ok to safe_output as it inlo goint to be user into the map line $item['text_end'] = io_safe_output($matches[1]); } } } if ($relation['child_type'] == NODE_MODULE) { $item['arrow_start'] = 'module'; $item['status_start'] = modules_get_agentmodule_status((int) $id_source_module, false, false, null); $item['id_module_start'] = (int) $id_source_module; $text_start = modules_get_agentmodule_name((int) $id_source_module); if (preg_match('/(.+)_ifOperStatus$/', (string) $text_start, $matches)) { if ($matches[1]) { // It's ok to safe_output as it inlo goint to be user into the map line. $item['text_start'] = io_safe_output($matches[1]); } } } $agent = 0; $agent2 = 0; $control1 = false; $control2 = false; if (($relation['parent_type'] == NODE_MODULE) && ($relation['child_type'] == NODE_MODULE)) { if (($item['status_start'] == AGENT_MODULE_STATUS_CRITICAL_BAD) || ($item['status_end'] == AGENT_MODULE_STATUS_CRITICAL_BAD)) { $item['link_color'] = '#e63c52'; } else if (($item['status_start'] == AGENT_MODULE_STATUS_WARNING) || ($item['status_end'] == AGENT_MODULE_STATUS_WARNING)) { $item['link_color'] = '#f3b200'; } $agent = agents_get_agent_id_by_module_id( $relation['id_parent_source_data'] ); $agent2 = agents_get_agent_id_by_module_id( $relation['id_child_source_data'] ); foreach ($nodes_graph as $key2 => $node) { if (isset($node['id_agent'])) { if ($node['id_agent'] == $agent) { $agent = $node['id_db']; $control1 = true; } if ($node['id_agent'] == $agent2) { $agent2 = $node['id_db']; $control2 = true; } if ($control1 === true && $control2 === true) { break; } } } } else if ($relation['child_type'] == NODE_MODULE) { if ($item['status_start'] == AGENT_MODULE_STATUS_CRITICAL_BAD) { $item['link_color'] = '#e63c52'; } else if ($item['status_start'] == AGENT_MODULE_STATUS_WARNING) { $item['link_color'] = '#f3b200'; } $agent2 = agents_get_agent_id_by_module_id( $relation['id_child_source_data'] ); foreach ($nodes_graph as $node) { if (isset($node['id_agent']) === true) { if ($node['id_agent'] == $relation['id_parent_source_data']) { $agent = $node['id_db']; $control1 = true; } if ($node['id_agent'] == $agent2) { $agent2 = $node['id_db']; $control2 = true; } if ($control1 === true && $control2 === true) { break; } } } } else if ($relation['parent_type'] == NODE_MODULE) { if ($item['status_end'] == AGENT_MODULE_STATUS_CRITICAL_BAD) { $item['link_color'] = '#e63c52'; } else if ($item['status_end'] == AGENT_MODULE_STATUS_WARNING) { $item['link_color'] = '#f3b200'; } $agent = agents_get_agent_id_by_module_id( $relation['id_parent_source_data'] ); foreach ($nodes_graph as $key2 => $node) { if (isset($node['id_agent'])) { if ($node['id_agent'] == $agent) { $agent = $node['id_db']; $control1 = true; } if ($node['id_agent'] == $relation['id_child_source_data']) { $agent2 = $node['id_db']; $control2 = true; } if ($control1 && $control2) { break; } } } } else if (($relation['parent_type'] == NODE_PANDORA) && ($relation['child_type'] == NODE_PANDORA) ) { foreach ($nodes_graph as $key2 => $node) { if ($relation['id_parent'] == $node['id_db']) { $agent = $node['id_db']; } } foreach ($nodes_graph as $key2 => $node) { if ($relation['id_child'] == $node['id_db']) { $agent2 = $node['id_db']; } } } else if (($relation['parent_type'] == NODE_PANDORA) || ($relation['child_type'] == NODE_PANDORA) ) { if ($relation['parent_type'] == NODE_PANDORA) { foreach ($nodes_graph as $node) { if ($relation['id_parent'] == $node['id_db']) { $agent = $node['id_db']; } else if ($node['id_agent'] == $relation['id_child_source_data']) { $agent2 = $node['id_db']; } } } else if ($relation['child_type'] == NODE_PANDORA) { foreach ($nodes_graph as $node) { if ($relation['id_child'] == $node['id_db']) { $agent2 = $node['id_db']; } else if ($node['id_agent'] == $relation['id_parent_source_data']) { $agent = $node['id_db']; } } } } else { foreach ($nodes_graph as $node) { if (isset($node['id_agent']) === true) { if ($node['id_agent'] == $relation['id_parent_source_data']) { $agent = $node['id_db']; } else if ($node['id_agent'] == $relation['id_child_source_data']) { $agent2 = $node['id_db']; } } } } foreach ($nodes_graph as $node) { if ($node['id_db'] == $agent) { $item['target'] = $node['id']; } else if ($node['id_db'] == $agent2) { $item['source'] = $node['id']; } } if ((($item['target'] == -1) || ($item['source'] == -1)) && $relation['parent_type'] == NODE_MODULE && $relation['child_type'] == NODE_MODULE ) { continue; } $return[] = $item; } return $return; } function get_status_color_module_networkmap($id_agente_modulo) { $status = modules_get_agentmodule_status($id_agente_modulo); // Set node status. switch ($status) { case 0: // At the moment the networkmap enterprise does not show the // alerts. case AGENT_MODULE_STATUS_NORMAL_ALERT: $status_color = COL_NORMAL; // Normal monitor. break; case 1: $status_color = COL_CRITICAL; // Critical monitor. break; case 2: $status_color = COL_WARNING; // Warning monitor. break; case 4: $status_color = COL_ALERTFIRED; // Alert fired. break; default: $status_color = COL_UNKNOWN; // Unknown monitor. break; } return $status_color; } function duplicate_networkmap($id) { $return = true; $values = db_get_row('tmap', 'id', $id); unset($values['id']); $free_name = false; $values['name'] = io_safe_input(__('Copy of ')).$values['name']; $count = 1; while ($free_name === false) { $exist = db_get_row_filter('tmap', ['name' => $values['name']]); if ($exist === false) { $free_name = true; } else { $values['name'] = $values['name'].io_safe_input(' '.$count); } } $correct_or_id = db_process_sql_insert('tmap', $values); if ($correct_or_id === false) { $return = false; } else { $new_id = $correct_or_id; duplicate_map_insert_nodes_and_relations($id, $new_id); } if ($return === true) { return true; } else { // Relations. delete_relations($new_id); // Nodes. delete_nodes($new_id); // Clean DB. db_process_sql_delete('tmap', ['id' => $new_id]); return false; } } function clean_duplicate_links($relations) { $segregation_links = []; $index = 0; $index2 = 0; $index3 = 0; $index4 = 0; foreach ($relations as $rel) { if (($rel['parent_type'] == 0) && ($rel['child_type'] == 0)) { $segregation_links['aa'][$index] = $rel; $index++; } else if (($rel['parent_type'] == 1) && ($rel['child_type'] == 1)) { $segregation_links['mm'][$index2] = $rel; $index2++; } else if (($rel['parent_type'] == 3) && ($rel['child_type'] == 3)) { $segregation_links['ff'][$index4] = $rel; $index4++; } else { $segregation_links['am'][$index3] = $rel; $index3++; } } $final_links = []; // ---------------------------------------------------------------- // --------------------- Clean duplicate links -------------------- // ---------------------------------------------------------------- $duplicated = false; $index_to_del = 0; $index = 0; if (isset($segregation_links['aa']) === true && is_array($segregation_links['aa']) === true) { foreach ($segregation_links['aa'] as $link) { foreach ($segregation_links['aa'] as $link2) { if ($link['id_parent'] == $link2['id_child'] && $link['id_child'] == $link2['id_parent']) { delete_link($segregation_links['aa'][$index_to_del]); unset($segregation_links['aa'][$index_to_del]); } $index_to_del++; } $final_links['aa'][$index] = $link; $index++; $duplicated = false; $index_to_del = 0; } } $duplicated = false; $index_to_del = 0; $index2 = 0; if (isset($segregation_links['mm']) === true && is_array($segregation_links['mm']) === true) { foreach ($segregation_links['mm'] as $link) { foreach ($segregation_links['mm'] as $link2) { if ($link['id_parent'] == $link2['id_child'] && $link['id_child'] == $link2['id_parent']) { delete_link($segregation_links['mm'][$index_to_del]); } $index_to_del++; } $final_links['mm'][$index2] = $link; $index2++; $duplicated = false; $index_to_del = 0; } } $duplicated = false; $index_to_del = 0; $index3 = 0; if (isset($segregation_links['ff']) === true && is_array($segregation_links['ff']) === true) { foreach ($segregation_links['ff'] as $link) { foreach ($segregation_links['ff'] as $link2) { if ($link['id_parent'] == $link2['id_child'] && $link['id_child'] == $link2['id_parent']) { delete_link($segregation_links['ff'][$index_to_del]); unset($segregation_links['ff'][$index_to_del]); } $index_to_del++; } $final_links['ff'][$index3] = $link; $index3++; $duplicated = false; $index_to_del = 0; } } $final_links['am'] = $segregation_links['am']; /* ---------------------------------------------------------------- ----------------- AA, AM and MM links management --------------- ------------------ Priority: ----------------------------------- -------------------- 1 -> MM (module - module) ----------------- -------------------- 2 -> AM (agent - module) ------------------ -------------------- 3 -> AA (agent - agent) ------------------- ---------------------------------------------------------------- */ $final_links2 = []; $index = 0; $l3_link = []; $agent1 = 0; $agent2 = 0; if (isset($final_links['mm']) === true && is_array($final_links['mm']) === true) { foreach ($final_links['mm'] as $rel_mm) { $module_parent = $rel_mm['id_parent_source_data']; $module_children = $rel_mm['id_child_source_data']; $agent1 = (int) agents_get_agent_id_by_module_id($module_parent); $agent2 = (int) agents_get_agent_id_by_module_id($module_children); foreach ($final_links['aa'] as $key => $rel_aa) { $l3_link = $rel_aa; $id_p_source_data = (int) $rel_aa['id_parent_source_data']; $id_c_source_data = (int) $rel_aa['id_child_source_data']; if ((($id_p_source_data == $agent1) && ($id_c_source_data == $agent2)) || (($id_p_source_data == $agent2) && ($id_c_source_data == $agent1)) ) { delete_link($final_links['aa'][$key]); unset($final_links['aa'][$key]); } } } } $final_links2['aa'] = $final_links['aa']; $final_links2['mm'] = $final_links['mm']; $final_links2['am'] = $final_links['am']; $final_links2['ff'] = $final_links['ff']; $same_m = []; $index = 0; if (isset($final_links2['am']) === true && is_array($final_links2['am']) === true) { foreach ($final_links2['am'] as $rel_am) { foreach ($final_links2['am'] as $rel_am2) { if (($rel_am['id_child_source_data'] == $rel_am2['id_child_source_data']) && ($rel_am['id_parent_source_data'] != $rel_am2['id_parent_source_data']) ) { $same_m[$index]['rel'] = $rel_am2; $same_m[$index]['agent_parent'] = $rel_am['id_parent_source_data']; $index++; } } } } $final_links3 = []; $index = 0; $l3_link = []; $have_l3 = false; if (isset($final_links2['aa']) === true && is_array($final_links2['aa']) === true ) { foreach ($final_links2['aa'] as $key => $rel_aa) { $l3_link = $rel_aa; foreach ($same_m as $rel_am) { if ((($rel_aa['id_parent_source_data'] == $rel_am['parent']['id_parent_source_data']) && ($rel_aa['id_child_source_data'] == $rel_am['rel']['id_parent_source_data'])) || (($rel_aa['id_child_source_data'] == $rel_am['parent']['id_parent_source_data']) && ($rel_aa['id_parent_source_data'] == $rel_am['rel']['id_parent_source_data'])) ) { delete_link($final_links2['aa'][$key]); unset($final_links2['aa'][$key]); } } } } $final_links3['aa'] = $final_links2['aa']; $final_links3['mm'] = $segregation_links['mm']; $final_links3['am'] = $segregation_links['am']; $final_links3['ff'] = $final_links2['ff']; $cleaned_links = []; if (isset($final_links3['aa']) === true && is_array($final_links3['aa']) === true ) { foreach ($final_links3['aa'] as $link) { $cleaned_links[] = $link; } } if (isset($final_links3['am']) === true && is_array($final_links3['am']) === true) { foreach ($final_links3['am'] as $link) { $cleaned_links[] = $link; } } if (isset($final_links3['mm']) === true && is_array($final_links3['mm']) === true) { foreach ($final_links3['mm'] as $link) { $cleaned_links[] = $link; } } if (isset($final_links3['ff']) === true && is_array($final_links3['ff']) === true ) { foreach ($final_links3['ff'] as $link) { $cleaned_links[] = $link; } } return $cleaned_links; } function migrate_older_open_maps($id) { global $config; $old_networkmap = db_get_row_filter( 'tnetwork_map', ['id_networkmap' => $id] ); $map_values = []; $map_values['id_group'] = $old_networkmap['id_group']; $map_values['id_user'] = $old_networkmap['id_user']; $map_values['type'] = 0; $map_values['subtype'] = 0; $map_values['name'] = $old_networkmap['name']; $new_map_filter = []; $new_map_filter['dont_show_subgroups'] = $old_networkmap['dont_show_subgroups']; $new_map_filter['node_radius'] = 40; $new_map_filter['x_offs'] = 0; $new_map_filter['y_offs'] = 0; $new_map_filter['z_dash'] = '0.5'; $new_map_filter['node_sep'] = '0.1'; $new_map_filter['rank_sep'] = 1; $new_map_filter['mindist'] = 1; $new_map_filter['kval'] = '0.1'; $map_values['filter'] = json_encode($new_map_filter); $map_values['description'] = 'Mapa open migrado'; $map_values['width'] = 4000; $map_values['height'] = 4000; $map_values['center_x'] = 2000; $map_values['center_y'] = 2000; $map_values['background'] = ''; $map_values['background_options'] = 0; $map_values['source_period'] = 60; $map_values['source'] = 0; $map_values['source_data'] = $old_networkmap['id_group']; $map_values['generation_method'] = 3; $map_values['generated'] = 0; $id_new_map = db_process_sql_insert('tmap', $map_values); if (!$id_new_map) { return false; } return true; } /** * Load cluetip required files and JS. * * @return void */ function networkmap_load_cluetip() { ui_require_css_file('cluetip', 'include/styles/js/'); ?> $node) { $values = []; $values['id_map'] = $id; $values['x'] = (int) $node['x']; $values['y'] = (int) $node['y']; $values['type'] = $node['type']; $values['source_data'] = $node['source_data']; $node_style = json_decode($node['style'], true); $style = []; if ($node['type'] == 1) { $style['id_agent'] = $node['id_agent']; } else if ($node['type'] == 0) { $style['id_group'] = db_get_value( 'id_grupo', 'tagente', 'id_agente', $node['source_data'] ); } $style['shape'] = $node_style['shape']; $style['image'] = $node_style['image']; $style['width'] = $node_style['width']; $style['height'] = $node_style['height']; $style['label'] = $node_style['label']; $values['style'] = json_encode($style); $id_or_result = db_process_sql_insert('titem', $values); $nodes_and_relations['nodes'][$key]['id_db'] = $id_or_result; } $i = 0; foreach ($nodes_and_relations['relations'] as $key => $relation) { $i++; $parent_source = $relation['id_parent_source_data']; $child_source = $relation['id_child_source_data']; if ($parent_source === null) { $parent_source = 0; } if ($child_source === null) { $child_source = 0; } $id_or_result = db_process_sql_insert( 'trel_item', [ 'id_map' => $id, 'id_parent' => $relation['id_parent'], 'id_child' => $relation['id_child'], 'id_parent_source_data' => $parent_source, 'id_child_source_data' => $child_source, 'parent_type' => $relation['parent_type'], 'child_type' => $relation['child_type'], ] ); $nodes_and_relations['relations'][$key]['id_db'] = $id_or_result; } // Update networkmap size. return $nodes_and_relations; } /** * Load a networkmap from DB. Do not call this method directly. * * @param object $nmObject Networkmap class object. * * @return array Graph loaded. */ function networkmap_load_map($nmObject) { global $config; $nodes = $nmObject->nodes; $relations = $nmObject->relations; $graph = []; $graph['nodes'] = []; $node_mapping = []; $i = 0; $node_sources = []; foreach ($nodes as $k => $node) { if ((bool) $node['deleted'] === false) { $tmp_node = []; $tmp_node['id_map'] = $node['id_map']; $tmp_node['id'] = $i; $tmp_node['id_db'] = $node['id']; $tmp_node['source_data'] = $node['source_data']; $tmp_node['type'] = $node['type']; $mapping_key = $node['source_data'].'_'.$node['type']; if ((int) $node['type'] === NODE_GENERIC) { $mapping_key = $node['id'].'_'.$node['type']; } if ((int) $tmp_node['type'] === NODE_AGENT) { $tmp_node['id_agent'] = $tmp_node['source_data']; $agent = agents_get_agents( ['id_agente' => $tmp_node['id_agent']], ['*'] ); if (is_array($agent) === true) { $node_sources[$mapping_key] = $agent[0]; $status = agents_get_status_from_counts( $node_sources[$mapping_key] ); } } else if ((int) $tmp_node['type'] === NODE_MODULE) { // Skip NetworkMap module nodes load due a bad previous // definition in databases. continue; } else { $tmp_node['id_agent'] = 0; $tmp_node['id_module'] = 0; } $style_node = json_decode($node['style'], true); if (is_array($style_node) === true) { $style = $style_node; } else { $style = []; $style['shape'] = $style_node['shape']; $style['image'] = $style_node['image']; $style['width'] = $style_node['width']; $style['height'] = $style_node['height']; $style['label'] = $style_node['label']; $style['color'] = $style_node['color']; } $style['id_networkmap'] = $style_node['networkmap']; $tmp_node['style'] = json_encode($style); $tmp_node['x'] = $node['x']; $tmp_node['y'] = $node['y']; $tmp_node['z'] = $node['z']; $tmp_node['color'] = $style['color']; $tmp_node['width'] = $style['width']; $tmp_node['height'] = $style['height']; $tmp_node['text'] = $style['label']; if ($tmp_node['type'] == NODE_MODULE) { $tmp_node['id_agent'] = $style_node['id_agent']; } // Fullfill node information, status, id_db... $node_sources[$mapping_key]['status'] = $status; $node_sources[$mapping_key]['id_db'] = $node['id']; // Map node. $nmObject->nodeMapping[$i] = $mapping_key; // Keep reverse node mapping for relations. $node_mapping[$mapping_key] = $i; // Add node to graph. $graph['nodes'][$i++] = $tmp_node; } } // Update nodes in networkmap object (set sources data). $nmObject->setNodes($node_sources); $graph['relations'] = []; $i = 0; if (is_array($relations) === true) { foreach ($relations as $rel) { $edge = []; $edge['id_map'] = $rel['id_map']; $edge['id_db'] = $rel['id']; // Default. $edge['id_parent_agent'] = 0; $edge['id_child_agent'] = 0; if ($rel['parent_type'] == NODE_AGENT) { $edge['id_parent_agent'] = $rel['id_parent_source_data']; } else if ($rel['parent_type'] == NODE_MODULE) { $edge['id_parent_agent'] = modules_get_agentmodule_agent( $rel['id_parent_source_data'] ); } if ($rel['child_type'] == NODE_AGENT) { $edge['id_child_agent'] = $rel['id_child_source_data']; } else if ($rel['child_type'] == NODE_MODULE) { $edge['id_child_agent'] = modules_get_agentmodule_agent( $rel['id_child_source_data'] ); } // Search parent by default search mapping id_source'_'type. if ($rel['parent_type'] == NODE_GENERIC) { $kp = $rel['id_parent'].'_'.$rel['parent_type']; } else { $kp = $rel['id_parent_source_data'].'_'.$rel['parent_type']; if ($node_mapping[$kp] === null) { // Not found in direct assignment. Search agent. $kp = $edge['id_parent_agent'].'_'.NODE_AGENT; } if ($node_mapping[$kp] === null) { // Not found in direct assignment. Search module. $kp = $edge['id_parent_agent'].'_'.NODE_MODULE; } } // Set parent. $edge['id_parent'] = $node_mapping[$kp]; $edge['parent_type'] = $rel['parent_type']; $edge['id_parent_source_data'] = $rel['id_parent_source_data']; // Search child. if ($rel['child_type'] == NODE_GENERIC) { $kc = $rel['id_child'].'_'.$rel['child_type']; } else { $kc = $rel['id_child_source_data'].'_'.$rel['child_type']; if ($node_mapping[$kc] === null) { // Not found in direct assignment. Search agent. $kc = $edge['id_child_agent'].'_'.NODE_AGENT; } if ($node_mapping[$kc] === null) { // Not found in direct assignment. Search module. $kc = $edge['id_child_agent'].'_'.NODE_MODULE; } } // Set child. $edge['id_child'] = $node_mapping[$kc]; $edge['child_type'] = $rel['child_type']; $edge['id_child_source_data'] = $rel['id_child_source_data']; // Both start and end defined and avoided self references. if ($edge['id_child'] !== null && $edge['id_parent'] !== null && $edge['id_parent'] != $edge['id_child'] ) { $graph['relations'][$i++] = $edge; } } } $nmObject->setRelations($graph['relations']); return $graph; } /** * Clean duplicate links * * @param integer $id Id. * * @return void */ function networkmap_clean_duplicate_links($id) { global $config; $sql_duplicate_links = 'SELECT * FROM trel_item t1 WHERE t1.deleted = 0 AND t1.id_child IN ( SELECT t2.id_child FROM trel_item t2 WHERE t1.id != t2.id AND t1.id_child = t2.id_child AND t1.id_parent = t2.id_parent AND t2.id_map = '.$id.') AND t1.id_map = '.$id.' ORDER BY id_parent, id_child, id_parent_source_data desc, id_child_source_data desc'; $rows = db_get_all_rows_sql($sql_duplicate_links); if (empty($rows) === true) { $rows = []; } $pre_parent = -1; $pre_child = -1; $pre_parent_source = -1; $pre_child_source = -1; foreach ($rows as $row) { if (($pre_parent === (int) $row['id_parent']) && ($pre_child === (int) $row['id_child']) ) { // Agent <-> Agent. if ((int) $row['parent_type'] === 0 && (int) $row['child_type'] === 0) { // Delete the duplicate row. db_process_sql_delete( 'trel_item', ['id' => $row['id']] ); } else { // Agent <-> Module or Module <-> Agent or Module <-> Module. if ($pre_parent_source === (int) $row['id_parent_source_data'] && $pre_child_source === (int) $row['id_child_source_data'] ) { // Delete the duplicate row. db_process_sql_delete( 'trel_item', ['id' => $row['id']] ); } else { $pre_parent_source = (int) $row['id_parent_source_data']; $pre_child_source = (int) $row['id_child_source_data']; } } } else { $pre_parent = (int) $row['id_parent']; $pre_child = (int) $row['id_child']; if ((int) $row['parent_type'] === 1 || (int) $row['child_type'] === 1) { $pre_parent_source = (int) $row['id_parent_source_data']; $pre_child_source = (int) $row['id_child_source_data']; } } } do { db_clean_cache(); $sql_duplicate_links_parent_as_children = ' SELECT * FROM trel_item t1 WHERE t1.deleted = 0 AND t1.id_child IN ( SELECT t2.id_parent FROM trel_item t2 WHERE t1.id_parent = t2.id_child AND t1.id_child = t2.id_parent AND t2.id_map = '.$id.') AND t1.id_map = '.$id.' ORDER BY id_parent, id_child'; $rows = db_get_all_rows_sql($sql_duplicate_links_parent_as_children); if (empty($rows) === true) { $rows = []; } $found = false; foreach ($rows as $row) { foreach ($rows as $row2) { if (($row['id'] != $row2['id']) && ($row['id_child'] == $row2['id_parent']) && ($row['id_parent'] == $row2['id_child']) && ($row['parent_type'] == $row2['child_type']) && ($row['child_type'] == $row2['parent_type']) ) { // Agent <-> Agent. if ((int) $row2['parent_type'] === 0 && (int) $row2['child_type'] === 0) { db_process_sql_delete( 'trel_item', ['id' => $row2['id']] ); $found = true; break; } else { // Agent <-> Module or Module <-> Agent or Module <-> Module. if ((int) $row['id_child_source_data'] === (int) $row2['id_parent_source_data'] && (int) $row['id_parent_source_data'] === (int) $row2['id_child_source_data'] ) { db_process_sql_delete( 'trel_item', ['id' => $row2['id']] ); $found = true; break; } } } else { // Si no son del mismo tipo pero hay un parent_type = 0 y child_type = 0 borrar. if ((int) $row['parent_type'] === 0 && (int) $row['child_type'] === 0) { db_process_sql_delete( 'trel_item', ['id' => $row['id']] ); $found = true; break; } else if ((int) $row2['parent_type'] === 0 && (int) $row2['child_type'] === 0) { db_process_sql_delete( 'trel_item', ['id' => $row2['id']] ); $found = true; break; } } } if ($found === true) { break; } } } while ($found === true); } /** * Get node structure. * * @param integer $id Id. * * @return array */ function get_structure_nodes($id) { $nodes = get_nodes_from_db($id); $relations = get_relations_from_db($id); $nodes_and_relations = []; $nodes_and_relations['nodes'] = []; $index_nodes = 0; foreach ($nodes as $node) { if ((bool) $node['deleted'] === false) { $nodes_and_relations['nodes'][$index_nodes]['id_map'] = $node['id_map']; $nodes_and_relations['nodes'][$index_nodes]['x'] = $node['x']; $nodes_and_relations['nodes'][$index_nodes]['y'] = $node['y']; $nodes_and_relations['nodes'][$index_nodes]['source_data'] = $node['source_data']; $nodes_and_relations['nodes'][$index_nodes]['type'] = $node['type']; $style_node = json_decode($node['style'], true); $style = []; $style['shape'] = $style_node['shape']; $style['image'] = $style_node['image']; $style['width'] = $style_node['width']; $style['height'] = $style_node['height']; $style['label'] = $style_node['label']; $style['id_networkmap'] = $style_node['networkmap']; $nodes_and_relations['nodes'][$index_nodes]['style'] = json_encode($style); if ($node['type'] == 1) { $nodes_and_relations['nodes'][$index_nodes]['id_agent'] = $style_node['id_agent']; } $nodes_and_relations['nodes'][$index_nodes]['id_in_db'] = $node['id']; $index_nodes++; } } $nodes_and_relations['relations'] = []; $index_relations = 0; foreach ($relations as $relation) { $nodes_and_relations['relations'][$index_relations]['id_map'] = $relation['id_map']; $nodes_and_relations['relations'][$index_relations]['id_parent'] = $relation['id_parent']; $nodes_and_relations['relations'][$index_relations]['id_child'] = $relation['id_child']; $nodes_and_relations['relations'][$index_relations]['parent_type'] = $relation['parent_type']; $nodes_and_relations['relations'][$index_relations]['child_type'] = $relation['child_type']; $nodes_and_relations['relations'][$index_relations]['id_parent_source_data'] = $relation['id_parent_source_data']; $nodes_and_relations['relations'][$index_relations]['id_child_source_data'] = $relation['id_child_source_data']; $index_relations++; } return $nodes_and_relations; } /** * Get nodes from database. * * @param integer $id Id. * * @return mixed */ function get_nodes_from_db($id) { return db_get_all_rows_filter( 'titem', [ 'id_map' => $id, 'deleted' => 0, ] ); } /** * Get relations from database. * * @param integer $id Id. * * @return mixed */ function get_relations_from_db($id) { return db_get_all_rows_filter( 'trel_item', [ 'id_map' => $id, 'deleted' => 0, ] ); } /** * Delete link. * * @param integer $link Link. * * @return mixed */ function delete_link($link) { db_process_sql_delete( 'trel_item', [ 'id_map' => $link['id_map'], 'id_parent' => $link['id_parent'], 'id_child' => $link['id_child'], 'id_parent_source_data' => $link['id_parent_source_data'], 'id_child_source_data' => $link['id_child_source_data'], 'parent_type' => $link['parent_type'], 'child_type' => $link['child_type'], ] ); } /** * Get relation id * * @param array $rel Relation. * * @return mixed. */ function get_relation_id($rel) { return db_get_value_filter( 'id', 'trel_item', [ 'id_parent' => $rel['id_parent'], 'id_child' => $rel['id_child'], 'id_parent_source_data' => $rel['id_parent_source_data'], 'id_child_source_data' => $rel['id_child_source_data'], 'id_map' => $rel['id_map'], 'parent_type' => $rel['parent_type'], 'deleted' => 0, 'child_type' => $rel['child_type'], ] ); } /** * Get target id and his source in database. * * @param array $rel Relation. * * @return array */ function get_id_target_and_source_in_db($rel) { $return = []; $return['target'] = db_get_value_filter( 'id', 'titem', [ 'source_data' => $rel['id_parent_source_data'], 'type' => $rel['parent_type'], ] ); $return['source'] = db_get_value_filter( 'id', 'titem', [ 'source_data' => $rel['id_child_source_data'], 'type' => $rel['child_type'], ] ); return $return; } /** * Delete link for network map. * * @param integer $networkmap_id Id of the networkmap. * @param integer $source_module_id Id of source module. * @param integer $target_module_id Id of target module. * @param integer $id_link Id of link. * * @return mixed */ function networkmap_delete_link( $networkmap_id, $source_module_id, $target_module_id, $id_link ) { $flag_delete_level2 = ((int) $source_module_id !== 0 && (int) $target_module_id !== 0); $link = db_get_row_filter( 'trel_item', [ 'id_map' => $networkmap_id, 'id' => $id_link, 'deleted' => 0, ] ); $result = db_process_sql_update( 'trel_item', [ 'deleted' => 1, 'id_map' => $networkmap_id, ], ['id' => $id_link] ); if ($result !== false && $flag_delete_level2 === true) { db_process_sql_delete('tmodule_relationship', ['module_a' => $link['id_parent_source_data'], 'module_b' => $link['id_child_source_data']]); db_process_sql_delete('tmodule_relationship', ['module_a' => $link['id_child_source_data'], 'module_b' => $link['id_parent_source_data']]); } return $result; } /** * Erase the node * * @param integer $id Id of node. * * @return boolean */ function erase_node($id) { $node = db_get_row('titem', 'id', $id['id']); if ($node['type'] !== '2') { $return = db_process_sql_update( 'titem', ['deleted' => 1], [ 'id' => (int) $node['id'], 'id_map' => (int) $node['id_map'], ] ); db_process_sql_update( 'trel_item', ['deleted' => 1], [ 'id_parent' => (int) $node['id'], 'id_map' => (int) $node['id_map'], ] ); db_process_sql_update( 'trel_item', ['deleted' => 1], [ 'id_child' => (int) $node['id'], 'id_map' => (int) $node['id_map'], ] ); $node_modules = db_get_all_rows_filter( 'titem', [ 'id_map' => $node['id_map'], 'type' => 1, ] ); foreach ($node_modules as $node_module) { $style = json_decode($node_module['style'], true); if ($style['id_agent'] == $node['source_data']) { db_process_sql_update( 'titem', ['deleted' => 1], [ 'id' => (int) $node_module['id'], 'id_map' => (int) $node_module['id_map'], ] ); db_process_sql_update( 'trel_item', ['deleted' => 1], [ 'id_parent_source_data' => (int) $node_module['source_data'], 'id_map' => (int) $node_module['id_map'], ] ); db_process_sql_update( 'trel_item', ['deleted' => 1], [ 'id_child_source_data' => (int) $node_module['source_data'], 'id_map' => (int) $node_module['id_map'], ] ); } } } else { $return = db_process_sql_delete( 'titem', [ 'id' => (int) $node['id'], 'id_map' => (int) $node['id_map'], ] ); db_process_sql_delete( 'trel_item', [ 'parent_type' => 2, 'id_map' => (int) $node['id_map'], ] ); db_process_sql_delete( 'trel_item', [ 'child_type' => 2, 'id_map' => (int) $node['id_map'], ] ); } if ($return === false) { return false; } else { return true; } } /** * Add agent for network map. * * @param integer $id Id. * @param string $agent_name_param Agent name. * @param integer $x X axis. * @param integer $y Y axis. * @param integer $id_agent_param Id agent parameter. * @param array $other_values Array with other values. * * @return mixed. */ function add_agent_networkmap( $id, $agent_name_param, $x, $y, $id_agent_param=false, $other_values=[] ) { global $config; if ($id_agent_param !== false) { $agent_name = agents_get_alias($id_agent_param); $id_agent = $id_agent_param; } else { $id_agent = agents_get_agent_id($agent_name_param); $agent_name = $agent_name_param; } if ($id_agent == false) { return false; } $agent = db_get_row('tagente', 'id_agente', $id_agent); $img_node = ui_print_os_icon( $agent['id_os'], false, true, true, true, true, true ); $img_node_dir = str_replace( $config['homeurl'], $config['homedir'], $img_node ); $size = getimagesize($img_node_dir); $width = $size[0]; $height = $size[1]; $data = []; $data['id_map'] = $id; $data['x'] = $x; $data['y'] = $y; $data['source_data'] = $id_agent; $style = []; $style['shape'] = 'circle'; $style['image'] = $img_node; $style['width'] = $width; $style['height'] = $height; $data['type'] = 0; // WORKAROUND FOR THE JSON ENCODE WITH FOR EXAMPLE Ñ OR Á. $style['label'] = 'json_encode_crash_with_ut8_chars'; if (isset($other_values['state']) === true) { $data['state'] = $other_values['state']; } if (isset($other_values['label']) === true) { $agent_name = $other_values['label']; } if (isset($other_values['id_module']) === true) { $data['source_data'] = $other_values['id_module']; $style['shape'] = 'arrowhead'; } if (isset($other_values['type']) === true) { $data['type'] = $other_values['type']; } if (isset($other_values['refresh']) === true) { $data['refresh'] = $other_values['refresh']; } $data['style'] = json_encode($style); $data['style'] = str_replace( 'json_encode_crash_with_ut8_chars', $agent_name, $data['style'] ); $id_node = db_process_sql_insert('titem', $data); $node = db_get_all_rows_filter('titem', ['id' => $id_node]); $node = $node[0]; $networkmap_filter = db_get_value_filter('filter', 'tmap', ['id' => $id]); $networkmap_filter = json_decode($networkmap_filter, true); $rel = []; if ((bool) $networkmap_filter['empty_map'] === false) { $index = 0; if ((int) $agent['id_parent'] !== 0) { $parent = db_get_row('tagente', 'id_agente', $agent['id_parent']); $parent_item = db_get_all_rows_filter('titem', ['source_data' => $agent['id_parent'], 'type' => 0]); $parent_item = $parent_item[0]; $values = []; $values['id_child'] = $id_node; $values['id_parent_source_data'] = $agent['id_parent']; $values['id_child_source_data'] = $agent['id_agente']; $values['id_parent'] = $parent_item['id']; $values['parent_type'] = 0; $values['child_type'] = 0; $values['id_item'] = 0; $values['deleted'] = 0; $values['id_map'] = $id; $rel[$index]['id_db'] = db_process_sql_insert('trel_item', $values); $rel[$index]['id_agent_end'] = $parent['id_agente']; $rel[$index]['id_agent_start'] = $agent['id_agente']; $rel[$index]['id_module_end'] = 0; $rel[$index]['id_module_start'] = 0; $rel[$index]['source_in_db'] = $id_node; $rel[$index]['target_in_db'] = $parent_item['id']; $rel[$index]['arrow_end'] = ''; $rel[$index]['arrow_start'] = ''; $rel[$index]['status_end'] = ''; $rel[$index]['status_start'] = ''; $rel[$index]['text_end'] = ''; $rel[$index]['text_start'] = ''; $index++; $childs_of_new_agent = db_get_all_rows_filter('tagente', ['id_parent' => $agent['id_agente']]); if (is_array($childs_of_new_agent) === true) { foreach ($childs_of_new_agent as $child) { $child_item = db_get_all_rows_filter('titem', ['source_data' => $child['id_agente'], 'type' => 0]); $child_item = $child_item[0]; $values = []; $values['id_child'] = $child_item['id']; $values['id_parent'] = $id_node; $values['id_parent_source_data'] = $agent['id_agente']; $values['id_child_source_data'] = $child['id_agente']; $values['parent_type'] = 0; $values['child_type'] = 0; $values['id_item'] = 0; $values['deleted'] = 0; $values['id_map'] = $id; $rel[$index]['id_db'] = db_process_sql_insert('trel_item', $values); $rel[$index]['id_agent_end'] = $agent['id_agente']; $rel[$index]['id_agent_start'] = $child['id_agente']; $rel[$index]['id_module_end'] = 0; $rel[$index]['id_module_start'] = 0; $rel[$index]['source_in_db'] = $child_item['id']; $rel[$index]['target_in_db'] = $id_node; $rel[$index]['arrow_end'] = ''; $rel[$index]['arrow_start'] = ''; $rel[$index]['status_end'] = ''; $rel[$index]['status_start'] = ''; $rel[$index]['text_end'] = ''; $rel[$index]['text_start'] = ''; $index++; } } } } $return_data = []; if ($id_node !== false) { $return_data['id_node'] = $id_node; $return_data['rel'] = $rel; return $return_data; } else { return false; } } /** * Status color of fictional point. * * @param integer $id_networkmap Id of network map. * @param string $parent Parent. * * @return string */ function get_status_color_networkmap_fictional_point($id_networkmap, $parent='') { $last_status = 0; if ((int) $id_networkmap !== 0) { $agents = db_get_all_rows_filter( 'titem', [ 'id_map' => $id_networkmap, 'deleted' => 0, ] ); if ((bool) $agents === false) { $agents = []; } $exit = false; foreach ($agents as $agent) { if ($agent['source_data'] == -1 || $agent['type'] == 2) { continue; } if ($agent['source_data'] == -2) { if (empty($parent) === true) { if (is_array($agent) === false) { $option = json_decode($agent, true); } if ($option['networkmap'] == 0) { $status = 0; } else { $status = get_status_color_networkmap($option['networkmap'], true); } } else { // TODO Calculate next levels. $status = 0; } } else { $status = get_status_color_networkmap($agent['source_data'], false); } switch ($status) { case AGENT_STATUS_NORMAL: // Normal monitor. Do nothing. break; case AGENT_STATUS_CRITICAL: // Critical monitor. $last_status = AGENT_STATUS_CRITICAL; $exit = true; break; case AGENT_STATUS_WARNING: // Warning monitor. $last_status = AGENT_STATUS_WARNING; break; case AGENT_STATUS_ALERT_FIRED: if ($last_status != AGENT_STATUS_WARNING) { $last_status = AGENT_STATUS_ALERT_FIRED; } break; default: // Unknown monitor. if (($last_status != AGENT_STATUS_WARNING) && ($last_status != AGENT_STATUS_ALERT_FIRED)) { $last_status = $status; } break; } if ($exit === true) { break; } } } if (empty($parent) === true) { switch ($last_status) { case AGENT_STATUS_NORMAL: // Normal monitor. $status_color = COL_NORMAL; break; case AGENT_STATUS_CRITICAL: // Critical monitor. $status_color = COL_CRITICAL; break; case AGENT_STATUS_WARNING: // Warning monitor. $status_color = COL_WARNING; break; case AGENT_STATUS_ALERT_FIRED: // Alert fired. $status_color = COL_ALERTFIRED; break; default: // Unknown monitor. $status_color = COL_UNKNOWN; break; } return $status_color; } else { return $last_status; } } /** * Refresh the holding area * * @param integer $id_networkmap Id of network map. * @param integer $x X Axis. * @param integer $y Y Axis. * * @return array */ function networkmap_refresh_holding_area($id_networkmap, $x, $y) { // Retrieve information from target networkmap. $networkmap = db_get_row_filter( 'tmap', ['id' => $id_networkmap] ); if ($networkmap === false) { return __('Map not found.'); } $networkmap['filter'] = json_decode( $networkmap['filter'], true ); // Search for missing nodes (and links). networkmap_get_new_nodes_and_links($networkmap, $x, $y); networkmap_clean_duplicate_links($id_networkmap); $rows = db_get_all_rows_filter( 'titem', [ 'id_map' => $id_networkmap, 'refresh' => '1', 'deleted' => 0, ] ); if (empty($rows) === true) { $rows = []; } $nodes = []; $count = 0; $count_item_holding_area = 0; foreach ($rows as $row) { if (isset($row['type']) === true) { if ((int) $row['type'] === 1) { continue; } } else { $row['type'] = ''; } $row['state'] = 'holding_area'; db_process_sql_update( 'titem', ['state' => $row['state']], ['id' => $row['id']] ); $row['style'] = json_decode($row['style'], true); $row['id_db'] = $row['id']; $row['id_in_db'] = $row['id']; $node = networkmap_db_node_to_js_node( $row, $count, $count_item_holding_area ); $nodes[$node['id']] = $node; } // Get all links of actual nodes // but in the javascript code filter the links and only add the // new links. $relations = db_get_all_rows_filter( 'trel_item', [ 'id_map' => $id_networkmap, 'deleted' => 0, ] ); if ($relations === false) { $relations = []; } networkmap_clean_relations_for_js($relations); $links_js = networkmap_links_to_js_links( $relations, $nodes ); return [ 'nodes' => $nodes, 'links' => $links_js, ]; } /** * Update Node. * * @param array $node Node information. * @param integer $holding_area_x X Axis. * @param integer $holding_area_y Y Axis. * * @return array */ function update_node($node, $holding_area_x, $holding_area_y) { $return = []; $return['correct'] = true; $return['state'] = ''; $values = []; $values['x'] = $node['x']; $values['y'] = $node['y']; $values['refresh'] = 0; if ($node['state'] === 'holding_area') { $networkmap_node = db_get_row_filter( 'titem', ['id' => $node['id_db']] ); $networkmap = db_get_row_filter( 'tmap', ['id' => $networkmap_node['id_map']] ); $networkmap['filter'] = json_decode($networkmap['filter'], true); // Hardcoded. $networkmap['filter']['holding_area'] = [ 500, 500, ]; if (((($holding_area_x + 500) > $node['x']) && (($holding_area_x) < $node['x'])) && ((($holding_area_y + 500) > $node['y']) && (($holding_area_y) < $node['y'])) ) { // Inside holding area. $return['state'] = 'holding_area'; $values['refresh'] = 1; } else { // The user move the node out the holding area. $return['state'] = ''; } } db_process_sql_update( 'titem', $values, ['id' => $node['id_db']] ); return $return; } /** * Add agent node in an option. * * @param integer $id_networkmap Id of networkmap. * @param integer $id_agent Id Agent. * @param integer $x X Axis. * @param integer $y Y Axis. * * @return mixed */ function add_agent_node_in_option($id_networkmap, $id_agent, $x, $y) { $networkmap = db_get_row_filter( 'tmap', ['id' => $id_networkmap] ); add_agent_networkmap( $id_networkmap, '', // Empty because the function fill with the id. $x, $y, $id_agent ); $networkmap_filter = db_get_value_filter('filter', 'tmap', ['id' => $id_networkmap]); $networkmap_filter = json_decode($networkmap_filter, true); if (!$networkmap_filter['empty_map']) { /* * Links Agent-Agent */ $parent = db_get_value_filter( 'id_parent', 'tagente', ['id_agente' => $id_agent] ); $child_node = db_get_value_filter( 'id', 'titem', [ 'source_data' => $id_agent, 'id_map' => $id_networkmap, 'deleted' => 0, ] ); $parent_node = []; if ($parent) { $parent_node = db_get_value_filter( 'id', 'titem', [ 'source_data' => $parent, 'id_map' => $id_networkmap, 'deleted' => 0, ] ); } if (empty($parent_node) === false) { if (empty($child_node) === false && empty($parent_node) === false) { $exist = db_get_row_filter( 'trel_item', [ 'id_map' => $id_networkmap, 'id_parent_source_data' => $parent, 'id_child_source_data' => $id_agent, 'parent_type' => 0, 'child_type' => 0, 'deleted' => 0, ] ); if (empty($exist) === true) { db_process_sql_insert( 'trel_item', [ 'id_map' => $id_networkmap, 'id_parent' => $parent_node, 'id_child' => $child_node, 'id_parent_source_data' => $parent, 'id_child_source_data' => $id_agent, 'parent_type' => 0, 'child_type' => 0, ] ); } } } else { if (empty($parent_node) === true) { $parent_node = db_get_value_filter( 'id', 'titem', [ 'source_data' => 0, 'id_map' => $id_networkmap, 'deleted' => 0, ] ); $child_node = db_get_value_filter( 'id', 'titem', [ 'source_data' => $id_agent, 'id_map' => $id_networkmap, 'deleted' => 0, ] ); $exist = db_get_row_filter( 'trel_item', [ 'id_map' => $id_networkmap, 'id_parent_source_data' => 0, 'id_child_source_data' => $id_agent, 'parent_type' => 0, 'child_type' => 0, 'deleted' => 0, ] ); if ((bool) $exist === false) { db_process_sql_insert( 'trel_item', [ 'id_map' => $id_networkmap, 'id_parent' => (int) $parent_node, 'id_child' => $child_node, 'id_parent_source_data' => 0, 'id_child_source_data' => $id_agent, 'parent_type' => 0, 'child_type' => 0, ] ); } } } $possible_childrens = db_get_all_rows_sql('SELECT * FROM tagente WHERE id_parent = '.$id_agent); if ($possible_childrens !== false) { foreach ($possible_childrens as $agent_child) { $child_node_aa = db_get_value_filter( 'id', 'titem', [ 'source_data' => $agent_child['id_agente'], 'id_map' => $id_networkmap, 'deleted' => 0, ] ); if ($child_node_aa) { $node_id_parent = db_get_value_filter( 'id', 'titem', [ 'source_data' => $id_agent, 'id_map' => $id_networkmap, 'deleted' => 0, ] ); $exist = db_get_row_filter( 'trel_item', [ 'id_map' => $id_networkmap, 'id_parent_source_data' => $id_agent, 'id_child_source_data' => $agent_child['id_agente'], 'parent_type' => 0, 'child_type' => 0, 'deleted' => 0, ] ); if (!$exist) { db_process_sql_insert( 'trel_item', [ 'id_map' => $id_networkmap, 'id_parent' => $node_id_parent, 'id_child' => $child_node_aa['id'], 'id_parent_source_data' => $id_agent, 'id_child_source_data' => $agent_child['id_agente'], 'parent_type' => 0, 'child_type' => 0, ] ); } } } } /* --------------------------------------------------------------- ------Links Agent-Module-Module-Agent (interfaces) ------------ --------------------------------------------------------------- */ $interfaces = modules_get_all_interfaces($id_agent); if (empty($interfaces) === true) { $interfaces = []; } foreach ($interfaces as $interface) { $style = []; $style['id_agent'] = $id_agent; $style['shape'] = 'circle'; $style['image'] = 'images/mod_snmp_proc.png'; $style['width'] = 50; $style['height'] = 16; $style['label'] = modules_get_agentmodule_name($interface['id_agente_modulo']); $id_int = db_process_sql_insert( 'titem', [ 'id_map' => $id_networkmap, 'x' => 666, 'y' => 666, 'z' => 0, 'deleted' => 0, 'type' => 1, 'refresh' => 0, 'source' => 0, 'source_data' => $interface['id_agente_modulo'], 'style' => json_encode($style), ] ); $relations = modules_get_relations( ['id_module' => $interface['id_agente_modulo']] ); if (empty($relations)) { $relations = []; } foreach ($relations as $relation) { $interface_a = db_get_value_filter( 'nombre', 'tagente_modulo', ['id_agente_modulo' => $relation['module_a']] ); $interface_b = db_get_value_filter( 'nombre', 'tagente_modulo', ['id_agente_modulo' => $relation['module_b']] ); $a_is_interface = false; if (preg_match('/(.+)_ifOperStatus$/', (string) $interface_a, $matches)) { if ($matches[1]) { $a_is_interface = true; } } $b_is_interface = false; if (preg_match('/(.+)_ifOperStatus$/', (string) $interface_b, $matches)) { if ($matches[1]) { $b_is_interface = true; } } if ($a_is_interface && $b_is_interface) { $exist_agent_in_map = false; if ($interface['id_agente_modulo'] == $relation['module_a']) { $exist_agent_in_map = db_get_value_filter( 'id', 'titem', ['source_data' => modules_get_agentmodule_agent($relation['module_b'])] ); $agent_a = $id_agent; $agent_b = modules_get_agentmodule_agent($relation['module_b']); } else { $exist_agent_in_map = db_get_value_filter( 'id', 'titem', ['source_data' => modules_get_agentmodule_agent($relation['module_a'])] ); $agent_a = modules_get_agentmodule_agent($relation['module_a']); $agent_b = $id_agent; } if ($exist_agent_in_map) { $exist = db_get_row_filter( 'trel_item', [ 'id_map' => $id_networkmap, 'id_parent_source_data' => $relation['module_a'], 'id_child_source_data' => $relation['module_b'], 'deleted' => 0, ] ); $exist_reverse = db_get_row_filter( 'trel_item', [ 'id_map' => $id_networkmap, 'id_parent_source_data' => $relation['module_b'], 'id_child_source_data' => $relation['module_a'], 'deleted' => 0, ] ); if (!$exist && !$exist_reverse) { if ($interface['id_agente_modulo'] == $relation['module_a']) { $id_int2 = db_get_value_filter( 'id', 'titem', [ 'source_data' => $relation['module_b'], 'id_map' => $id_networkmap, ] ); db_process_sql_insert( 'trel_item', [ 'id_map' => $id_networkmap, 'id_parent' => $id_int, 'id_child' => $id_int2, 'id_parent_source_data' => $relation['module_a'], 'id_child_source_data' => $relation['module_b'], 'parent_type' => 1, 'child_type' => 1, ] ); } else { $id_int2 = db_get_value_filter( 'id', 'titem', [ 'source_data' => $relation['module_a'], 'id_map' => $id_networkmap, ] ); db_process_sql_insert( 'trel_item', [ 'id_map' => $id_networkmap, 'id_parent' => $id_int2, 'id_child' => $id_int, 'id_parent_source_data' => $relation['module_a'], 'id_child_source_data' => $relation['module_b'], 'parent_type' => 1, 'child_type' => 1, ] ); } } } } } } /* --------------------------------------------------------------- ------Links Agent-Module-Module-Agent ------------------------- --------------------------------------------------------------- */ $relations = modules_get_relations(['id_agent' => $id_agent]); if ($relations === false) { $relations = []; } foreach ($relations as $key => $relation) { $module_a = $relation['module_a']; $agent_a = modules_get_agentmodule_agent($module_a); $module_b = $relation['module_b']; $agent_b = modules_get_agentmodule_agent($module_b); $exist = db_get_row_filter( 'trel_item', [ 'id_map' => $id_networkmap, 'id_parent_source_data' => $module_a, 'id_child_source_data' => $module_b, 'deleted' => 0, ] ); $exist_reverse = db_get_row_filter( 'trel_item', [ 'id_map' => $id_networkmap, 'id_parent_source_data' => $module_b, 'id_child_source_data' => $module_a, 'deleted' => 0, ] ); $new_relation = false; if (empty($exist) === true && empty($exist_reverse) === true) { $style = []; $style['id_agent'] = $agent_a; $style['shape'] = 'circle'; $style['image'] = 'images/mod_snmp_proc.png'; $style['width'] = 50; $style['height'] = 16; $style['label'] = modules_get_agentmodule_name($module_a); $id_int1 = db_process_sql_insert( 'titem', [ 'id_map' => $id_networkmap, 'x' => 666, 'y' => 666, 'z' => 0, 'deleted' => 0, 'type' => 1, 'refresh' => 0, 'source' => 0, 'source_data' => $module_a, 'style' => json_encode($style), ] ); $style = []; $style['id_agent'] = $agent_b; $style['shape'] = 'circle'; $style['image'] = 'images/mod_snmp_proc.png'; $style['width'] = 50; $style['height'] = 16; $style['label'] = modules_get_agentmodule_name($module_b); $id_int2 = db_process_sql_insert( 'titem', [ 'id_map' => $id_networkmap, 'x' => 666, 'y' => 666, 'z' => 0, 'deleted' => 0, 'type' => 1, 'refresh' => 0, 'source' => 0, 'source_data' => $module_b, 'style' => json_encode($style), ] ); $ins_mod = db_process_sql_insert( 'trel_item', [ 'id_map' => $id_networkmap, 'id_parent' => $id_int1, 'id_child' => $id_int2, 'id_parent_source_data' => $module_a, 'id_child_source_data' => $module_b, 'parent_type' => 1, 'child_type' => 1, ] ); if ($ins_mod) { $new_relation = true; } } if ($new_relation) { $old_relation_wit_center = db_get_row_filter( 'trel_item', [ 'id_map' => $id_networkmap, 'id_parent_source_data' => 0, 'id_child_source_data' => $id_agent, 'deleted' => 0, ] ); if ($old_relation_wit_center) { db_process_sql_delete( 'trel_item', [ 'id_map' => $id_networkmap, 'id' => $old_relation_wit_center['id'], ] ); } } } } $new_node = db_get_row_sql( sprintf( 'SELECT * FROM titem WHERE id_map = %s AND type = 0 AND source_data = %s', $id_networkmap, $id_agent ) ); return $new_node; } function networkmap_get_new_nodes_and_links($networkmap, $x, $y) { $id_networkmap = $networkmap['id']; $id_recon = $networkmap['source_data']; $map_filter = $networkmap['filter']; if (is_array($map_filter) === false) { $map_filter = json_decode($map_filter, true); } if ((int) $networkmap['source'] === SOURCE_TASK) { $agents = enterprise_hook('get_discovery_agents', [$id_recon, true]); $relations_discovery = modules_get_relations(['id_rt' => $id_recon, 'distinct' => true]); $array_aux = $relations_discovery; $target_aux = $relations_discovery; foreach ($relations_discovery as $key => $rel) { foreach ($array_aux as $key2 => $rel2) { if ($key2 <= $key) { continue; } if ($rel['module_a'] === $rel2['module_a']) { $agent1 = modules_get_agentmodule_agent($rel['module_b']); $agent2 = modules_get_agentmodule_agent($rel2['module_b']); if ($agent1 === $agent2) { $name1 = modules_get_agentmodule_name($rel['module_b']); $name2 = modules_get_agentmodule_name($rel2['module_b']); if ($name1 == 'Host Alive') { unset($target_aux[$key]); } else if ($name2 == 'Host Alive') { unset($target_aux[$key2]); } continue; } } if ($rel['module_b'] === $rel2['module_b']) { $agent1 = modules_get_agentmodule_agent($rel['module_a']); $agent2 = modules_get_agentmodule_agent($rel2['module_a']); if ($agent1 === $agent2) { $name1 = modules_get_agentmodule_name($rel['module_a']); $name2 = modules_get_agentmodule_name($rel2['module_a']); if ($name1 == 'Host Alive') { unset($target_aux[$key]); } else if ($name2 == 'Host Alive') { unset($target_aux[$key2]); } continue; } } if ($rel['module_a'] === $rel2['module_b']) { $agent1 = modules_get_agentmodule_agent($rel['module_b']); $agent2 = modules_get_agentmodule_agent($rel2['module_a']); if ($agent1 === $agent2) { $name1 = modules_get_agentmodule_name($rel['module_b']); $name2 = modules_get_agentmodule_name($rel2['module_a']); if ($name1 == 'Host Alive') { unset($target_aux[$key]); } else if ($name2 == 'Host Alive') { unset($target_aux[$key2]); } continue; } } if ($rel['module_b'] === $rel2['module_a']) { $agent1 = modules_get_agentmodule_agent($rel['module_a']); $agent2 = modules_get_agentmodule_agent($rel2['module_b']); if ($agent1 === $agent2) { $name1 = modules_get_agentmodule_name($rel['module_a']); $name2 = modules_get_agentmodule_name($rel2['module_b']); if ($name1 == 'Host Alive') { unset($target_aux[$key]); } else if ($name2 == 'Host Alive') { unset($target_aux[$key2]); } continue; } } } } $relations_discovery = $target_aux; db_process_sql_delete('trel_item', ['id_map' => $id_networkmap, 'parent_type' => 1, 'child_type' => 1]); $id_recon = $id_networkmap; // Relations Module <-> Module. foreach ($relations_discovery as $key => $relation) { $module_a = $relation['module_a']; $agent_a = modules_get_agentmodule_agent($module_a); $module_b = $relation['module_b']; $agent_b = modules_get_agentmodule_agent($module_b); $exist = db_get_row_filter( 'trel_item', [ 'id_map' => $id_networkmap, 'id_parent_source_data' => $module_a, 'id_child_source_data' => $module_b, 'deleted' => 0, ] ); $exist_reverse = db_get_row_filter( 'trel_item', [ 'id_map' => $id_networkmap, 'id_parent_source_data' => $module_b, 'id_child_source_data' => $module_a, 'deleted' => 0, ] ); if (empty($exist) === true && empty($exist_reverse) === true) { $item_a = db_get_value( 'id', 'titem', 'source_data', $agent_a ); $item_b = db_get_value( 'id', 'titem', 'source_data', $agent_b ); db_process_sql_insert( 'trel_item', [ 'id_map' => $id_networkmap, 'id_parent' => $item_a, 'id_child' => $item_b, 'id_parent_source_data' => $module_a, 'id_child_source_data' => $module_b, 'parent_type' => 1, 'child_type' => 1, ] ); } } } else if ((int) $networkmap['source'] === SOURCE_NETWORK) { // Network map, based on direct network. $agents = networkmap_get_nodes_from_ip_mask( $id_recon, true ); } else { if ($map_filter['dont_show_subgroups'] == 'true' && $map_filter['dont_show_subgroups'] !== 0) { // Show only current selected group. $filter['id_grupo'] = $networkmap['id_group']; } else { // Show current group and children. $childrens = groups_get_children($networkmap['id_group'], null, true); if (empty($childrens) === false) { $childrens = array_keys($childrens); $filter['id_grupo'] = $childrens; $filter['id_grupo'][] = $networkmap['id_group']; } else { $filter['id_grupo'] = $networkmap['id_group']; } } // Group map. $agents = agents_get_agents( $filter, ['*'], 'AR', [ 'field' => 'id_parent', 'order' => 'ASC', ] ); if (is_array($agents)) { // Remap ids. $agents = array_reduce( $agents, function ($carry, $item) { $carry[$item['id_agente']] = $item['id_agente']; return $carry; } ); } else { $agents = []; } } // At this point $agents contains all agents must be registered in the // network map. $new_agents = []; if (!empty($agents)) { $sql = ' SELECT t1.id_agente FROM tagente t1 WHERE t1.id_agente IN ('.implode(',', $agents).') AND t1.disabled = 0 AND t1.id_agente NOT IN ( SELECT source_data FROM titem WHERE id_map = '.$id_networkmap.' AND source='.NODE_AGENT.') '; $new_agents = db_get_all_rows_sql($sql); } if (!is_array($new_agents)) { $new_agents = []; } // Insert the new nodes. foreach ($new_agents as $new_agent) { // Agent name parameter is empty because the function fill with the id. add_agent_networkmap( $id_networkmap, '', $x, $y, $new_agent['id_agente'], ['refresh' => 1] ); } $new_agents_id = []; foreach ($new_agents as $id_agent) { $new_agents_id[] = $id_agent['id_agente']; } if (empty($new_agents_id) === true || (is_array($networkmap['filter']) === true && isset($networkmap['filter']['empty_map']) === true && (int) $networkmap['filter']['empty_map'] === 1) ) { // In empty maps do not calculate links, let the user paint them. // Also return if no new agents are detected. return; } // Links. $sql = 'SELECT source_data FROM titem WHERE id_map = '.$id_networkmap.' AND source_data IN ('.implode(',', $new_agents_id).') AND type = 0 AND deleted = 0 GROUP BY source_data'; $nodes = db_get_all_rows_sql($sql); foreach ($nodes as $node) { // First the relation parents without l2 interfaces. $parent = db_get_value_filter( 'id_parent', 'tagente', ['id_agente' => $node['source_data']] ); $child_node = db_get_value_filter( 'id', 'titem', [ 'source_data' => $node['source_data'], 'id_map' => $id_networkmap, 'deleted' => 0, ] ); $parent_node = db_get_value_filter( 'id', 'titem', [ 'source_data' => $parent, 'id_map' => $id_networkmap, 'deleted' => 0, ] ); if (empty($child_node) === false && empty($parent_node) === false) { $exist = db_get_row_filter( 'trel_item', [ 'id_map' => $id_networkmap, 'id_parent_source_data' => $parent, 'id_child_source_data' => $node['source_data'], 'parent_type' => 0, 'child_type' => 0, 'deleted' => 0, ] ); if (empty($exist) === true) { db_process_sql_insert( 'trel_item', [ 'id_map' => $id_networkmap, 'id_parent' => $parent_node, 'id_child' => $child_node, 'id_parent_source_data' => $parent, 'id_child_source_data' => $node['source_data'], 'parent_type' => 2, 'child_type' => 0, ] ); } } if (empty($parent_node) === true) { $parent_node = db_get_value_filter( 'id', 'titem', [ 'source_data' => 0, 'id_map' => $id_networkmap, 'deleted' => 0, ] ); $child_node = db_get_value_filter( 'id', 'titem', [ 'source_data' => $node['source_data'], 'id_map' => $id_networkmap, 'deleted' => 0, ] ); $exist = db_get_row_filter( 'trel_item', [ 'id_map' => $id_networkmap, 'id_parent_source_data' => 0, 'id_child_source_data' => $node['source_data'], 'parent_type' => 0, 'child_type' => 0, 'deleted' => 0, ] ); if (empty($exist) === true) { db_process_sql_insert( 'trel_item', [ 'id_map' => $id_networkmap, 'id_parent' => $parent_node, 'id_child' => $child_node, 'id_parent_source_data' => 0, 'id_child_source_data' => $node['source_data'], 'parent_type' => 0, 'child_type' => 0, 'deleted' => 0, ] ); } } $relations = modules_get_relations( [ 'id_agent' => $node['source_data'], 'networkmap' => true, ] ); if ($relations === false) { $relations = []; } // Relations Module <-> Module. foreach ($relations as $key => $relation) { $module_a = $relation['module_a']; $agent_a = modules_get_agentmodule_agent($module_a); $module_b = $relation['module_b']; $agent_b = modules_get_agentmodule_agent($module_b); $exist = db_get_row_filter( 'trel_item', [ 'id_map' => $id_networkmap, 'id_parent_source_data' => $module_a, 'id_child_source_data' => $module_b, 'deleted' => 0, ] ); $exist_reverse = db_get_row_filter( 'trel_item', [ 'id_map' => $id_networkmap, 'id_parent_source_data' => $module_b, 'id_child_source_data' => $module_a, 'deleted' => 0, ] ); if (empty($exist) === true && empty($exist_reverse) === true) { $item_a = db_get_value( 'id', 'titem', 'source_data', $agent_a ); $item_b = db_get_value( 'id', 'titem', 'source_data', $agent_b ); db_process_sql_insert( 'trel_item', [ 'id_map' => $id_networkmap, 'id_parent' => $item_a, 'id_child' => $item_b, 'id_parent_source_data' => $module_a, 'id_child_source_data' => $module_b, 'parent_type' => 1, 'child_type' => 1, ] ); } } // Get L2 interface relations. $interfaces = modules_get_interfaces( $node['source_data'], [ 'id_agente', 'id_agente_modulo', ] ); if (empty($interfaces) === true) { $interfaces = []; } } } /** * Delete nodes with id agent given. * * @param integer $id_agent Id Agent. * * @return void */ function networkmap_delete_nodes_by_agent($id_agent) { $rows = db_get_all_rows_filter( 'titem', ['source_data' => $id_agent] ); if (empty($rows) === true) { $rows = []; } foreach ($rows as $row) { db_process_sql_delete( 'trel_item', ['id_parent' => $row['id']] ); db_process_sql_delete( 'trel_item', ['id_child' => $row['id']] ); } db_process_sql_delete( 'titem', ['source_data' => $id_agent] ); } /** * Delete a relation. * * @param integer $id_map Id Map. * * @return mixed */ function delete_relations($id_map) { return db_process_sql_delete('trel_item', ['id_map' => $id_map]); } /** * Delete a node. * * @param integer $id_map Id Map. * * @return mixed */ function delete_nodes($id_map) { return db_process_sql_delete('titem', ['id_map' => $id_map]); } function duplicate_map_insert_nodes_and_relations($id, $new_id) { $return = true; $relations = []; $nodes = []; $nodes = db_get_all_rows_filter( 'titem', ['id_map' => $id] ); if ($nodes === false) { $nodes = []; } $relations = db_get_all_rows_filter( 'trel_item', [ 'id_map' => $id, 'deleted' => 0, ] ); if ($relations === false) { $relations = []; } foreach ($nodes as $node) { $values = $node; unset($values['id']); $values['id_map'] = $new_id; $result_or_id = db_process_sql_insert('titem', $values); if ($result_or_id === false) { $return = false; break; } } // Get fictional nodes in original map. $fictional_nodes = db_get_all_rows_filter( 'titem', [ 'id_map' => $id, 'type' => NODE_GENERIC, ] ); // Get fictional nodes in new duplicate map. $fictional_nodes_new = db_get_all_rows_filter( 'titem', [ 'id_map' => $new_id, 'type' => NODE_GENERIC, ] ); // Insert the new relations. if ($return) { foreach ($relations as $relation) { $values = []; $values['id_parent'] = $relation['id_parent']; $values['id_child'] = $relation['id_child']; // In fictional nodes, we need its node id (It doesn't have agent id or module id). if ($relation['parent_type'] == NODE_GENERIC || $relation['child_type'] == NODE_GENERIC) { foreach ($fictional_nodes as $key => $fn) { if ($relation['parent_type'] == NODE_GENERIC && ($relation['id_parent'] == $fn['id'])) { $values['id_parent'] = $fictional_nodes_new[$key]['id']; } if ($relation['child_type'] == NODE_GENERIC && ($relation['id_child'] == $fn['id'])) { $values['id_child'] = $fictional_nodes_new[$key]['id']; } } } $values['id_parent_source_data'] = $relation['id_parent_source_data']; $values['id_child_source_data'] = $relation['id_child_source_data']; $values['id_map'] = $new_id; $values['parent_type'] = $relation['parent_type']; $values['child_type'] = $relation['child_type']; $result = db_process_sql_insert('trel_item', $values); if ($result === false) { $return = false; break; } } } } function migrate_older_networkmap_enterprise($id) { global $config; $old_networkmap = db_get_row_filter( 'tnetworkmap_enterprise', ['id' => $id] ); $map_values = []; $map_values['id_group'] = $old_networkmap['id_group']; $map_values['id_user'] = $config['id_user']; $map_values['type'] = 0; $map_values['subtype'] = 0; $map_values['name'] = $old_networkmap['name']; $old_networkmap_options = json_decode($old_networkmap['options'], true); $new_map_filter = []; $new_map_filter['dont_show_subgroups'] = $old_networkmap_options['dont_show_subgroups']; $new_map_filter['node_radius'] = 40; $new_map_filter['id_migrate_map'] = $id; $map_values['filter'] = json_encode($new_map_filter); $map_values['description'] = 'Mapa enterprise migrado'; $map_values['width'] = 4000; $map_values['height'] = 4000; if (!isset($old_networkmap_options['center_x'])) { $map_values['center_x'] = 2000; } else { if ($old_networkmap_options['center_x'] == null) { $map_values['center_x'] = 2000; } else { $map_values['center_x'] = $old_networkmap_options['center_x']; } } if (!isset($old_networkmap_options['center_y'])) { $map_values['center_y'] = 2000; } else { if ($old_networkmap_options['center_y'] == null) { $map_values['center_y'] = 2000; } else { $map_values['center_y'] = $old_networkmap_options['center_y']; } } $map_values['background'] = ''; $map_values['background_options'] = 0; if ($old_networkmap_options['refresh_state'] == null) { $map_values['source_period'] = 50; } else { $map_values['source_period'] = $old_networkmap_options['refresh_state']; } switch ($old_networkmap_options['source_data']) { case 'group': $map_values['source'] = 0; $map_values['source_data'] = $old_networkmap['id_group']; break; case 'recon_task': $map_values['source'] = 1; $map_values['source_data'] = $old_networkmap_options['recon_task_id']; break; case 'ip_mask': $map_values['source'] = 2; $map_values['source_data'] = $old_networkmap_options['ip_mask']; break; default: // Do none. break; } switch ($old_networkmap_options['method']) { case 'twopi': $map_values['generation_method'] = LAYOUT_RADIAL; break; case 'dot': $map_values['generation_method'] = LAYOUT_FLAT; break; case 'circo': $map_values['generation_method'] = LAYOUT_CIRCULAR; break; case 'neato': $map_values['generation_method'] = LAYOUT_SPRING1; break; case 'fdp': $map_values['generation_method'] = LAYOUT_SPRING2; break; default: $map_values['generation_method'] = LAYOUT_RADIAL; break; } $map_values['generated'] = 1; $id_new_map = db_process_sql_insert('tmap', $map_values); if ((bool) $id_new_map === true) { $old_nodes = db_get_all_rows_filter( 'tnetworkmap_enterprise_nodes', ['id_networkmap_enterprise' => $old_networkmap['id']] ); $old_nodes_source_data = []; foreach ($old_nodes as $key => $old_node) { $key = $old_node['id']; $old_nodes_source_data[$key]['id_agent'] = $old_node['id_agent']; $old_nodes_source_data[$key]['id_module'] = $old_node['id_module']; $node_values = []; $node_values['id_map'] = $id_new_map; $node_values['x'] = $old_node['x']; $node_values['y'] = $old_node['y']; $node_values['z'] = $old_node['z']; $node_values['deleted'] = $old_node['deleted']; $node_values['source'] = 0; $node_values['options'] = ''; $old_node_style = json_decode($old_node['options'], true); $node_style = []; $node_style['shape'] = $old_node_style['shape']; $node_style['image'] = $old_node_style['image']; $node_style['width'] = $old_node_style['width']; $node_style['height'] = $old_node_style['height']; $node_style['label'] = $old_node_style['text']; $node_style['id_group'] = $map_values['id_group']; $node_values['type'] = 0; $node_values['source_data'] = $old_node['id_agent']; $node_values['style'] = json_encode($node_style); db_process_sql_insert('titem', $node_values); } $old_relations = db_get_all_rows_filter( 'tnetworkmap_ent_rel_nodes', ['id_networkmap_enterprise' => $old_networkmap['id']] ); foreach ($old_relations as $old_relation) { $new_item_parent = db_get_row_filter( 'titem', [ 'source_data' => $old_nodes_source_data[$old_relation['parent']]['id_agent'], 'id_map' => $id_new_map, ] ); $new_item_child = db_get_row_filter( 'titem', [ 'source_data' => $old_nodes_source_data[$old_relation['child']]['id_agent'], 'id_map' => $id_new_map, ] ); $relation_values = []; $relation_values['id_map'] = $id_new_map; $relation_values['deleted'] = $old_relation['deleted']; $relation_values['parent_type'] = 0; $relation_values['id_parent_source_data'] = $old_nodes_source_data[$old_relation['parent']]['id_agent']; $relation_values['id_parent'] = $new_item_parent['id']; $relation_values['child_type'] = 0; $relation_values['id_child_source_data'] = $old_nodes_source_data[$old_relation['child']]['id_agent']; $relation_values['id_child'] = $new_item_child['id']; if (isset($relation_values['id_parent_source_data']) === false) { $relation_values['id_parent_source_data'] = 0; } if (isset($relation_values['id_parent']) === false) { $relation_values['id_parent'] = 0; } if (isset($relation_values['id_child_source_data']) === false) { $relation_values['id_child_source_data'] = 0; } if (isset($relation_values['id_child']) === false) { $relation_values['id_child'] = 0; } db_process_sql_insert('trel_item', $relation_values); } } else { return false; } return true; }