vendor/api-platform/core/src/Symfony/EventListener/QueryParameterValidateListener.php line 41

  1. <?php
  2. /*
  3.  * This file is part of the API Platform project.
  4.  *
  5.  * (c) Kévin Dunglas <dunglas@gmail.com>
  6.  *
  7.  * For the full copyright and license information, please view the LICENSE
  8.  * file that was distributed with this source code.
  9.  */
  10. declare(strict_types=1);
  11. namespace ApiPlatform\Symfony\EventListener;
  12. use ApiPlatform\Api\QueryParameterValidator\QueryParameterValidator;
  13. use ApiPlatform\Doctrine\Orm\State\Options;
  14. use ApiPlatform\Metadata\CollectionOperationInterface;
  15. use ApiPlatform\Metadata\Resource\Factory\ResourceMetadataCollectionFactoryInterface;
  16. use ApiPlatform\Util\OperationRequestInitiatorTrait;
  17. use ApiPlatform\Util\RequestAttributesExtractor;
  18. use ApiPlatform\Util\RequestParser;
  19. use Symfony\Component\HttpKernel\Event\RequestEvent;
  20. /**
  21.  * Validates query parameters depending on filter description.
  22.  *
  23.  * @author Julien Deniau <julien.deniau@mapado.com>
  24.  */
  25. final class QueryParameterValidateListener
  26. {
  27.     use OperationRequestInitiatorTrait;
  28.     public const OPERATION_ATTRIBUTE_KEY 'query_parameter_validate';
  29.     public function __construct(private readonly QueryParameterValidator $queryParameterValidator, ?ResourceMetadataCollectionFactoryInterface $resourceMetadataCollectionFactory null)
  30.     {
  31.         $this->resourceMetadataCollectionFactory $resourceMetadataCollectionFactory;
  32.     }
  33.     public function onKernelRequest(RequestEvent $event): void
  34.     {
  35.         $request $event->getRequest();
  36.         if (
  37.             !$request->isMethodSafe()
  38.             || !($attributes RequestAttributesExtractor::extractAttributes($request))
  39.             || 'GET' !== $request->getMethod()
  40.         ) {
  41.             return;
  42.         }
  43.         $operation $this->initializeOperation($request);
  44.         if (!($operation?->getQueryParameterValidationEnabled() ?? true) || !$operation instanceof CollectionOperationInterface) {
  45.             return;
  46.         }
  47.         $queryString RequestParser::getQueryString($request);
  48.         $queryParameters $queryString RequestParser::parseRequestParams($queryString) : [];
  49.         $class $attributes['resource_class'];
  50.         if (($options $operation->getStateOptions()) && $options instanceof Options && $options->getEntityClass()) {
  51.             $class $options->getEntityClass();
  52.         }
  53.         $this->queryParameterValidator->validateFilters($class$operation->getFilters() ?? [], $queryParameters);
  54.     }
  55. }