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

api-platform / core / 15040977736

15 May 2025 09:02AM UTC coverage: 21.754% (+13.3%) from 8.423%
15040977736

Pull #6960

github

web-flow
Merge 7a7a13526 into 1862d03b7
Pull Request #6960: feat(json-schema): mutualize json schema between formats

320 of 460 new or added lines in 24 files covered. (69.57%)

1863 existing lines in 109 files now uncovered.

11069 of 50882 relevant lines covered (21.75%)

29.49 hits per line

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

0.0
/src/State/Provider/BackedEnumProvider.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\State\Provider;
15

16
use ApiPlatform\Metadata\CollectionOperationInterface;
17
use ApiPlatform\Metadata\Exception\RuntimeException;
18
use ApiPlatform\Metadata\Operation;
19
use ApiPlatform\State\ProviderInterface;
20
use Symfony\Component\HttpKernel\Exception\NotFoundHttpException;
21

22
final class BackedEnumProvider implements ProviderInterface
23
{
24
    public function provide(Operation $operation, array $uriVariables = [], array $context = []): object|array|null
25
    {
UNCOV
26
        $resourceClass = $operation->getClass();
×
UNCOV
27
        if (!$resourceClass || !is_a($resourceClass, \BackedEnum::class, true)) {
×
28
            throw new RuntimeException('This resource is not an enum');
×
29
        }
30

UNCOV
31
        if ($operation instanceof CollectionOperationInterface) {
×
UNCOV
32
            return $resourceClass::cases();
×
33
        }
34

UNCOV
35
        $id = $uriVariables['id'] ?? null;
×
UNCOV
36
        if (null === $id) {
×
37
            throw new NotFoundHttpException('Not Found');
×
38
        }
39

UNCOV
40
        if ($enum = $this->resolveEnum($resourceClass, $id)) {
×
UNCOV
41
            return $enum;
×
42
        }
43

UNCOV
44
        throw new NotFoundHttpException('Not Found');
×
45
    }
46

47
    /**
48
     * @param class-string $resourceClass
49
     */
50
    private function resolveEnum(string $resourceClass, string|int $id): ?\BackedEnum
51
    {
UNCOV
52
        $reflectEnum = new \ReflectionEnum($resourceClass);
×
UNCOV
53
        $type = (string) $reflectEnum->getBackingType();
×
54

UNCOV
55
        if ('int' === $type) {
×
UNCOV
56
            if (!is_numeric($id)) {
×
57
                return null;
×
58
            }
UNCOV
59
            $enum = $resourceClass::tryFrom((int) $id);
×
60
        } else {
UNCOV
61
            $enum = $resourceClass::tryFrom($id);
×
62
        }
63

64
        // @deprecated enums will be indexable only by value in 4.0
UNCOV
65
        $enum ??= array_reduce($resourceClass::cases(), static fn ($c, \BackedEnum $case) => $id === $case->name ? $case : $c, null);
×
66

UNCOV
67
        return $enum;
×
68
    }
69
}
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