375 lines
13 KiB
PHP
375 lines
13 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.
|
|
|
|
if (isset($_GET['get_ptr'])) {
|
|
if ($_GET['get_ptr'] == 1) {
|
|
|
|
if (file_exists("../include/config.php"))
|
|
require ("../include/config.php");
|
|
else {
|
|
//TODO FIX AND SET AS RELATIVE DIRECTORY
|
|
if (file_exists("/var/www/pandora_console/include/config.php"))
|
|
require ("/var/www/pandora_console/include/config.php");
|
|
if (file_exists("/srv/www/htdocs/pandora_console/include/config.php"))
|
|
require ("/srv/www/htdocs/pandora_console/include/config.php");
|
|
}
|
|
|
|
if (! isset ($_SESSION["id_usuario"])) {
|
|
session_start ();
|
|
session_write_close ();
|
|
}
|
|
|
|
// Login check
|
|
if (!isset($_SESSION["id_usuario"])) {
|
|
$config['id_user'] = null;
|
|
}
|
|
else {
|
|
$config['id_user'] = $_SESSION["id_usuario"];
|
|
}
|
|
|
|
|
|
if (! check_acl ($config['id_user'], 0, "PM") && ! is_user_admin ($config['id_user'])) {
|
|
pandora_audit("ACL Violation", "Trying to access Setup Management");
|
|
require ("general/noaccess.php");
|
|
return;
|
|
}
|
|
|
|
$hook_enterprise = enterprise_include ('extensions/resource_exportation/functions.php');
|
|
|
|
header("Content-type: binary");
|
|
header("Content-Disposition: attachment; filename=\"".get_name_xml_resource($hook_enterprise)) . "\"";
|
|
header("Pragma: no-cache");
|
|
header("Expires: 0");
|
|
|
|
output_xml_resource($hook_enterprise);
|
|
}
|
|
}
|
|
else {
|
|
add_godmode_menu_option (__('Resource exportation'), 'PM','gservers','');
|
|
add_extension_godmode_function('resource_exportation_extension_main');
|
|
}
|
|
|
|
function output_xml_resource($hook_enterprise) {
|
|
global $config;
|
|
|
|
$type = get_parameter('type');
|
|
$id = (int)get_parameter('id');
|
|
|
|
switch ($type) {
|
|
case 'report':
|
|
output_xml_report($id);
|
|
break;
|
|
case 'visual_console':
|
|
output_xml_visual_console($id);
|
|
break;
|
|
default:
|
|
if ($hook_enterprise === true)
|
|
return enterprise_output_xml_resource($type, $id);
|
|
break;
|
|
}
|
|
}
|
|
|
|
function output_xml_report($id) {
|
|
$report = get_db_row('treport', 'id_report', $id);
|
|
|
|
echo '<?xml version="1.0" encoding="UTF-8" ?>' . "\n";
|
|
echo "<report>\n";
|
|
echo "<name><![CDATA[" . safe_output($report['name']) . "]]></name>\n";
|
|
if (isset($report['description']))
|
|
echo "<description><![CDATA[" . safe_output($report['description']) . "]]></description>\n";
|
|
$group = get_db_value('nombre', 'tgrupo', 'id_grupo', $report['id_group']);
|
|
echo "<group><![CDATA[" . safe_output($group) . "]]></group>\n";
|
|
$items = get_db_all_rows_field_filter('treport_content', 'id_report', $report['id_report']);
|
|
foreach ($items as $item) {
|
|
echo "<item>\n";
|
|
echo "<type>" . safe_output($item['type']) . "</type>\n";
|
|
echo "<description>" . safe_output($item['description']) . "</description>\n";
|
|
echo "<period>" . safe_output($item['period']) . "</period>\n";
|
|
if ($item['id_agent'] != 0) {
|
|
$agent = get_agent_name($item['id_agent']);
|
|
}
|
|
if ($item['id_agent_module'] != 0) {
|
|
$module = get_db_value('nombre', 'tagente_modulo', 'id_agente_modulo', $item['id_agent_module']);
|
|
$id_agent = get_db_value('id_agente', 'tagente_modulo', 'id_agente_modulo', $item['id_agent_module']);
|
|
$agent = get_agent_name($item['id_agent']);
|
|
|
|
echo "<module><![CDATA[" . safe_output($module) . "]]></module>\n";
|
|
}
|
|
if (isset($agent))
|
|
echo "<agent><![CDATA[" . $agent . "]]></agent>\n";
|
|
$agent = null;
|
|
switch (safe_output($item['type'])) {
|
|
case 1:
|
|
case 'simple_graph':
|
|
break;
|
|
case 'simple_baseline_graph':
|
|
break;
|
|
case 2:
|
|
case 'custom_graph':
|
|
$graph = get_db_value('name', 'tgraph', 'id_graph', $item['id_gs']);
|
|
echo "<graph><![CDATA[" . safe_output($graph) . "]]></graph>\n";
|
|
break;
|
|
case 3:
|
|
case 'SLA':
|
|
echo "<only_display_wrong>" . $item['only_display_wrong'] . "</only_display_wrong>\n";
|
|
echo "<monday>" . $item['monday'] . "</monday>\n";
|
|
echo "<tuesday>" . $item['tuesday'] . "</tuesday>\n";
|
|
echo "<wednesday>" . $item['wednesday'] . "</wednesday>\n";
|
|
echo "<thursday>" . $item['thursday'] . "</thursday>\n";
|
|
echo "<friday>" . $item['friday'] . "</friday>\n";
|
|
echo "<saturday>" . $item['saturday'] . "</saturday>\n";
|
|
echo "<sunday>" . $item['sunday'] . "</sunday>\n";
|
|
echo "<time_from>" . $item['time_from'] . "</time_from>\n";
|
|
echo "<time_to>" . $item['time_to'] . "</time_to>\n";
|
|
|
|
$slas = get_db_all_rows_field_filter('treport_content_sla_combined', 'id_report_content', $item['id_rc']);
|
|
if ($slas === false) $slas = array();
|
|
|
|
foreach ($slas as $sla) {
|
|
$module = get_db_value('nombre', 'tagente_modulo', 'id_agente_modulo', $sla['id_agent_module']);
|
|
$id_agent = get_db_value('id_agente', 'tagente_modulo', 'id_agente_modulo', $sla['id_agent_module']);
|
|
$agent = get_agent_name($item['id_agent']);
|
|
echo "<sla>";
|
|
echo "<agent><![CDATA[" . $agent . "]]></agent>\n";
|
|
echo "<module><![CDATA[" . safe_output($module) . "]]></module>\n";
|
|
echo "<sla_max>" . $sla['sla_max'] . "</sla_max>\n";
|
|
echo "<sla_min>" . $sla['sla_min'] . "</sla_min>\n";
|
|
echo "<sla_limit>" . $sla['sla_limit'] . "</sla_limit>\n";
|
|
echo "</sla>";
|
|
}
|
|
break;
|
|
case 6:
|
|
case 'monitor_report':
|
|
break;
|
|
case 7:
|
|
case 'avg_value':
|
|
break;
|
|
case 8:
|
|
case 'max_value':
|
|
break;
|
|
case 9:
|
|
case 'min_value':
|
|
break;
|
|
case 10:
|
|
case 'sumatory':
|
|
break;
|
|
case 'agent_detailed_event':
|
|
case 'event_report_agent':
|
|
break;
|
|
case 'text':
|
|
echo "<text><![CDATA[" . safe_output($item['text']) . "]]></text>\n";
|
|
break;
|
|
case 'sql':
|
|
echo "<header_definition><![CDATA[" . safe_output($item['header_definition']) . "]]></header_definition>\n";
|
|
if (!empty($item['external_source'])) {
|
|
echo "<sql><![CDATA[" . safe_output($item['external_source']) . "]]></sql>\n";
|
|
}
|
|
else {
|
|
$sql = get_db_value('sql', 'treport_custom_sql', 'id', $item['treport_custom_sql_id']);
|
|
echo "<sql>" . safe_output($sql) . "</sql>\n";
|
|
}
|
|
break;
|
|
case 'sql_graph_pie':
|
|
case 'sql_graph_vbar':
|
|
case 'sql_graph_hbar':
|
|
echo "<header_definition>" . safe_output($item['header_definition']) . "</header_definition>\n";
|
|
if (!empty($item['external_source'])) {
|
|
echo "<sql>" . safe_output($item['external_source']) . "</sql>\n";
|
|
}
|
|
else {
|
|
$sql = get_db_value('sql', 'treport_custom_sql', 'id', $item['treport_custom_sql_id']);
|
|
echo "<sql>" . safe_output($sql) . "</sql>\n";
|
|
}
|
|
break;
|
|
case 'event_report_group':
|
|
$group = get_db_value('nombre', 'tgrupo', 'id_grupo', $item['id_agent']);
|
|
echo "<group><![CDATA[" . safe_output($group) . "]]></group>\n";
|
|
break;
|
|
case 'event_report_module':
|
|
break;
|
|
case 'alert_report_module':
|
|
break;
|
|
case 'alert_report_agent':
|
|
break;
|
|
case 'url':
|
|
echo "<url><![CDATA[" . safe_output($values["external_source"]) . "]]></url>";
|
|
break;
|
|
case 'database_serialized':
|
|
echo "<header_definition><![CDATA[" . safe_output($item["header_definition"]) . "]]></header_definition>";
|
|
echo "<line_separator><![CDATA[" . safe_output($item["line_separator"]) . "]]></line_separator>";
|
|
echo "<column_separator><![CDATA[" . safe_output($item["header_definition"]) . "]]></column_separator>";
|
|
break;
|
|
case 'TTRT':
|
|
break;
|
|
case 'TTO':
|
|
break;
|
|
case 'MTBF':
|
|
break;
|
|
case 'MTTR':
|
|
break;
|
|
}
|
|
echo "</item>\n";
|
|
}
|
|
echo "</report>\n";
|
|
}
|
|
|
|
function output_xml_visual_console($id) {
|
|
$visual_map = get_db_row('tlayout', 'id', $id);
|
|
|
|
echo '<?xml version="1.0" encoding="UTF-8" ?>' . "\n";
|
|
echo "<visual_map>\n";
|
|
echo "<name><![CDATA[" . safe_output($visual_map['name']) . "]]></name>\n";
|
|
if ($visual_map['id_group'] != 0) {
|
|
$group = get_db_value('nombre', 'tgrupo', 'id_grupo', $visual_map['id_group']);
|
|
echo "<group><![CDATA[" . safe_output($group) . "]]></group>\n";
|
|
}
|
|
echo "<background><![CDATA[" . safe_output($visual_map['background']) . "]]></background>\n";
|
|
echo "<height>" . safe_output($visual_map['height']) . "</height>\n";
|
|
echo "<width>" . safe_output($visual_map['width']) . "</width>\n";
|
|
$items = get_db_all_rows_field_filter('tlayout_data', 'id_layout', $visual_map['id']);
|
|
if ($items === false) $items = array();
|
|
foreach ($items as $item){
|
|
echo "<item>\n";
|
|
echo "<other_id>" . $item['id'] . "</other_id>\n"; //OLD ID USE FOR parent item
|
|
if (!empty($item['label'])) {
|
|
echo "<label><![CDATA[" . safe_output($item['label']) . "]]></label>\n";
|
|
}
|
|
echo "<x>" . $item['pos_x'] . "</x>\n";
|
|
echo "<y>" . $item['pos_y'] . "</y>\n";
|
|
echo "<type>" . $item['type'] . "</type>\n";
|
|
if ($item['width'] != 0) {
|
|
echo "<width>" . $item['width'] . "</width>\n";
|
|
}
|
|
if ($item['height'] != 0) {
|
|
echo "<height>" . $item['height'] . "</height>\n";
|
|
}
|
|
if (!empty($item['image'])) {
|
|
echo "<image>" . $item['image'] . "</image>\n";
|
|
}
|
|
if ($item['period'] != 0) {
|
|
echo "<period>" . $item['period'] . "</period>\n";
|
|
}
|
|
$agent = '';
|
|
if ($item['id_agent'] != 0) {
|
|
$agent = get_agent_name($item['id_agent']);
|
|
}
|
|
if (isset($item['id_agente_modulo'])) {
|
|
if ($item['id_agente_modulo'] != 0) {
|
|
$module = get_db_value('nombre', 'tagente_modulo', 'id_agente_modulo', $item['id_agente_modulo']);
|
|
$id_agent = get_db_value('id_agente', 'tagente_modulo', 'id_agente_modulo', $item['id_agente_modulo']);
|
|
$agent = get_agent_name($id_agent);
|
|
|
|
echo "<module><![CDATA[" . safe_output($module) . "]]></module>\n";
|
|
}
|
|
}
|
|
if (!empty($agent)) {
|
|
echo "<agent><![CDATA[" . $agent . "]]></agent>\n";
|
|
}
|
|
if ($item['id_layout_linked'] != 0) {
|
|
echo "<id_layout_linked>" . $item['id_layout_linked'] . "</id_layout_linked>\n";
|
|
}
|
|
if ($item['parent_item'] != 0) {
|
|
echo "<parent_item>" . $item['parent_item'] . "</parent_item>\n";
|
|
}
|
|
if (!empty($item['label_color'])) {
|
|
echo "<label_color>" . $item['label_color'] . "</label_color>\n";
|
|
}
|
|
echo "</item>\n";
|
|
}
|
|
echo "</visual_map>\n";
|
|
}
|
|
|
|
function get_name_xml_resource($hook_enterprise) {
|
|
global $config;
|
|
|
|
$type = get_parameter('type');
|
|
$id = (int)get_parameter('id');
|
|
|
|
switch ($type) {
|
|
case 'report':
|
|
$name = get_db_value('name', 'treport', 'id_report', $id);
|
|
break;
|
|
case 'visual_console':
|
|
$name = get_db_value('name', 'tlayout', 'id', $id);
|
|
break;
|
|
default:
|
|
if ($hook_enterprise === true)
|
|
return enterprise_get_name_xml_resource($type, $id);
|
|
break;
|
|
}
|
|
|
|
$file = $name . ".ptr";
|
|
|
|
return $file;
|
|
}
|
|
|
|
function get_xml_resource() {
|
|
global $config;
|
|
|
|
$hook_enterprise = enterprise_include ('extensions/resource_exportation/functions.php');
|
|
}
|
|
|
|
function resource_exportation_extension_main() {
|
|
global $config;
|
|
|
|
if (! check_acl ($config['id_user'], 0, "PM") && ! is_user_admin ($config['id_user'])) {
|
|
pandora_audit("ACL Violation", "Trying to access Setup Management");
|
|
require ("general/noaccess.php");
|
|
return;
|
|
}
|
|
|
|
$hook_enterprise = enterprise_include ('extensions/resource_exportation/functions.php');
|
|
|
|
print_page_header (__('Resource exportation'), "images/extensions.png", false, "", true, "" );
|
|
|
|
echo "<div class=notify>";
|
|
echo __("This extension makes exportation of resource template more easy. " .
|
|
"Here you can export as a resource template in Pandora FMS 3.x format (.ptr). ");
|
|
echo "</div>";
|
|
|
|
echo "<br /><br />";
|
|
|
|
$table = null;
|
|
$table->width = '50%';
|
|
$table->style[0] = 'width: 30%;';
|
|
$table->style[1] = 'width: 10%;';
|
|
$table->class = "databox_color";
|
|
$table->data[0][0] = __('Report');
|
|
$table->data[0][1] = print_select_from_sql('SELECT id_report, name FROM treport', 'report', '', '', '', 0, true);
|
|
$table->data[0][2] = print_button(__('Export'), '', false, 'export_to_ptr(\'report\');', 'class="sub"', true);
|
|
$table->data[1][0] = __('Visual console');
|
|
$table->data[1][1] = print_select_from_sql('SELECT id, name FROM tlayout', 'visual_console', '', '', '', 0, true);
|
|
$table->data[1][2] = print_button(__('Export'), '', false, 'export_to_ptr(\'visual_console\');', 'class="sub"', true);
|
|
|
|
if ($hook_enterprise === true)
|
|
add_rows_for_enterprise($table->data);
|
|
|
|
print_table($table);
|
|
|
|
?>
|
|
<script type="text/javascript">
|
|
function export_to_ptr(type) {
|
|
id = $("select#" + type + " option:selected").val();
|
|
url = location.href.split('index');
|
|
url = url[0] + 'extensions/resource_exportation.php?get_ptr=1&type=' + type
|
|
+ '&id=' + id;
|
|
|
|
location.href=url;
|
|
}
|
|
</script>
|
|
<?php
|
|
}
|
|
?>
|