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

Open in your IDE?
  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\Odm\State\Options as ODMOptions;
  14. use ApiPlatform\Doctrine\Orm\State\Options;
  15. use ApiPlatform\Metadata\CollectionOperationInterface;
  16. use ApiPlatform\Metadata\Resource\Factory\ResourceMetadataCollectionFactoryInterface;
  17. use ApiPlatform\State\Util\OperationRequestInitiatorTrait;
  18. use ApiPlatform\State\Util\RequestParser;
  19. use ApiPlatform\Symfony\Util\RequestAttributesExtractor;
  20. use Symfony\Component\HttpKernel\Event\RequestEvent;
  21. /**
  22.  * Validates query parameters depending on filter description.
  23.  *
  24.  * @author Julien Deniau <julien.deniau@mapado.com>
  25.  */
  26. final class QueryParameterValidateListener
  27. {
  28.     use OperationRequestInitiatorTrait;
  29.     public const OPERATION_ATTRIBUTE_KEY 'query_parameter_validate';
  30.     public function __construct(private readonly QueryParameterValidator $queryParameterValidator, ?ResourceMetadataCollectionFactoryInterface $resourceMetadataCollectionFactory null)
  31.     {
  32.         $this->resourceMetadataCollectionFactory $resourceMetadataCollectionFactory;
  33.     }
  34.     public function onKernelRequest(RequestEvent $event): void
  35.     {
  36.         $request $event->getRequest();
  37.         if (
  38.             !$request->isMethodSafe()
  39.             || !($attributes RequestAttributesExtractor::extractAttributes($request))
  40.             || 'GET' !== $request->getMethod()
  41.             || $request->attributes->get('_api_platform_disable_listeners')
  42.         ) {
  43.             return;
  44.         }
  45.         $operation $this->initializeOperation($request);
  46.         if ('api_platform.symfony.main_controller' === $operation?->getController()) {
  47.             return;
  48.         }
  49.         if (!($operation?->getQueryParameterValidationEnabled() ?? true) || !$operation instanceof CollectionOperationInterface) {
  50.             return;
  51.         }
  52.         $queryString RequestParser::getQueryString($request);
  53.         $queryParameters $queryString RequestParser::parseRequestParams($queryString) : [];
  54.         $class $attributes['resource_class'];
  55.         if ($options $operation->getStateOptions()) {
  56.             if ($options instanceof Options && $options->getEntityClass()) {
  57.                 $class $options->getEntityClass();
  58.             }
  59.             if ($options instanceof ODMOptions && $options->getDocumentClass()) {
  60.                 $class $options->getDocumentClass();
  61.             }
  62.         }
  63.         $this->queryParameterValidator->validateFilters($class$operation->getFilters() ?? [], $queryParameters);
  64.     }
  65. }