MonologProvisioner   A
last analyzed

Complexity

Total Complexity 3

Size/Duplication

Total Lines 28
Duplicated Lines 0 %

Test Coverage

Coverage 0%

Importance

Changes 2
Bugs 0 Features 0
Metric Value
eloc 18
c 2
b 0
f 0
dl 0
loc 28
ccs 0
cts 11
cp 0
rs 10
wmc 3

1 Method

Rating   Name   Duplication   Size   Complexity  
A provision() 0 26 3
1
<?php declare(strict_types=1);
2
/**
3
 * This file is part of the daikon-cqrs/boot project.
4
 *
5
 * For the full copyright and license information, please view the LICENSE
6
 * file that was distributed with this source code.
7
 */
8
9
namespace Daikon\Boot\Service\Provisioner;
10
11
use Auryn\Injector;
12
use Daikon\Boot\Service\ServiceDefinitionInterface;
13
use Daikon\Config\ConfigProviderInterface;
14
use Daikon\Interop\RuntimeException;
15
use Monolog\Level;
16
use Monolog\Logger;
17
use Monolog\Handler\ErrorLogHandler;
18
use Monolog\Handler\StreamHandler;
19
use Psr\Log\LoggerInterface;
20
21
final class MonologProvisioner implements ProvisionerInterface
22
{
23
    public function provision(
24
        Injector $injector,
25
        ConfigProviderInterface $configProvider,
26
        ServiceDefinitionInterface $serviceDefinition
27
    ): void {
28
        $className = $serviceDefinition->getServiceClass();
29
        $settings = $serviceDefinition->getSettings();
30
        if (!isset($settings['location'])) {
31
            throw new RuntimeException('Please provide a logging service output location.');
32
        }
33
        $settings['level'] = $settings['level'] ? constant(Level::class.'::'.$settings['level']) : Level::Info;
34
        $settings['name'] = $settings['name'] ?? 'default-logger';
35
36
        $injector
37
            ->alias(LoggerInterface::class, $className)
38
            ->share($className)
39
            ->delegate(
40
                $className,
41
                function () use ($className, $settings): Logger {
42
                    /** @var Logger $logger */
43
                    $logger = new $className($settings['name']);
44
                    $logger->setHandlers([
45
                        new ErrorLogHandler(ErrorLogHandler::OPERATING_SYSTEM, $settings['level']),
46
                        new StreamHandler($settings['location'], $settings['level'])
47
                    ]);
48
                    return $logger;
49
                }
50
            );
51
    }
52
}
53