implement message deletion

This commit is contained in:
2025-03-25 13:26:19 -04:00
parent 02643c1197
commit 9870b79854
4 changed files with 55 additions and 0 deletions

View File

@@ -41,6 +41,7 @@ func Start() {
r.Route("/{messageID}", func(r chi.Router) {
r.Use(MessageCtx) // Load message
r.Get("/", GetMessage)
r.Delete("/", DeleteMessage)
})
r.Post("/new", NewMessage)
})

View File

@@ -97,3 +97,7 @@ func dbAddMessage(message *Message) error {
}
return db.AddMessage(dbMessage)
}
func dbDeleteMessage(id string) error {
return db.DeleteMessage(id)
}

View File

@@ -48,6 +48,23 @@ func GetMessage(w http.ResponseWriter, r *http.Request) {
}
func DeleteMessage(w http.ResponseWriter, r *http.Request) {
if r.Method != http.MethodDelete {
http.Error(w, "Invalid request method", http.StatusMethodNotAllowed)
return
}
message, ok := r.Context().Value(messageKey{}).(*Message)
if !ok || message == nil {
render.Render(w, r, ErrNotFound)
return
}
dbDeleteMessage(message.ID)
if err := render.Render(w, r, NewMessageResponse(message)); err != nil {
render.Render(w, r, ErrRender(err))
return
}
}
func ListMessages(w http.ResponseWriter, r *http.Request) {
dbMessages, err := dbGetAllMessages()
if err != nil {

View File

@@ -93,3 +93,36 @@ func AddMessage(message map[string]interface{}) error {
messages = append(messages, message)
return WriteDB("messages", messages)
}
func DeleteMessage(messageID string) error {
currentData := ExecDB("messages")
if currentData == nil {
return fmt.Errorf("error reading messages database")
}
messages, ok := currentData["messages"].([]interface{})
if !ok {
return fmt.Errorf("messages data is in an unexpected format")
}
var updatedMessages []interface{}
found := false
for _, value := range messages {
if item, ok := value.(map[string]interface{}); ok {
if id, exists := item["ID"]; exists {
if idStr, ok := id.(string); ok && idStr == messageID {
found = true
continue
}
}
}
updatedMessages = append(updatedMessages, value)
}
if !found {
return fmt.Errorf("message with ID %s not found", messageID)
}
return WriteDB("messages", updatedMessages)
}