branches
+ {{ $name := .name }} + {{ range .branches }} ++ {{ .Name.Short }} + browse + log +
+ {{ end }} + {{ if .tags }} + {{ range .tags }} +{{ .Name }}
+ {{ if .Message }} +{{ .Message }}
+ {{ end }} + {{ end }} + {{ end }} +diff --git a/git/git.go b/git/git.go
index 34a25e5..a34d679 100644
--- a/git/git.go
+++ b/git/git.go
@@ -78,3 +78,35 @@ func (g *GitRepo) FileContent(path string) (string, error) {
return file.Contents()
}
+
+func (g *GitRepo) Tags() ([]*object.Tag, error) {
+ ti, err := g.r.TagObjects()
+ if err != nil {
+ return nil, fmt.Errorf("tag objects: %w", err)
+ }
+
+ tags := []*object.Tag{}
+
+ _ = ti.ForEach(func(t *object.Tag) error {
+ tags = append(tags, t)
+ return nil
+ })
+
+ return tags, nil
+}
+
+func (g *GitRepo) Branches() ([]*plumbing.Reference, error) {
+ bi, err := g.r.Branches()
+ if err != nil {
+ return nil, fmt.Errorf("branchs: %w", err)
+ }
+
+ branches := []*plumbing.Reference{}
+
+ _ = bi.ForEach(func(ref *plumbing.Reference) error {
+ branches = append(branches, ref)
+ return nil
+ })
+
+ return branches, nil
+}
diff --git a/routes/handler.go b/routes/handler.go
index 0c4f7b8..3abc4fd 100644
--- a/routes/handler.go
+++ b/routes/handler.go
@@ -21,5 +21,6 @@ func Handlers(c *config.Config) *flow.Mux {
mux.HandleFunc("/:name/blob/:ref/...", d.FileContent, "GET")
mux.HandleFunc("/:name/log/:ref", d.Log, "GET")
mux.HandleFunc("/:name/commit/:ref", d.Diff, "GET")
+ mux.HandleFunc("/:name/refs", d.Refs, "GET")
return mux
}
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
+ }
+}
diff --git a/templates/refs.html b/templates/refs.html
new file mode 100644
index 0000000..e1668d2
--- /dev/null
+++ b/templates/refs.html
@@ -0,0 +1,32 @@
+{{ define "refs" }}
+
+{{ template "head" . }}
+
+ {{ .meta.Title }}
+ {{ .meta.Description }}
+
+ {{ .Name.Short }} + browse + log +
+ {{ end }} + {{ if .tags }} + {{ range .tags }} +{{ .Name }}
+ {{ if .Message }} +{{ .Message }}
+ {{ end }} + {{ end }} + {{ end }} +