AppLoggerFactory::__invoke()   A
last analyzed

Complexity

Conditions 4
Paths 8

Size

Total Lines 19

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 10
CRAP Score 4

Importance

Changes 0
Metric Value
dl 0
loc 19
ccs 10
cts 10
cp 1
rs 9.6333
c 0
b 0
f 0
cc 4
nc 8
nop 1
crap 4
1
<?php
2
declare(strict_types=1);
3
4
namespace SlayerBirden\DataFlowServer\Logger;
5
6
use Monolog\Handler\HandlerInterface;
7
use Monolog\Handler\StreamHandler;
8
use Monolog\Logger;
9
use Psr\Container\ContainerInterface;
10
11
class AppLoggerFactory
12
{
13
    /**
14
     * @param ContainerInterface $container
15
     * @return Logger
16
     * @throws \Psr\Container\ContainerExceptionInterface
17
     * @throws \Psr\Container\NotFoundExceptionInterface
18
     * @throws \Exception
19
     */
20 136
    public function __invoke(ContainerInterface $container)
21
    {
22 136
        $config = $container->has('config') ? $container->get('config') : [];
23 136
        $loggerConfig = $config['logger'] ?? [];
24
25 136
        $logger = new Logger('app');
26
27 136
        if (!empty($loggerConfig)) {
28 136
            $this->addHandlers($logger, $loggerConfig, $container);
29
        }
30
31 136
        if (!$logger->getHandlers()) {
32
            // add default handler
33 2
            $baseHandler = new StreamHandler('data/log/app.log');
34 2
            $logger->pushHandler($baseHandler);
35
        }
36
37 136
        return $logger;
38
    }
39
40 136
    private function addHandlers(Logger $logger, array $loggerConfig, ContainerInterface $container): void
41
    {
42 136
        $handlers = $loggerConfig['handlers'] ?? [];
43 136
        if (!empty($handlers) && is_array($handlers)) {
44 136
            foreach ($handlers as $handler) {
45 136
                if (is_object($handler) && $handler instanceof HandlerInterface) {
46 2
                    $logger->pushHandler($handler);
47 134
                } elseif (is_string($handler) && $container->has($handler)) {
48 136
                    $logger->pushHandler($container->get($handler));
49
                }
50
            }
51
        }
52 136
    }
53
}
54