pandorafms/pandora_console/operation/agentes/export_csv.php

101 lines
3.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 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.
// Don't start a session before this import.
// The session is configured and started inside the config process.
require_once '../../include/config.php';
require_once '../../include/functions.php';
require_once '../../include/functions_db.php';
require_once '../../include/functions_modules.php';
require_once '../../include/functions_agents.php';
$config['id_user'] = $_SESSION['id_usuario'];
if (! check_acl($config['id_user'], 0, 'AR') && ! check_acl($config['id_user'], 0, 'AW')) {
include '../../general/noaccess.php';
return;
}
if (isset($_GET['agentmodule']) && isset($_GET['agent'])) {
$id_agentmodule = $_GET['agentmodule'];
$id_agent = $_GET['agent'];
$agentmodule_name = modules_get_agentmodule_name($id_agentmodule);
if (! check_acl($config['id_user'], agents_get_agent_group($id_agent), 'AR')) {
db_pandora_audit(
AUDIT_LOG_ACL_VIOLATION,
'Trying to access Agent Export Data'
);
include '../../general/noaccess.php';
exit;
}
$now = date('Y/m/d H:i:s');
// Show contentype header
header('Content-type: text/txt');
header('Content-Disposition: attachment; filename="pandora_export_'.$agentmodule_name.'.txt"');
if (isset($_GET['from_date'])) {
$from_date = $_GET['from_date'];
} else {
$from_date = $now;
}
if (isset($_GET['to_date'])) {
$to_date = $_GET['to_date'];
} else {
$to_date = $now;
}
// Convert to unix date
$from_date = date('U', strtotime($from_date));
$to_date = date('U', strtotime($to_date));
// Make the query
$sql1 = "
SELECT *
FROM tdatos
WHERE id_agente = $id_agent
AND id_agente_modulo = $id_agentmodule";
$tipo = modules_get_moduletype_name(modules_get_agentmodule_type($id_agentmodule));
if ($tipo == 'generic_data_string') {
$sql1 = "
SELECT *
FROM tagente_datos_string
WHERE utimestamp > $from_date AND utimestamp < $to_date
AND id_agente_modulo = $id_agentmodule
ORDER BY utimestamp DESC";
} else {
$sql1 = "
SELECT *
FROM tagente_datos
WHERE utimestamp > $from_date AND utimestamp < $to_date
AND id_agente_modulo = $id_agentmodule
ORDER BY utimestamp DESC";
}
$result1 = db_get_all_rows_sql($sql1, true);
if ($result1 === false) {
$result1 = [];
}
// Render data
foreach ($result1 as $row) {
echo $agentmodule_name;
echo ',';
echo $row['datos'];
echo ',';
echo $row['utimestamp'];
echo chr(13);
}
}