96 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
			
		
		
	
	
			96 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
<?php
 | 
						|
/*
 | 
						|
 * This file is part of the Monolog package.
 | 
						|
 *
 | 
						|
 * (c) Jordi Boggiano <j.boggiano@seld.be>
 | 
						|
 *
 | 
						|
 * For the full copyright and license information, please view the LICENSE
 | 
						|
 * file that was distributed with this source code.
 | 
						|
 */
 | 
						|
 | 
						|
namespace Monolog\Handler;
 | 
						|
 | 
						|
use Monolog\Formatter\NormalizerFormatter;
 | 
						|
use Monolog\Logger;
 | 
						|
 | 
						|
/**
 | 
						|
 * Handler sending logs to Zend Monitor
 | 
						|
 *
 | 
						|
 * @author  Christian Bergau <cbergau86@gmail.com>
 | 
						|
 */
 | 
						|
class ZendMonitorHandler extends AbstractProcessingHandler
 | 
						|
{
 | 
						|
    /**
 | 
						|
     * Monolog level / ZendMonitor Custom Event priority map
 | 
						|
     *
 | 
						|
     * @var array
 | 
						|
     */
 | 
						|
    protected $levelMap = array(
 | 
						|
        Logger::DEBUG     => 1,
 | 
						|
        Logger::INFO      => 2,
 | 
						|
        Logger::NOTICE    => 3,
 | 
						|
        Logger::WARNING   => 4,
 | 
						|
        Logger::ERROR     => 5,
 | 
						|
        Logger::CRITICAL  => 6,
 | 
						|
        Logger::ALERT     => 7,
 | 
						|
        Logger::EMERGENCY => 0,
 | 
						|
    );
 | 
						|
 | 
						|
    /**
 | 
						|
     * Construct
 | 
						|
     *
 | 
						|
     * @param  int                       $level
 | 
						|
     * @param  bool                      $bubble
 | 
						|
     * @throws MissingExtensionException
 | 
						|
     */
 | 
						|
    public function __construct($level = Logger::DEBUG, $bubble = true)
 | 
						|
    {
 | 
						|
        if (!function_exists('zend_monitor_custom_event')) {
 | 
						|
            throw new MissingExtensionException('You must have Zend Server installed in order to use this handler');
 | 
						|
        }
 | 
						|
        parent::__construct($level, $bubble);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * {@inheritdoc}
 | 
						|
     */
 | 
						|
    protected function write(array $record)
 | 
						|
    {
 | 
						|
        $this->writeZendMonitorCustomEvent(
 | 
						|
            $this->levelMap[$record['level']],
 | 
						|
            $record['message'],
 | 
						|
            $record['formatted']
 | 
						|
        );
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Write a record to Zend Monitor
 | 
						|
     *
 | 
						|
     * @param int    $level
 | 
						|
     * @param string $message
 | 
						|
     * @param array  $formatted
 | 
						|
     */
 | 
						|
    protected function writeZendMonitorCustomEvent($level, $message, $formatted)
 | 
						|
    {
 | 
						|
        zend_monitor_custom_event($level, $message, $formatted);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * {@inheritdoc}
 | 
						|
     */
 | 
						|
    public function getDefaultFormatter()
 | 
						|
    {
 | 
						|
        return new NormalizerFormatter();
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Get the level map
 | 
						|
     *
 | 
						|
     * @return array
 | 
						|
     */
 | 
						|
    public function getLevelMap()
 | 
						|
    {
 | 
						|
        return $this->levelMap;
 | 
						|
    }
 | 
						|
}
 |