/** * @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; } }