barryserver-git
Barry Splitting into more pages + commit pages a6603d5 (3 years, 2 months ago)
diff --git a/commit.php b/commit.php
new file mode 100644
index 0000000..f0fb241
--- /dev/null
+++ b/commit.php
@@ -0,0 +1,35 @@
+<?php require_once $_SERVER["DOCUMENT_ROOT"]."/config.php"; ?>
+<?php $SIDE_LINKS = array(); ?>
+<?php
+ if (!isset($_GET["repo"])) {header("Location: /");die();}
+ $repo = $_GET["repo"]??"";
+ if (isset($_GET["repo"])) {
+ $PAGE_TITLE = $repo;
+ }
+
+ if (!is_dir(GIT_DIR."/".$repo.".git")) { ?>
+<?php require_once $_SERVER["DOCUMENT_ROOT"]."/head.php"; ?>
+<main>
+ <h1>Repository not found</h1>
+ <article>The repository you were looking for was not found on this server. Please check the URL and look for$
+</main>
+<?php require_once $_SERVER["DOCUMENT_ROOT"]."/foot.php"; ?>
+<?php die();}
+ $branch = $_GET["object"]??DEFAULT_BRANCH;
+ $path = $_GET["path"]??".";
+ chdir(GIT_DIR."/".$repo.".git");
+ if ($branch === "") {
+ $branch = DEFAULT_BRANCH;
+ }
+ $SIDE_LINKS["git clone"] = "git://".$_SERVER["SERVER_NAME"]."/".$repo.".git";
+ $SIDE_LINKS["Browse Files"] = "/".$repo."/tree/".$branch."/".$path;
+ $PAGE_TITLE = "Commit ".substr($branch,0,7)." @ ".$PAGE_TITLE;
+ require_once $_SERVER["DOCUMENT_ROOT"]."/head.php";
+ echo "<main><h1>".$repo."</h1>\n";
+ $lastcommit = shell_exec("git log --summary --quiet --oneline --abbrev-commit --format=format:'<b>%an</b> %s <span><a href=\"/".escapeshellcmd($repo)."/commit/%H/".escapeshellcmd($path)."\">%h</a> (%ar)</span>' -n 1 ".escapeshellarg($branch)." -- ".escapeshellarg($path));
+ echo "<span class=\"last-commit\">".$lastcommit."</span>";
+ $content = shell_exec("git --git-dir ".GIT_DIR."/".escapeshellcmd($repo).".git/ log --format= -p -n 1 ".escapeshellarg($branch)." -- ".escapeshellarg($path));
+ echo "<pre class=\"prettyprint\">\n".htmlspecialchars($content)."</pre>\n";
+?>
+</main>
+<?php require_once $_SERVER["DOCUMENT_ROOT"]."/foot.php"; ?>