|
4 | 4 |
|
5 | 5 | use Micro\Component\DependencyInjection\Container; |
6 | 6 | use Micro\Framework\Kernel\Plugin\AbstractPlugin; |
7 | | -use Micro\Plugin\Logger\Impl\LoggerFactory; |
8 | | -use \Closure; |
| 7 | +use Micro\Plugin\Logger\Business\Factory\LoggerFactory; |
| 8 | +use Micro\Plugin\Logger\Business\Factory\LoggerFactoryInterface; |
| 9 | +use Micro\Plugin\Logger\Business\Provider\LoggerProvider; |
| 10 | +use Micro\Plugin\Logger\Business\Provider\LoggerProviderInterface; |
9 | 11 |
|
10 | | -class LoggerPlugin extends AbstractPlugin |
| 12 | +abstract class LoggerPlugin extends AbstractPlugin |
11 | 13 | { |
12 | | - public const SERVICE_LOGGER = 'logger'; |
| 14 | + /** |
| 15 | + * @var LoggerProviderInterface|null |
| 16 | + */ |
| 17 | + private ?LoggerProviderInterface $loggerProvider = null; |
13 | 18 |
|
14 | 19 | /** |
15 | 20 | * {@inheritDoc} |
16 | 21 | */ |
17 | 22 | public function provideDependencies(Container $container): void |
18 | 23 | { |
19 | | - $container->register(self::SERVICE_LOGGER, $this->createLoggerServiceCallback()); |
| 24 | + $container->register(LoggerFacadeInterface::class, function (Container $container) { |
| 25 | + return $this->createLoggerFacade(); |
| 26 | + }); |
20 | 27 | } |
21 | 28 |
|
22 | 29 | /** |
23 | | - * @return Closure |
| 30 | + * @return LoggerProviderInterface |
24 | 31 | */ |
25 | | - private function createLoggerServiceCallback(): Closure |
| 32 | + protected function getLoggerProvider(): LoggerProviderInterface |
26 | 33 | { |
27 | | - return function (Container $container) |
28 | | - { |
29 | | - return $this->createLoggerFactory()->create(); |
30 | | - }; |
| 34 | + if(!$this->loggerProvider) { |
| 35 | + $this->loggerProvider = $this->createLoggerProvider(); |
| 36 | + } |
| 37 | + |
| 38 | + return $this->loggerProvider; |
31 | 39 | } |
32 | 40 |
|
33 | 41 | /** |
34 | | - * @return LoggerFactoryInterface |
| 42 | + * @return LoggerProviderInterface |
35 | 43 | */ |
36 | | - private function createLoggerFactory(): LoggerFactoryInterface |
| 44 | + protected function createLoggerProvider(): LoggerProviderInterface |
37 | 45 | { |
38 | | - return new LoggerFactory($this->configuration); |
| 46 | + return new LoggerProvider( |
| 47 | + $this->createLoggerFactory() |
| 48 | + ); |
39 | 49 | } |
| 50 | + |
| 51 | + /** |
| 52 | + * @return LoggerFacadeInterface |
| 53 | + */ |
| 54 | + protected function createLoggerFacade(): LoggerFacadeInterface |
| 55 | + { |
| 56 | + return new LoggerFacade($this->getLoggerProvider()); |
| 57 | + } |
| 58 | + |
| 59 | + /** |
| 60 | + * @return LoggerFactoryInterface |
| 61 | + */ |
| 62 | + abstract protected function createLoggerFactory(): LoggerFactoryInterface; |
40 | 63 | } |
0 commit comments