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

api-platform / core / 11176269767

04 Oct 2024 08:02AM UTC coverage: 7.725% (+0.3%) from 7.441%
11176269767

push

github

soyuka
chore: remove useless require-dev

12744 of 164973 relevant lines covered (7.72%)

27.04 hits per line

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

85.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
    {
26
        $resourceClass = $operation->getClass();
48✔
27
        if (!$resourceClass || !is_a($resourceClass, \BackedEnum::class, true)) {
48✔
28
            throw new RuntimeException('This resource is not an enum');
×
29
        }
30

31
        if ($operation instanceof CollectionOperationInterface) {
48✔
32
            return $resourceClass::cases();
21✔
33
        }
34

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

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

44
        throw new NotFoundHttpException('Not Found');
6✔
45
    }
46

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

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

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

67
        return $enum;
27✔
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

© 2026 Coveralls, Inc