aboutsummaryrefslogtreecommitdiff
path: root/handle_repo_raw.go
diff options
context:
space:
mode:
Diffstat (limited to 'handle_repo_raw.go')
-rw-r--r--handle_repo_raw.go25
1 files changed, 19 insertions, 6 deletions
diff --git a/handle_repo_raw.go b/handle_repo_raw.go
index 5693660..d3ffe3e 100644
--- a/handle_repo_raw.go
+++ b/handle_repo_raw.go
@@ -1,11 +1,11 @@
package main
import (
+ "errors"
"net/http"
"path"
"strings"
- "github.com/go-git/go-git/v5/plumbing"
"github.com/go-git/go-git/v5/plumbing/object"
)
@@ -13,19 +13,32 @@ func handle_repo_raw(w http.ResponseWriter, r *http.Request) {
data := make(map[string]any)
// TODO: Sanitize path values
raw_path_spec := r.PathValue("rest")
- ref_name, group_name, repo_name, path_spec := r.PathValue("ref"), r.PathValue("group_name"), r.PathValue("repo_name"), strings.TrimSuffix(raw_path_spec, "/")
- data["ref"], data["group_name"], data["repo_name"], data["path_spec"] = ref_name, group_name, repo_name, path_spec
+ group_name, repo_name, path_spec := r.PathValue("group_name"), r.PathValue("repo_name"), strings.TrimSuffix(raw_path_spec, "/")
+
+ ref_type, ref_name, err := get_param_ref_and_type(r)
+ if err != nil {
+ if errors.Is(err, err_no_ref_spec) {
+ ref_type = "head"
+ } else {
+ _, _ = w.Write([]byte("Error querying ref type: " + err.Error()))
+ return
+ }
+ }
+
+ data["ref_type"], data["ref"], data["group_name"], data["repo_name"], data["path_spec"] = ref_type, ref_name, group_name, repo_name, path_spec
+
repo, err := open_git_repo(group_name, repo_name)
if err != nil {
_, _ = w.Write([]byte("Error opening repo: " + err.Error()))
return
}
- ref, err := repo.Reference(plumbing.NewBranchReferenceName(ref_name), true)
+
+ ref_hash, err := get_ref_hash_from_type_and_name(repo, ref_type, ref_name)
if err != nil {
- _, _ = w.Write([]byte("Error getting repo reference: " + err.Error()))
+ _, _ = w.Write([]byte("Error getting ref hash: " + err.Error()))
return
}
- ref_hash := ref.Hash()
+
commit_object, err := repo.CommitObject(ref_hash)
if err != nil {
_, _ = w.Write([]byte("Error getting commit object: " + err.Error()))