RestExceptionListener::onKernelException()   A
last analyzed

Complexity

Conditions 2
Paths 2

Size

Total Lines 21

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 13
CRAP Score 2

Importance

Changes 0
Metric Value
dl 0
loc 21
ccs 13
cts 13
cp 1
rs 9.584
c 0
b 0
f 0
cc 2
nc 2
nop 1
crap 2
1
<?php
2
declare(strict_types=1);
3
4
namespace Paysera\Bundle\ApiBundle\Listener;
5
6
use Paysera\Bundle\ApiBundle\Service\ResponseBuilder;
7
use Paysera\Bundle\ApiBundle\Service\RestRequestHelper;
8
use Paysera\Component\Normalization\CoreNormalizer;
9
use Psr\Log\LogLevel;
10
use Psr\Log\NullLogger;
11
use Symfony\Component\HttpFoundation\Response;
12
use Symfony\Component\HttpKernel\Event\ExceptionEvent;
13
use Symfony\Component\HttpKernel\Event\GetResponseForExceptionEvent;
14
use Psr\Log\LoggerInterface;
15
use Exception;
16
use Paysera\Bundle\ApiBundle\Service\ErrorBuilderInterface;
17
18
/**
19
 * @internal
20
 */
21
class RestExceptionListener
22
{
23
    private $requestHelper;
24
    private $errorBuilder;
25
    private $coreNormalizer;
26
    private $responseBuilder;
27
    private $logger;
28
29 101
    public function __construct(
30
        RestRequestHelper $requestHelper,
31
        ErrorBuilderInterface $errorBuilder,
32
        CoreNormalizer $coreNormalizer,
33
        ResponseBuilder $responseBuilder,
34
        LoggerInterface $logger = null
35
    ) {
36 101
        $this->requestHelper = $requestHelper;
37 101
        $this->errorBuilder = $errorBuilder;
38 101
        $this->coreNormalizer = $coreNormalizer;
39 101
        $this->responseBuilder = $responseBuilder;
40 101
        $this->logger = $logger ?? new NullLogger();
41 101
    }
42
43
    /**
44
     * Ran on kernel.exception event
45
     *
46
     * Both events are typecasted as one is deprecated from 4.3, but another not available before this version
47
     * @param GetResponseForExceptionEvent|ExceptionEvent $event
48
     * @throws Exception
49
     */
50 41
    public function onKernelException($event)
51
    {
52 41
        $request = $event->getRequest();
53
54 41
        if (!$this->requestHelper->isRestRequest($request)) {
55 1
            return;
56
        }
57
58 40
        $exception = $event->getException();
0 ignored issues
show
Deprecated Code introduced by
The method Symfony\Component\HttpKe...onEvent::getException() has been deprecated with message: since Symfony 4.4, use getThrowable instead

This method has been deprecated. The supplier of the class has supplied an explanatory message.

The explanatory message should give you some clue as to whether and when the method will be removed from the class and what other method or class to use instead.

Loading history...
59 40
        $error = $this->errorBuilder->createErrorFromException($exception);
60 40
        $normalizedError = $this->coreNormalizer->normalize($error);
61
62 40
        $response = $this->responseBuilder->buildResponse(
63 40
            $normalizedError,
64 40
            $error->getStatusCode() ?? Response::HTTP_BAD_REQUEST
65
        );
66
67 40
        $this->logException($response, $exception);
68
69 40
        $event->setResponse($response);
70 40
    }
71
72 40
    private function logException(Response $response, Exception $exception)
73
    {
74 40
        if ($response->getStatusCode() >= 500) {
75 2
            $level = LogLevel::ERROR;
76 38
        } elseif ($response->getStatusCode() === 404) {
77 4
            $level = LogLevel::NOTICE;
78
        } else {
79 34
            $level = LogLevel::WARNING;
80
        }
81
82 40
        $this->logger->debug('Setting error response', [$response->getContent()]);
83 40
        $this->logger->log($level, $exception->getMessage(), ['exception' => $exception]);
84 40
    }
85
}
86