145 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
		
		
			
		
	
	
			145 lines
		
	
	
		
			3.8 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 RollbarNotifier; | ||
|  | use Exception; | ||
|  | use Monolog\Logger; | ||
|  | 
 | ||
|  | /** | ||
|  |  * Sends errors to Rollbar | ||
|  |  * | ||
|  |  * If the context data contains a `payload` key, that is used as an array | ||
|  |  * of payload options to RollbarNotifier's report_message/report_exception methods. | ||
|  |  * | ||
|  |  * Rollbar's context info will contain the context + extra keys from the log record | ||
|  |  * merged, and then on top of that a few keys: | ||
|  |  * | ||
|  |  *  - level (rollbar level name) | ||
|  |  *  - monolog_level (monolog level name, raw level, as rollbar only has 5 but monolog 8) | ||
|  |  *  - channel | ||
|  |  *  - datetime (unix timestamp) | ||
|  |  * | ||
|  |  * @author Paul Statezny <paulstatezny@gmail.com> | ||
|  |  */ | ||
|  | class RollbarHandler extends AbstractProcessingHandler | ||
|  | { | ||
|  |     /** | ||
|  |      * Rollbar notifier | ||
|  |      * | ||
|  |      * @var RollbarNotifier | ||
|  |      */ | ||
|  |     protected $rollbarNotifier; | ||
|  | 
 | ||
|  |     protected $levelMap = array( | ||
|  |         Logger::DEBUG     => 'debug', | ||
|  |         Logger::INFO      => 'info', | ||
|  |         Logger::NOTICE    => 'info', | ||
|  |         Logger::WARNING   => 'warning', | ||
|  |         Logger::ERROR     => 'error', | ||
|  |         Logger::CRITICAL  => 'critical', | ||
|  |         Logger::ALERT     => 'critical', | ||
|  |         Logger::EMERGENCY => 'critical', | ||
|  |     ); | ||
|  | 
 | ||
|  |     /** | ||
|  |      * Records whether any log records have been added since the last flush of the rollbar notifier | ||
|  |      * | ||
|  |      * @var bool | ||
|  |      */ | ||
|  |     private $hasRecords = false; | ||
|  | 
 | ||
|  |     protected $initialized = false; | ||
|  | 
 | ||
|  |     /** | ||
|  |      * @param RollbarNotifier $rollbarNotifier RollbarNotifier object constructed with valid token | ||
|  |      * @param int             $level           The minimum logging level at which this handler will be triggered | ||
|  |      * @param bool            $bubble          Whether the messages that are handled can bubble up the stack or not | ||
|  |      */ | ||
|  |     public function __construct(RollbarNotifier $rollbarNotifier, $level = Logger::ERROR, $bubble = true) | ||
|  |     { | ||
|  |         $this->rollbarNotifier = $rollbarNotifier; | ||
|  | 
 | ||
|  |         parent::__construct($level, $bubble); | ||
|  |     } | ||
|  | 
 | ||
|  |     /** | ||
|  |      * {@inheritdoc} | ||
|  |      */ | ||
|  |     protected function write(array $record) | ||
|  |     { | ||
|  |         if (!$this->initialized) { | ||
|  |             // __destructor() doesn't get called on Fatal errors
 | ||
|  |             register_shutdown_function(array($this, 'close')); | ||
|  |             $this->initialized = true; | ||
|  |         } | ||
|  | 
 | ||
|  |         $context = $record['context']; | ||
|  |         $payload = array(); | ||
|  |         if (isset($context['payload'])) { | ||
|  |             $payload = $context['payload']; | ||
|  |             unset($context['payload']); | ||
|  |         } | ||
|  |         $context = array_merge($context, $record['extra'], array( | ||
|  |             'level' => $this->levelMap[$record['level']], | ||
|  |             'monolog_level' => $record['level_name'], | ||
|  |             'channel' => $record['channel'], | ||
|  |             'datetime' => $record['datetime']->format('U'), | ||
|  |         )); | ||
|  | 
 | ||
|  |         if (isset($context['exception']) && $context['exception'] instanceof Exception) { | ||
|  |             $payload['level'] = $context['level']; | ||
|  |             $exception = $context['exception']; | ||
|  |             unset($context['exception']); | ||
|  | 
 | ||
|  |             $this->rollbarNotifier->report_exception($exception, $context, $payload); | ||
|  |         } else { | ||
|  |             $this->rollbarNotifier->report_message( | ||
|  |                 $record['message'], | ||
|  |                 $context['level'], | ||
|  |                 $context, | ||
|  |                 $payload | ||
|  |             ); | ||
|  |         } | ||
|  | 
 | ||
|  |         $this->hasRecords = true; | ||
|  |     } | ||
|  | 
 | ||
|  |     public function flush() | ||
|  |     { | ||
|  |         if ($this->hasRecords) { | ||
|  |             $this->rollbarNotifier->flush(); | ||
|  |             $this->hasRecords = false; | ||
|  |         } | ||
|  |     } | ||
|  | 
 | ||
|  |     /** | ||
|  |      * {@inheritdoc} | ||
|  |      */ | ||
|  |     public function close() | ||
|  |     { | ||
|  |         $this->flush(); | ||
|  |     } | ||
|  | 
 | ||
|  |     /** | ||
|  |      * {@inheritdoc} | ||
|  |      */ | ||
|  |     public function reset() | ||
|  |     { | ||
|  |         $this->flush(); | ||
|  | 
 | ||
|  |         parent::reset(); | ||
|  |     } | ||
|  | 
 | ||
|  | 
 | ||
|  | } |