feed.go 3.8 KB

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