Froxlor/admin_logger.php

77 lines
2.4 KiB
PHP
Raw Normal View History

<?php
/**
* This file is part of the Froxlor project.
* Copyright (c) 2010 the Froxlor Team (see authors).
*
2022-04-28 18:48:00 +00:00
* 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; either version 2
* of the License, or (at your option) any later version.
*
2022-04-28 18:48:00 +00:00
* 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.
*
2022-04-28 18:48:00 +00:00
* You should have received a copy of the GNU General Public License
* along with this program; if not, you can also view it online at
* https://files.froxlor.org/misc/COPYING.txt
*
* @copyright the authors
* @author Froxlor team <team@froxlor.org>
* @license https://files.froxlor.org/misc/COPYING.txt GPLv2
*/
const AREA = 'admin';
require __DIR__ . '/lib/init.php';
use Froxlor\Api\Commands\SysLog;
2022-04-28 18:48:00 +00:00
use Froxlor\UI\Collection;
use Froxlor\UI\HTML;
use Froxlor\UI\Listing;
use Froxlor\UI\Panel\UI;
2022-04-28 18:48:00 +00:00
use Froxlor\UI\Response;
if ($page == 'log' && $userinfo['change_serversettings'] == '1') {
2013-04-27 07:48:42 +00:00
if ($action == '') {
try {
$syslog_list_data = include_once dirname(__FILE__) . '/lib/tablelisting/tablelisting.syslog.php';
2022-04-28 18:48:00 +00:00
$collection = (new Collection(SysLog::class, $userinfo))
->withPagination($syslog_list_data['syslog_list']['columns'], $syslog_list_data['syslog_list']['default_sorting']);
} catch (Exception $e) {
2022-04-28 18:48:00 +00:00
Response::dynamicError($e->getMessage());
}
2022-03-18 11:53:34 +00:00
UI::view('user/table.html.twig', [
2022-04-28 18:48:00 +00:00
'listing' => Listing::format($collection, $syslog_list_data, 'syslog_list'),
'actions_links' => [
[
'href' => $linker->getLink(['section' => 'logger', 'page' => 'log', 'action' => 'truncate']),
'label' => lng('logger.truncate'),
'icon' => 'fa-solid fa-recycle',
'class' => 'btn-warning'
]
]
]);
2013-04-27 07:48:42 +00:00
} elseif ($action == 'truncate') {
if (isset($_POST['send']) && $_POST['send'] == 'send') {
try {
2022-04-28 18:48:00 +00:00
SysLog::getLocal($userinfo, [
'min_to_keep' => 10
2022-04-28 18:48:00 +00:00
])->delete();
} catch (Exception $e) {
2022-04-28 18:48:00 +00:00
Response::dynamicError($e->getMessage());
}
2022-04-28 18:48:00 +00:00
Response::redirectTo($filename, [
'page' => $page
2022-04-28 18:48:00 +00:00
]);
2013-04-27 07:48:42 +00:00
} else {
2022-04-28 18:48:00 +00:00
HTML::askYesNo('logger_reallytruncate', $filename, [
'page' => $page,
'action' => $action
2022-04-28 18:48:00 +00:00
], TABLE_PANEL_LOG);
}
}
}