\Zend\DiactorosRequestTrait

Trait with common request behaviors.

Server and client-side requests differ slightly in how the Host header is handled; on client-side, it should be calculated on-the-fly from the composed URI (if present), while on server-side, it will be calculated from the environment. As such, this trait exists to provide the common code between both client-side and server-side requests, and each can then use the headers functionality required by their implementations.

Summary

Methods
Properties
Constants
getRequestTarget()
withRequestTarget()
getMethod()
withMethod()
getUri()
withUri()
No public properties found
No constants found
No protected methods found
No protected properties found
N/A
initialize()
createUri()
validateMethod()
getHostFromUri()
$method
$requestTarget
$uri
N/A

Properties

$method

$method : string

Type

string

$requestTarget

$requestTarget : null|string

The request-target, if it has been provided or calculated.

Type

null|string

Methods

getRequestTarget()

getRequestTarget() : string

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 "/".

Returns

string

withRequestTarget()

withRequestTarget(mixed  $requestTarget) : static

Create a new instance with a 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 a new instance that has the changed request target.

Parameters

mixed $requestTarget

Throws

\InvalidArgumentException

if the request target is invalid.

Returns

static

getMethod()

getMethod() : string

Retrieves the HTTP method of the request.

Returns

string —

Returns the request method.

withMethod()

withMethod(string  $method) : static

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.

Parameters

string $method

Case-insensitive method.

Throws

\InvalidArgumentException

for invalid HTTP methods.

Returns

static

getUri()

getUri() : \Psr\Http\Message\UriInterface

Retrieves the URI instance.

This method MUST return a UriInterface instance.

Returns

\Psr\Http\Message\UriInterface

Returns a UriInterface instance representing the URI of the request, if any.

withUri()

withUri(\Psr\Http\Message\UriInterface  $uri, boolean  $preserveHost = false) : static

Returns an instance with the provided URI.

This method will 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 will 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, the returned request will not update the Host header of the returned message -- even if the message contains no Host header. This means that a call to getHeader('Host') on the original request MUST equal the return value of a call to getHeader('Host') on 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.

Parameters

\Psr\Http\Message\UriInterface $uri

New request URI to use.

boolean $preserveHost

Preserve the original state of the Host header.

Returns

static

initialize()

initialize(null|string|\Psr\Http\Message\UriInterface  $uri = null, null|string  $method = null, string|resource|\Psr\Http\Message\StreamInterface  $body = 'php://memory', array  $headers = array()) 

Initialize request state.

Used by constructors.

Parameters

null|string|\Psr\Http\Message\UriInterface $uri

URI for the request, if any.

null|string $method

HTTP method for the request, if any.

string|resource|\Psr\Http\Message\StreamInterface $body

Message body, if any.

array $headers

Headers for the message, if any.

Throws

\InvalidArgumentException

for any invalid value.

createUri()

createUri(null|string|\Psr\Http\Message\UriInterface  $uri) : \Psr\Http\Message\UriInterface

Create and return a URI instance.

If $uri is a already a UriInterface instance, returns it.

If $uri is a string, passes it to the Uri constructor to return an instance.

If $uri is null, creates and returns an emptyUri` instance.

Otherwise, it raises an exception.

Parameters

null|string|\Psr\Http\Message\UriInterface $uri

Throws

\InvalidArgumentException

Returns

\Psr\Http\Message\UriInterface

validateMethod()

validateMethod(null|string  $method) 

Validate the HTTP method

Parameters

null|string $method

Throws

\InvalidArgumentException

on invalid HTTP method.

getHostFromUri()

getHostFromUri() : string

Retrieve the host from the URI instance

Returns

string