-
Notifications
You must be signed in to change notification settings - Fork 152
Request HTTP method defaults to empty string #150
Comments
What would you consider a valid default? GET? HEAD? OPTIONS? Additionally, IIRC, somebody presented a use case for allowing a nullable
|
That is a good question, but I'm fairly sure that 90% of the web traffic is just Overall, this logic can be encapsulated in a tiny |
I've just remembered that i implemented psr-7 starting from phly/http and added a default method in the constructor ('GET') and a simple http-method filtering method (mwop would have nameed it marhallMethod). Juts to get an idea form ths code fragment //...
protected static $validMethods = [
'OPTIONS' => true,
'GET' => true,
'HEAD' => true,
'POST' => true,
'PUT' => true,
'DELETE' => true,
'TRACE' => true,
'CONNECT' => true,
'PATCH' => true,
'PROPFIND' => true,
];
/**
* Array of possible CSRF Header names
* @var array
*/
protected static $csrfHeaderNames = [
'X-CSRF-Token',
'X-CSRFToken',
'X-XSRF-TOKEN',
];
/**
* Constructor
* @param UriInterface $uri
* @param string $method
* @param array $headers
* @param Stream|resource|string $body
* @param string $protocolVersion
* @throws InvalidArgumentExceptions
*/
public function __construct(
$uri = null,
$method = 'GET',
$headers = [],
$body = 'php://temp',
$protocolVersion = '1.1'
) {
parent::__construct($protocolVersion, $headers, $body);
$this->method = $this->filterMethod($method);
// Initialize uri from constructor argument or build uri from request
// environment
if (null === $uri) {
$this->uri = new Uri('');
} else if (is_string($uri)) {
$this->uri = new Uri($uri);
} elseif($uri instanceof UriInterface) {
$this->uri = $uri;
} else {
throw new InvalidArgumentException(
'The constructor $uri must be a string, an instance of UriInterface or null'
);
}
}
//...
/**
* Validate the HTTP method
*
* @param null|string $method
* @throws InvalidArgumentException on invalid HTTP method.
*/
protected function filterMethod($method)
{
if (null === $method) {
return 'GET';
}
if (! is_string($method)) {
throw new InvalidArgumentException(
'The HTTP method must be a string'
);
}
$method = strtoupper($method);
if (! isset(static::$validMethods[$method])) {
throw new InvalidArgumentException(sprintf(
'Unsupported HTTP method "%s"',
$method
));
}
return $method;
} |
This repository has been closed and moved to laminas/laminas-diactoros; a new issue has been opened at laminas/laminas-diactoros#26. |
Discovered while digging in php-http/curl-client#14
Apparently, diactoros defaults the HTTP method when building a
new Request('http://example.com')
to''
(empty string). As far as I know, an empty string is not a valid HTTP method (not sure if that assumption is reflected in the HTTP spec), and therefore the initial state of a diactoros HTTP request is invalid, and should lead to an exception.The text was updated successfully, but these errors were encountered: