category.go 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. // Copyright 2017 Frédéric Guillot. All rights reserved.
  2. // Use of this source code is governed by the Apache 2.0
  3. // license that can be found in the LICENSE file.
  4. package api
  5. import (
  6. "errors"
  7. "github.com/miniflux/miniflux/http/handler"
  8. )
  9. // CreateCategory is the API handler to create a new category.
  10. func (c *Controller) CreateCategory(ctx *handler.Context, request *handler.Request, response *handler.Response) {
  11. userID := ctx.UserID()
  12. category, err := decodeCategoryPayload(request.Body())
  13. if err != nil {
  14. response.JSON().BadRequest(err)
  15. return
  16. }
  17. category.UserID = userID
  18. if err := category.ValidateCategoryCreation(); err != nil {
  19. response.JSON().BadRequest(err)
  20. return
  21. }
  22. if c, err := c.store.CategoryByTitle(userID, category.Title); err != nil || c != nil {
  23. response.JSON().BadRequest(errors.New("This category already exists"))
  24. return
  25. }
  26. err = c.store.CreateCategory(category)
  27. if err != nil {
  28. response.JSON().ServerError(errors.New("Unable to create this category"))
  29. return
  30. }
  31. response.JSON().Created(category)
  32. }
  33. // UpdateCategory is the API handler to update a category.
  34. func (c *Controller) UpdateCategory(ctx *handler.Context, request *handler.Request, response *handler.Response) {
  35. categoryID, err := request.IntegerParam("categoryID")
  36. if err != nil {
  37. response.JSON().BadRequest(err)
  38. return
  39. }
  40. category, err := decodeCategoryPayload(request.Body())
  41. if err != nil {
  42. response.JSON().BadRequest(err)
  43. return
  44. }
  45. category.UserID = ctx.UserID()
  46. category.ID = categoryID
  47. if err := category.ValidateCategoryModification(); err != nil {
  48. response.JSON().BadRequest(err)
  49. return
  50. }
  51. err = c.store.UpdateCategory(category)
  52. if err != nil {
  53. response.JSON().ServerError(errors.New("Unable to update this category"))
  54. return
  55. }
  56. response.JSON().Created(category)
  57. }
  58. // GetCategories is the API handler to get a list of categories for a given user.
  59. func (c *Controller) GetCategories(ctx *handler.Context, request *handler.Request, response *handler.Response) {
  60. categories, err := c.store.Categories(ctx.UserID())
  61. if err != nil {
  62. response.JSON().ServerError(errors.New("Unable to fetch categories"))
  63. return
  64. }
  65. response.JSON().Standard(categories)
  66. }
  67. // RemoveCategory is the API handler to remove a category.
  68. func (c *Controller) RemoveCategory(ctx *handler.Context, request *handler.Request, response *handler.Response) {
  69. userID := ctx.UserID()
  70. categoryID, err := request.IntegerParam("categoryID")
  71. if err != nil {
  72. response.JSON().BadRequest(err)
  73. return
  74. }
  75. if !c.store.CategoryExists(userID, categoryID) {
  76. response.JSON().NotFound(errors.New("Category not found"))
  77. return
  78. }
  79. if err := c.store.RemoveCategory(userID, categoryID); err != nil {
  80. response.JSON().ServerError(errors.New("Unable to remove this category"))
  81. return
  82. }
  83. response.JSON().NoContent()
  84. }