vendor/symfony/framework-bundle/Controller/RedirectController.php line 99

Open in your IDE?
  1. <?php
  2. /*
  3.  * This file is part of the Symfony package.
  4.  *
  5.  * (c) Fabien Potencier <fabien@symfony.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. namespace Symfony\Bundle\FrameworkBundle\Controller;
  11. use Symfony\Component\HttpFoundation\RedirectResponse;
  12. use Symfony\Component\HttpFoundation\Request;
  13. use Symfony\Component\HttpFoundation\Response;
  14. use Symfony\Component\HttpKernel\Exception\HttpException;
  15. use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
  16. /**
  17.  * Redirects a request to another URL.
  18.  *
  19.  * @author Fabien Potencier <fabien@symfony.com>
  20.  *
  21.  * @final
  22.  */
  23. class RedirectController {
  24.     private $router;
  25.     private $httpPort;
  26.     private $httpsPort;
  27.     public function __construct(UrlGeneratorInterface $router nullint $httpPort nullint $httpsPort null) {
  28.         $this->router $router;
  29.         $this->httpPort $httpPort;
  30.         $this->httpsPort $httpsPort;
  31.     }
  32.     /**
  33.      * Redirects to another route with the given name.
  34.      *
  35.      * The response status code is 302 if the permanent parameter is false (default),
  36.      * and 301 if the redirection is permanent.
  37.      *
  38.      * In case the route name is empty, the status code will be 404 when permanent is false
  39.      * and 410 otherwise.
  40.      *
  41.      * @param Request    $request           The request instance
  42.      * @param string     $route             The route name to redirect to
  43.      * @param bool       $permanent         Whether the redirection is permanent
  44.      * @param bool|array $ignoreAttributes  Whether to ignore attributes or an array of attributes to ignore
  45.      * @param bool       $keepRequestMethod Whether redirect action should keep HTTP request method
  46.      *
  47.      * @throws HttpException In case the route name is empty
  48.      */
  49.     public function redirectAction(Request $requeststring $routebool $permanent false$ignoreAttributes falsebool $keepRequestMethod falsebool $keepQueryParams false): Response {
  50.         if ('' == $route) {
  51.             throw new HttpException($permanent 410 404);
  52.         }
  53.         $attributes = [];
  54.         if (false === $ignoreAttributes || \is_array($ignoreAttributes)) {
  55.             $attributes $request->attributes->get('_route_params');
  56.             $attributes $keepQueryParams array_merge($request->query->all(), $attributes) : $attributes;
  57.             unset($attributes['route'], $attributes['permanent'], $attributes['ignoreAttributes'], $attributes['keepRequestMethod'], $attributes['keepQueryParams']);
  58.             if ($ignoreAttributes) {
  59.                 $attributes array_diff_key($attributesarray_flip($ignoreAttributes));
  60.             }
  61.         }
  62.         if ($keepRequestMethod) {
  63.             $statusCode $permanent 308 307;
  64.         } else {
  65.             $statusCode $permanent 301 302;
  66.         }
  67.         return new RedirectResponse($this->router->generate($route$attributesUrlGeneratorInterface::ABSOLUTE_URL), $statusCode);
  68.     }
  69.     /**
  70.      * Redirects to a URL.
  71.      *
  72.      * The response status code is 302 if the permanent parameter is false (default),
  73.      * and 301 if the redirection is permanent.
  74.      *
  75.      * In case the path is empty, the status code will be 404 when permanent is false
  76.      * and 410 otherwise.
  77.      *
  78.      * @param Request     $request           The request instance
  79.      * @param string      $path              The absolute path or URL to redirect to
  80.      * @param bool        $permanent         Whether the redirect is permanent or not
  81.      * @param string|null $scheme            The URL scheme (null to keep the current one)
  82.      * @param int|null    $httpPort          The HTTP port (null to keep the current one for the same scheme or the default configured port)
  83.      * @param int|null    $httpsPort         The HTTPS port (null to keep the current one for the same scheme or the default configured port)
  84.      * @param bool        $keepRequestMethod Whether redirect action should keep HTTP request method
  85.      *
  86.      * @throws HttpException In case the path is empty
  87.      */
  88.     public function urlRedirectAction(Request $requeststring $pathbool $permanent falsestring $scheme nullint $httpPort nullint $httpsPort nullbool $keepRequestMethod false): Response {
  89.         if ('' == $path) {
  90.             throw new HttpException($permanent 410 404);
  91.         }
  92.         if ($keepRequestMethod) {
  93.             $statusCode $permanent 308 307;
  94.         } else {
  95.             $statusCode $permanent 301 302;
  96.         }
  97.         // redirect if the path is a full URL
  98.         if (parse_url($pathPHP_URL_SCHEME)) {
  99.             return new RedirectResponse($path$statusCode);
  100.         }
  101.         if (null === $scheme) {
  102.             $scheme $request->getScheme();
  103.         }
  104.         $qs $request->getQueryString();
  105.         if ($qs) {
  106.             if (false === strpos($path'?')) {
  107.                 $qs '?' $qs;
  108.             } else {
  109.                 $qs '&' $qs;
  110.             }
  111.         }
  112.         $port '';
  113.         if ('http' === $scheme) {
  114.             if (null === $httpPort) {
  115.                 if ('http' === $request->getScheme()) {
  116.                     $httpPort $request->getPort();
  117.                 } else {
  118.                     $httpPort $this->httpPort;
  119.                 }
  120.             }
  121.             if (null !== $httpPort && 80 != $httpPort) {
  122.                 $port ":$httpPort";
  123.             }
  124.         } elseif ('https' === $scheme) {
  125.             if (null === $httpsPort) {
  126.                 if ('https' === $request->getScheme()) {
  127.                     $httpsPort $request->getPort();
  128.                 } else {
  129.                     $httpsPort $this->httpsPort;
  130.                 }
  131.             }
  132.             if (null !== $httpsPort && 443 != $httpsPort) {
  133.                 $port ":$httpsPort";
  134.             }
  135.         }
  136.         $url $scheme '://' $request->getHost() . $port $request->getBaseUrl() . $path $qs;
  137.         return new RedirectResponse($url$statusCode);
  138.     }
  139. }