. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Http\RequestHandlers; use DateTimeImmutable; use DateTimeZone; use Fisharebest\Webtrees\Auth; use Fisharebest\Webtrees\Contracts\UserInterface; use Fisharebest\Webtrees\DB; use Fisharebest\Webtrees\Http\ViewResponseTrait; use Fisharebest\Webtrees\I18N; use Fisharebest\Webtrees\Registry; use Fisharebest\Webtrees\Services\TreeService; use Fisharebest\Webtrees\Services\UserService; use Fisharebest\Webtrees\Tree; use Fisharebest\Webtrees\User; use Fisharebest\Webtrees\Validator; use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; use Psr\Http\Server\RequestHandlerInterface; use function date; use function max; use function min; /** * Show logs. */ class SiteLogsPage implements RequestHandlerInterface { use ViewResponseTrait; private TreeService $tree_service; private UserService $user_service; /** * @param TreeService $tree_service * @param UserService $user_service */ public function __construct(TreeService $tree_service, UserService $user_service) { $this->tree_service = $tree_service; $this->user_service = $user_service; } /** * @param ServerRequestInterface $request * * @return ResponseInterface */ public function handle(ServerRequestInterface $request): ResponseInterface { $this->layout = 'layouts/administration'; // First and last change in the database $earliest = DB::table('log')->min('log_time') ?? date('Y-m-d H:i:s'); $latest = DB::table('log')->max('log_time') ?? date('Y-m-d H:i:s'); $earliest = DateTimeImmutable::createFromFormat('Y-m-d H:i:s', $earliest, new DateTimeZone('UTC')) ->setTimezone(new DateTimeZone(Auth::user()->getPreference(UserInterface::PREF_TIME_ZONE, 'UTC'))) ->format('Y-m-d'); $latest = DateTimeImmutable::createFromFormat('Y-m-d H:i:s', $latest, new DateTimeZone('UTC')) ->setTimezone(new DateTimeZone(Auth::user()->getPreference(UserInterface::PREF_TIME_ZONE, 'UTC'))) ->format('Y-m-d'); $action = Validator::queryParams($request)->string('action', ''); $from = Validator::queryParams($request)->string('from', $earliest); $to = Validator::queryParams($request)->string('to', $latest); $type = Validator::queryParams($request)->string('type', ''); $text = Validator::queryParams($request)->string('text', ''); $ip = Validator::queryParams($request)->string('ip', ''); $username = Validator::queryParams($request)->string('username', ''); $tree = Validator::queryParams($request)->string('tree', ''); $from = max($from, $earliest); $to = min(max($from, $to), $latest); $user_options = $this->user_service->all()->mapWithKeys(static fn (User $user): array => [$user->userName() => $user->userName()]); $user_options->prepend('', ''); $tree_options = $this->tree_service->all()->mapWithKeys(static fn (Tree $tree): array => [$tree->name() => $tree->title()]); $tree_options->prepend('', ''); $title = I18N::translate('Website logs'); return $this->viewResponse('admin/site-logs', [ 'action' => $action, 'earliest' => $earliest, 'from' => $from, 'tree' => $tree, 'ip' => $ip, 'latest' => $latest, 'tree_options' => $tree_options, 'title' => $title, 'to' => $to, 'text' => $text, 'type' => $type, 'username' => $username, 'user_options' => $user_options, ]); } }