summaryrefslogtreecommitdiff
path: root/server/cmd
diff options
context:
space:
mode:
authorMichael Hunteman <michael@huntm.net>2024-05-18 15:04:43 -0700
committerMichael Hunteman <michael@huntm.net>2024-05-18 15:04:43 -0700
commit0b2490ed46d1958625dc3c660455a5465adaf763 (patch)
tree690cf84c318fc814d96d57433b64d1d068999000 /server/cmd
parent07c92081b91552e99f02b4c5e3a454a1d4e2d41b (diff)
Add more error handling
Diffstat (limited to 'server/cmd')
-rw-r--r--server/cmd/main.go21
1 files changed, 21 insertions, 0 deletions
diff --git a/server/cmd/main.go b/server/cmd/main.go
index ed4f748..3cd118d 100644
--- a/server/cmd/main.go
+++ b/server/cmd/main.go
@@ -35,11 +35,13 @@ func (h *guestHandler) getGuests(w http.ResponseWriter, _ *http.Request) {
guests, err := h.store.Get()
if err != nil {
http.Error(w, err.Error(), http.StatusBadRequest)
+ return
}
jsonBytes, err := json.Marshal(guests)
if err != nil {
http.Error(w, err.Error(), http.StatusBadRequest)
+ return
}
w.WriteHeader(http.StatusOK)
@@ -55,6 +57,19 @@ func (h *guestHandler) createGuest(w http.ResponseWriter, r *http.Request) {
return
}
+ guests, err := h.store.Get()
+ if err != nil {
+ http.Error(w, err.Error(), http.StatusBadRequest)
+ return
+ }
+
+ for _, g := range guests {
+ if g.Id == guest.Id {
+ http.Error(w, "Id already exists", http.StatusBadRequest)
+ return
+ }
+ }
+
err = h.store.Add(guest.Id, guest)
if err != nil {
http.Error(w, err.Error(), http.StatusBadRequest)
@@ -68,6 +83,7 @@ func (h *guestHandler) updateGuest(w http.ResponseWriter, r *http.Request) {
matches := guestIdRe.FindStringSubmatch(r.URL.Path)
if len(matches) < 2 {
http.Error(w, "No id found", http.StatusBadRequest)
+ return
}
var guest guests.Guest
@@ -75,16 +91,19 @@ func (h *guestHandler) updateGuest(w http.ResponseWriter, r *http.Request) {
defer r.Body.Close()
if err != nil {
http.Error(w, err.Error(), http.StatusBadRequest)
+ return
}
id, err := strconv.Atoi(matches[1])
if err != nil {
http.Error(w, "Cannot convert string to integer", http.StatusBadRequest)
+ return
}
err = h.store.Update(id, guest)
if err != nil {
http.Error(w, "Guest not found", http.StatusBadRequest)
+ return
}
}
@@ -96,6 +115,8 @@ func (h *guestHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
h.createGuest(w, r)
case r.Method == http.MethodPut && guestIdRe.MatchString(r.URL.Path):
h.updateGuest(w, r)
+ default:
+ w.WriteHeader(http.StatusNotFound)
}
}