/** * @param Request $request * * @return Response */ public function indexAction(Request $request) { /* @var Session */ $session = $this->app['app.session']; $user = $session->getUser(); if ($user) { return new RedirectResponse('/'); } if ($request->getMethod() == 'POST') { /* @var UserRepository */ $repository = $this->app['app.repository.user']; $user = $repository->findByNameAndPassword($request->get('post', 'name', false), $request->get('post', 'password', false)); if (!$user) { return $this->render('Login\\index.html.twig', ['error' => 'Name or password invalid']); } $session->setUser($user); if ($session->has('app.redirect_on_login')) { return new RedirectResponse($session->get('app.redirect_on_login')); } return new RedirectResponse('/'); } return $this->render('Login\\index.html.twig', []); }
/** * @param Request $request * * @return Response */ public function handle(Request $request) { $this['app.request'] = $request; if ($this->isRequestApi($request->getUri())) { $isGranted = $this['api.firewall']->isGranted($request->getMethod(), $request->getUri(), $this['api.user']); if (!$isGranted) { return new JsonResponse(['code' => Response::HTTP_UNAUTHORIZED, 'message' => 'Unauthorized'], Response::HTTP_UNAUTHORIZED); } } else { $isGranted = $this['app.firewall']->isGranted($request->getMethod(), $request->getUri(), $this['app.user']); if (!$isGranted) { if ($this['app.user']) { return new Response($this['twig']->render('Error\\index.html.twig', ['code' => Response::HTTP_UNAUTHORIZED, 'message' => 'Unauthorized']), Response::HTTP_UNAUTHORIZED); } $this['app.session']->set('app.redirect_on_login', $request->getUri()); return new RedirectResponse('/login'); } } try { $routeInfo = $this['app.router']->dispatch($request->getMethod(), $request->getUri()); switch ($routeInfo[0]) { case \FastRoute\Dispatcher::NOT_FOUND: return new Response($this['twig']->render('Error\\index.html.twig', ['code' => 404, 'message' => 'Not Found']), Response::HTTP_NOT_FOUND, ['Content-Type' => 'text/html; charset=UTF-8']); case \FastRoute\Dispatcher::METHOD_NOT_ALLOWED: return new Response($this['twig']->render('Error\\index.html.twig', ['code' => 405, 'message' => 'Not Allowed']), Response::HTTP_METHOD_NOT_ALLOWED, ['Content-Type' => 'text/html; charset=UTF-8']); case \FastRoute\Dispatcher::FOUND: default: $handler = $routeInfo[1]; $controller = 'app.controller.' . $handler[0]; $method = $handler[1] . 'Action'; $this['twig']->addGlobal('app_user', $this['app.user']); return $this[$controller]->{$method}($request, $routeInfo[2]); } } catch (\Exception $e) { $message = $this['debug'] ? $e->getMessage() : 'Internal Server Error'; return new Response($this['twig']->render('Error\\index.html.twig', ['code' => 500, 'message' => $message]), Response::HTTP_INTERNAL_SERVER_ERROR); } }
/** * @dataProvider dataProviderForTestMethodAndUri * * @param string $method * @param string $uri */ public function testMethodAndUri($method, $uri) { $request = new Request($method, [], [], ['REQUEST_URI' => $uri]); $this->assertEquals($method, $request->getMethod()); }