diff options
author | 2017-12-24 18:04:34 -0800 | |
---|---|---|
committer | 2017-12-24 18:04:34 -0800 | |
commit | d5b8f2fb8839189bdf6893da0f86f3bb26001d3d (patch) | |
tree | a62d6ac75f2ede87f750a7083f7ef8e7a5308ab2 /server/api/controller | |
parent | 3f473e4a0910d95bc5adb57d367f6f3a060de08d (diff) | |
download | v2-d5b8f2fb8839189bdf6893da0f86f3bb26001d3d.tar.gz v2-d5b8f2fb8839189bdf6893da0f86f3bb26001d3d.tar.zst v2-d5b8f2fb8839189bdf6893da0f86f3bb26001d3d.zip |
Improve API
Diffstat (limited to 'server/api/controller')
-rw-r--r-- | server/api/controller/category.go | 10 | ||||
-rw-r--r-- | server/api/controller/feed.go | 36 |
2 files changed, 44 insertions, 2 deletions
diff --git a/server/api/controller/category.go b/server/api/controller/category.go index 13a7438e..d7b2922b 100644 --- a/server/api/controller/category.go +++ b/server/api/controller/category.go @@ -13,15 +13,21 @@ import ( // CreateCategory is the API handler to create a new category. func (c *Controller) CreateCategory(ctx *core.Context, request *core.Request, response *core.Response) { + userID := ctx.UserID() category, err := payload.DecodeCategoryPayload(request.Body()) if err != nil { response.JSON().BadRequest(err) return } - category.UserID = ctx.UserID() + category.UserID = userID if err := category.ValidateCategoryCreation(); err != nil { - response.JSON().ServerError(err) + response.JSON().BadRequest(err) + return + } + + if c, err := c.store.CategoryByTitle(userID, category.Title); err != nil || c != nil { + response.JSON().BadRequest(errors.New("This category already exists")) return } diff --git a/server/api/controller/feed.go b/server/api/controller/feed.go index f0212c97..fcaeee78 100644 --- a/server/api/controller/feed.go +++ b/server/api/controller/feed.go @@ -20,6 +20,26 @@ func (c *Controller) CreateFeed(ctx *core.Context, request *core.Request, respon return } + if feedURL == "" { + response.JSON().BadRequest(errors.New("The feed_url is required")) + return + } + + if categoryID <= 0 { + response.JSON().BadRequest(errors.New("The category_id is required")) + return + } + + if c.store.FeedURLExists(userID, feedURL) { + response.JSON().BadRequest(errors.New("This feed_url already exists")) + return + } + + if !c.store.CategoryExists(userID, categoryID) { + response.JSON().BadRequest(errors.New("This category_id doesn't exists or doesn't belongs to this user")) + return + } + feed, err := c.feedHandler.CreateFeed(userID, categoryID, feedURL, false) if err != nil { response.JSON().ServerError(errors.New("Unable to create this feed")) @@ -42,6 +62,11 @@ func (c *Controller) RefreshFeed(ctx *core.Context, request *core.Request, respo return } + if !c.store.FeedExists(userID, feedID) { + response.JSON().NotFound(errors.New("Unable to find this feed")) + return + } + err = c.feedHandler.RefreshFeed(userID, feedID) if err != nil { response.JSON().ServerError(errors.New("Unable to refresh this feed")) @@ -66,6 +91,11 @@ func (c *Controller) UpdateFeed(ctx *core.Context, request *core.Request, respon return } + if newFeed.Category != nil && newFeed.Category.ID != 0 && !c.store.CategoryExists(userID, newFeed.Category.ID) { + response.JSON().BadRequest(errors.New("This category_id doesn't exists or doesn't belongs to this user")) + return + } + originalFeed, err := c.store.FeedByID(userID, feedID) if err != nil { response.JSON().NotFound(errors.New("Unable to find this feed")) @@ -83,6 +113,12 @@ func (c *Controller) UpdateFeed(ctx *core.Context, request *core.Request, respon return } + originalFeed, err = c.store.FeedByID(userID, feedID) + if err != nil { + response.JSON().ServerError(errors.New("Unable to fetch this feed")) + return + } + response.JSON().Created(originalFeed) } |