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

api-platform / core / 9835534319

08 Jul 2024 07:42AM UTC coverage: 64.804% (-0.007%) from 64.811%
9835534319

push

github

soyuka
Merge 3.3

11 of 14 new or added lines in 5 files covered. (78.57%)

182 existing lines in 29 files now uncovered.

11458 of 17681 relevant lines covered (64.8%)

67.53 hits per line

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

71.43
/src/GraphQl/Resolver/Stage/SecurityPostDenormalizeStage.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\GraphQl\Resolver\Stage;
15

16
use ApiPlatform\Metadata\GraphQl\Operation;
17
use ApiPlatform\Metadata\ResourceAccessCheckerInterface;
18
use ApiPlatform\Symfony\Security\ResourceAccessCheckerInterface as LegacyResourceAccessCheckerInterface;
19
use Symfony\Component\HttpKernel\Exception\AccessDeniedHttpException;
20

21
/**
22
 * Security post denormalize stage of GraphQL resolvers.
23
 *
24
 * @author Vincent Chalamon <vincentchalamon@gmail.com>
25
 */
26
final class SecurityPostDenormalizeStage implements SecurityPostDenormalizeStageInterface
27
{
28
    /**
29
     * @var LegacyResourceAccessCheckerInterface|ResourceAccessCheckerInterface
30
     */
31
    private $resourceAccessChecker;
32

33
    /**
34
     * @param LegacyResourceAccessCheckerInterface|ResourceAccessCheckerInterface|null $resourceAccessChecker
35
     */
36
    public function __construct($resourceAccessChecker)
37
    {
UNCOV
38
        $this->resourceAccessChecker = $resourceAccessChecker;
8✔
39
    }
40

41
    /**
42
     * {@inheritdoc}
43
     */
44
    public function __invoke(string $resourceClass, Operation $operation, array $context): void
45
    {
UNCOV
46
        $isGranted = $operation->getSecurityPostDenormalize();
8✔
47

UNCOV
48
        if (null !== $isGranted && null === $this->resourceAccessChecker) {
8✔
49
            throw new \LogicException('Cannot check security expression when SecurityBundle is not installed. Try running "composer require symfony/security-bundle".');
×
50
        }
51

UNCOV
52
        if (null === $isGranted || $this->resourceAccessChecker->isGranted($resourceClass, (string) $isGranted, $context['extra_variables'])) {
8✔
UNCOV
53
            return;
8✔
54
        }
55

56
        throw new AccessDeniedHttpException($operation->getSecurityPostDenormalizeMessage() ?? 'Access Denied.');
×
57
    }
58
}
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