|
Server IP : 10.2.73.233 / Your IP : 216.73.216.59 Web Server : Apache/2.4.59 (Debian) System : Linux polon 4.19.0-27-amd64 #1 SMP Debian 4.19.316-1 (2024-06-25) x86_64 User : www-data ( 33) PHP Version : 5.6.40-64+0~20230107.71+debian10~1.gbp673146 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority, MySQL : ON | cURL : ON | WGET : ON | Perl : ON | Python : ON Directory (0755) : /home/ifk/web/assets/../prado4.3.2/Util/ |
| [ Home ] | [ C0mmand ] | [ Upload File ] |
|---|
<?php
/**
* TLogRouter, TLogRoute, TFileLogRoute, TEmailLogRoute class file
*
* @author Qiang Xue <qiang.xue@gmail.com>
* @link https://github.com/pradosoft/prado
* @license https://github.com/pradosoft/prado/blob/master/LICENSE
*/
namespace Prado\Util;
use Prado\Prado;
/**
* TFirePhpLogRoute class.
*
* TFirePhpLogRoute prints log messages in the firebug log console via firephp.
*
* {@link http://www.getfirebug.com/ FireBug Website}
* {@link http://www.firephp.org/ FirePHP Website}
*
* @author Yves Berkholz <godzilla80[at]gmx[dot]net>
* @since 3.1.5
*/
class TFirePhpLogRoute extends TLogRoute
{
/**
* Default group label
*/
public const DEFAULT_LABEL = 'Prado\Util\TLogRouter(TFirePhpLogRoute)';
private $_groupLabel;
public function processLogs($logs)
{
if (empty($logs) || $this->getApplication()->getMode() === 'Performance') {
return;
}
if (headers_sent()) {
echo '
<div style="width:100%; background-color:darkred; color:#FFF; padding:2px">
TFirePhpLogRoute.GroupLabel "<i>' . $this -> getGroupLabel() . '</i>" -
Routing to FirePHP impossible, because headers already sent!
</div>
';
$fallback = new TBrowserLogRoute();
$fallback->processLogs($logs);
return;
}
$firephp = \FirePHP::getInstance(true);
$firephp->setOptions(['useNativeJsonEncode' => false]);
$firephp->group($this->getGroupLabel(), ['Collapsed' => true]);
$firephp->log('Time, Message');
$first = $logs[0][3];
$total = 0;
$c = count($logs);
for ($i = 0, $n = $c; $i < $n; ++$i) {
$message = $logs[$i][0];
$level = $logs[$i][1];
$category = $logs[$i][2];
if ($i < $n - 1) {
$delta = $logs[$i + 1][3] - $logs[$i][3];
$total = $logs[$i + 1][3] - $first;
} else {
$delta = '?';
$total = $logs[$i][3] - $first;
}
$message = sPrintF('+%0.6f: %s', $delta, preg_replace('/\(line[^\)]+\)$/', '', $message));
$firephp->fb($message, $category, self::translateLogLevel($level));
}
$firephp->log(sPrintF('%0.6f', $total), 'Cumulated Time');
$firephp->groupEnd();
}
/**
* Translates a PRADO log level attribute into one understood by FirePHP for correct visualization
* @param string $level prado log level
* @return string FirePHP log level
*/
protected static function translateLogLevel($level)
{
switch ($level) {
case TLogger::INFO:
return \FirePHP::INFO;
case TLogger::DEBUG:
case TLogger::NOTICE:
return \FirePHP::LOG;
case TLogger::WARNING:
return \FirePHP::WARN;
case TLogger::ERROR:
case TLogger::ALERT:
case TLogger::FATAL:
return \FirePHP::ERROR;
default:
return \FirePHP::LOG;
}
}
/**
* @return string group label. Defaults to TFirePhpLogRoute::DEFAULT_LABEL
*/
public function getGroupLabel()
{
if ($this->_groupLabel === null) {
$this->_groupLabel = self::DEFAULT_LABEL;
}
return $this->_groupLabel;
}
/**
* @param string $value group label.
*/
public function setGroupLabel($value)
{
$this->_groupLabel = $value;
}
}