205 Zeilen
6,1 KiB
PHP
205 Zeilen
6,1 KiB
PHP
|
<?php
|
||
|
/**
|
||
|
* Zend Framework
|
||
|
*
|
||
|
* LICENSE
|
||
|
*
|
||
|
* This source file is subject to the new BSD license that is bundled
|
||
|
* with this package in the file LICENSE.txt.
|
||
|
* It is also available through the world-wide-web at this URL:
|
||
|
* http://framework.zend.com/license/new-bsd
|
||
|
* If you did not receive a copy of the license and are unable to
|
||
|
* obtain it through the world-wide-web, please send an email
|
||
|
* to license@zend.com so we can send you a copy immediately.
|
||
|
*
|
||
|
* @category Zend
|
||
|
* @package Zend_Log
|
||
|
* @subpackage Writer
|
||
|
* @copyright Copyright (c) 2005-2011 Zend Technologies USA Inc. (http://www.zend.com)
|
||
|
* @license http://framework.zend.com/license/new-bsd New BSD License
|
||
|
* @version $Id$
|
||
|
*/
|
||
|
|
||
|
/** Zend_Log */
|
||
|
require_once 'Zend/Log.php';
|
||
|
|
||
|
/** Zend_Log_Writer_Abstract */
|
||
|
require_once 'Zend/Log/Writer/Abstract.php';
|
||
|
|
||
|
/** Zend_Log_Formatter_Firebug */
|
||
|
require_once 'Zend/Log/Formatter/Firebug.php';
|
||
|
|
||
|
/** Zend_Wildfire_Plugin_FirePhp */
|
||
|
require_once 'Zend/Wildfire/Plugin/FirePhp.php';
|
||
|
|
||
|
/**
|
||
|
* Writes log messages to the Firebug Console via FirePHP.
|
||
|
*
|
||
|
* @category Zend
|
||
|
* @package Zend_Log
|
||
|
* @subpackage Writer
|
||
|
* @copyright Copyright (c) 2005-2011 Zend Technologies USA Inc. (http://www.zend.com)
|
||
|
* @license http://framework.zend.com/license/new-bsd New BSD License
|
||
|
*/
|
||
|
class Zend_Log_Writer_Firebug extends Zend_Log_Writer_Abstract
|
||
|
{
|
||
|
/**
|
||
|
* Maps logging priorities to logging display styles
|
||
|
*
|
||
|
* @var array
|
||
|
*/
|
||
|
protected $_priorityStyles = array(Zend_Log::EMERG => Zend_Wildfire_Plugin_FirePhp::ERROR,
|
||
|
Zend_Log::ALERT => Zend_Wildfire_Plugin_FirePhp::ERROR,
|
||
|
Zend_Log::CRIT => Zend_Wildfire_Plugin_FirePhp::ERROR,
|
||
|
Zend_Log::ERR => Zend_Wildfire_Plugin_FirePhp::ERROR,
|
||
|
Zend_Log::WARN => Zend_Wildfire_Plugin_FirePhp::WARN,
|
||
|
Zend_Log::NOTICE => Zend_Wildfire_Plugin_FirePhp::INFO,
|
||
|
Zend_Log::INFO => Zend_Wildfire_Plugin_FirePhp::INFO,
|
||
|
Zend_Log::DEBUG => Zend_Wildfire_Plugin_FirePhp::LOG);
|
||
|
|
||
|
/**
|
||
|
* The default logging style for un-mapped priorities
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
protected $_defaultPriorityStyle = Zend_Wildfire_Plugin_FirePhp::LOG;
|
||
|
|
||
|
/**
|
||
|
* Flag indicating whether the log writer is enabled
|
||
|
*
|
||
|
* @var boolean
|
||
|
*/
|
||
|
protected $_enabled = true;
|
||
|
|
||
|
/**
|
||
|
* Class constructor
|
||
|
*
|
||
|
* @return void
|
||
|
*/
|
||
|
public function __construct()
|
||
|
{
|
||
|
if (php_sapi_name() == 'cli') {
|
||
|
$this->setEnabled(false);
|
||
|
}
|
||
|
|
||
|
$this->_formatter = new Zend_Log_Formatter_Firebug();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Create a new instance of Zend_Log_Writer_Firebug
|
||
|
*
|
||
|
* @param array|Zend_Config $config
|
||
|
* @return Zend_Log_Writer_Firebug
|
||
|
*/
|
||
|
static public function factory($config)
|
||
|
{
|
||
|
return new self();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Enable or disable the log writer.
|
||
|
*
|
||
|
* @param boolean $enabled Set to TRUE to enable the log writer
|
||
|
* @return boolean The previous value.
|
||
|
*/
|
||
|
public function setEnabled($enabled)
|
||
|
{
|
||
|
$previous = $this->_enabled;
|
||
|
$this->_enabled = $enabled;
|
||
|
return $previous;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Determine if the log writer is enabled.
|
||
|
*
|
||
|
* @return boolean Returns TRUE if the log writer is enabled.
|
||
|
*/
|
||
|
public function getEnabled()
|
||
|
{
|
||
|
return $this->_enabled;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Set the default display style for user-defined priorities
|
||
|
*
|
||
|
* @param string $style The default log display style
|
||
|
* @return string Returns previous default log display style
|
||
|
*/
|
||
|
public function setDefaultPriorityStyle($style)
|
||
|
{
|
||
|
$previous = $this->_defaultPriorityStyle;
|
||
|
$this->_defaultPriorityStyle = $style;
|
||
|
return $previous;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get the default display style for user-defined priorities
|
||
|
*
|
||
|
* @return string Returns the default log display style
|
||
|
*/
|
||
|
public function getDefaultPriorityStyle()
|
||
|
{
|
||
|
return $this->_defaultPriorityStyle;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Set a display style for a logging priority
|
||
|
*
|
||
|
* @param int $priority The logging priority
|
||
|
* @param string $style The logging display style
|
||
|
* @return string|boolean The previous logging display style if defined or TRUE otherwise
|
||
|
*/
|
||
|
public function setPriorityStyle($priority, $style)
|
||
|
{
|
||
|
$previous = true;
|
||
|
if (array_key_exists($priority,$this->_priorityStyles)) {
|
||
|
$previous = $this->_priorityStyles[$priority];
|
||
|
}
|
||
|
$this->_priorityStyles[$priority] = $style;
|
||
|
return $previous;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get a display style for a logging priority
|
||
|
*
|
||
|
* @param int $priority The logging priority
|
||
|
* @return string|boolean The logging display style if defined or FALSE otherwise
|
||
|
*/
|
||
|
public function getPriorityStyle($priority)
|
||
|
{
|
||
|
if (array_key_exists($priority,$this->_priorityStyles)) {
|
||
|
return $this->_priorityStyles[$priority];
|
||
|
}
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Log a message to the Firebug Console.
|
||
|
*
|
||
|
* @param array $event The event data
|
||
|
* @return void
|
||
|
*/
|
||
|
protected function _write($event)
|
||
|
{
|
||
|
if (!$this->getEnabled()) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
if (array_key_exists($event['priority'],$this->_priorityStyles)) {
|
||
|
$type = $this->_priorityStyles[$event['priority']];
|
||
|
} else {
|
||
|
$type = $this->_defaultPriorityStyle;
|
||
|
}
|
||
|
|
||
|
$message = $this->_formatter->format($event);
|
||
|
|
||
|
$label = isset($event['firebugLabel'])?$event['firebugLabel']:null;
|
||
|
|
||
|
Zend_Wildfire_Plugin_FirePhp::getInstance()->send($message,
|
||
|
$label,
|
||
|
$type,
|
||
|
array('traceOffset'=>4,
|
||
|
'fixZendLogOffsetIfApplicable'=>true));
|
||
|
}
|
||
|
}
|