category.go 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  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/server/api/payload"
  8. "github.com/miniflux/miniflux/server/core"
  9. )
  10. // CreateCategory is the API handler to create a new category.
  11. func (c *Controller) CreateCategory(ctx *core.Context, request *core.Request, response *core.Response) {
  12. userID := ctx.UserID()
  13. category, err := payload.DecodeCategoryPayload(request.Body())
  14. if err != nil {
  15. response.JSON().BadRequest(err)
  16. return
  17. }
  18. category.UserID = userID
  19. if err := category.ValidateCategoryCreation(); err != nil {
  20. response.JSON().BadRequest(err)
  21. return
  22. }
  23. if c, err := c.store.CategoryByTitle(userID, category.Title); err != nil || c != nil {
  24. response.JSON().BadRequest(errors.New("This category already exists"))
  25. return
  26. }
  27. err = c.store.CreateCategory(category)
  28. if err != nil {
  29. response.JSON().ServerError(errors.New("Unable to create this category"))
  30. return
  31. }
  32. response.JSON().Created(category)
  33. }
  34. // UpdateCategory is the API handler to update a category.
  35. func (c *Controller) UpdateCategory(ctx *core.Context, request *core.Request, response *core.Response) {
  36. categoryID, err := request.IntegerParam("categoryID")
  37. if err != nil {
  38. response.JSON().BadRequest(err)
  39. return
  40. }
  41. category, err := payload.DecodeCategoryPayload(request.Body())
  42. if err != nil {
  43. response.JSON().BadRequest(err)
  44. return
  45. }
  46. category.UserID = ctx.UserID()
  47. category.ID = categoryID
  48. if err := category.ValidateCategoryModification(); err != nil {
  49. response.JSON().BadRequest(err)
  50. return
  51. }
  52. err = c.store.UpdateCategory(category)
  53. if err != nil {
  54. response.JSON().ServerError(errors.New("Unable to update this category"))
  55. return
  56. }
  57. response.JSON().Created(category)
  58. }
  59. // GetCategories is the API handler to get a list of categories for a given user.
  60. func (c *Controller) GetCategories(ctx *core.Context, request *core.Request, response *core.Response) {
  61. categories, err := c.store.Categories(ctx.UserID())
  62. if err != nil {
  63. response.JSON().ServerError(errors.New("Unable to fetch categories"))
  64. return
  65. }
  66. response.JSON().Standard(categories)
  67. }
  68. // RemoveCategory is the API handler to remove a category.
  69. func (c *Controller) RemoveCategory(ctx *core.Context, request *core.Request, response *core.Response) {
  70. userID := ctx.UserID()
  71. categoryID, err := request.IntegerParam("categoryID")
  72. if err != nil {
  73. response.JSON().BadRequest(err)
  74. return
  75. }
  76. if !c.store.CategoryExists(userID, categoryID) {
  77. response.JSON().NotFound(errors.New("Category not found"))
  78. return
  79. }
  80. if err := c.store.RemoveCategory(userID, categoryID); err != nil {
  81. response.JSON().ServerError(errors.New("Unable to remove this category"))
  82. return
  83. }
  84. response.JSON().NoContent()
  85. }