diff options
Diffstat (limited to 'framework/logging/CWebLogRoute.php')
| -rw-r--r-- | framework/logging/CWebLogRoute.php | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/framework/logging/CWebLogRoute.php b/framework/logging/CWebLogRoute.php new file mode 100644 index 0000000..9e120d8 --- /dev/null +++ b/framework/logging/CWebLogRoute.php @@ -0,0 +1,67 @@ +<?php +/** + * CWebLogRoute class file. + * + * @author Qiang Xue <qiang.xue@gmail.com> + * @link http://www.yiiframework.com/ + * @copyright Copyright © 2008-2011 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> + * @version $Id: CWebLogRoute.php 3001 2011-02-24 16:42:44Z alexander.makarow $ + * @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; + + /** + * 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(); + + if($this->showInFireBug) + { + if($isAjax && $this->ignoreAjaxInFireBug) + return; + $view.='-firebug'; + } + else if(!($app instanceof CWebApplication) || $isAjax) + return; + + $viewFile=YII_PATH.DIRECTORY_SEPARATOR.'views'.DIRECTORY_SEPARATOR.$view.'.php'; + include($app->findLocalizedFile($viewFile,'en')); + } +}
\ No newline at end of file |
