implement message deletion
This commit is contained in:
@@ -41,6 +41,7 @@ func Start() {
|
|||||||
r.Route("/{messageID}", func(r chi.Router) {
|
r.Route("/{messageID}", func(r chi.Router) {
|
||||||
r.Use(MessageCtx) // Load message
|
r.Use(MessageCtx) // Load message
|
||||||
r.Get("/", GetMessage)
|
r.Get("/", GetMessage)
|
||||||
|
r.Delete("/", DeleteMessage)
|
||||||
})
|
})
|
||||||
r.Post("/new", NewMessage)
|
r.Post("/new", NewMessage)
|
||||||
})
|
})
|
||||||
|
@@ -97,3 +97,7 @@ func dbAddMessage(message *Message) error {
|
|||||||
}
|
}
|
||||||
return db.AddMessage(dbMessage)
|
return db.AddMessage(dbMessage)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func dbDeleteMessage(id string) error {
|
||||||
|
return db.DeleteMessage(id)
|
||||||
|
}
|
||||||
|
@@ -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) {
|
func ListMessages(w http.ResponseWriter, r *http.Request) {
|
||||||
dbMessages, err := dbGetAllMessages()
|
dbMessages, err := dbGetAllMessages()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@@ -93,3 +93,36 @@ func AddMessage(message map[string]interface{}) error {
|
|||||||
messages = append(messages, message)
|
messages = append(messages, message)
|
||||||
return WriteDB("messages", messages)
|
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)
|
||||||
|
}
|
||||||
|
Reference in New Issue
Block a user