Completed
Push — master ( 67a91e...657487 )
by Peter
06:52
created

LoggerMiddlewareHandler::handle()   A

Complexity

Conditions 3
Paths 3

Size

Total Lines 22
Code Lines 17

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 12

Importance

Changes 0
Metric Value
dl 0
loc 22
ccs 0
cts 18
cp 0
rs 9.2
c 0
b 0
f 0
cc 3
eloc 17
nc 3
nop 2
crap 12
1
<?php
2
3
/**
4
 * GpsLab component.
5
 *
6
 * @author    Peter Gribanov <[email protected]>
7
 * @copyright Copyright (c) 2011, Peter Gribanov
8
 * @license   http://opensource.org/licenses/MIT
9
 */
10
11
namespace GpsLab\Component\Middleware\Handler;
12
13
use Psr\Log\LoggerInterface;
14
15
class LoggerMiddlewareHandler implements MiddlewareHandler
16
{
17
    /**
18
     * @var LoggerInterface
19
     */
20
    private $logger;
21
22
    /**
23
     * @param LoggerInterface $logger
24
     */
25
    public function __construct(LoggerInterface $logger)
26
    {
27
        $this->logger = $logger;
28
    }
29
30
    /**
31
     * @param mixed    $message
32
     * @param callable $next
33
     *
34
     * @return mixed
35
     */
36
    public function handle($message, callable $next)
37
    {
38
        switch (gettype($message)) {
39
            case 'object':
40
                $class_parts = explode('\\', get_class($message));
41
                $log_message = sprintf('Middleware handle a "%s".', end($class_parts));
42
                $context = json_decode(json_encode($message), true);
43
                break;
44
            case 'resource':
45
                $log_message = 'Middleware handle a resource';
46
                $context = ['type' => get_resource_type($message)];
47
                break;
48
            default:
49
                $log_message = 'Middleware handle a message';
50
                $context = ['message' => $message];
51
                break;
52
        }
53
54
        $this->logger->debug($log_message, $context);
55
56
        return $next($message);
57
    }
58
}
59