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

api-platform / core / 14954769666

11 May 2025 10:14AM UTC coverage: 0.0% (-8.5%) from 8.457%
14954769666

Pull #7135

github

web-flow
Merge bf21e0bc7 into 4dd0cdfc4
Pull Request #7135: fix(symfony,laravel): InvalidUriVariableException status code (e400)

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

11040 existing lines in 370 files now uncovered.

0 of 48303 relevant lines covered (0.0%)

0.0 hits per line

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

0.0
/src/Doctrine/Common/Filter/ExistsFilterTrait.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\Doctrine\Common\Filter;
15

16
use ApiPlatform\Doctrine\Common\PropertyHelperTrait;
17
use ApiPlatform\Metadata\Exception\InvalidArgumentException;
18
use Psr\Log\LoggerInterface;
19

20
/**
21
 * Trait for filtering the collection by whether a property value exists or not.
22
 *
23
 * @author Teoh Han Hui <teohhanhui@gmail.com>
24
 * @author Alan Poulain <contact@alanpoulain.eu>
25
 */
26
trait ExistsFilterTrait
27
{
28
    use PropertyHelperTrait;
29

30
    /**
31
     * @var string Keyword used to retrieve the value
32
     */
33
    private readonly string $existsParameterName;
34

35
    /**
36
     * {@inheritdoc}
37
     */
38
    public function getDescription(string $resourceClass): array
39
    {
UNCOV
40
        $description = [];
×
41

UNCOV
42
        $properties = $this->getProperties();
×
UNCOV
43
        if (null === $properties) {
×
UNCOV
44
            $properties = array_fill_keys($this->getClassMetadata($resourceClass)->getFieldNames(), null);
×
45
        }
46

UNCOV
47
        foreach ($properties as $property => $unused) {
×
UNCOV
48
            if (!$this->isPropertyMapped($property, $resourceClass, true) || !$this->isNullableField($property, $resourceClass)) {
×
UNCOV
49
                continue;
×
50
            }
UNCOV
51
            $propertyName = $this->normalizePropertyName($property);
×
UNCOV
52
            $description[\sprintf('%s[%s]', $this->existsParameterName, $propertyName)] = [
×
UNCOV
53
                'property' => $propertyName,
×
UNCOV
54
                'type' => 'bool',
×
UNCOV
55
                'required' => false,
×
UNCOV
56
            ];
×
57
        }
58

UNCOV
59
        return $description;
×
60
    }
61

62
    /**
63
     * Determines whether the given property refers to a nullable field.
64
     */
65
    abstract protected function isNullableField(string $property, string $resourceClass): bool;
66

67
    abstract protected function getProperties(): ?array;
68

69
    abstract protected function getLogger(): LoggerInterface;
70

71
    abstract protected function normalizePropertyName(string $property): string;
72

73
    private function normalizeValue($value, string $property): ?bool
74
    {
UNCOV
75
        if (\in_array($value, [true, 'true', '1', '', null], true)) {
×
UNCOV
76
            return true;
×
77
        }
78

UNCOV
79
        if (\in_array($value, [false, 'false', '0'], true)) {
×
UNCOV
80
            return false;
×
81
        }
82

83
        $this->getLogger()->notice('Invalid filter ignored', [
×
84
            'exception' => new InvalidArgumentException(\sprintf('Invalid value for "%s[%s]", expected one of ( "%s" )', $this->existsParameterName, $property, implode('" | "', [
×
85
                'true',
×
86
                'false',
×
87
                '1',
×
88
                '0',
×
89
            ]))),
×
90
        ]);
×
91

92
        return null;
×
93
    }
94
}
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