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

api-platform / core / 14131982970

28 Mar 2025 03:08PM UTC coverage: 8.983% (+0.5%) from 8.517%
14131982970

push

github

soyuka
docs: changelog 4.1.4

13389 of 149040 relevant lines covered (8.98%)

24.16 hits per line

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

92.0
/src/Symfony/Security/State/LinkAccessCheckerProvider.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\HttpOperation;
17
use ApiPlatform\Metadata\Link;
18
use ApiPlatform\Metadata\Operation;
19
use ApiPlatform\State\ProviderInterface;
20
use ApiPlatform\Symfony\Security\Exception\AccessDeniedException;
21
use ApiPlatform\Symfony\Security\ResourceAccessCheckerInterface;
22

23
/**
24
 * Checks the individual parts of the linked resource for access rights.
25
 *
26
 * @experimental
27
 */
28
final class LinkAccessCheckerProvider implements ProviderInterface
29
{
30
    public function __construct(
31
        private readonly ProviderInterface $decorated,
32
        private readonly ResourceAccessCheckerInterface $resourceAccessChecker,
33
    ) {
34
    }
1,717✔
35

36
    public function provide(Operation $operation, array $uriVariables = [], array $context = []): object|array|null
37
    {
38
        $request = ($context['request'] ?? null);
1,695✔
39

40
        $data = $this->decorated->provide($operation, $uriVariables, $context);
1,695✔
41

42
        if ($operation instanceof HttpOperation && $operation->getUriVariables()) {
1,681✔
43
            foreach ($operation->getUriVariables() as $uriVariable) {
683✔
44
                if (!$uriVariable instanceof Link || !$uriVariable->getSecurity()) {
683✔
45
                    continue;
669✔
46
                }
47

48
                $targetResource = $uriVariable->getFromClass() ?? $uriVariable->getToClass();
22✔
49

50
                if (!$targetResource) {
22✔
51
                    continue;
×
52
                }
53

54
                $propertyName = $uriVariable->getToProperty() ?? $uriVariable->getFromProperty();
22✔
55
                $securityObjectName = $uriVariable->getSecurityObjectName();
22✔
56

57
                if (!$securityObjectName) {
22✔
58
                    $securityObjectName = $propertyName;
14✔
59
                }
60

61
                if (!$securityObjectName) {
22✔
62
                    continue;
×
63
                }
64

65
                $resourceAccessCheckerContext = [
22✔
66
                    'object' => $data,
22✔
67
                    'previous_object' => $request?->attributes->get('previous_data'),
22✔
68
                    $securityObjectName => $request?->attributes->get($securityObjectName),
22✔
69
                    'request' => $request,
22✔
70
                ];
22✔
71

72
                if (!$this->resourceAccessChecker->isGranted($targetResource, $uriVariable->getSecurity(), $resourceAccessCheckerContext)) {
22✔
73
                    throw new AccessDeniedException($uriVariable->getSecurityMessage() ?? 'Access Denied.');
12✔
74
                }
75
            }
76
        }
77

78
        return $data;
1,677✔
79
    }
80
}
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

© 2026 Coveralls, Inc