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

  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\Metadata\CollectionOperationInterface;
  14. use ApiPlatform\Metadata\Resource\Factory\ResourceMetadataCollectionFactoryInterface;
  15. use ApiPlatform\Util\OperationRequestInitiatorTrait;
  16. use ApiPlatform\Util\RequestAttributesExtractor;
  17. use ApiPlatform\Util\RequestParser;
  18. use Symfony\Component\HttpKernel\Event\RequestEvent;
  19. /**
  20.  * Validates query parameters depending on filter description.
  21.  *
  22.  * @author Julien Deniau <julien.deniau@mapado.com>
  23.  */
  24. final class QueryParameterValidateListener
  25. {
  26.     use OperationRequestInitiatorTrait;
  27.     public const OPERATION_ATTRIBUTE_KEY 'query_parameter_validate';
  28.     public function __construct(private readonly QueryParameterValidator $queryParameterValidator, ?ResourceMetadataCollectionFactoryInterface $resourceMetadataCollectionFactory null)
  29.     {
  30.         $this->resourceMetadataCollectionFactory $resourceMetadataCollectionFactory;
  31.     }
  32.     public function onKernelRequest(RequestEvent $event): void
  33.     {
  34.         $request $event->getRequest();
  35.         if (
  36.             !$request->isMethodSafe()
  37.             || !($attributes RequestAttributesExtractor::extractAttributes($request))
  38.             || 'GET' !== $request->getMethod()
  39.         ) {
  40.             return;
  41.         }
  42.         $operation $this->initializeOperation($request);
  43.         if (!($operation?->getQueryParameterValidationEnabled() ?? true) || !$operation instanceof CollectionOperationInterface) {
  44.             return;
  45.         }
  46.         $queryString RequestParser::getQueryString($request);
  47.         $queryParameters $queryString RequestParser::parseRequestParams($queryString) : [];
  48.         $this->queryParameterValidator->validateFilters($attributes['resource_class'], $operation->getFilters() ?? [], $queryParameters);
  49.     }
  50. }