274 lines
9.2 KiB
PHP
Executable File
274 lines
9.2 KiB
PHP
Executable File
<?php
|
|
// Pandora FMS - http://pandorafms.com
|
|
// ==================================================
|
|
// Copyright (c) 2005-2010 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 General Public License
|
|
// as published by the Free Software Foundation for 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.
|
|
|
|
include("../include/functions_reporting.php");
|
|
include("../include/functions_servers.php");
|
|
|
|
class Tactical {
|
|
private $correct_acl = false;
|
|
|
|
function __construct() {
|
|
$system = System::getInstance();
|
|
|
|
if ($system->checkACL()) {
|
|
$this->correct_acl = true;
|
|
}
|
|
else {
|
|
$this->correct_acl = false;
|
|
}
|
|
}
|
|
|
|
public function show() {
|
|
if (!$this->correct_acl) {
|
|
$this->show_fail_acl();
|
|
}
|
|
else {
|
|
$this->show_tactical();
|
|
}
|
|
}
|
|
|
|
public function ajax($parameter2 = false) {
|
|
$system = System::getInstance();
|
|
|
|
if (!$this->correct_acl) {
|
|
return;
|
|
}
|
|
else {
|
|
switch ($parameter2) {
|
|
case 'render_status_pie':
|
|
$links = $system->getRequest('links', '');
|
|
$data = $system->getRequest('data', '');
|
|
$width = $system->getRequest('width', 230);
|
|
|
|
$max_width = 399;
|
|
|
|
if($width > $max_width) {
|
|
$width = $max_width;
|
|
}
|
|
|
|
echo reporting_get_stats_modules_status(json_decode($data, true), $width, $width/2, json_decode($links, true));
|
|
exit;
|
|
}
|
|
}
|
|
}
|
|
|
|
private function show_fail_acl() {
|
|
$error['type'] = 'onStart';
|
|
$error['title_text'] = __('You don\'t have access to this page');
|
|
$error['content_text'] = __('Access to this page is restricted to authorized users only, please contact system administrator if you need assistance. <br><br>Please know that all attempts to access this page are recorded in security logs of Pandora System Database');
|
|
if (class_exists("HomeEnterprise"))
|
|
$home = new HomeEnterprise();
|
|
else
|
|
$home = new Home();
|
|
$home->show($error);
|
|
}
|
|
|
|
private function show_tactical() {
|
|
$ui = Ui::getInstance();
|
|
|
|
$ui->createPage();
|
|
$ui->createDefaultHeader(__("Tactical view"),
|
|
$ui->createHeaderButton(
|
|
array('icon' => 'back',
|
|
'pos' => 'left',
|
|
'text' => __('Back'),
|
|
'href' => 'index.php?page=home')));
|
|
$ui->showFooter(false);
|
|
$ui->beginContent();
|
|
$ui->contentBeginGrid('responsive');
|
|
$data = reporting_get_group_stats();
|
|
$data['mobile'] = true;
|
|
|
|
$formatted_data = reporting_get_stats_indicators($data, 100, 10, false);
|
|
$formatted_data_untiny = reporting_get_stats_indicators($data, 140, 15, false);
|
|
|
|
$overview = '<table class="tactical_bars">
|
|
<tr>
|
|
<td>' . $formatted_data['server_health']['title'] . '</td>
|
|
<td class="tiny tactical_bar">' . $formatted_data['server_health']['graph'] . '</td>
|
|
<td class="untiny tactical_bar">' . $formatted_data_untiny['server_health']['graph'] . '</td>
|
|
</tr>
|
|
<tr>
|
|
<td>' . $formatted_data['monitor_health']['title'] . '</td>
|
|
<td class="tiny tactical_bar">' . $formatted_data['monitor_health']['graph'] . '</td>
|
|
<td class="untiny tactical_bar">' . $formatted_data_untiny['monitor_health']['graph'] . '</td>
|
|
</tr>
|
|
<tr>
|
|
<td>' . $formatted_data['module_sanity']['title'] . '</td>
|
|
<td class="tiny tactical_bar">' . $formatted_data['module_sanity']['graph'] . '</td>
|
|
<td class="untiny tactical_bar">' . $formatted_data_untiny['module_sanity']['graph'] . '</td>
|
|
</tr>
|
|
<tr>
|
|
<td>' . $formatted_data['alert_level']['title'] . '</td>
|
|
<td class="tiny tactical_bar">' . $formatted_data['alert_level']['graph'] . '</td>
|
|
<td class="untiny tactical_bar">' . $formatted_data_untiny['alert_level']['graph'] . '</td>
|
|
</tr>
|
|
</table>';
|
|
|
|
$agents_monitors = reporting_get_stats_agents_monitors($data);
|
|
$alerts_stats = reporting_get_stats_alerts($data);
|
|
|
|
$overview .= "<br />\n" . $agents_monitors;
|
|
$overview .= "<br />\n" . $alerts_stats;
|
|
|
|
$ui->contentGridAddCell($overview, 'tactical1');
|
|
|
|
ob_start();
|
|
$links = array();
|
|
$links['monitor_critical'] = "index.php?page=modules&status=1";
|
|
$links['monitor_warning'] = "index.php?page=modules&status=2";
|
|
$links['monitor_ok'] = "index.php?page=modules&status=0";
|
|
$links['monitor_unknown'] = "index.php?page=modules&status=3";
|
|
$links['monitor_not_init'] = "index.php?page=modules&status=5";
|
|
|
|
$modules_status_untiny = reporting_get_stats_modules_status($data, 230, 150, $links);
|
|
$modules_status_tiny = reporting_get_stats_modules_status($data, 185, 110, $links);
|
|
$formatted_data = "<div id='status_pie'></div>";
|
|
$formatted_data .= html_print_div (array('id' => 'status_pie_links','content' => json_encode($links), 'hidden' => '1'), true);
|
|
$formatted_data .= html_print_div (array('id' => 'status_pie_data','content' => json_encode($data), 'hidden' => '1'), true);
|
|
$graph_js = ob_get_clean();
|
|
$formatted_data = $graph_js . $formatted_data;
|
|
$ui->contentGridAddCell($formatted_data, 'tactical2');
|
|
$ui->contentEndGrid();
|
|
|
|
$this->getLastActivity();
|
|
$ui->contentBeginCollapsible(__('Last activity'));
|
|
|
|
$table = new Table();
|
|
$table->importFromHash($this->getLastActivity());
|
|
$ui->contentCollapsibleAddItem($table->getHTML());
|
|
$ui->contentEndCollapsible();
|
|
$ui->contentAddHtml("<script type=\"text/javascript\">
|
|
$(document).ready(function(){
|
|
function set_same_heigth() {
|
|
//Set same height to boxes
|
|
var max_height = 0;
|
|
if ($('#tactical1').height() > $('#tactical2 .tactical_set').height()) {
|
|
max_height = $('#tactical1').height();
|
|
$('#tactical2 .tactical_set').height(max_height);
|
|
}
|
|
else {
|
|
max_height = $('#tactical2 .tactical_set').height();
|
|
$('#tactical1').height(max_height);
|
|
}
|
|
}
|
|
|
|
function ajax_load_status_pie() {
|
|
$('#status_pie').html('<div style=\"text-align: center\"> " . __('Loading...') . "<br /><img src=\"images/ajax-loader.gif\" /></div>');
|
|
|
|
var pie_width = $('#tactical2').width() * 0.9;
|
|
|
|
postvars = {};
|
|
postvars[\"action\"] = \"ajax\";
|
|
postvars[\"parameter1\"] = \"tactical\";
|
|
postvars[\"parameter2\"] = \"render_status_pie\";
|
|
postvars[\"links\"] = $('#status_pie_links').html();
|
|
postvars[\"data\"] = $('#status_pie_data').html();
|
|
postvars[\"width\"] = pie_width;
|
|
$.post(\"index.php\",
|
|
postvars,
|
|
function (data) {
|
|
$('#status_pie').html(data);
|
|
set_same_heigth();
|
|
},
|
|
\"html\");
|
|
}
|
|
|
|
// Detect orientation change to refresh dinamic content
|
|
$(window).on({
|
|
orientationchange: function(e) {
|
|
// Refresh events bar
|
|
ajax_load_status_pie();
|
|
|
|
// Keep same height on boxes
|
|
if ($('.ui-block-b').css('float') == 'none') {
|
|
$('#tactical1').height('auto');
|
|
$('#tactical2').height('auto');
|
|
}
|
|
else {
|
|
set_same_heigth();
|
|
}
|
|
}
|
|
});
|
|
|
|
if ($('.ui-block-b').css('float') != 'none') {
|
|
set_same_heigth();
|
|
}
|
|
|
|
ajax_load_status_pie();
|
|
});
|
|
</script>");
|
|
$ui->endContent();
|
|
$ui->showPage();
|
|
}
|
|
|
|
private function getLastActivity() {
|
|
global $config;
|
|
|
|
switch ($config["dbtype"]) {
|
|
case "mysql":
|
|
$sql = sprintf ("SELECT id_usuario,accion,fecha,ip_origen,descripcion,utimestamp
|
|
FROM tsesion
|
|
WHERE (`utimestamp` > UNIX_TIMESTAMP(NOW()) - " . SECONDS_1WEEK . ")
|
|
AND `id_usuario` = '%s' ORDER BY `utimestamp` DESC LIMIT 10", $config["id_user"]);
|
|
break;
|
|
case "postgresql":
|
|
$sql = sprintf ("SELECT \"id_usuario\", accion, fecha, \"ip_origen\", descripcion, utimestamp
|
|
FROM tsesion
|
|
WHERE (\"utimestamp\" > ceil(date_part('epoch', CURRENT_TIMESTAMP)) - " . SECONDS_1WEEK . ")
|
|
AND \"id_usuario\" = '%s' ORDER BY \"utimestamp\" DESC LIMIT 10", $config["id_user"]);
|
|
break;
|
|
case "oracle":
|
|
$sql = sprintf ("SELECT id_usuario, accion, fecha, ip_origen, descripcion, utimestamp
|
|
FROM tsesion
|
|
WHERE ((utimestamp > ceil((sysdate - to_date('19700101000000','YYYYMMDDHH24MISS')) * (" . SECONDS_1DAY . ")) - " . SECONDS_1WEEK . ")
|
|
AND id_usuario = '%s') AND rownum <= 10 ORDER BY utimestamp DESC", $config["id_user"]);
|
|
break;
|
|
}
|
|
|
|
$sessions = db_get_all_rows_sql ($sql);
|
|
|
|
if ($sessions === false)
|
|
$sessions = array ();
|
|
|
|
$return = array();
|
|
foreach ($sessions as $session) {
|
|
$data = array();
|
|
|
|
switch ($config["dbtype"]) {
|
|
case "mysql":
|
|
case "oracle":
|
|
$session_id_usuario = $session['id_usuario'];
|
|
$session_ip_origen = $session['ip_origen'];
|
|
break;
|
|
case "postgresql":
|
|
$session_id_usuario = $session['id_usuario'];
|
|
$session_ip_origen = $session['ip_origen'];
|
|
break;
|
|
}
|
|
|
|
$data[__("Action")] = ui_print_session_action_icon ($session['accion'], true);
|
|
$data[__("User")] = $session_id_usuario;
|
|
$data[__("Date")] = human_time_comparation($session['utimestamp'], 'tiny');
|
|
$data[__("Source IP")] = $session_ip_origen;
|
|
$data[__("Description")] = io_safe_output ($session['descripcion']);
|
|
|
|
$return[] = $data;
|
|
}
|
|
|
|
return $return;
|
|
}
|
|
}
|
|
?>
|