. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Http\Middleware; use Closure; use Fisharebest\Webtrees\FlashMessages; use Fisharebest\Webtrees\I18N; use Fisharebest\Webtrees\Session; use Symfony\Component\HttpFoundation\RedirectResponse; use Symfony\Component\HttpFoundation\Request; use Symfony\Component\HttpFoundation\Response; use Symfony\Component\HttpKernel\Exception\AccessDeniedHttpException; /** * Middleware to wrap a request in a transaction. */ class CheckCsrf implements MiddlewareInterface { /** * @param Request $request * @param Closure $next * * @return Response * @throws AccessDeniedHttpException */ public function handle(Request $request, Closure $next): Response { $client_token = $request->get('csrf', $request->headers->get('X_CSRF_TOKEN')); $session_token = Session::get('CSRF_TOKEN'); if ($client_token !== $session_token) { FlashMessages::addMessage(I18N::translate('This form has expired. Try again.')); return new RedirectResponse($request->getRequestUri()); } return $next($request); } }