Completed
Pull Request — master (#37)
by Eugene
08:41
created

LoggingMiddleware::process()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 15
Code Lines 8

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
eloc 8
dl 0
loc 15
rs 10
c 0
b 0
f 0
cc 1
nc 1
nop 2
1
<?php
2
3
declare(strict_types=1);
4
5
/*
6
 * This file is part of the Tarantool Client package.
7
 *
8
 * (c) Eugene Leonovich <[email protected]>
9
 *
10
 * For the full copyright and license information, please view the LICENSE
11
 * file that was distributed with this source code.
12
 */
13
14
namespace Tarantool\Client\Middleware;
15
16
use Psr\Log\LoggerInterface;
17
use Tarantool\Client\Handler\Handler;
18
use Tarantool\Client\Request\Request;
19
use Tarantool\Client\Response;
20
21
final class LoggingMiddleware implements Middleware
22
{
23
    private $logger;
24
25
    public function __construct(LoggerInterface $logger)
26
    {
27
        $this->logger = $logger;
28
    }
29
30
    public function process(Request $request, Handler $handler) : Response
31
    {
32
        $this->logger->debug('Starting handling request "{class}"', [
33
            'request' => $request,
34
            'class' => $requestClass = \get_class($request),
35
        ]);
36
37
        $response = $handler->handle($request);
38
39
        $this->logger->debug('Finished handling request "{class}"', [
40
            'response' => $response,
41
            'class' => $requestClass,
42
        ]);
43
44
        return $response;
45
    }
46
}
47