package handlers import ( "fmt" "strconv" "demoon/config" "demoon/internal/database/repos" "demoon/internal/models" "html/template" "log/slog" "net/http" "os" ) // Handlers structure type Handlers struct { cfg config.Config log *slog.Logger repo repos.FullRepo } // NewHandlers constructor func NewHandlers( cfg config.Config, l *slog.Logger, repo repos.FullRepo, ) *Handlers { if l == nil { l = slog.New(slog.NewJSONHandler(os.Stdout, nil)) } h := &Handlers{ cfg: cfg, log: l, repo: repo, } return h } func (h *Handlers) Ping(w http.ResponseWriter, r *http.Request) { h.log.Info("got ping request") w.Write([]byte("pong")) } func (h *Handlers) HandleAnswer(w http.ResponseWriter, r *http.Request) { if err := r.ParseForm(); err != nil { h.log.Error("failed to parse form", "error", err) abortWithError(w, "Invalid form data") return } selectedIndex := r.FormValue("selected") questionID := r.FormValue("question_id") if selectedIndex == "" || questionID == "" { h.log.Error("missing form values", "selected", selectedIndex, "question_id", questionID) abortWithError(w, "Missing required fields") return } h.log.Info("answer received", "selected", selectedIndex, "question_id", questionID) question, err := h.repo.DBGetQuestion(questionID) if err != nil { h.log.Error("failed to get question", "error", err, "question_id", questionID) abortWithError(w, "Question not found") return } // Convert selectedIndex to int for comparison selectedIdx, err := strconv.Atoi(selectedIndex) if err != nil { h.log.Error("invalid selected index", "error", err, "selected", selectedIndex) abortWithError(w, "Invalid answer selection") return } // Validate selected index is within bounds if selectedIdx < 0 || selectedIdx > 3 { h.log.Error("selected index out of bounds", "selected", selectedIndex) abortWithError(w, "Invalid answer selection") return } feedback := "" if selectedIdx == int(question.CorrectIndex) { feedback = `