aboutsummaryrefslogtreecommitdiff
path: root/forged/internal/incoming/web/stub.go
diff options
context:
space:
mode:
authorRunxi Yu <me@runxiyu.org>2025-08-17 17:47:38 +0800
committerRunxi Yu <me@runxiyu.org>2025-08-17 18:04:34 +0800
commitf58f56701d047398cc8d7a6433719de1b6070242 (patch)
treeeddba41fc84549f8532af4da040cb227a0304f65 /forged/internal/incoming/web/stub.go
parentgofumpt (diff)
downloadforge-f58f56701d047398cc8d7a6433719de1b6070242.tar.gz
forge-f58f56701d047398cc8d7a6433719de1b6070242.tar.zst
forge-f58f56701d047398cc8d7a6433719de1b6070242.zip
Refactor handlers structure and add BaseData
Diffstat (limited to 'forged/internal/incoming/web/stub.go')
-rw-r--r--forged/internal/incoming/web/stub.go38
1 files changed, 16 insertions, 22 deletions
diff --git a/forged/internal/incoming/web/stub.go b/forged/internal/incoming/web/stub.go
index 7207756..4fffd73 100644
--- a/forged/internal/incoming/web/stub.go
+++ b/forged/internal/incoming/web/stub.go
@@ -4,41 +4,35 @@ import (
"fmt"
"net/http"
"strings"
-)
-
-func (h *handler) index(w http.ResponseWriter, r *http.Request, p Params) {
- _, _ = w.Write([]byte("index: replace with template render"))
-}
-func (h *handler) groupIndex(w http.ResponseWriter, r *http.Request, p Params) {
- g := p["group_path"].([]string) // captured by @group
- _, _ = w.Write([]byte("group index for: /" + strings.Join(g, "/") + "/"))
-}
+ wtypes "go.lindenii.runxiyu.org/forge/forged/internal/incoming/web/types"
+)
-func (h *handler) repoIndex(w http.ResponseWriter, r *http.Request, p Params) {
- repo := p["repo"].(string)
- g := p["group_path"].([]string)
- _, _ = w.Write([]byte(fmt.Sprintf("repo index: group=%q repo=%q", "/"+strings.Join(g, "/")+"/", repo)))
+func (h *handler) groupIndex(w http.ResponseWriter, r *http.Request, _ wtypes.Vars) {
+ base := wtypes.Base(r)
+ _, _ = w.Write([]byte("group index for: /" + strings.Join(base.GroupPath, "/") + "/"))
}
-func (h *handler) repoTree(w http.ResponseWriter, r *http.Request, p Params) {
- repo := p["repo"].(string)
- rest := p["rest"].(string) // may be ""
- if p["dir_mode"].(bool) && rest != "" && !strings.HasSuffix(rest, "/") {
+func (h *handler) repoTree(w http.ResponseWriter, r *http.Request, v wtypes.Vars) {
+ base := wtypes.Base(r)
+ repo := v["repo"]
+ rest := v["rest"] // may be ""
+ if base.DirMode && rest != "" && !strings.HasSuffix(rest, "/") {
rest += "/"
}
_, _ = w.Write([]byte(fmt.Sprintf("tree: repo=%q path=%q", repo, rest)))
}
-func (h *handler) repoRaw(w http.ResponseWriter, r *http.Request, p Params) {
- repo := p["repo"].(string)
- rest := p["rest"].(string)
- if p["dir_mode"].(bool) && rest != "" && !strings.HasSuffix(rest, "/") {
+func (h *handler) repoRaw(w http.ResponseWriter, r *http.Request, v wtypes.Vars) {
+ base := wtypes.Base(r)
+ repo := v["repo"]
+ rest := v["rest"]
+ if base.DirMode && rest != "" && !strings.HasSuffix(rest, "/") {
rest += "/"
}
_, _ = w.Write([]byte(fmt.Sprintf("raw: repo=%q path=%q", repo, rest)))
}
-func (h *handler) notImplemented(w http.ResponseWriter, _ *http.Request, _ Params) {
+func (h *handler) notImplemented(w http.ResponseWriter, _ *http.Request, _ wtypes.Vars) {
http.Error(w, "not implemented", http.StatusNotImplemented)
}