/**
  * @param RequestResponseEvent $event
  */
 public function listen(RequestResponseEvent $event)
 {
     $request = $event->getRequest();
     $response = $event->getResponse();
     if ($response instanceof BinaryFileResponse) {
         return;
     }
     if ($request->isXmlHttpRequest()) {
         //handle with ajax
         $debugBar = $this->container['debug_bar.debug_bar'];
         $response->headers->add($debugBar->getDataAsHeaders());
     } else {
         //replace http response
         if ($response->headers->get('content-type') && $response->headers->get('content-type') != 'text/html') {
             return;
         }
         $debugBar = $this->container['debug_bar.debug_bar'];
         $renderer = $debugBar->getJavascriptRenderer();
         /* @var $renderer \DebugBar\JavascriptRenderer */
         $renderer->setBaseUrl('/public/debugbar');
         $body = $event->getResponse()->getContent();
         $body = str_ireplace(array('</head>', '</body>'), array($renderer->renderHead() . PHP_EOL . '</head>', $renderer->render() . PHP_EOL . '</body>'), $body);
         $response->setContent($body);
     }
 }
 /**
  * @param RequestResponseEvent $event
  */
 public function listen(RequestResponseEvent $event)
 {
     $request = $event->getRequest();
     $cmsPrefix = $this->container->getParameter('cms.prefix');
     if (strpos($request->getPathInfo(), $cmsPrefix) === 0) {
         //in any way we should try to extract data from session
         $session = $this->container->getSession();
         $tokenParameter = $this->container->getParameter('cms_authentication.session.storage_key');
         $securityContext = $this->container->getSecurityContext();
         if ($session->has($tokenParameter)) {
             $securityContext->setToken($session->get($tokenParameter));
             $this->container->getEventDispatcher()->dispatch(AuthController::TOKEN_CHANGE_EVENT, new DataAgnosticEvent());
         }
         //non-authorized users that are not on anonymous paths are getting redirected to login
         if ((!$securityContext->getToken() || !$securityContext->getToken()->getUser()) && !in_array($request->getPathInfo(), $this->container->getParameter('cms_authentication.paths.anonymous'))) {
             if ($request->isXmlHttpRequest()) {
                 $event->setResponse(new Response(AuthController::EMPTY_BODY, AuthController::FAILURE_STATUS));
             } else {
                 $event->setResponse(new RedirectResponse($this->container->getRouter()->generate('cms_authentication_login')));
             }
             $event->stopPropagation();
         }
         //authorized users on login path are redirected to dashboard
         if ($securityContext->getToken() && $securityContext->getToken()->getUser() && strpos($request->getPathInfo(), $this->container->getParameter('cms_authentication.paths.login')) === 0) {
             $event->setResponse(new RedirectResponse($cmsPrefix));
             $event->stopPropagation();
         }
     }
 }
 /**
  * @param RequestResponseEvent $event
  */
 public function request(RequestResponseEvent $event)
 {
     $request = $event->getRequest();
     if ($request instanceof Request) {
         $this->getTimeCollector()->startMeasure('request_' . spl_object_hash($request), $this->formatRequest($request));
     }
 }
 /**
  * @param RequestResponseEvent $event
  */
 public function listen(RequestResponseEvent $event)
 {
     if ($event->hasResponse()) {
         // do nothing if response exists already
         return;
     }
     $request = $event->getRequest();
     $pageController = $this->container['cms.pages.controller'];
     /* @var $pageController \Supra\Package\Cms\Controller\PageController */
     $request->attributes->set('path', '404');
     $pageRequest = new PageRequestView($request);
     $pageRequest->setContainer($this->container);
     try {
         $event->setResponse($pageController->execute($pageRequest));
     } catch (ResourceNotFoundException $e) {
     }
     // ignore silently
 }
 /**
  * @param RequestResponseEvent $event
  */
 public function listen(RequestResponseEvent $event)
 {
     $path = $event->getRequest()->getPathInfo();
     $parts = pathinfo($path);
     $parts = array_merge(array('dirname' => '', 'basename' => '', 'extension' => '', 'filename'), $parts);
     switch (strtolower($parts['extension'])) {
         case 'css':
             //possible it's not yet compiled less file?
             $lessFile = $this->container->getApplication()->getWebRoot() . $path . '.less';
             if (is_file($lessFile)) {
                 $asset = new FileAsset($lessFile);
                 $asset->ensureFilter(new LessphpFilter());
                 $content = $this->container->getCache()->fetch('assets_404', $path, function () use($asset) {
                     return $asset->dump();
                 }, $asset->getLastModified(), 0, true);
                 $event->setResponse(new Response($content, 200, array('Content-Type' => 'text/css')));
                 $event->stopPropagation();
                 return;
             }
             break;
     }
 }