ICanBoogie/HTTP v2.6.0
  • Namespace
  • Class

Namespaces

  • ICanBoogie
    • Exception
    • HTTP
      • Headers
      • Request
      • RequestDispatcher

Classes

  • CallableDispatcher
  • DispatcherProvider
  • File
  • FileInfo
  • FileList
  • FileResponse
  • Headers
  • ProvideDispatcher
  • RedirectResponse
  • Request
  • RequestDispatcher
  • RequestOptionsMapper
  • RequestRange
  • Response
  • Status
  • WeightedDispatcher

Interfaces

  • Dispatcher
  • Exception
  • FileOptions
  • RequestMethods
  • RequestOptions
  • ResponseStatus
  • SecurityError

Exceptions

  • AuthenticationRequired
  • ClientError
  • DispatcherNotDefined
  • DispatcherProviderNotDefined
  • ForceRedirect
  • MethodNotSupported
  • NotFound
  • PermissionRequired
  • ServerError
  • ServiceUnavailable
  • StatusCodeNotValid

Functions

  • dispatch
  • get_dispatcher
  • get_initial_request
 1  2  3  4  5  6  7  8  9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 
<?php

/*
 * This file is part of the ICanBoogie package.
 *
 * (c) Olivier Laviale <olivier.laviale@gmail.com>
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace ICanBoogie\HTTP;

/**
 * A HTTP response doing a redirect.
 */
class RedirectResponse extends Response
{
    /**
     * Initializes the `Location` header.
     *
     * @param string $url URL to redirect to.
     * @param int $status Status code (default to {@link Status::FOUND}).
     * @param array $headers Additional headers.
     *
     * @throws \InvalidArgumentException if the provided status code is not a redirect.
     */
    public function __construct($url, $status = Status::FOUND, array $headers = [])
    {
        parent::__construct
        (
            function(Response $response) {

                $location = $response->location;
                $title = \ICanBoogie\escape($location);

                echo <<<EOT
<!DOCTYPE html>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <meta http-equiv="refresh" content="1;url={$location}" />

    <title>Redirecting to {$title}</title>
</head>
<body>
    Redirecting to <a href="{$location}">{$title}</a>.
</body>
</html>
EOT
; // @codeCoverageIgnore
            },

            $status, [ 'Location' => $url ] + $headers
        );

        if (!$this->status->is_redirect)
        {
            throw new StatusCodeNotValid($this->status->code, "The HTTP status code is not a redirect: {$status}.");
        }
    }
}
ICanBoogie/HTTP v2.6.0 API documentation generated by ApiGen