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
|
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"`
|
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
|
// GetListByID returns a list by its ID
|
||||||
func GetListByID(id int64) (list List, err error) {
|
func GetListByID(id int64) (list List, err error) {
|
||||||
exists, err := x.ID(id).Get(&list) // tName ist hässlich, geht das nicht auch anders?
|
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}
|
return list, ErrListDoesNotExist{ID: id}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get the list owner
|
/*items, err := GetItemsByListID(list.ID)
|
||||||
list.Owner, _, err = GetUserByID(list.OwnerID)
|
|
||||||
if err != nil {
|
|
||||||
return List{}, err
|
|
||||||
}
|
|
||||||
|
|
||||||
items, err := GetItemsByListID(list.ID)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
list.Items = items
|
list.Items = items*/
|
||||||
|
|
||||||
return list, nil
|
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.POST("/tokenTest", apiv1.CheckToken)
|
||||||
|
|
||||||
a.GET("/lists", apiv1.GetListsByUser)
|
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.POST("/lists/:id", apiv1.UpdateList)
|
||||||
a.PUT("/lists/:id", apiv1.AddListItem)
|
a.PUT("/lists/:id", apiv1.AddListItem)
|
||||||
a.DELETE("/lists/:id", apiv1.DeleteListByID)
|
a.DELETE("/lists/:id", apiv1.DeleteListByID)
|
||||||
|
|
Loading…
Reference in a new issue