2014-05-08 20:01:10 +02:00
|
|
|
<?php
|
|
|
|
|
2021-11-04 16:28:15 +01:00
|
|
|
// Pandora FMS - http://pandorafms.com
|
2014-05-08 20:01:10 +02:00
|
|
|
// ==================================================
|
2020-11-27 13:52:35 +01:00
|
|
|
// Copyright (c) 2005-2021 Artica Soluciones Tecnologicas
|
2014-05-08 20:01:10 +02:00
|
|
|
// 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; 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.
|
|
|
|
global $config;
|
|
|
|
|
|
|
|
if (is_ajax()) {
|
2019-01-30 16:18:44 +01:00
|
|
|
if (! check_acl($config['id_user'], 0, 'ER')) {
|
|
|
|
db_pandora_audit('ACL Violation', 'Trying to access event viewer');
|
|
|
|
return;
|
|
|
|
}
|
2014-05-08 20:01:10 +02:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$get_last_events = (bool) get_parameter('get_last_events');
|
|
|
|
if ($get_last_events) {
|
|
|
|
include_once 'include/functions_io.php';
|
|
|
|
include_once 'include/functions_tags.php';
|
2014-05-08 20:01:10 +02:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$limit = (int) get_parameter('limit', 5);
|
2014-05-08 20:01:10 +02:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$tags_condition = tags_get_acl_tags($config['id_user'], 0, 'ER', 'event_condition', 'AND');
|
2018-10-05 09:40:08 +02:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$filter = "estado <> 1 $tags_condition";
|
2014-05-08 20:01:10 +02:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$sql = sprintf(
|
|
|
|
'SELECT id_agente, evento, utimestamp
|
2018-10-05 09:40:08 +02:00
|
|
|
FROM tevento
|
|
|
|
LEFT JOIN tagent_secondary_group
|
|
|
|
ON tevento.id_agente = tagent_secondary_group.id_agent
|
|
|
|
WHERE %s
|
2019-01-30 16:18:44 +01:00
|
|
|
ORDER BY utimestamp DESC LIMIT %d',
|
|
|
|
$filter,
|
|
|
|
$limit
|
|
|
|
);
|
2014-05-08 20:01:10 +02:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$result = db_get_all_rows_sql($sql);
|
2014-05-08 20:01:10 +02:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
$events = [];
|
|
|
|
if (! empty($result)) {
|
|
|
|
foreach ($result as $key => $value) {
|
|
|
|
$event = [];
|
|
|
|
$event['agent'] = (empty($value['id_agente'])) ? 'System' : agents_get_name($value['id_agente']);
|
|
|
|
$event['text'] = io_safe_output($value['evento']);
|
|
|
|
$event['date'] = date(io_safe_output($config['date_format']), $value['utimestamp']);
|
|
|
|
$events[] = $event;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
sleep(5);
|
|
|
|
}
|
2014-05-08 20:01:10 +02:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
echo json_encode($events);
|
|
|
|
return;
|
|
|
|
}
|
2014-05-08 20:01:10 +02:00
|
|
|
|
2019-01-30 16:18:44 +01:00
|
|
|
return;
|
|
|
|
}
|