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

api-platform / core / 15133993414

20 May 2025 09:30AM UTC coverage: 26.313% (-1.2%) from 27.493%
15133993414

Pull #7161

github

web-flow
Merge e2c03d45f into 5459ba375
Pull Request #7161: fix(metadata): infer parameter string type from schema

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

11019 existing lines in 363 files now uncovered.

12898 of 49018 relevant lines covered (26.31%)

34.33 hits per line

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

97.3
/src/Symfony/Security/State/AccessCheckerProvider.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\Security\State;
15

16
use ApiPlatform\Metadata\Exception\RuntimeException;
17
use ApiPlatform\Metadata\GraphQl\Operation as GraphQlOperation;
18
use ApiPlatform\Metadata\GraphQl\QueryCollection;
19
use ApiPlatform\Metadata\HttpOperation;
20
use ApiPlatform\Metadata\Operation;
21
use ApiPlatform\State\ProviderInterface;
22
use ApiPlatform\Symfony\Security\Exception\AccessDeniedException;
23
use ApiPlatform\Symfony\Security\ResourceAccessCheckerInterface;
24
use Symfony\Component\HttpKernel\Exception\AccessDeniedHttpException;
25

26
/**
27
 * Allows access based on the ApiPlatform\Symfony\Security\ResourceAccessCheckerInterface.
28
 * This implementation covers GraphQl and HTTP.
29
 *
30
 * @see ResourceAccessCheckerInterface
31
 */
32
final class AccessCheckerProvider implements ProviderInterface
33
{
34
    public function __construct(private readonly ProviderInterface $decorated, private readonly ResourceAccessCheckerInterface $resourceAccessChecker, private readonly ?string $event = null)
35
    {
UNCOV
36
    }
950✔
37

38
    public function provide(Operation $operation, array $uriVariables = [], array $context = []): object|array|null
39
    {
UNCOV
40
        switch ($this->event) {
927✔
UNCOV
41
            case 'post_denormalize':
927✔
UNCOV
42
                $isGranted = $operation->getSecurityPostDenormalize();
923✔
UNCOV
43
                $message = $operation->getSecurityPostDenormalizeMessage();
923✔
UNCOV
44
                break;
923✔
UNCOV
45
            case 'post_validate':
926✔
UNCOV
46
                $isGranted = $operation->getSecurityPostValidation();
923✔
UNCOV
47
                $message = $operation->getSecurityPostValidationMessage();
923✔
UNCOV
48
                break;
923✔
UNCOV
49
            case 'after_resolver':
925✔
UNCOV
50
                if (!$operation instanceof GraphQlOperation) {
125✔
51
                    throw new RuntimeException('Not a graphql operation');
×
52
                }
53

UNCOV
54
                $isGranted = $operation->getSecurityAfterResolver();
125✔
UNCOV
55
                $message = $operation->getSecurityMessageAfterResolver();
125✔
UNCOV
56
                break;
125✔
57
            default:
UNCOV
58
                $isGranted = $operation->getSecurity();
925✔
UNCOV
59
                $message = $operation->getSecurityMessage();
925✔
60
        }
61

UNCOV
62
        $body = $this->decorated->provide($operation, $uriVariables, $context);
927✔
UNCOV
63
        if (null === $isGranted) {
923✔
UNCOV
64
            return $body;
904✔
65
        }
66

67
        // On a GraphQl QueryCollection we want to perform security stage only on the top-level query
UNCOV
68
        if ($operation instanceof QueryCollection && null !== ($context['source'] ?? null)) {
72✔
69
            return $body;
2✔
70
        }
71

UNCOV
72
        if ($operation instanceof HttpOperation) {
72✔
UNCOV
73
            $request = $context['request'] ?? null;
37✔
74

UNCOV
75
            $resourceAccessCheckerContext = [
37✔
UNCOV
76
                'object' => $body,
37✔
UNCOV
77
                'previous_object' => $request?->attributes->get('previous_data'),
37✔
UNCOV
78
                'request' => $request,
37✔
UNCOV
79
            ];
37✔
80
        } else {
UNCOV
81
            $resourceAccessCheckerContext = [
35✔
UNCOV
82
                'object' => $body,
35✔
UNCOV
83
                'previous_object' => $context['graphql_context']['previous_object'] ?? null,
35✔
UNCOV
84
            ];
35✔
85
        }
86

UNCOV
87
        if (!$this->resourceAccessChecker->isGranted($operation->getClass(), $isGranted, $resourceAccessCheckerContext)) {
72✔
UNCOV
88
            $operation instanceof GraphQlOperation ? throw new AccessDeniedHttpException($message ?? 'Access Denied.') : throw new AccessDeniedException($message ?? 'Access Denied.');
24✔
89
        }
90

UNCOV
91
        return $body;
50✔
92
    }
93
}
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