You are here

interface RequestInterface in Zircon Profile 8

Same name in this branch
  1. 8 vendor/zendframework/zend-stdlib/src/RequestInterface.php \Zend\Stdlib\RequestInterface
  2. 8 vendor/psr/http-message/src/RequestInterface.php \Psr\Http\Message\RequestInterface
Same name and namespace in other branches
  1. 8.0 vendor/psr/http-message/src/RequestInterface.php \Psr\Http\Message\RequestInterface

Representation of an outgoing, client-side request.

Per the HTTP specification, this interface includes properties for each of the following:

  • Protocol version
  • HTTP method
  • URI
  • Headers
  • Message body

During construction, implementations MUST attempt to set the Host header from a provided URI if no Host header is provided.

Requests are considered immutable; all methods that might change state MUST be implemented such that they retain the internal state of the current message and return an instance that contains the changed state.

Hierarchy

Expanded class hierarchy of RequestInterface

All classes that implement RequestInterface

28 files declare their use of RequestInterface
Client.php in vendor/guzzlehttp/guzzle/src/Client.php
ClientInterface.php in vendor/guzzlehttp/guzzle/src/ClientInterface.php
ConnectException.php in vendor/guzzlehttp/guzzle/src/Exception/ConnectException.php
CookieJar.php in vendor/guzzlehttp/guzzle/src/Cookie/CookieJar.php
CookieJarInterface.php in vendor/guzzlehttp/guzzle/src/Cookie/CookieJarInterface.php

... See full list

File

vendor/psr/http-message/src/RequestInterface.php, line 24

Namespace

Psr\Http\Message
View source
interface RequestInterface extends MessageInterface {

  /**
   * Retrieves the message's request target.
   *
   * Retrieves the message's request-target either as it will appear (for
   * clients), as it appeared at request (for servers), or as it was
   * specified for the instance (see withRequestTarget()).
   *
   * In most cases, this will be the origin-form of the composed URI,
   * unless a value was provided to the concrete implementation (see
   * withRequestTarget() below).
   *
   * If no URI is available, and no request-target has been specifically
   * provided, this method MUST return the string "/".
   *
   * @return string
   */
  public function getRequestTarget();

  /**
   * Return an instance with the specific request-target.
   *
   * If the request needs a non-origin-form request-target — e.g., for
   * specifying an absolute-form, authority-form, or asterisk-form —
   * this method may be used to create an instance with the specified
   * request-target, verbatim.
   *
   * This method MUST be implemented in such a way as to retain the
   * immutability of the message, and MUST return an instance that has the
   * changed request target.
   *
   * @link http://tools.ietf.org/html/rfc7230#section-2.7 (for the various
   *     request-target forms allowed in request messages)
   * @param mixed $requestTarget
   * @return self
   */
  public function withRequestTarget($requestTarget);

  /**
   * Retrieves the HTTP method of the request.
   *
   * @return string Returns the request method.
   */
  public function getMethod();

  /**
   * Return an instance with the provided HTTP method.
   *
   * While HTTP method names are typically all uppercase characters, HTTP
   * method names are case-sensitive and thus implementations SHOULD NOT
   * modify the given string.
   *
   * This method MUST be implemented in such a way as to retain the
   * immutability of the message, and MUST return an instance that has the
   * changed request method.
   *
   * @param string $method Case-sensitive method.
   * @return self
   * @throws \InvalidArgumentException for invalid HTTP methods.
   */
  public function withMethod($method);

  /**
   * Retrieves the URI instance.
   *
   * This method MUST return a UriInterface instance.
   *
   * @link http://tools.ietf.org/html/rfc3986#section-4.3
   * @return UriInterface Returns a UriInterface instance
   *     representing the URI of the request.
   */
  public function getUri();

  /**
   * Returns an instance with the provided URI.
   *
   * This method MUST update the Host header of the returned request by
   * default if the URI contains a host component. If the URI does not
   * contain a host component, any pre-existing Host header MUST be carried
   * over to the returned request.
   *
   * You can opt-in to preserving the original state of the Host header by
   * setting `$preserveHost` to `true`. When `$preserveHost` is set to
   * `true`, this method interacts with the Host header in the following ways:
   *
   * - If the the Host header is missing or empty, and the new URI contains
   *   a host component, this method MUST update the Host header in the returned
   *   request.
   * - If the Host header is missing or empty, and the new URI does not contain a
   *   host component, this method MUST NOT update the Host header in the returned
   *   request.
   * - If a Host header is present and non-empty, this method MUST NOT update
   *   the Host header in the returned request.
   *
   * This method MUST be implemented in such a way as to retain the
   * immutability of the message, and MUST return an instance that has the
   * new UriInterface instance.
   *
   * @link http://tools.ietf.org/html/rfc3986#section-4.3
   * @param UriInterface $uri New request URI to use.
   * @param bool $preserveHost Preserve the original state of the Host header.
   * @return self
   */
  public function withUri(UriInterface $uri, $preserveHost = false);

}

Members

Namesort descending Modifiers Type Description Overrides
MessageInterface::getBody public function Gets the body of the message. 1
MessageInterface::getHeader public function Retrieves a message header value by the given case-insensitive name. 1
MessageInterface::getHeaderLine public function Retrieves a comma-separated string of the values for a single header. 1
MessageInterface::getHeaders public function Retrieves all message header values. 1
MessageInterface::getProtocolVersion public function Retrieves the HTTP protocol version as a string. 1
MessageInterface::hasHeader public function Checks if a header exists by the given case-insensitive name. 1
MessageInterface::withAddedHeader public function Return an instance with the specified header appended with the given value. 1
MessageInterface::withBody public function Return an instance with the specified message body. 1
MessageInterface::withHeader public function Return an instance with the provided value replacing the specified header. 2
MessageInterface::withoutHeader public function Return an instance without the specified header. 1
MessageInterface::withProtocolVersion public function Return an instance with the specified HTTP protocol version. 1
RequestInterface::getMethod public function Retrieves the HTTP method of the request. 3
RequestInterface::getRequestTarget public function Retrieves the message's request target. 2
RequestInterface::getUri public function Retrieves the URI instance. 2
RequestInterface::withMethod public function Return an instance with the provided HTTP method. 3
RequestInterface::withRequestTarget public function Return an instance with the specific request-target. 2
RequestInterface::withUri public function Returns an instance with the provided URI. 2