mirror of
				https://github.com/Seldaek/monolog.git
				synced 2025-10-22 00:56:08 +02:00 
			
		
		
		
	Merge remote-tracking branch 'michaelmoussa/psr-handler'
This commit is contained in:
		
							
								
								
									
										57
									
								
								src/Monolog/Handler/PsrHandler.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								src/Monolog/Handler/PsrHandler.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,57 @@ | ||||
| <?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\Logger; | ||||
| use Psr\Log\LoggerInterface; | ||||
|  | ||||
| /** | ||||
|  * Proxies log messages to an existing PSR-3 compliant logger. | ||||
|  * | ||||
|  * @author Michael Moussa <michael.moussa@gmail.com> | ||||
|  */ | ||||
| class PsrHandler extends AbstractHandler | ||||
| { | ||||
|     /** | ||||
|      * PSR-3 compliant logger | ||||
|      * | ||||
|      * @var LoggerInterface | ||||
|      */ | ||||
|     protected $logger; | ||||
|  | ||||
|     /** | ||||
|      * @param LoggerInterface $logger The underlying PSR-3 compliant logger to which messages will be proxied | ||||
|      * @param int             $level  The minimum logging level at which this handler will be triggered | ||||
|      * @param Boolean         $bubble Whether the messages that are handled can bubble up the stack or not | ||||
|      */ | ||||
|     public function __construct(LoggerInterface $logger, $level = Logger::DEBUG, $bubble = true) | ||||
|     { | ||||
|         parent::__construct($level, $bubble); | ||||
|  | ||||
|         $this->logger = $logger; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function handle(array $record) | ||||
|     { | ||||
|         if (!$this->isHandling($record)) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         $logMethodName = strtolower($record['level_name']); | ||||
|         call_user_func([$this->logger, $logMethodName], $record['message'], $record['context']); | ||||
|  | ||||
|         return false === $this->bubble; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										50
									
								
								tests/Monolog/Handler/PsrHandlerTest.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								tests/Monolog/Handler/PsrHandlerTest.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,50 @@ | ||||
| <?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\TestCase; | ||||
| use Monolog\Logger; | ||||
|  | ||||
| /** | ||||
|  * @covers Monolog\Handler\PsrHandler::handle | ||||
|  */ | ||||
| class PsrHandlerTest extends TestCase | ||||
| { | ||||
|     public function logLevelProvider() | ||||
|     { | ||||
|         $levels = []; | ||||
|         $monologLogger = new Logger('', [], []); | ||||
|  | ||||
|         foreach ($monologLogger->getLevels() as $levelName => $level) { | ||||
|             $levels[] = [$levelName, $level]; | ||||
|         } | ||||
|  | ||||
|         return $levels; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @dataProvider logLevelProvider | ||||
|      */ | ||||
|     public function testHandlesAllLevels($levelName, $level) | ||||
|     { | ||||
|         $message = 'Hello, world!'; | ||||
|         $context = ['foo' => 'bar']; | ||||
|  | ||||
|         $psrLogger = $this->getMock('Psr\Log\NullLogger'); | ||||
|         $psrLogger->expects($this->once()) | ||||
|             ->method(strtolower($levelName)) | ||||
|             ->with($message, $context); | ||||
|  | ||||
|         $handler = new PsrHandler($psrLogger); | ||||
|         $handler->handle(['level' => $level, 'level_name' => $levelName, 'message' => $message, 'context' => $context]); | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user