feed.go 4.7 KB

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