aboutsummaryrefslogtreecommitdiff
path: root/http_handle_group_index.go
diff options
context:
space:
mode:
authorRunxi Yu <me@runxiyu.org>2025-02-13 00:31:48 +0800
committerRunxi Yu <me@runxiyu.org>2025-02-13 00:32:01 +0800
commitd87f80d3e14990e5d9fc83990ff04e29affa3a94 (patch)
tree5df543f16b96388c1dc7c6456c24d8b0d66b9d5d /http_handle_group_index.go
parentREADME.md: Add a bit of detail (diff)
downloadforge-d87f80d3e14990e5d9fc83990ff04e29affa3a94.tar.gz
forge-d87f80d3e14990e5d9fc83990ff04e29affa3a94.tar.zst
forge-d87f80d3e14990e5d9fc83990ff04e29affa3a94.zip
*.go: Mass rename files for clarity
Diffstat (limited to 'http_handle_group_index.go')
-rw-r--r--http_handle_group_index.go42
1 files changed, 42 insertions, 0 deletions
diff --git a/http_handle_group_index.go b/http_handle_group_index.go
new file mode 100644
index 0000000..2a8e1ca
--- /dev/null
+++ b/http_handle_group_index.go
@@ -0,0 +1,42 @@
+package main
+
+import (
+ "net/http"
+)
+
+func handle_group_repos(w http.ResponseWriter, r *http.Request, params map[string]string) {
+ data := make(map[string]any)
+ data["global"] = global_data
+ group_name := params["group_name"]
+ data["group_name"] = group_name
+
+ var names []string
+ rows, err := database.Query(r.Context(), "SELECT r.name FROM repos r JOIN groups g ON r.group_id = g.id WHERE g.name = $1;", group_name)
+ if err != nil {
+ _, _ = w.Write([]byte("Error getting groups: " + err.Error()))
+ return
+ }
+ defer rows.Close()
+
+ for rows.Next() {
+ var name string
+ if err := rows.Scan(&name); err != nil {
+ _, _ = w.Write([]byte("Error scanning row: " + err.Error()))
+ return
+ }
+ names = append(names, name)
+ }
+
+ if err := rows.Err(); err != nil {
+ _, _ = w.Write([]byte("Error iterating over rows: " + err.Error()))
+ return
+ }
+
+ data["repos"] = names
+
+ err = templates.ExecuteTemplate(w, "group_repos", data)
+ if err != nil {
+ _, _ = w.Write([]byte("Error rendering template: " + err.Error()))
+ return
+ }
+}