Hi… I am well aware that this diff view is very suboptimal. It will be fixed when the refactored server comes along!
handle_index: Query group names from database
package main import ( "net/http"
"os"
)
func handle_index(w http.ResponseWriter, r *http.Request) {
	data := make(map[string]any)
entries, err := os.ReadDir(config.Git.Root)
rows, err := database.Query(r.Context(), "SELECT name FROM groups")
	if err != nil {
		_, _ = w.Write([]byte("Error listing groups: " + err.Error()))
		_, _ = w.Write([]byte("Error querying groups: " + err.Error()))
return }
defer rows.Close()
	groups := []string{}
	for _, entry := range entries {
		groups = append(groups, entry.Name())
	for rows.Next() {
		var groupName string
		if err := rows.Scan(&groupName); err != nil {
			_, _ = w.Write([]byte("Error scanning group name: " + err.Error()))
			return
		}
		groups = append(groups, groupName)
}
	if err := rows.Err(); err != nil {
		_, _ = w.Write([]byte("Error iterating over rows: " + err.Error()))
		return
	}
	data["groups"] = groups
	err = templates.ExecuteTemplate(w, "index", data)
	if err != nil {
		_, _ = w.Write([]byte("Error rendering template: " + err.Error()))
		return
	}
}