var/www/pages/index.php : properly handle directories, pipe unused output to /dev/null

This commit is contained in:
codeberg.org 2020-05-04 21:14:53 +02:00
parent 972c0879c3
commit 981c0dd904

View file

@ -44,13 +44,19 @@ if (substr($git_root, 0, strlen($git_prefix)) !== $git_prefix) {
}
if (end($parts) === '') {
array_shift($parts);
array_pop($parts);
}
$file_url = implode("/", $parts);
if ($file_url === "") {
$command = "sh -c \"cd '$git_root' && /usr/bin/git ls-tree 'master:$file_url' > /dev/null\"";
exec($command, $output, $retval);
if ($retval == 0) {
if ($file_url == "" ) {
$file_url = "index.html";
} else {
$file_url .= "/index.html";
}
}
$ext = pathinfo($file_url, PATHINFO_EXTENSION);
@ -83,21 +89,16 @@ $command = "sh -c \"cd '$git_root' && /usr/bin/git show 'master:$file_url'\"";
## We are executing command twice (first for send_response-checking, then for actual raw output to stream),
## which seems wasteful, but it seems exec+echo cannot do raw binary output? Is this true?
exec($command, $output, $retval);
exec($command . " > /dev/null", $output, $retval);
if ($retval != 0) {
# Try to append index.html to path, in case it was an abbreviated folder. Whatever happens from now on, we will always render HTML:
header("Content-Type: text/html");
$command = "sh -c \"cd '$git_root' && /usr/bin/git show 'master:$file_url/index.html'\"";
exec($command, $output, $retval);
if ($retval != 0) {
# Render user-provided 404.html if exists, generic 404 message if not:
http_response_code(404);
header("Content-Type: text/html");
$command = "sh -c \"cd '$git_root' && /usr/bin/git show 'master:404.html'\"";
exec($command, $output, $retval);
exec($command . " > /dev/null", $output, $retval);
if ($retval != 0) {
send_response(404 , "no such file in repo: '" . htmlspecialchars($file_url) . "'");
}
http_response_code(404);
}
}
## If we could directly exec+echo raw output from above, we wouldn't need to execute command twice: