| Conditions | 3 |
| Paths | 3 |
| Total Lines | 26 |
| Code Lines | 13 |
| Lines | 0 |
| Ratio | 0 % |
| Tests | 14 |
| CRAP Score | 3 |
| Changes | 3 | ||
| Bugs | 0 | Features | 0 |
| 1 | <?php |
||
| 24 | 2 | public function __invoke(ContainerInterface $container, $requestedName, ?array $options = null): Logger |
|
| 25 | { |
||
| 26 | 2 | if (!$this->logger) { |
|
| 27 | 2 | $this->logger = new Logger(); |
|
| 28 | |||
| 29 | // Log to file |
||
| 30 | 2 | $fileWriter = new Stream('logs/all.log'); |
|
| 31 | 2 | $this->logger->addWriter($fileWriter); |
|
| 32 | |||
| 33 | // Log to DB |
||
| 34 | 2 | $dbWriter = $container->get(Db::class); |
|
| 35 | 2 | $dbWriter->addFilter(Logger::INFO); |
|
| 36 | 2 | $this->logger->addWriter($dbWriter); |
|
| 37 | |||
| 38 | // Maybe log to emails |
||
| 39 | 2 | $mailWriter = $container->get(Mail::class); |
|
| 40 | 2 | if ($mailWriter) { |
|
| 41 | 1 | $this->logger->addWriter($mailWriter); |
|
| 42 | } |
||
| 43 | |||
| 44 | // Register to log all kind of PHP errors |
||
| 45 | 2 | Logger::registerErrorHandler($this->logger, true); |
|
| 46 | 2 | Logger::registerFatalErrorShutdownFunction($this->logger); |
|
| 47 | } |
||
| 48 | |||
| 49 | 2 | return $this->logger; |
|
| 50 | } |
||
| 52 |