diff options
-rw-r--r-- | git/git.go | 32 | ||||
-rw-r--r-- | routes/handler.go | 1 | ||||
-rw-r--r-- | routes/routes.go | 39 | ||||
-rw-r--r-- | templates/refs.html | 32 |
4 files changed, 104 insertions, 0 deletions
@@ -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" }} +<html> +{{ template "head" . }} + + <header> + <h1>{{ .meta.Title }}</h1> + <h2>{{ .meta.Description }}</h2> + </header> + <body> + {{ template "nav" . }} + <main> + <h3>branches</h3> + {{ $name := .name }} + {{ range .branches }} + <p> + <strong>{{ .Name.Short }}</strong> + <a href="/{{ $name }}/tree/{{ .Name.Short }}/">browse</a> + <a href="/{{ $name }}/log/{{ .Name.Short }}">log</a> + </p> + {{ end }} + {{ if .tags }} + {{ range .tags }} + <p>{{ .Name }}</p> + {{ if .Message }} + <p>{{ .Message }}</p> + {{ end }} + {{ end }} + {{ end }} + </main> + </body> +</html> +{{ end }} |