aboutsummaryrefslogtreecommitdiff
path: root/routes/routes.go
diff options
context:
space:
mode:
authorAnirudh Oppiliappan <x@icyphox.sh>2022-12-11 21:17:04 +0530
committerAnirudh Oppiliappan <x@icyphox.sh>2022-12-11 21:17:04 +0530
commitce71721c6dc80db8af63f2098a1548308e2621b2 (patch)
tree80a4083382113b095de03f9c5d9032591f4ea439 /routes/routes.go
parentgit: fix trees (diff)
downloadlegitrx-ce71721c6dc80db8af63f2098a1548308e2621b2.tar.gz
legitrx-ce71721c6dc80db8af63f2098a1548308e2621b2.tar.zst
legitrx-ce71721c6dc80db8af63f2098a1548308e2621b2.zip
routes, templates: tree and log views
Diffstat (limited to 'routes/routes.go')
-rw-r--r--routes/routes.go75
1 files changed, 50 insertions, 25 deletions
diff --git a/routes/routes.go b/routes/routes.go
index 5d5dc2c..f1eef06 100644
--- a/routes/routes.go
+++ b/routes/routes.go
@@ -1,13 +1,12 @@
package routes
import (
+ "html/template"
"log"
"net/http"
"path/filepath"
"github.com/alexedwards/flow"
- gogit "github.com/go-git/go-git/v5"
- "github.com/go-git/go-git/v5/plumbing"
"icyphox.sh/legit/config"
"icyphox.sh/legit/git"
)
@@ -21,27 +20,25 @@ func (d *deps) RepoIndex(w http.ResponseWriter, r *http.Request) {
name = filepath.Clean(name)
// TODO: remove .git
path := filepath.Join(d.c.Git.ScanPath, name+".git")
- repo, err := gogit.PlainOpen(path)
+ gr, err := git.Open(path, "")
if err != nil {
Write404(w, *d.c)
return
}
- head, err := repo.Head()
+ files, err := gr.FileTree("")
if err != nil {
Write500(w, *d.c)
log.Println(err)
return
}
- files, err := git.FilesAtRef(repo, head.Hash(), "")
- if err != nil {
- Write500(w, *d.c)
- log.Println(err)
- return
- }
+ data := make(map[string]any)
+ data["name"] = name
+ // TODO: make this configurable
+ data["ref"] = "master"
- d.listFiles(files, w)
+ d.listFiles(files, data, w)
return
}
@@ -53,27 +50,25 @@ func (d *deps) RepoTree(w http.ResponseWriter, r *http.Request) {
name = filepath.Clean(name)
// TODO: remove .git
path := filepath.Join(d.c.Git.ScanPath, name+".git")
- repo, err := gogit.PlainOpen(path)
+ gr, err := git.Open(path, ref)
if err != nil {
Write404(w, *d.c)
return
}
- hash, err := repo.ResolveRevision(plumbing.Revision(ref))
+ files, err := gr.FileTree(treePath)
if err != nil {
Write500(w, *d.c)
log.Println(err)
return
}
- files, err := git.FilesAtRef(repo, *hash, treePath)
- if err != nil {
- Write500(w, *d.c)
- log.Println(err)
- return
- }
+ data := make(map[string]any)
+ data["name"] = name
+ data["ref"] = ref
+ data["parent"] = treePath
- d.listFiles(files, w)
+ d.listFiles(files, data, w)
return
}
@@ -85,20 +80,50 @@ func (d *deps) FileContent(w http.ResponseWriter, r *http.Request) {
name = filepath.Clean(name)
// TODO: remove .git
path := filepath.Join(d.c.Git.ScanPath, name+".git")
- repo, err := gogit.PlainOpen(path)
+ gr, err := git.Open(path, ref)
if err != nil {
Write404(w, *d.c)
return
}
- hash, err := repo.ResolveRevision(plumbing.Revision(ref))
+ contents, err := gr.FileContent(treePath)
+ data := make(map[string]any)
+ data["name"] = name
+ data["ref"] = ref
+
+ d.showFile(contents, data, w)
+ return
+}
+
+func (d *deps) Log(w http.ResponseWriter, r *http.Request) {
+ name := flow.Param(r.Context(), "name")
+ ref := flow.Param(r.Context(), "ref")
+
+ path := filepath.Join(d.c.Git.ScanPath, name+".git")
+ gr, err := git.Open(path, ref)
+ if err != nil {
+ Write404(w, *d.c)
+ return
+ }
+
+ commits, err := gr.Commits()
if err != nil {
Write500(w, *d.c)
log.Println(err)
return
}
- contents, err := git.FileContentAtRef(repo, *hash, treePath)
- d.showFile(contents, w)
- return
+ tpath := filepath.Join(d.c.Template.Dir, "*")
+ t := template.Must(template.ParseGlob(tpath))
+
+ data := make(map[string]interface{})
+ data["commits"] = commits
+ data["meta"] = d.c.Meta
+ data["name"] = name
+ data["ref"] = ref
+
+ if err := t.ExecuteTemplate(w, "log", data); err != nil {
+ log.Println(err)
+ return
+ }
}