. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Http\Middleware; use Closure; use Fisharebest\Webtrees\Auth; use Fisharebest\Webtrees\Carbon; use Fisharebest\Webtrees\Contracts\UserInterface; use Fisharebest\Webtrees\Session; use Symfony\Component\HttpFoundation\Request; use Symfony\Component\HttpFoundation\Response; use Throwable; /** * Middleware to activate sessions. */ class UseSession implements MiddlewareInterface { /** * @param Request $request * @param Closure $next * * @return Response * @throws Throwable */ public function handle(Request $request, Closure $next): Response { // Sessions Session::start(); // Update the last-login time no more than once a minute. $next_session_update = Carbon::createFromTimestamp((int) Session::get('session_time_updates'))->addMinute(); if ($next_session_update < Carbon::now()) { $timestamp_now = Carbon::now()->unix(); if (Session::get('masquerade') === null) { Auth::user()->setPreference('sessiontime', (string) $timestamp_now); } Session::put('session_time_updates', $timestamp_now); } app()->instance(UserInterface::class, Auth::user()); return $next($request); } }