. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Http\Middleware; use Fisharebest\Webtrees\Http\RequestHandlers\LoginPage; 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\MiddlewareInterface; use Psr\Http\Server\RequestHandlerInterface; use function redirect; /** * Middleware to restrict access to logged-in users. */ class AuthLoggedIn implements MiddlewareInterface { /** * @param ServerRequestInterface $request * @param RequestHandlerInterface $handler * * @return ResponseInterface */ public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface { $tree = Validator::attributes($request)->treeOptional(); $user = Validator::attributes($request)->user(); // Logged in? if ($user instanceof User) { return $handler->handle($request); } // Not logged in. return redirect(route(LoginPage::class, [ 'tree' => $tree?->name(), 'url' => (string) $request->getUri(), ])); } }