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();
}
}
private function show_fail_acl() {
$ui = Ui::getInstance();
$ui->createPage();
$options['type'] = 'onStart';
$options['title_text'] = __('You don\'t have access to this page');
$options['content_text'] = __('Access to this page is restricted to authorized users only, please contact system administrator if you need assistance. Please know that all attempts to access this page are recorded in security logs of Pandora System Database');
$ui->addDialog($options);
$ui->showPage();
}
private function show_tactical() {
$ui = Ui::getInstance();
$ui->createPage();
$ui->createDefaultHeader(__("PandoraFMS: Tactical"));
$ui->showFooter(false);
$ui->beginContent();
$ui->contentBeginGrid('responsive');
$data = reporting_get_group_stats();
$data['mobile'] = true;
$formatted_data = reporting_get_stats_indicators($data, 200, 10, false);
/*
$overview = '
' .
$formatted_data['server_health']['title'] .
' ' .
$formatted_data['server_health']['graph'] .
' ' .
'
' .
$formatted_data['monitor_health']['title'] .
' ' .
$formatted_data['monitor_health']['graph'] .
' ' .
'' .
'
' .
$formatted_data['module_sanity']['title'] .
' ' .
$formatted_data['module_sanity']['graph'] .
' ' .
'' .
'
' .
$formatted_data['alert_level']['title'] .
' ' .
$formatted_data['alert_level']['graph'] .
' ';
*/
$overview = '
' . $formatted_data['server_health']['title'] . '
' . $formatted_data['server_health']['graph'] . '
' . $formatted_data['monitor_health']['title'] . '
' . $formatted_data['monitor_health']['graph'] . '
' . $formatted_data['module_sanity']['title'] . '
' . $formatted_data['module_sanity']['graph'] . '
' . $formatted_data['alert_level']['title'] . '
' . $formatted_data['alert_level']['graph'] . '
';
$ui->contentGridAddCell($overview);
$formatted_data = reporting_get_stats_alerts($data);
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";
$formatted_data .= reporting_get_stats_modules_status($data, 250, 150, $links) . " \n" .
reporting_get_stats_agents_monitors($data);
$graph_js = ob_get_clean();
$formatted_data = $graph_js . $formatted_data;
$ui->contentGridAddCell($formatted_data, 'tactical');
$ui->contentEndGrid();
$this->getLastActivity();
$ui->contentBeginCollapsible(__('Last activity'));
$table = new Table();
$table->importFromHash($this->getLastActivity());
$ui->contentCollapsibleAddItem($table->getHTML());
$ui->contentEndCollapsible();
$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[__("User")] = '' . $session_id_usuario . ' ';
$data[__("Action")] = ui_print_session_action_icon ($session['accion'], true);
$data[__("Action")] .= $session['accion'];
$data[__("Date")] = human_time_comparation($session['utimestamp']);
$data[__("Source IP")] = $session_ip_origen;
$data[__("Description")] = io_safe_output ($session['descripcion']);
$return[] = $data;
}
return $return;
}
}
?>