[core] fixes and tests for get_base_href + get_query, see #1024

This commit is contained in:
Shish 2024-02-07 22:47:12 +00:00
parent c6e65a21f9
commit 7adb7348d7
6 changed files with 95 additions and 21 deletions

View file

@ -306,21 +306,22 @@ function get_base_href(): string
if (defined("BASE_HREF") && !empty(BASE_HREF)) { if (defined("BASE_HREF") && !empty(BASE_HREF)) {
return BASE_HREF; return BASE_HREF;
} }
$possible_vars = ['SCRIPT_NAME', 'PHP_SELF', 'PATH_INFO', 'ORIG_PATH_INFO']; if(str_ends_with($_SERVER['PHP_SELF'], 'index.php')) {
$ok_var = null; $self = $_SERVER['PHP_SELF'];
foreach ($possible_vars as $var) {
if (isset($_SERVER[$var]) && substr($_SERVER[$var], -4) === '.php') {
$ok_var = $_SERVER[$var];
break;
}
} }
if(empty($ok_var) && isset($_SERVER['SCRIPT_FILENAME']) && isset($_SERVER['DOCUMENT_ROOT'])) { elseif(isset($_SERVER['SCRIPT_FILENAME']) && isset($_SERVER['DOCUMENT_ROOT'])) {
$ok_var = substr($_SERVER['SCRIPT_FILENAME'], strlen($_SERVER['DOCUMENT_ROOT'])); $self = substr($_SERVER['SCRIPT_FILENAME'], strlen(rtrim($_SERVER['DOCUMENT_ROOT'], "/")));
} }
assert(!empty($ok_var)); /*
$dir = dirname($ok_var); die(var_export([
$_SERVER['PHP_SELF'],
$_SERVER['SCRIPT_FILENAME'],
$_SERVER['DOCUMENT_ROOT'],
$self
], true));
*/
$dir = dirname($self);
$dir = str_replace("\\", "/", $dir); $dir = str_replace("\\", "/", $dir);
$dir = str_replace("//", "/", $dir);
$dir = rtrim($dir, "/"); $dir = rtrim($dir, "/");
return $dir; return $dir;
} }

View file

@ -254,4 +254,42 @@ class PolyfillsTest extends TestCase
deltree($dir); deltree($dir);
$this->assertFalse(file_exists($dir)); $this->assertFalse(file_exists($dir));
} }
private function _tbh(array $vars, string $result): void
{
// update $_SERVER with $vars, call get_base_href() and check result, then reset $_SERVER to original value
$old_server = $_SERVER;
$_SERVER = array_merge($_SERVER, $vars);
$this->assertEquals($result, get_base_href());
$_SERVER = $old_server;
}
public function test_get_base_href(): void
{
// PHP_SELF should point to "the currently executing script
// relative to the document root"
$this->_tbh(["PHP_SELF" => "/index.php"], "");
$this->_tbh(["PHP_SELF" => "/mydir/index.php"], "/mydir");
// SCRIPT_FILENAME should point to "the absolute pathname of
// the currently executing script" and DOCUMENT_ROOT should
// point to "the document root directory under which the
// current script is executing"
$this->_tbh([
"PHP_SELF" => "<invalid>",
"SCRIPT_FILENAME" => "/var/www/html/mydir/index.php",
"DOCUMENT_ROOT" => "/var/www/html",
], "/mydir");
$this->_tbh([
"PHP_SELF" => "<invalid>",
"SCRIPT_FILENAME" => "/var/www/html/mydir/index.php",
"DOCUMENT_ROOT" => "/var/www/html/",
], "/mydir");
$this->_tbh([
"PHP_SELF" => "<invalid>",
"SCRIPT_FILENAME" => "/var/www/html/index.php",
"DOCUMENT_ROOT" => "/var/www/html",
], "");
}
} }

View file

@ -162,4 +162,23 @@ class UtilTest extends TestCase
path_to_tags("/category:/tag/baz.jpg") path_to_tags("/category:/tag/baz.jpg")
); );
} }
public function test_get_query(): void
{
// no query string
$_SERVER["REQUEST_URI"] = "/tasty/cake";
$this->assertEquals("/tasty/cake", _get_query());
// query string
$_SERVER["REQUEST_URI"] = "index.php?q=/tasty/cake";
$this->assertEquals("/tasty/cake", _get_query());
// leave url encoding alone
$_SERVER["REQUEST_URI"] = "index.php?q=/tasty/cake%20pie";
$this->assertEquals("/tasty/cake%20pie", _get_query());
// if just viewing index.php
$_SERVER["REQUEST_URI"] = "index.php";
$this->assertEquals("/", _get_query());
}
} }

View file

@ -715,19 +715,33 @@ function _get_user(): User
function _get_query(): string function _get_query(): string
{ {
// if query is explicitly set, use it // if q is set in POST, use that
$q = @$_POST["q"] ?: @$_GET["q"]; if(isset($_POST["q"])) {
if(!empty($q)) { return $_POST["q"];
return $q;
} }
// if q is set in GET, use that
// (we need to manually parse the query string because PHP's $_GET
// does an extra round of URL decoding, which we don't want)
$parts = parse_url($_SERVER['REQUEST_URI']);
$qs = [];
foreach(explode('&', $parts['query'] ?? "") as $z) {
$qps = explode('=', $z, 2);
if(count($qps) == 2) {
$qs[$qps[0]] = $qps[1];
}
}
if(isset($qs["q"])) {
return $qs["q"];
}
// if we're just looking at index.php, use the default query // if we're just looking at index.php, use the default query
elseif (str_contains($_SERVER['REQUEST_URI'], "index.php")) { if(str_ends_with($parts["path"], "index.php")) {
return "/"; return "/";
} }
// otherwise, use the request URI // otherwise, use the request URI
else { return $parts["path"];
return explode("?", $_SERVER['REQUEST_URI'])[0];
}
} }

View file

@ -19,7 +19,10 @@ require_once "core/sys_config.php";
require_once "core/polyfills.php"; require_once "core/polyfills.php";
require_once "core/util.php"; require_once "core/util.php";
$_SERVER['SCRIPT_FILENAME'] = '/var/www/html/test/index.php';
$_SERVER['DOCUMENT_ROOT'] = '/var/www/html';
$_SERVER['QUERY_STRING'] = '/'; $_SERVER['QUERY_STRING'] = '/';
if (file_exists("data/test-trace.json")) { if (file_exists("data/test-trace.json")) {
unlink("data/test-trace.json"); unlink("data/test-trace.json");
} }

View file

@ -20,7 +20,6 @@ define("VERSION", 'unit-tests');
define("TRACE_FILE", null); define("TRACE_FILE", null);
define("TRACE_THRESHOLD", 0.0); define("TRACE_THRESHOLD", 0.0);
define("TIMEZONE", 'UTC'); define("TIMEZONE", 'UTC');
define("BASE_HREF", "/test");
define("CLI_LOG_LEVEL", 50); define("CLI_LOG_LEVEL", 50);
define("STATSD_HOST", null); define("STATSD_HOST", null);
define("TRUSTED_PROXIES", []); define("TRUSTED_PROXIES", []);