mirror of
				https://github.com/Seldaek/monolog.git
				synced 2025-10-24 18:16:10 +02:00 
			
		
		
		
	Add AsMonologProcessor attribute (#1637)
This commit is contained in:
		
							
								
								
									
										36
									
								
								src/Monolog/Attribute/AsMonologProcessor.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								src/Monolog/Attribute/AsMonologProcessor.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,36 @@ | |||||||
|  | <?php declare(strict_types=1); | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * 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\Attribute; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * A reusable attribute to help configure a class or a method as a processor. | ||||||
|  |  *  | ||||||
|  |  * Using it offers no guarantee: it needs to be leveraged by a Monolog third-party consumer. | ||||||
|  |  *  | ||||||
|  |  * Using it with the Monolog library only has no effect at all: processors should still be turned into a callable if | ||||||
|  |  * needed and manually pushed to the loggers and to the processable handlers. | ||||||
|  |  */ | ||||||
|  | #[\Attribute(\Attribute::TARGET_CLASS | \Attribute::TARGET_METHOD | \Attribute::IS_REPEATABLE)] | ||||||
|  | class AsMonologProcessor | ||||||
|  | { | ||||||
|  |     /** | ||||||
|  |      * @param string|null $channel  The logging channel the processor should be pushed to. | ||||||
|  |      * @param string|null $handler  The handler the processor should be pushed to. | ||||||
|  |      * @param string|null $method   The method that processes the records (if the attribute is used at the class level). | ||||||
|  |      */ | ||||||
|  |     public function __construct( | ||||||
|  |         public ?string $channel = null, | ||||||
|  |         public ?string $handler = null, | ||||||
|  |         public ?string $method = null, | ||||||
|  |     ) { | ||||||
|  |     } | ||||||
|  | }  | ||||||
							
								
								
									
										33
									
								
								tests/Monolog/Attribute/AsMonologProcessorTest.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								tests/Monolog/Attribute/AsMonologProcessorTest.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | |||||||
|  | <?php declare(strict_types=1); | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * 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\Attribute; | ||||||
|  |  | ||||||
|  | use PHPUnit\Framework\TestCase; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * @requires PHP 8.0 | ||||||
|  |  */ | ||||||
|  | final class AsMonologProcessorTest extends TestCase | ||||||
|  | { | ||||||
|  |     public function test(): void | ||||||
|  |     { | ||||||
|  |         $asMonologProcessor = new AsMonologProcessor('channel', 'handler', 'method'); | ||||||
|  |         $this->assertSame('channel', $asMonologProcessor->channel); | ||||||
|  |         $this->assertSame('handler', $asMonologProcessor->handler); | ||||||
|  |         $this->assertSame('method', $asMonologProcessor->method); | ||||||
|  |  | ||||||
|  |         $asMonologProcessor = new AsMonologProcessor(null, null, null); | ||||||
|  |         $this->assertNull($asMonologProcessor->channel); | ||||||
|  |         $this->assertNull($asMonologProcessor->handler); | ||||||
|  |         $this->assertNull($asMonologProcessor->method); | ||||||
|  |     } | ||||||
|  | } | ||||||
		Reference in New Issue
	
	Block a user