Added CRUD helper method
This commit is contained in:
parent
2d0d074f89
commit
490f32d46b
4 changed files with 88 additions and 9 deletions
|
@ -14,3 +14,16 @@ func GetIntURLParam(param string, c echo.Context) (intParam int64, err error) {
|
|||
|
||||
return intParam, err
|
||||
}
|
||||
|
||||
func GetByID(id int64, result interface{}) (err error) {
|
||||
exists, err := x.ID(id).Get(result)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
if !exists {
|
||||
return ErrListDoesNotExist{}
|
||||
}
|
||||
|
||||
return
|
||||
}
|
|
@ -15,6 +15,15 @@ type List struct {
|
|||
Updated int64 `xorm:"updated" json:"updated"`
|
||||
}
|
||||
|
||||
func (l *List) AfterLoad() {
|
||||
|
||||
// Get the owner
|
||||
l.Owner, _, _ = GetUserByID(l.OwnerID)
|
||||
|
||||
// Get the list items
|
||||
l.Items, _ = GetItemsByListID(l.ID)
|
||||
}
|
||||
|
||||
// GetListByID returns a list by its ID
|
||||
func GetListByID(id int64) (list List, err error) {
|
||||
exists, err := x.ID(id).Get(&list) // tName ist hässlich, geht das nicht auch anders?
|
||||
|
@ -26,17 +35,11 @@ func GetListByID(id int64) (list List, err error) {
|
|||
return list, ErrListDoesNotExist{ID: id}
|
||||
}
|
||||
|
||||
// Get the list owner
|
||||
list.Owner, _, err = GetUserByID(list.OwnerID)
|
||||
if err != nil {
|
||||
return List{}, err
|
||||
}
|
||||
|
||||
items, err := GetItemsByListID(list.ID)
|
||||
/*items, err := GetItemsByListID(list.ID)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
list.Items = items
|
||||
list.Items = items*/
|
||||
|
||||
return list, nil
|
||||
}
|
||||
|
|
57
routes/api/v1/CRUD_helper.go
Normal file
57
routes/api/v1/CRUD_helper.go
Normal file
|
@ -0,0 +1,57 @@
|
|||
package v1
|
||||
|
||||
import (
|
||||
"git.kolaente.de/konrad/list/models"
|
||||
"github.com/labstack/echo"
|
||||
"net/http"
|
||||
"strconv"
|
||||
)
|
||||
|
||||
// Basic Method definitions
|
||||
type CRUD interface {
|
||||
Create()
|
||||
Read(int64) (error)
|
||||
Update()
|
||||
Delete()
|
||||
}
|
||||
|
||||
// We use this to acces the default methods
|
||||
type DefaultCRUD struct {
|
||||
CRUD
|
||||
Target interface{}
|
||||
}
|
||||
|
||||
// This method gets our data, which will be called by ReadWeb()
|
||||
func (d *DefaultCRUD) Read(id int64) (err error) {
|
||||
return models.GetByID(id, d.Target)
|
||||
}
|
||||
|
||||
// This does web stuff, aka returns json etc. Uses DefaultCRUD Methods to get the data
|
||||
type CRUDWebHandler struct {
|
||||
CObject CRUD
|
||||
}
|
||||
|
||||
// This does json, handles the request
|
||||
func (c *CRUDWebHandler) ReadOneWeb(ctx echo.Context) error {
|
||||
|
||||
// Get the ID
|
||||
id, err := strconv.ParseInt(ctx.Param("id"), 10, 64)
|
||||
if err != nil {
|
||||
return ctx.JSON(http.StatusBadRequest, models.Message{"Invalid ID."})
|
||||
}
|
||||
|
||||
// TODO check rights
|
||||
|
||||
// Get our object
|
||||
err = c.CObject.Read(id)
|
||||
if err != nil {
|
||||
if models.IsErrListDoesNotExist(err) {
|
||||
return ctx.JSON(http.StatusNotFound, models.Message{"Not found."})
|
||||
}
|
||||
|
||||
return ctx.JSON(http.StatusInternalServerError, models.Message{"An error occured."})
|
||||
}
|
||||
|
||||
// TODO how can we return c.CObject.Targetdirectly?
|
||||
return ctx.JSON(http.StatusOK, c.CObject)
|
||||
}
|
|
@ -84,7 +84,13 @@ func RegisterRoutes(e *echo.Echo) {
|
|||
a.POST("/tokenTest", apiv1.CheckToken)
|
||||
|
||||
a.GET("/lists", apiv1.GetListsByUser)
|
||||
a.GET("/lists/:id", apiv1.GetListByID)
|
||||
//a.GET("/lists/:id", apiv1.GetListByID)
|
||||
listHandler := &apiv1.CRUDWebHandler{
|
||||
CObject: &apiv1.DefaultCRUD{
|
||||
Target: &models.List{},
|
||||
},
|
||||
}
|
||||
a.GET("/lists/:id", listHandler.ReadOneWeb)
|
||||
a.POST("/lists/:id", apiv1.UpdateList)
|
||||
a.PUT("/lists/:id", apiv1.AddListItem)
|
||||
a.DELETE("/lists/:id", apiv1.DeleteListByID)
|
||||
|
|
Loading…
Reference in a new issue