diff options
Diffstat (limited to 'routes/handler.go')
-rw-r--r-- | routes/handler.go | 36 |
1 files changed, 9 insertions, 27 deletions
diff --git a/routes/handler.go b/routes/handler.go index c0b146c..a0e7832 100644 --- a/routes/handler.go +++ b/routes/handler.go @@ -1,26 +1,16 @@ package routes import ( - "log" "net/http" - "path/filepath" "git.icyphox.sh/legit/config" "github.com/alexedwards/flow" - "github.com/sosedoff/gitkit" ) -type depsWrapper struct { - actualDeps deps - gitsvc *gitkit.Server -} - // Checks for gitprotocol-http(5) specific smells; if found, passes // the request on to the git http service, else render the web frontend. -func (dw *depsWrapper) Multiplex(w http.ResponseWriter, r *http.Request) { +func (d *deps) Multiplex(w http.ResponseWriter, r *http.Request) { path := flow.Param(r.Context(), "...") - name := flow.Param(r.Context(), "name") - name = filepath.Clean(name) if r.URL.RawQuery == "service=git-receive-pack" { w.WriteHeader(http.StatusBadRequest) @@ -28,12 +18,14 @@ func (dw *depsWrapper) Multiplex(w http.ResponseWriter, r *http.Request) { return } - if path == "info/refs" && r.URL.RawQuery == "service=git-upload-pack" && r.Method == "GET" { - dw.gitsvc.ServeHTTP(w, r) + if path == "info/refs" && + r.URL.RawQuery == "service=git-upload-pack" && + r.Method == "GET" { + d.InfoRefs(w, r) } else if path == "git-upload-pack" && r.Method == "POST" { - dw.gitsvc.ServeHTTP(w, r) + d.UploadPack(w, r) } else if r.Method == "GET" { - dw.actualDeps.RepoIndex(w, r) + d.RepoIndex(w, r) } } @@ -41,29 +33,19 @@ func Handlers(c *config.Config) *flow.Mux { mux := flow.New() d := deps{c} - gitsvc := gitkit.New(gitkit.Config{ - Dir: c.Repo.ScanPath, - AutoCreate: false, - }) - if err := gitsvc.Setup(); err != nil { - log.Fatalf("git server: %s", err) - } - - dw := depsWrapper{actualDeps: d, gitsvc: gitsvc} - mux.NotFound = http.HandlerFunc(func(w http.ResponseWriter, _ *http.Request) { d.Write404(w) }) mux.HandleFunc("/", d.Index, "GET") mux.HandleFunc("/static/:file", d.ServeStatic, "GET") - mux.HandleFunc("/:name", dw.Multiplex, "GET", "POST") + mux.HandleFunc("/:name", d.Multiplex, "GET", "POST") mux.HandleFunc("/:name/tree/:ref/...", d.RepoTree, "GET") 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") - mux.HandleFunc("/:name/...", dw.Multiplex, "GET", "POST") + mux.HandleFunc("/:name/...", d.Multiplex, "GET", "POST") return mux } |