示例#1
0
 /**
  * @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', []);
 }
示例#2
0
 /**
  * @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);
     }
 }
示例#3
0
 /**
  * @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());
 }