12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485 |
- <?php
- /**
- * CWebLogRoute class file.
- *
- * @author Qiang Xue <qiang.xue@gmail.com>
- * @link http://www.yiiframework.com/
- * @copyright 2008-2013 Yii Software LLC
- * @license http://www.yiiframework.com/license/
- */
- /**
- * CWebLogRoute shows the log content in Web page.
- *
- * The log content can appear either at the end of the current Web page
- * or in FireBug console window (if {@link showInFireBug} is set true).
- *
- * @author Qiang Xue <qiang.xue@gmail.com>
- * @package system.logging
- * @since 1.0
- */
- class CWebLogRoute extends CLogRoute
- {
- /**
- * @var boolean whether the log should be displayed in FireBug instead of browser window. Defaults to false.
- */
- public $showInFireBug=false;
- /**
- * @var boolean whether the log should be ignored in FireBug for ajax calls. Defaults to true.
- * This option should be used carefully, because an ajax call returns all output as a result data.
- * For example if the ajax call expects a json type result any output from the logger will cause ajax call to fail.
- */
- public $ignoreAjaxInFireBug=true;
- /**
- * @var boolean whether the log should be ignored in FireBug for Flash/Flex calls. Defaults to true.
- * This option should be used carefully, because an Flash/Flex call returns all output as a result data.
- * For example if the Flash/Flex call expects an XML type result any output from the logger will cause Flash/Flex call to fail.
- * @since 1.1.11
- */
- public $ignoreFlashInFireBug=true;
- /**
- * @var boolean whether the log should be collapsed by default in Firebug. Defaults to false.
- * @since 1.1.13.
- */
- public $collapsedInFireBug=false;
- /**
- * Displays the log messages.
- * @param array $logs list of log messages
- */
- public function processLogs($logs)
- {
- $this->render('log',$logs);
- }
- /**
- * Renders the view.
- * @param string $view the view name (file name without extension). The file is assumed to be located under framework/data/views.
- * @param array $data data to be passed to the view
- */
- protected function render($view,$data)
- {
- $app=Yii::app();
- $isAjax=$app->getRequest()->getIsAjaxRequest();
- $isFlash=$app->getRequest()->getIsFlashRequest();
- if($this->showInFireBug)
- {
- // do not output anything for ajax and/or flash requests if needed
- if($isAjax && $this->ignoreAjaxInFireBug || $isFlash && $this->ignoreFlashInFireBug)
- return;
- $view.='-firebug';
- if(($userAgent=$app->getRequest()->getUserAgent())!==null && preg_match('/msie [5-9]/i',$userAgent))
- {
- echo '<script type="text/javascript">';
- echo file_get_contents(dirname(__FILE__).'/../vendors/console-normalizer/normalizeconsole.min.js');
- echo "</script>\n";
- }
- }
- elseif(!($app instanceof CWebApplication) || $isAjax || $isFlash)
- return;
- $viewFile=YII_PATH.DIRECTORY_SEPARATOR.'views'.DIRECTORY_SEPARATOR.$view.'.php';
- include($app->findLocalizedFile($viewFile,'en'));
- }
- }
|