Issues (9)

src/Utils/DispatchingLogger.php (1 issue)

Severity
1
<?php
2
3
/**
4
 * This file is part of byrokrat\giroapp.
5
 *
6
 * byrokrat\giroapp is free software: you can redistribute it and/or
7
 * modify it under the terms of the GNU General Public License as published
8
 * by the Free Software Foundation, either version 3 of the License, or
9
 * (at your option) any later version.
10
 *
11
 * byrokrat\giroapp is distributed in the hope that it will be useful,
12
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14
 * GNU General Public License for more details.
15
 *
16
 * You should have received a copy of the GNU General Public License
17
 * along with byrokrat\giroapp. If not, see <http://www.gnu.org/licenses/>.
18
 *
19
 * Copyright 2016-21 Hannes Forsgård
20
 */
21
22
declare(strict_types=1);
23
24
namespace byrokrat\giroapp\Utils;
25
26
use byrokrat\giroapp\DependencyInjection\DispatcherProperty;
27
use byrokrat\giroapp\Event\LogEvent;
28
use Psr\Log\LoggerInterface;
29
use Psr\Log\LoggerTrait;
30
31
final class DispatchingLogger implements LoggerInterface
32
{
33
    use DispatcherProperty;
34
    use LoggerTrait;
35
36
    /**
37
     * @param mixed $level
38
     * @param string $message
39
     * @param array<string> $context
40
     * @return void
41
     */
42
    public function log($level, $message, array $context = [])
43
    {
44
        if (!is_scalar($level)) {
45
            throw new \InvalidArgumentException('$level must be a scalar value');
46
        }
47
48
        if (!is_scalar($message)) {
0 ignored issues
show
The condition is_scalar($message) is always true.
Loading history...
49
            throw new \InvalidArgumentException('$message must be a scalar value');
50
        }
51
52
        $this->dispatcher->dispatch(
53
            new LogEvent((string)$message, (string)$level, $context)
54
        );
55
    }
56
}
57