Added method to delete a todo item from a list

This commit is contained in:
kolaente 2018-06-12 18:07:47 +02:00
parent 91f67dc364
commit 853fb2a2b7
Signed by untrusted user: konrad
GPG Key ID: F40E70337AB24C9B
4 changed files with 39 additions and 1 deletions

View File

@ -38,11 +38,15 @@ Ab v0.3 können wir mit clients anfangen.
* [ ] Todopunkte hinzufügen/abhaken/löschen
* [x] Erstellen
* [ ] Bearbeiten (abhaken)
* [ ] Löschen
* [x] Löschen
#### v0.2
* [ ] Listen teilbar
* [ ] Mit anderen Nutzern
* [ ] Mit Link
* [ ] Offen
* [ ] Passwortgeschützt
#### v0.3

View File

@ -64,3 +64,10 @@ func GetItemsByListID(listID int64) (items []*ListItem, err error) {
return
}
// DeleteListItemByID deletes a list item by its ID
func DeleteListItemByIDtemByID(itemID int64) (err error) {
_, err = x.ID(itemID).Delete(ListItem{})
return
}

View File

@ -0,0 +1,25 @@
package v1
import (
"github.com/labstack/echo"
"strconv"
"net/http"
"git.kolaente.de/konrad/list/models"
)
func DeleteListItemByIDtemByID(c echo.Context) error {
// Check if we have our ID
id := c.Param("id")
// Make int
itemID, err := strconv.ParseInt(id, 10, 64)
if err != nil {
return c.JSON(http.StatusBadRequest, models.Message{"Invalid ID."})
}
err = models.DeleteListItemByIDtemByID(itemID)
if err != nil {
return c.JSON(http.StatusInternalServerError, models.Message{"An error occured."})
}
return c.JSON(http.StatusOK, models.Message{"The item was deleted with success."})
}

View File

@ -58,4 +58,6 @@ func RegisterRoutes(e *echo.Echo) {
a.GET("/lists/:id", apiv1.GetListByID)
a.POST("/lists/:id", apiv1.AddOrUpdateList)
a.PUT("/lists/:id", apiv1.AddOrUpdateListItem)
a.DELETE("/item/:id", apiv1.DeleteListItemByIDtemByID)
}