pandorafms/pandora_console/include/functions_maps.php

191 lines
5.7 KiB
PHP

<?php
// Pandora FMS - http://pandorafms.com
// ==================================================
// Copyright (c) 2005-2011 Artica Soluciones Tecnologicas
// Please see http://pandorafms.org 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;
}