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

LoggerMiddlewareHandler   A

Complexity

Total Complexity 4

Size/Duplication

Total Lines 44
Duplicated Lines 0 %

Coupling/Cohesion

Components 0
Dependencies 1

Test Coverage

Coverage 0%

Importance

Changes 0
Metric Value
wmc 4
lcom 0
cbo 1
dl 0
loc 44
ccs 0
cts 21
cp 0
rs 10
c 0
b 0
f 0

2 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 4 1
A handle() 0 22 3
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