• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

api-platform / core / 14954769666

11 May 2025 10:14AM UTC coverage: 0.0% (-8.5%) from 8.457%
14954769666

Pull #7135

github

web-flow
Merge bf21e0bc7 into 4dd0cdfc4
Pull Request #7135: fix(symfony,laravel): InvalidUriVariableException status code (e400)

0 of 2 new or added lines in 2 files covered. (0.0%)

11040 existing lines in 370 files now uncovered.

0 of 48303 relevant lines covered (0.0%)

0.0 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

0.0
/src/Symfony/EventListener/ExceptionListener.php
1
<?php
2

3
/*
4
 * This file is part of the API Platform project.
5
 *
6
 * (c) Kévin Dunglas <dunglas@gmail.com>
7
 *
8
 * For the full copyright and license information, please view the LICENSE
9
 * file that was distributed with this source code.
10
 */
11

12
declare(strict_types=1);
13

14
namespace ApiPlatform\Symfony\EventListener;
15

16
use ApiPlatform\Metadata\Error;
17
use ApiPlatform\State\Util\RequestAttributesExtractor;
18
use Symfony\Component\HttpKernel\Event\ExceptionEvent;
19
use Symfony\Component\HttpKernel\EventListener\ErrorListener;
20

21
/**
22
 * Handles requests errors.
23
 *
24
 * @author Samuel ROZE <samuel.roze@gmail.com>
25
 * @author Kévin Dunglas <dunglas@gmail.com>
26
 */
27
final class ExceptionListener
28
{
29
    public function __construct(private readonly ErrorListener $errorListener, public bool $handleSymfonyErrors = false)
30
    {
UNCOV
31
    }
×
32

33
    public function onKernelException(ExceptionEvent $event): void
34
    {
UNCOV
35
        $request = $event->getRequest();
×
36

37
        // Normalize exceptions only for routes managed by API Platform
38
        if (
UNCOV
39
            false === $this->handleSymfonyErrors
×
UNCOV
40
            && !((RequestAttributesExtractor::extractAttributes($request)['respond'] ?? $request->attributes->getBoolean('_api_respond', false)) || $request->attributes->getBoolean('_graphql', false))
×
41
        ) {
42
            return;
×
43
        }
44

45
        // Don't loop on errors leave it to Symfony as we could not handle this properly
UNCOV
46
        if (($operation = $request->attributes->get('_api_operation')) && $operation instanceof Error) {
×
47
            return;
×
48
        }
49

UNCOV
50
        $this->errorListener->onKernelException($event);
×
51
    }
52
}
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2025 Coveralls, Inc