pandorafms/pandora_console/extensions/matrix_events/ajax.php

68 lines
2.2 KiB
PHP

<?php
// Pandora FMS - https://pandorafms.com
// ==================================================
// Copyright (c) 2005-2023 Pandora FMS
// Please see https://pandorafms.com/community/ 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()) {
if (! check_acl($config['id_user'], 0, 'ER')) {
db_pandora_audit(
AUDIT_LOG_ACL_VIOLATION,
'Trying to access event viewer'
);
return;
}
$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';
$limit = (int) get_parameter('limit', 5);
$tags_condition = tags_get_acl_tags($config['id_user'], 0, 'ER', 'event_condition', 'AND');
$filter = "estado <> 1 $tags_condition";
$sql = sprintf(
'SELECT id_agente, evento, utimestamp
FROM tevento
LEFT JOIN tagent_secondary_group
ON tevento.id_agente = tagent_secondary_group.id_agent
WHERE %s
ORDER BY utimestamp DESC LIMIT %d',
$filter,
$limit
);
$result = db_get_all_rows_sql($sql);
$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);
}
echo json_encode($events);
return;
}
return;
}