440 lines
12 KiB
PHP
440 lines
12 KiB
PHP
<?php
|
|
|
|
// Pandora FMS - http://pandorafms.com
|
|
// ==================================================
|
|
// Copyright (c) 2005-2023 Pandora FMS
|
|
// Please see http://pandorafms.com/community/ for full contribution list
|
|
// This program is free software; you can redistribute it and/or
|
|
// modify it under the terms of the GNU Lesser General Public License
|
|
// as published by the Free Software Foundation; version 2
|
|
// This program is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
|
|
/**
|
|
* @package Include
|
|
* @subpackage Maps
|
|
*/
|
|
|
|
|
|
function maps_save_map($values)
|
|
{
|
|
$result_add = db_process_sql_insert('tmap', $values);
|
|
return $result_add;
|
|
}
|
|
|
|
|
|
function maps_get_maps($filter)
|
|
{
|
|
return db_get_all_rows_filter('tmap', $filter);
|
|
}
|
|
|
|
|
|
function maps_get_subtype_string($subtype)
|
|
{
|
|
switch ($subtype) {
|
|
case MAP_SUBTYPE_TOPOLOGY:
|
|
return __('Topology');
|
|
|
|
break;
|
|
case MAP_SUBTYPE_POLICIES:
|
|
return __('Policies');
|
|
|
|
break;
|
|
case MAP_SUBTYPE_GROUPS:
|
|
return __('Groups');
|
|
|
|
break;
|
|
case MAP_SUBTYPE_RADIAL_DYNAMIC:
|
|
return __('Dynamic');
|
|
|
|
break;
|
|
default:
|
|
return __('Unknown');
|
|
break;
|
|
}
|
|
}
|
|
|
|
|
|
function maps_duplicate_map($id)
|
|
{
|
|
global $config;
|
|
$map = db_get_all_rows_sql('SELECT * FROM tmap WHERE id = '.$id);
|
|
$result = false;
|
|
$map = $map[0];
|
|
if (!empty($map)) {
|
|
$map_names = db_get_row_sql("SELECT name FROM tmap WHERE name LIKE '".$map['name']."%'");
|
|
$index = 0;
|
|
foreach ($map_names as $map_name) {
|
|
$index++;
|
|
}
|
|
|
|
$new_name = __('Copy of ').$map['name'];
|
|
$result = db_process_sql_insert(
|
|
'tmap',
|
|
[
|
|
'id_group' => $map['id_group'],
|
|
'id_user' => $config['id_user'],
|
|
'type' => $map['type'],
|
|
'subtype' => $map['subtype'],
|
|
'name' => $new_name,
|
|
'description' => $map['description'],
|
|
'width' => $map['width'],
|
|
'height' => $map['height'],
|
|
'center_x' => $map['center_x'],
|
|
'center_y' => $map['center_y'],
|
|
'background' => $map['background'],
|
|
'background_options' => $map['background_options'],
|
|
'source_period' => $map['source_period'],
|
|
'source' => $map['source'],
|
|
'source_data' => $map['source_data'],
|
|
'generation_method' => $map['generation_method'],
|
|
'filter' => $map['filter'],
|
|
]
|
|
);
|
|
}
|
|
|
|
if ($result) {
|
|
$map_items = db_get_all_rows_sql('SELECT * FROM titem WHERE id_map = '.$id);
|
|
maps_duplicate_items_map($result, $map_items);
|
|
}
|
|
|
|
return (int) $result;
|
|
}
|
|
|
|
|
|
function maps_duplicate_items_map($id, $map_items)
|
|
{
|
|
if (empty($map_items)) {
|
|
return;
|
|
}
|
|
|
|
foreach ($map_items as $item) {
|
|
$copy_items = [
|
|
'id_map' => $id,
|
|
'x' => $item['x'],
|
|
'y' => $item['y'],
|
|
'z' => $item['z'],
|
|
'deleted' => $item['deleted'],
|
|
'type' => $item['type'],
|
|
'refresh' => $item['refresh'],
|
|
'source' => $item['source'],
|
|
'source_data' => $item['source_data'],
|
|
'options' => $item['options'],
|
|
'style' => $item['style'],
|
|
];
|
|
$result_copy_item = db_process_sql_insert('titem', $copy_items);
|
|
if ($result_copy_item) {
|
|
$item_relations = db_get_all_rows_sql('SELECT * FROM trel_item WHERE id = '.$item['id'].' AND deleted = 0');
|
|
if ($item['id'] == $item_relations['parent_id']) {
|
|
$copy_item_relations = [
|
|
'id_parent' => $result_copy_item,
|
|
'id_child' => $item_relations['id_child'],
|
|
'parent_type' => $item_relations['parent_type'],
|
|
'child_type' => $item_relations['child_type'],
|
|
'id_item' => $item_relations['id_item'],
|
|
'deleted' => $item_relations['deleted'],
|
|
];
|
|
} else {
|
|
$copy_item_relations = [
|
|
'id_parent' => $item_relations['id_parent'],
|
|
'id_child' => $result_copy_item,
|
|
'parent_type' => $item_relations['parent_type'],
|
|
'child_type' => $item_relations['child_type'],
|
|
'id_item' => $item_relations['id_item'],
|
|
'deleted' => $item_relations['deleted'],
|
|
];
|
|
}
|
|
|
|
db_process_sql_insert('trel_item', $copy_item_relations);
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
function maps_delete_map($id)
|
|
{
|
|
$where = 'id='.$id;
|
|
$result = db_process_sql_delete('tmap', $where);
|
|
return (int) $result;
|
|
}
|
|
|
|
|
|
function maps_get_count_nodes($id)
|
|
{
|
|
$result = db_get_sql('SELECT COUNT(*) FROM titem WHERE id_map = '.$id);
|
|
return (int) $result;
|
|
}
|
|
|
|
|
|
function maps_update_map($id, $values)
|
|
{
|
|
$where = 'id='.$id;
|
|
$result = db_process_sql_update('tmap', $values, $where);
|
|
return (int) $result;
|
|
}
|
|
|
|
|
|
function maps_add_node($values)
|
|
{
|
|
$result_add_node = db_process_sql_insert('titem', $values);
|
|
return $result_add_node;
|
|
}
|
|
|
|
|
|
function maps_add_node_relationship($values)
|
|
{
|
|
$result_add_node_rel = db_process_sql_insert('trel_item', $values);
|
|
return $result_add_node_rel;
|
|
}
|
|
|
|
|
|
function run_graphviz($filename_map, $filename_dot, $layout, $graph)
|
|
{
|
|
switch (PHP_OS) {
|
|
case 'WIN32':
|
|
case 'WINNT':
|
|
case 'Windows':
|
|
$filename_plain = sys_get_temp_dir().'\\plain.txt';
|
|
break;
|
|
|
|
default:
|
|
$filename_plain = sys_get_temp_dir().'/plain.txt';
|
|
break;
|
|
}
|
|
|
|
file_put_contents($filename_dot, $graph);
|
|
file_put_contents($filename_dot, $graph);
|
|
|
|
$cmd = $layout.' -Tcmapx -o'.$filename_map.' -Tplain -o'.$filename_plain.' '.$filename_dot;
|
|
|
|
system($cmd);
|
|
|
|
if (file_exists($filename_map)) {
|
|
unlink($filename_map);
|
|
}
|
|
|
|
if (file_exists($filename_dot)) {
|
|
unlink($filename_dot);
|
|
}
|
|
|
|
return $filename_plain;
|
|
}
|
|
|
|
|
|
function open_graph($size_x=50, $size_y=25)
|
|
{
|
|
$size = '';
|
|
|
|
$size = $size_x.','.$size_y;
|
|
|
|
// BEWARE: graphwiz DONT use single ('), you need double (").
|
|
$head = 'graph vmwaremap { labeljust=l; margin=0; ';
|
|
$head .= 'ratio=fill;';
|
|
$head .= 'root=0;';
|
|
$head .= 'rankdir=LR;';
|
|
$head .= 'size="'.$size.'";';
|
|
|
|
return $head;
|
|
}
|
|
|
|
|
|
function create_node($node, $font_size=10)
|
|
{
|
|
// Set node status.
|
|
if (isset($node['status'])) {
|
|
switch ($node['status']) {
|
|
case AGENT_MODULE_STATUS_NORMAL:
|
|
$status_color = COL_NORMAL;
|
|
// Normal monitor.
|
|
break;
|
|
|
|
case AGENT_MODULE_STATUS_CRITICAL_BAD:
|
|
$status_color = COL_CRITICAL;
|
|
// Critical monitor.
|
|
break;
|
|
|
|
case AGENT_MODULE_STATUS_WARNING:
|
|
$status_color = COL_WARNING;
|
|
// Warning monitor.
|
|
break;
|
|
|
|
case AGENT_STATUS_ALERT_FIRED:
|
|
case AGENT_MODULE_STATUS_CRITICAL_ALERT:
|
|
case AGENT_MODULE_STATUS_WARNING_ALERT:
|
|
$status_color = COL_ALERTFIRED;
|
|
// Alert fired.
|
|
break;
|
|
|
|
case AGENT_MODULE_STATUS_NOT_INIT:
|
|
$status_color = COL_NOTINIT;
|
|
// Not init.
|
|
break;
|
|
|
|
default:
|
|
$status_color = COL_UNKNOWN;
|
|
// Unknown monitor.
|
|
break;
|
|
}
|
|
|
|
$status_color = 'color="'.$status_color.'",';
|
|
} else {
|
|
$status_color = '';
|
|
}
|
|
|
|
// Short name.
|
|
if (isset($node['nombre'])) {
|
|
$name = io_safe_output(strtolower($node['nombre']));
|
|
if (strlen($name) > 16) {
|
|
$name = substr($name, 0, 16).'...';
|
|
}
|
|
}
|
|
|
|
// Set node icon.
|
|
if (isset($node['image'])) {
|
|
if (file_exists($node['image'])) {
|
|
$img_node = $node['image'];
|
|
} else {
|
|
$img_node = null;
|
|
}
|
|
} else {
|
|
$img_node = null;
|
|
}
|
|
|
|
$result = $node['id_node'].' [ '.$status_color.' fontsize='.$font_size.', style="filled", fixedsize=true, width=0.40, height=0.40, label=<<TABLE CELLPADDING="0" CELLSPACING="0" BORDER="0"><TR><TD>'.html_print_image($img_node, true, false, false, true).'</TD></TR>
|
|
<TR><TD>'.$name.'</TD></TR></TABLE>>,
|
|
shape="doublecircle",
|
|
tooltip="ajax.php?page=operation/agentes/ver_agente&get_agent_status_tooltip=1&id_agent='.$node['id'].'"];';
|
|
|
|
return $result;
|
|
}
|
|
|
|
|
|
/**
|
|
* Returns an edge definition.
|
|
*
|
|
* @param string $head Origin.
|
|
* @param string $tail Target.
|
|
*
|
|
* @return string Edge str.
|
|
*/
|
|
function create_edge($head, $tail)
|
|
{
|
|
// Token edgeURL allows node navigation.
|
|
$edge = $head.' -- '.$tail.'[color="#BDBDBD", headclip=false, tailclip=false];'."\n";
|
|
|
|
return $edge;
|
|
}
|
|
|
|
|
|
// Closes a graph definition
|
|
function close_graph()
|
|
{
|
|
return '}';
|
|
}
|
|
|
|
|
|
function loadfile_map($file='', $graph)
|
|
{
|
|
global $config;
|
|
|
|
$networkmap_nodes = [];
|
|
|
|
$relations = [];
|
|
|
|
$other_file = file($file);
|
|
$graph = explode(']', $graph);
|
|
|
|
$ids = [];
|
|
foreach ($graph as $node) {
|
|
$line = str_replace("\n", ' ', $node);
|
|
if (preg_match('/([0-9]+) \[.*tooltip.*id_agent=([0-9]+)/', $line, $match) != 0) {
|
|
$ids[$match[1]] = ['id_agent' => $match[2]];
|
|
}
|
|
}
|
|
|
|
foreach ($other_file as $key => $line) {
|
|
$line = preg_replace('/[ ]+/', ' ', $line);
|
|
|
|
$data = [];
|
|
|
|
if (preg_match('/^node.*$/', $line) != 0) {
|
|
$items = explode(' ', $line);
|
|
$node_id = $items[1];
|
|
$node_x = ($items[2] * 100);
|
|
// 200 is for show more big
|
|
$node_y = ($height_map - $items[3] * 100);
|
|
// 200 is for show more big
|
|
$data['id'] = $node_id;
|
|
$data['image'] = '';
|
|
$data['width'] = 10;
|
|
$data['height'] = 10;
|
|
$data['id_agent'] = 0;
|
|
|
|
if (preg_match('/<img src=\"([^\"]*)\"/', $line, $match) == 1) {
|
|
$image = $match[1];
|
|
$data['image'] = $config['homeurl'].'/'.$image;
|
|
$size = getimagesize($config['homeurl'].'/'.$image);
|
|
$data['image_width'] = $size[0];
|
|
$data['image_height'] = $size[1];
|
|
if ($ids[$node_id]['id_agent'] == '') {
|
|
$data['id_agent'] = 0;
|
|
$data['label'] = get_product_name();
|
|
$data['color'] = COL_UNKNOWN;
|
|
} else {
|
|
$data['id_agent'] = $ids[$node_id]['id_agent'];
|
|
$data['label'] = io_safe_output(agents_get_alias($data['id_agent']));
|
|
|
|
$status = agents_get_status($data['id_agent']);
|
|
|
|
switch ($status) {
|
|
case 0:
|
|
$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;
|
|
}
|
|
|
|
$data['color'] = $status_color;
|
|
}
|
|
}
|
|
|
|
$data['x'] = $node_x;
|
|
$data['y'] = $node_y;
|
|
|
|
$networkmap_nodes['nodes'][] = $data;
|
|
} else if (preg_match('/^edge.*$/', $line) != 0) {
|
|
$items = explode(' ', $line);
|
|
$line_orig = $items[2];
|
|
$line_dest = $items[1];
|
|
|
|
$networkmap_nodes['arrows'][] = [
|
|
'orig' => $line_orig,
|
|
'dest' => $line_dest,
|
|
];
|
|
}
|
|
}
|
|
|
|
return $networkmap_nodes;
|
|
}
|