Completed
Push — master ( afc178...f9ad3c )
by Krzysztof
06:00
created

LogEventMiddleware   A

Complexity

Total Complexity 2

Size/Duplication

Total Lines 33
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 2
Metric Value
wmc 2
lcom 1
cbo 2
dl 0
loc 33
rs 10

2 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 5 1
A handle() 0 6 1
1
<?php
2
3
namespace Clearcode\SimpleBusElkBundle\CommandBus;
4
5
use Clearcode\SimpleBusElkBundle\Converter\ObjectToArrayConverterInterface;
6
use Psr\Log\LoggerInterface;
7
use SimpleBus\Message\Bus\Middleware\MessageBusMiddleware;
8
9
class LogEventMiddleware implements MessageBusMiddleware
10
{
11
    /**
12
     * @var LoggerInterface
13
     */
14
    private $logger;
15
16
    /**
17
     * @var ObjectToArrayConverterInterface
18
     */
19
    private $converter;
20
21
    /**
22
     * LogEventMiddleware constructor.
23
     *
24
     * @param LoggerInterface $logger
25
     */
26
    public function __construct(LoggerInterface $logger, ObjectToArrayConverterInterface $converter)
27
    {
28
        $this->logger    = $logger;
29
        $this->converter = $converter;
30
    }
31
32
    /**
33
     * {@inheritdoc}
34
     */
35
    public function handle($message, callable $next)
36
    {
37
        $this->logger->info('Event recorded', $this->converter->toArray($message));
38
39
        $next($message);
40
    }
41
}
42