Psr7RequestValueResolver.php

Same filename in other branches
  1. 9 core/lib/Drupal/Core/Controller/ArgumentResolver/Psr7RequestValueResolver.php
  2. 8.9.x core/lib/Drupal/Core/Controller/ArgumentResolver/Psr7RequestValueResolver.php
  3. 11.x core/lib/Drupal/Core/Controller/ArgumentResolver/Psr7RequestValueResolver.php

Namespace

Drupal\Core\Controller\ArgumentResolver

File

core/lib/Drupal/Core/Controller/ArgumentResolver/Psr7RequestValueResolver.php

View source
<?php

namespace Drupal\Core\Controller\ArgumentResolver;

use Psr\Http\Message\ServerRequestInterface;
use Symfony\Bridge\PsrHttpMessage\HttpMessageFactoryInterface;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpKernel\Controller\ValueResolverInterface;
use Symfony\Component\HttpKernel\ControllerMetadata\ArgumentMetadata;

/**
 * Yields a PSR7 request object based on the request object passed along.
 */
final class Psr7RequestValueResolver implements ValueResolverInterface {
    
    /**
     * The PSR-7 converter.
     *
     * @var \Symfony\Bridge\PsrHttpMessage\HttpMessageFactoryInterface
     */
    protected $httpMessageFactory;
    
    /**
     * Constructs a new ControllerResolver.
     *
     * @param \Symfony\Bridge\PsrHttpMessage\HttpMessageFactoryInterface $http_message_factory
     *   The PSR-7 converter.
     */
    public function __construct(HttpMessageFactoryInterface $http_message_factory) {
        $this->httpMessageFactory = $http_message_factory;
    }
    
    /**
     * {@inheritdoc}
     *
     * @deprecated in drupal:10.2.0 and is removed from drupal:11.0.0.
     *    There is no replacement.
     *
     * @see https://www.drupal.org/node/3383585
     */
    public function supports(Request $request, ArgumentMetadata $argument) : bool {
        @trigger_error(__METHOD__ . ' is deprecated in drupal:10.2.0 and is removed from drupal:11.0.0. There is no replacement. See https://www.drupal.org/node/3383585', E_USER_DEPRECATED);
        return $argument->getType() == ServerRequestInterface::class;
    }
    
    /**
     * {@inheritdoc}
     */
    public function resolve(Request $request, ArgumentMetadata $argument) : array {
        return $argument->getType() === ServerRequestInterface::class ? [
            $this->httpMessageFactory
                ->createRequest($request),
        ] : [];
    }

}

Classes

Title Deprecated Summary
Psr7RequestValueResolver Yields a PSR7 request object based on the request object passed along.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.