mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
NEW: Add HTTPRequest::getScheme()/setScheme()
NEW: Add HTTPRequest::setIP() API: Rely on HTTPRequestBuilder to set scheme and IP These changes tidy up HTTPRequest making it a container for information and removing special logic from it. This makes it less feature-rich: it doesn’t contain trusted-proxy logic. This will be able to provided by a middleware. The new getScheme() method is designed to be closish to PSR-7’s getUri()->getScheme() equivalent. There are no more direct $_SERVER references in HTTPRequest.
This commit is contained in:
parent
4d89daac78
commit
c4d038f20d
@ -52,6 +52,20 @@ class HTTPRequest implements ArrayAccess
|
||||
*/
|
||||
protected $httpMethod;
|
||||
|
||||
/**
|
||||
* The URL scheme in lowercase: http or https
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
protected $scheme;
|
||||
|
||||
/**
|
||||
* The client IP address
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
protected $ip;
|
||||
|
||||
/**
|
||||
* Contains alls HTTP GET parameters passed into this request.
|
||||
*
|
||||
@ -146,6 +160,7 @@ class HTTPRequest implements ArrayAccess
|
||||
$this->getVars = (array) $getVars;
|
||||
$this->postVars = (array) $postVars;
|
||||
$this->body = $body;
|
||||
$this->scheme = "http";
|
||||
}
|
||||
|
||||
/**
|
||||
@ -757,35 +772,23 @@ class HTTPRequest implements ArrayAccess
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the client IP address which
|
||||
* originated this request.
|
||||
* Returns the client IP address which originated this request.
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
public function getIP()
|
||||
{
|
||||
$headerOverrideIP = null;
|
||||
if (TRUSTED_PROXY) {
|
||||
$headers = (getenv('SS_TRUSTED_PROXY_IP_HEADER')) ? array(getenv('SS_TRUSTED_PROXY_IP_HEADER')) : null;
|
||||
if (!$headers) {
|
||||
// Backwards compatible defaults
|
||||
$headers = array('HTTP_CLIENT_IP', 'HTTP_X_FORWARDED_FOR');
|
||||
}
|
||||
foreach ($headers as $header) {
|
||||
if (!empty($_SERVER[$header])) {
|
||||
$headerOverrideIP = $_SERVER[$header];
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
return $this->ip;
|
||||
}
|
||||
|
||||
if ($headerOverrideIP && filter_var($headerOverrideIP, FILTER_VALIDATE_IP, FILTER_FLAG_NO_PRIV_RANGE | FILTER_FLAG_NO_RES_RANGE)) {
|
||||
return $this->getIPFromHeaderValue($headerOverrideIP);
|
||||
} elseif (isset($_SERVER['REMOTE_ADDR'])) {
|
||||
return $_SERVER['REMOTE_ADDR'];
|
||||
} else {
|
||||
return null;
|
||||
}
|
||||
/**
|
||||
* Sets the client IP address which originated this request.
|
||||
*
|
||||
* @param $ip string
|
||||
*/
|
||||
public function setIP($ip)
|
||||
{
|
||||
$this->ip = $ip;
|
||||
}
|
||||
|
||||
/**
|
||||
@ -837,6 +840,25 @@ class HTTPRequest implements ArrayAccess
|
||||
return $this->httpMethod;
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the URL scheme (e.g. "http" or "https").
|
||||
* Equivalent to PSR-7 getUri()->getScheme()
|
||||
* @return string
|
||||
*/
|
||||
public function getScheme() {
|
||||
return $this->scheme;
|
||||
}
|
||||
|
||||
/**
|
||||
* Set the URL scheme (e.g. "http" or "https").
|
||||
* Equivalent to PSR-7 getUri()->getScheme(),
|
||||
*
|
||||
* @param string $scheme
|
||||
*/
|
||||
public function setScheme($scheme) {
|
||||
$this->scheme = $scheme;
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the "real" HTTP method for a request.
|
||||
*
|
||||
|
@ -45,6 +45,17 @@ class HTTPRequestBuilder
|
||||
$input
|
||||
);
|
||||
|
||||
// Set the scheme to HTTPS if needed
|
||||
if ((!empty($variables['_SERVER']['HTTPS']) && $variables['_SERVER']['HTTPS'] != 'off')
|
||||
|| isset($variables['_SERVER']['SSL'])) {
|
||||
$request->setScheme('https');
|
||||
}
|
||||
|
||||
// Set the client IP
|
||||
if (!empty($variables['_SERVER']['REMOTE_ADDR'])) {
|
||||
$request->setIP($variables['_SERVER']['REMOTE_ADDR']);
|
||||
}
|
||||
|
||||
// Add headers
|
||||
$headers = static::extractRequestHeaders($variables['_SERVER']);
|
||||
foreach ($headers as $header => $value) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user