From 7a6ff3565e8e5f55d50c509c9ee12438b61c850e Mon Sep 17 00:00:00 2001 From: Anirudh Oppiliappan Date: Mon, 12 Dec 2022 21:58:47 +0530 Subject: routes: refs view --- routes/routes.go | 39 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 39 insertions(+) (limited to 'routes/routes.go') diff --git a/routes/routes.go b/routes/routes.go index ebb1622..1683404 100644 --- a/routes/routes.go +++ b/routes/routes.go @@ -216,3 +216,42 @@ func (d *deps) Diff(w http.ResponseWriter, r *http.Request) { return } } + +func (d *deps) Refs(w http.ResponseWriter, r *http.Request) { + name := flow.Param(r.Context(), "name") + + path := filepath.Join(d.c.Git.ScanPath, name) + gr, err := git.Open(path, "") + if err != nil { + d.Write404(w) + return + } + + tags, err := gr.Tags() + if err != nil { + // Non-fatal, we *should* have at least one branch to show. + log.Println(err) + } + + branches, err := gr.Branches() + if err != nil { + log.Println(err) + d.Write500(w) + return + } + + tpath := filepath.Join(d.c.Template.Dir, "*") + t := template.Must(template.ParseGlob(tpath)) + + data := make(map[string]interface{}) + + data["meta"] = d.c.Meta + data["name"] = name + data["branches"] = branches + data["tags"] = tags + + if err := t.ExecuteTemplate(w, "refs", data); err != nil { + log.Println(err) + return + } +} -- cgit v1.2.3