TerminalLogger::log()   A
last analyzed

Complexity

Conditions 2
Paths 2

Size

Total Lines 11
Code Lines 8

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 6

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 2
eloc 8
c 1
b 0
f 0
nc 2
nop 3
dl 0
loc 11
ccs 0
cts 9
cp 0
crap 6
rs 10
1
<?php
2
3
declare(strict_types=1);
4
5
namespace PhpCfdi\SatCatalogosPopulate\Commands;
6
7
use Psr\Log\AbstractLogger;
8
use Psr\Log\LogLevel;
9
10
class TerminalLogger extends AbstractLogger
11
{
12
    /**
13
     * @param string $level
14
     * @param string $message
15
     * @param mixed[] $context
16
     */
17
    public function log($level, $message, array $context = []): void
18
    {
19
        $logValue = $this->logValue($level);
20
        $streamName = 'stdout';
21
        if ($logValue > 3) { // greater than warning
22
            $streamName = 'stderr';
23
        }
24
        file_put_contents(
25
            'php://' . $streamName,
26
            date('Y-m-d H:i:s') . ' ' . $level . ': ' . $message . PHP_EOL,
27
            FILE_APPEND
28
        );
29
    }
30
31
    public function logValue(string $level): int
32
    {
33
        $map = [
34
            LogLevel::EMERGENCY => 7,
35
            LogLevel::ALERT => 6,
36
            LogLevel::CRITICAL => 5,
37
            LogLevel::ERROR => 4,
38
            LogLevel::WARNING => 3,
39
            LogLevel::NOTICE => 2,
40
            LogLevel::INFO => 1,
41
            LogLevel::DEBUG => 0,
42
        ];
43
44
        return $map[$level] ?? 0;
45
    }
46
}
47