feed.go 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  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. // CreateFeed is the API handler to create a new feed.
  10. func (c *Controller) CreateFeed(ctx *handler.Context, request *handler.Request, response *handler.Response) {
  11. userID := ctx.UserID()
  12. feedURL, categoryID, err := decodeFeedCreationPayload(request.Body())
  13. if err != nil {
  14. response.JSON().BadRequest(err)
  15. return
  16. }
  17. if feedURL == "" {
  18. response.JSON().BadRequest(errors.New("The feed_url is required"))
  19. return
  20. }
  21. if categoryID <= 0 {
  22. response.JSON().BadRequest(errors.New("The category_id is required"))
  23. return
  24. }
  25. if c.store.FeedURLExists(userID, feedURL) {
  26. response.JSON().BadRequest(errors.New("This feed_url already exists"))
  27. return
  28. }
  29. if !c.store.CategoryExists(userID, categoryID) {
  30. response.JSON().BadRequest(errors.New("This category_id doesn't exists or doesn't belongs to this user"))
  31. return
  32. }
  33. feed, err := c.feedHandler.CreateFeed(userID, categoryID, feedURL, false)
  34. if err != nil {
  35. response.JSON().ServerError(errors.New("Unable to create this feed"))
  36. return
  37. }
  38. type result struct {
  39. FeedID int64 `json:"feed_id"`
  40. }
  41. response.JSON().Created(&result{FeedID: feed.ID})
  42. }
  43. // RefreshFeed is the API handler to refresh a feed.
  44. func (c *Controller) RefreshFeed(ctx *handler.Context, request *handler.Request, response *handler.Response) {
  45. userID := ctx.UserID()
  46. feedID, err := request.IntegerParam("feedID")
  47. if err != nil {
  48. response.JSON().BadRequest(err)
  49. return
  50. }
  51. if !c.store.FeedExists(userID, feedID) {
  52. response.JSON().NotFound(errors.New("Unable to find this feed"))
  53. return
  54. }
  55. err = c.feedHandler.RefreshFeed(userID, feedID)
  56. if err != nil {
  57. response.JSON().ServerError(errors.New("Unable to refresh this feed"))
  58. return
  59. }
  60. response.JSON().NoContent()
  61. }
  62. // UpdateFeed is the API handler that is used to update a feed.
  63. func (c *Controller) UpdateFeed(ctx *handler.Context, request *handler.Request, response *handler.Response) {
  64. userID := ctx.UserID()
  65. feedID, err := request.IntegerParam("feedID")
  66. if err != nil {
  67. response.JSON().BadRequest(err)
  68. return
  69. }
  70. newFeed, err := decodeFeedModificationPayload(request.Body())
  71. if err != nil {
  72. response.JSON().BadRequest(err)
  73. return
  74. }
  75. if newFeed.Category != nil && newFeed.Category.ID != 0 && !c.store.CategoryExists(userID, newFeed.Category.ID) {
  76. response.JSON().BadRequest(errors.New("This category_id doesn't exists or doesn't belongs to this user"))
  77. return
  78. }
  79. originalFeed, err := c.store.FeedByID(userID, feedID)
  80. if err != nil {
  81. response.JSON().NotFound(errors.New("Unable to find this feed"))
  82. return
  83. }
  84. if originalFeed == nil {
  85. response.JSON().NotFound(errors.New("Feed not found"))
  86. return
  87. }
  88. originalFeed.Merge(newFeed)
  89. if err := c.store.UpdateFeed(originalFeed); err != nil {
  90. response.JSON().ServerError(errors.New("Unable to update this feed"))
  91. return
  92. }
  93. originalFeed, err = c.store.FeedByID(userID, feedID)
  94. if err != nil {
  95. response.JSON().ServerError(errors.New("Unable to fetch this feed"))
  96. return
  97. }
  98. response.JSON().Created(originalFeed)
  99. }
  100. // GetFeeds is the API handler that get all feeds that belongs to the given user.
  101. func (c *Controller) GetFeeds(ctx *handler.Context, request *handler.Request, response *handler.Response) {
  102. feeds, err := c.store.Feeds(ctx.UserID())
  103. if err != nil {
  104. response.JSON().ServerError(errors.New("Unable to fetch feeds from the database"))
  105. return
  106. }
  107. response.JSON().Standard(feeds)
  108. }
  109. // GetFeed is the API handler to get a feed.
  110. func (c *Controller) GetFeed(ctx *handler.Context, request *handler.Request, response *handler.Response) {
  111. userID := ctx.UserID()
  112. feedID, err := request.IntegerParam("feedID")
  113. if err != nil {
  114. response.JSON().BadRequest(err)
  115. return
  116. }
  117. feed, err := c.store.FeedByID(userID, feedID)
  118. if err != nil {
  119. response.JSON().ServerError(errors.New("Unable to fetch this feed"))
  120. return
  121. }
  122. if feed == nil {
  123. response.JSON().NotFound(errors.New("Feed not found"))
  124. return
  125. }
  126. response.JSON().Standard(feed)
  127. }
  128. // RemoveFeed is the API handler to remove a feed.
  129. func (c *Controller) RemoveFeed(ctx *handler.Context, request *handler.Request, response *handler.Response) {
  130. userID := ctx.UserID()
  131. feedID, err := request.IntegerParam("feedID")
  132. if err != nil {
  133. response.JSON().BadRequest(err)
  134. return
  135. }
  136. if !c.store.FeedExists(userID, feedID) {
  137. response.JSON().NotFound(errors.New("Feed not found"))
  138. return
  139. }
  140. if err := c.store.RemoveFeed(userID, feedID); err != nil {
  141. response.JSON().ServerError(errors.New("Unable to remove this feed"))
  142. return
  143. }
  144. response.JSON().NoContent()
  145. }