aboutsummaryrefslogtreecommitdiff
path: root/handle_repo_tree.go
diff options
context:
space:
mode:
authorRunxi Yu <me@runxiyu.org>2025-02-10 09:18:16 +0800
committerRunxi Yu <me@runxiyu.org>2025-02-10 09:18:16 +0800
commit3849c3dcf5efc338753a6e592e582238d33ead53 (patch)
treebbb4819ca33228e1f1c2d307f9189159fe2bc937 /handle_repo_tree.go
parentmain: Add {$} to path handlers that need it (diff)
downloadforge-3849c3dcf5efc338753a6e592e582238d33ead53.tar.gz
forge-3849c3dcf5efc338753a6e592e582238d33ead53.tar.zst
forge-3849c3dcf5efc338753a6e592e582238d33ead53.zip
repo_tree: Support listing directories other than /
Diffstat (limited to 'handle_repo_tree.go')
-rw-r--r--handle_repo_tree.go28
1 files changed, 17 insertions, 11 deletions
diff --git a/handle_repo_tree.go b/handle_repo_tree.go
index 0ee8870..e1f356b 100644
--- a/handle_repo_tree.go
+++ b/handle_repo_tree.go
@@ -2,6 +2,7 @@ package main
import (
"bytes"
+ "strings"
"github.com/go-git/go-git/v5"
"github.com/go-git/go-git/v5/plumbing/object"
"github.com/microcosm-cc/bluemonday"
@@ -14,8 +15,8 @@ import (
func handle_repo_tree(w http.ResponseWriter, r *http.Request) {
data := make(map[string]any)
// TODO: Sanitize path values
- project_name, repo_name := r.PathValue("project_name"), r.PathValue("repo_name")
- data["project_name"], data["repo_name"] = project_name, repo_name
+ project_name, repo_name, path_spec := r.PathValue("project_name"), r.PathValue("repo_name"), strings.TrimSuffix(r.PathValue("rest"), "/")
+ data["project_name"], data["repo_name"], data["path_spec"] = project_name, repo_name, path_spec
repo, err := git.PlainOpen(filepath.Join(config.Git.Root, project_name, repo_name+".git"))
if err != nil {
w.Write([]byte("Error opening repo: " + err.Error()))
@@ -53,20 +54,25 @@ func handle_repo_tree(w http.ResponseWriter, r *http.Request) {
w.Write([]byte("Error getting file tree: " + err.Error()))
return
}
- readme_file, err := tree.File("README.md")
+ tree, err = tree.Tree(path_spec)
if err != nil {
- w.Write([]byte("Error getting file: " + err.Error()))
+ w.Write([]byte("Error getting subtree: " + err.Error()))
return
}
- readme_file_contents, err := readme_file.Contents()
- var readme_rendered_unsafe bytes.Buffer
- err = goldmark.Convert([]byte(readme_file_contents), &readme_rendered_unsafe)
+ readme_file, err := tree.File("README.md")
if err != nil {
- readme_rendered_unsafe.WriteString("Unable to render README: " + err.Error())
- return
+ data["readme"] = ""
+ } else {
+ readme_file_contents, err := readme_file.Contents()
+ var readme_rendered_unsafe bytes.Buffer
+ err = goldmark.Convert([]byte(readme_file_contents), &readme_rendered_unsafe)
+ if err != nil {
+ readme_rendered_unsafe.WriteString("Unable to render README: " + err.Error())
+ return
+ }
+ readme_rendered_safe := template.HTML(bluemonday.UGCPolicy().SanitizeBytes(readme_rendered_unsafe.Bytes()))
+ data["readme"] = readme_rendered_safe
}
- readme_rendered_safe := template.HTML(bluemonday.UGCPolicy().SanitizeBytes(readme_rendered_unsafe.Bytes()))
- data["readme"] = readme_rendered_safe
display_git_tree := make([]display_git_tree_entry_t, 0)
for _, entry := range tree.Entries {