diff options
author | Runxi Yu <me@runxiyu.org> | 2025-02-13 00:31:48 +0800 |
---|---|---|
committer | Runxi Yu <me@runxiyu.org> | 2025-02-13 00:32:01 +0800 |
commit | d87f80d3e14990e5d9fc83990ff04e29affa3a94 (patch) | |
tree | 5df543f16b96388c1dc7c6456c24d8b0d66b9d5d /http_handle_group_index.go | |
parent | README.md: Add a bit of detail (diff) | |
download | forge-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.go | 42 |
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 + } +} |