ave-cms/class/class.logs.php

329 lines
8.5 KiB
PHP
Raw Permalink Normal View History

2017-06-24 00:58:56 +03:00
<?php
/**
2018-04-19 19:11:58 +03:00
* AVE.cms
*
* Класс, предназначенный для управления журналом системных сообщений
*
* @package AVE.cms
* @version 3.x
* @filesource
* @copyright © 2007-2014 AVE.cms, http://www.ave-cms.ru
2017-06-24 00:58:56 +03:00
*
*/
2018-04-19 19:11:58 +03:00
class AVE_Logs
{
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
/**
* Свойства класса
*/
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
/**
* Файлы для хранения записей
*
* @public
*/
2024-10-18 12:31:03 +03:00
public $_404dir = '/tmp/logs/404.csv';
public $_logdir = '/tmp/logs/log.csv';
public $_sqldir = '/tmp/logs/sql.csv';
2017-06-24 00:58:56 +03:00
/**
2018-04-19 19:11:58 +03:00
* Внутренние методы класса
2017-06-24 00:58:56 +03:00
*/
2018-04-19 19:11:58 +03:00
/**
* Внешние методы класса
*/
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
/**
* Метод, предназначенный для отображения всех записей Журнала событий
*
*/
2024-10-18 12:31:03 +03:00
function logList ()
2018-04-19 19:11:58 +03:00
{
global $AVE_Template;
2017-06-24 00:58:56 +03:00
2024-10-18 12:31:03 +03:00
$file_name = BASE_DIR . $this->_logdir;
$_lines = [];
2017-06-24 00:58:56 +03:00
2024-10-18 12:31:03 +03:00
if (file_exists($file_name) && $fp = @fopen($file_name, 'rb'))
{
$_count = 10000;
2017-06-24 00:58:56 +03:00
2024-10-18 12:31:03 +03:00
$_size = @filesize($file_name);
$_slice = 10240;
2017-06-24 00:58:56 +03:00
2024-10-18 12:31:03 +03:00
$_size > $_slice && fseek($fp, $_size - $_slice);
while (!feof($fp))
{
$event = fgetcsv($fp, $_slice);
if (empty($event[0]) || count($event) < 3) {
continue;
}
$_lines[] = [
'log_time' => $event['0'],
'log_ip' => $event['1'],
'log_url' => $event['2'],
'log_user_id' => $event['3'],
'log_user_name' => $event['4'],
'log_text' => $event['5'],
'log_type' => $event['6'],
'log_rubric' => $event['7']
];
}
count($_lines) > $_count && $_lines = array_slice($_lines, -$_count);
}
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
// Передаем данные в шаблон для вывода и отображаем страницу
2024-10-18 12:31:03 +03:00
$AVE_Template->assign('logs', $_lines);
2018-04-19 19:11:58 +03:00
$AVE_Template->assign('content', $AVE_Template->fetch('logs/logs.tpl'));
}
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
/**
* Метод, предназначенный для отображения всех записей Журнала событий 404
*
*/
function List404()
{
global $AVE_Template;
2017-06-24 00:58:56 +03:00
2024-10-18 12:31:03 +03:00
$file_name = BASE_DIR . $this->_404dir;
$_lines = [];
2017-06-24 00:58:56 +03:00
2024-10-18 12:31:03 +03:00
if (file_exists($file_name) && $fp = @fopen($file_name, 'rb'))
{
$_count = 10000;
2017-06-24 00:58:56 +03:00
2024-10-18 12:31:03 +03:00
$_size = @filesize($file_name);
$_slice = 10240;
$_size > $_slice && fseek($fp, $_size - $_slice);
2017-06-24 00:58:56 +03:00
2024-10-18 12:31:03 +03:00
while (!feof($fp))
{
$event = fgetcsv($fp, $_slice);
if (empty($event[0]) || count($event) < 3) {
continue;
}
$_lines[] = [
'log_time' => $event['0'],
'log_ip' => $event['1'],
'log_query' => $event['2'],
'log_user_agent' => $event['3'],
'log_user_referer' => $event['4'],
'log_request_uri' => $event['5']
];
}
count($_lines) > $_count && $_lines = array_slice($_lines, -$_count);
}
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
// Передаем данные в шаблон для вывода и отображаем страницу
2024-10-18 12:31:03 +03:00
$AVE_Template->assign('logs', $_lines);
2018-04-19 19:11:58 +03:00
$AVE_Template->assign('content', $AVE_Template->fetch('logs/404.tpl'));
}
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
/**
* Метод, предназначенный для отображения всех записей Журнала событий 404
*
*/
function ListSql()
{
global $AVE_Template;
2017-06-24 00:58:56 +03:00
2024-10-18 12:31:03 +03:00
$file_name = BASE_DIR . $this->_sqldir;
$_lines = [];
2017-06-24 00:58:56 +03:00
2024-10-18 12:31:03 +03:00
if (file_exists($file_name) && $fp = @fopen($file_name, 'rb'))
{
$_count = 10000;
2017-06-24 00:58:56 +03:00
2024-10-18 12:31:03 +03:00
$_size = @filesize($file_name);
$_slice = 10240;
$_size > $_slice && fseek($fp, $_size - $_slice);
2017-06-24 00:58:56 +03:00
2024-10-18 12:31:03 +03:00
while (!feof($fp))
{
$event = fgetcsv($fp, $_slice);
if (empty($event[0]) || count($event) < 3) {
continue;
}
$_lines[] = [
'log_time' => $event['0'],
'log_ip' => $event['1'],
'log_url' => $event['2'],
'log_user_id' => $event['3'],
'log_user_name' => $event['4'],
'log_text' => unserialize(base64_decode($event['5']))
];
}
count($_lines) > $_count && $_lines = array_slice($_lines, -$_count);
}
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
// Передаем данные в шаблон для вывода и отображаем страницу
2024-10-18 12:31:03 +03:00
$AVE_Template->assign('logs', $_lines);
2018-04-19 19:11:58 +03:00
$AVE_Template->assign('content', $AVE_Template->fetch('logs/sql.tpl'));
}
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
/**
* Метод, предназначенный для удаление записей Журнала событий
*
*/
function logDelete()
{
global $AVE_Template;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
$logfile = BASE_DIR . $this->_logdir;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
if(file_exists($logfile))
unlink($logfile);
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
// Сохраняем системное сообщение в журнал
reportLog($AVE_Template->get_config_vars('LOGS_CLEAN'));
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
header('Location:index.php?do=logs&cp=' . SESSION);
exit;
}
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
/**
* Метод, предназначенный для удаление записей Журнала событий 404
*
*/
function DeleteSql()
{
global $AVE_Template;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
$logfile = BASE_DIR . $this->_sqldir;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
if(file_exists($logfile))
unlink($logfile);
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
// Сохраняем системное сообщение в журнал
reportLog($AVE_Template->get_config_vars('LOGS_SQL_CLEAN'));
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
header('Location:index.php?do=logs&action=logsql&cp=' . SESSION);
exit;
}
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
/**
* Метод, предназначенный для удаление записей Журнала событий 404
*
*/
function Delete404()
{
global $AVE_Template;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
$logfile = BASE_DIR . $this->_404dir;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
if(file_exists($logfile))
unlink($logfile);
// Сохраняем системное сообщение в журнал
reportLog($AVE_Template->get_config_vars('LOGS_404_CLEAN'));
header('Location:index.php?do=logs&action=log404&cp=' . SESSION);
exit;
}
/**
* Метод, предназначенный для экспорта системных сообщений
*
*/
function logExport()
2017-06-24 00:58:56 +03:00
{
2018-04-19 19:11:58 +03:00
global $AVE_Template;
2024-10-18 12:31:03 +03:00
$file_name = BASE_DIR . $this->_logdir;
$dateName = 'system_log_' . date('dmyhis', time()) . '.csv';
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
// Определяем заголовки документа
header('Content-Encoding: windows-1251');
header('Content-type: text/csv; charset=windows-1251');
header('Expires: ' . gmdate('D, d M Y H:i:s') . ' GMT');
2024-10-18 12:31:03 +03:00
header('Content-Disposition: attachment; filename="' . $dateName . '"');
header('Content-Length: ' . filesize($file_name));
2018-04-19 19:11:58 +03:00
header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
header('Pragma: public');
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
// Выводим данные
2024-10-18 12:31:03 +03:00
readfile($file_name);
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
// Сохраняем системное сообщение в журнал
reportLog($AVE_Template->get_config_vars('LOGS_EXPORT'));
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
exit;
}
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
/**
* Метод, предназначенный для экспорта сообщений 404
*
*/
function Export404()
{
global $AVE_Template;
2017-06-24 00:58:56 +03:00
2024-10-18 12:31:03 +03:00
$file_name = BASE_DIR . $this->_404dir;
$dateName = 'system_log_' . date('dmyhis', time()) . '.csv';
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
// Определяем заголовки документа
header('Content-Encoding: windows-1251');
header('Content-type: text/csv; charset=windows-1251');
header('Expires: ' . gmdate('D, d M Y H:i:s') . ' GMT');
2024-10-18 12:31:03 +03:00
header('Content-Disposition: attachment; filename="' . $dateName . '"');
header('Content-Length: ' . filesize($file_name));
2018-04-19 19:11:58 +03:00
header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
header('Pragma: public');
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
// Выводим данные
2024-10-18 12:31:03 +03:00
readfile($file_name);
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
// Сохраняем системное сообщение в журнал
2024-10-18 12:31:03 +03:00
reportLog($AVE_Template->get_config_vars('LOGS_EXPORT'));
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
exit;
}
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
/**
* Метод, предназначенный для экспорта сообщений 404
*
*/
function ExportSql()
{
global $AVE_Template;
2017-06-24 00:58:56 +03:00
2024-10-18 12:31:03 +03:00
$file_name = BASE_DIR . $this->_sqldir;
$dateName = 'system_log_' . date('dmyhis', time()) . '.csv';
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
// Определяем заголовки документа
header('Content-Encoding: windows-1251');
header('Content-type: text/csv; charset=windows-1251');
header('Expires: ' . gmdate('D, d M Y H:i:s') . ' GMT');
2024-10-18 12:31:03 +03:00
header('Content-Disposition: attachment; filename="' . $dateName . '"');
header('Content-Length: ' . filesize($file_name));
2018-04-19 19:11:58 +03:00
header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
header('Pragma: public');
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
// Выводим данные
2024-10-18 12:31:03 +03:00
readfile($file_name);
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
// Сохраняем системное сообщение в журнал
2024-10-18 12:31:03 +03:00
reportLog($AVE_Template->get_config_vars('LOGS_EXPORT'));
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
exit;
}
2024-10-18 12:31:03 +03:00
}