mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
Simplified request building
This commit is contained in:
parent
bd11bc16c7
commit
1e051386c6
@ -21,9 +21,6 @@ class HTTPRequestBuilder
|
||||
// Health-check prior to creating environment
|
||||
$req = static::createFromVariables($variables, @file_get_contents('php://input'));
|
||||
|
||||
// Normalise URL
|
||||
$variables['_SERVER']['REQUEST_URI'] = $req->getURL();
|
||||
|
||||
Environment::setVariables($variables); // Currently necessary for SSViewer, etc to work
|
||||
|
||||
return $req;
|
||||
@ -38,7 +35,7 @@ class HTTPRequestBuilder
|
||||
*/
|
||||
public static function createFromVariables(array $variables, $input)
|
||||
{
|
||||
$url = self::getRequestUri($variables);
|
||||
$url = $variables['_SERVER']['REQUEST_URI'];
|
||||
|
||||
// Build request
|
||||
$request = new HTTPRequest(
|
||||
@ -130,54 +127,22 @@ class HTTPRequestBuilder
|
||||
(array)$variables['_COOKIE']
|
||||
);
|
||||
|
||||
return $variables;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param array $variables
|
||||
* @return string
|
||||
*/
|
||||
protected static function getRequestUri(array $variables)
|
||||
{
|
||||
$server = $variables['_SERVER'];
|
||||
|
||||
$ruLen = strlen($server['REQUEST_URI']);
|
||||
$snLen = strlen($server['SCRIPT_NAME']);
|
||||
|
||||
$isIIS = (strpos($server['SERVER_SOFTWARE'], 'Microsoft-IIS') !== false);
|
||||
|
||||
// IIS will populate server variables using one of these two ways
|
||||
if ($isIIS) {
|
||||
if ($server['REQUEST_URI'] == $server['SCRIPT_NAME']) {
|
||||
$url = "";
|
||||
} elseif ($ruLen > $snLen && substr($server['REQUEST_URI'], 0, $snLen + 1) == ($server['SCRIPT_NAME'] . '/')) {
|
||||
$url = substr($server['REQUEST_URI'], $snLen + 1);
|
||||
$url = strtok($url, '?');
|
||||
} else {
|
||||
$url = $server['REQUEST_URI'];
|
||||
if ($url[0] == '/') {
|
||||
$url = substr($url, 1);
|
||||
}
|
||||
$url = strtok($url, '?');
|
||||
}
|
||||
|
||||
// Apache will populate the server variables this way
|
||||
} else {
|
||||
// Remove query parameters (they're retained separately through $server['_GET']
|
||||
$url = parse_url($server['REQUEST_URI'], PHP_URL_PATH);
|
||||
// if ($ruLen > $snLen && substr($server['REQUEST_URI'], 0, $snLen + 1) == ($server['SCRIPT_NAME'] . '/')) {
|
||||
// $url = substr($server['REQUEST_URI'], $snLen + 1);
|
||||
// $url = strtok($url, '?');
|
||||
// } else {
|
||||
// $url = "";
|
||||
// }
|
||||
}
|
||||
$url = parse_url($variables['_SERVER']['REQUEST_URI'], PHP_URL_PATH);
|
||||
|
||||
// Remove SCRIPT_NAME from url in case no rewriting is in place on the webserver.
|
||||
// Example: index.php/admin/pages -> /admin/pages
|
||||
$url = preg_replace('#^' . preg_quote($server['SCRIPT_NAME'], '#') . '#', '', $url);
|
||||
|
||||
// Remove base folders from the URL if webroot is hosted in a subfolder
|
||||
if (substr(strtolower($url), 0, strlen(BASE_URL)) === strtolower(BASE_URL)) {
|
||||
$url = substr($url, strlen(BASE_URL));
|
||||
}
|
||||
|
||||
return $url;
|
||||
// Normalise URI
|
||||
$variables['_SERVER']['REQUEST_URI'] = $url;
|
||||
|
||||
return $variables;
|
||||
}
|
||||
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user