Completed
Push — master ( e75b4a...6eabf7 )
by Dmitry
14:01
created

ConsoleLogTarget::export()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 7

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 7
rs 10
c 0
b 0
f 0
cc 2
nc 2
nop 0
1
<?php
2
3
namespace hiapi\console;
4
5
use Psr\Log\LogLevel;
6
use yii\helpers\Console;
7
use yii\helpers\VarDumper;
8
9
/**
10
 * Class ConsoleLogTarget
11
 *
12
 * @author Dmytro Naumenko <[email protected]>
13
 */
14
class ConsoleLogTarget extends \yii\log\Target
15
{
16
    public $exportInterval = 1;
17
18
    public $exportContext = [
19
        LogLevel::EMERGENCY => false,
20
        LogLevel::ERROR     => false,
21
        LogLevel::ALERT     => false,
22
        LogLevel::CRITICAL  => false,
23
        LogLevel::WARNING   => false,
24
    ];
25
26
    public static $styles = [
27
        LogLevel::EMERGENCY => [Console::BOLD, Console::BG_RED],
28
        LogLevel::ERROR     => [Console::FG_RED, Console::BOLD],
29
        LogLevel::ALERT     => [Console::FG_RED],
30
        LogLevel::CRITICAL  => [Console::FG_RED],
31
        LogLevel::WARNING   => [Console::FG_YELLOW],
32
    ];
33
34
    public function export()
35
    {
36
        foreach ($this->messages as $message) {
37
            $this->out($message[0], $message[1]);
38
            $this->outContext($message[0], $message[2]);
39
        }
40
    }
41
42
    private function outContext($level, $context)
43
    {
44
        if ($this->exportContext[$level] ?? false) {
45
            $export = VarDumper::export($context);
46
            Console::stdout($export . "\n");
47
        }
48
    }
49
50
    public function out($level, $message)
51
    {
52
        $style = self::$styles[$level];
53
        if ($style) {
54
            $message = Console::ansiFormat($message, $style);
55
        } else {
56
            return;
57
        }
58
        Console::stdout($message . "\n");
59
    }
60
61
    protected function getContextMessage()
62
    {
63
        return '';
64
    }
65
}
66