opml_upload.go 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. // Copyright 2018 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 ui // import "miniflux.app/ui"
  5. import (
  6. "net/http"
  7. "miniflux.app/config"
  8. "miniflux.app/http/client"
  9. "miniflux.app/http/request"
  10. "miniflux.app/http/response/html"
  11. "miniflux.app/http/route"
  12. "miniflux.app/logger"
  13. "miniflux.app/reader/opml"
  14. "miniflux.app/ui/session"
  15. "miniflux.app/ui/view"
  16. )
  17. func (h *handler) uploadOPML(w http.ResponseWriter, r *http.Request) {
  18. user, err := h.store.UserByID(request.UserID(r))
  19. if err != nil {
  20. html.ServerError(w, r, err)
  21. return
  22. }
  23. file, fileHeader, err := r.FormFile("file")
  24. if err != nil {
  25. logger.Error("[UI:UploadOPML] %v", err)
  26. html.Redirect(w, r, route.Path(h.router, "import"))
  27. return
  28. }
  29. defer file.Close()
  30. logger.Debug(
  31. "[UI:UploadOPML] User #%d uploaded this file: %s (%d bytes)",
  32. user.ID,
  33. fileHeader.Filename,
  34. fileHeader.Size,
  35. )
  36. sess := session.New(h.store, request.SessionID(r))
  37. view := view.New(h.tpl, r, sess)
  38. view.Set("menu", "feeds")
  39. view.Set("user", user)
  40. view.Set("countUnread", h.store.CountUnreadEntries(user.ID))
  41. view.Set("countErrorFeeds", h.store.CountUserFeedsWithErrors(user.ID))
  42. if fileHeader.Size == 0 {
  43. view.Set("errorMessage", "error.empty_file")
  44. html.OK(w, r, view.Render("import"))
  45. return
  46. }
  47. if impErr := opml.NewHandler(h.store).Import(user.ID, file); impErr != nil {
  48. view.Set("errorMessage", impErr)
  49. html.OK(w, r, view.Render("import"))
  50. return
  51. }
  52. html.Redirect(w, r, route.Path(h.router, "feeds"))
  53. }
  54. func (h *handler) fetchOPML(w http.ResponseWriter, r *http.Request) {
  55. user, err := h.store.UserByID(request.UserID(r))
  56. if err != nil {
  57. html.ServerError(w, r, err)
  58. return
  59. }
  60. url := r.FormValue("url")
  61. if url == "" {
  62. html.Redirect(w, r, route.Path(h.router, "import"))
  63. return
  64. }
  65. logger.Debug(
  66. "[UI:FetchOPML] User #%d fetching this URL: %s",
  67. user.ID,
  68. url,
  69. )
  70. sess := session.New(h.store, request.SessionID(r))
  71. view := view.New(h.tpl, r, sess)
  72. view.Set("menu", "feeds")
  73. view.Set("user", user)
  74. view.Set("countUnread", h.store.CountUnreadEntries(user.ID))
  75. view.Set("countErrorFeeds", h.store.CountUserFeedsWithErrors(user.ID))
  76. clt := client.NewClientWithConfig(url, config.Opts)
  77. resp, err := clt.Get()
  78. if err != nil {
  79. view.Set("errorMessage", err)
  80. html.OK(w, r, view.Render("import"))
  81. return
  82. }
  83. if impErr := opml.NewHandler(h.store).Import(user.ID, resp.Body); impErr != nil {
  84. view.Set("errorMessage", impErr)
  85. html.OK(w, r, view.Render("import"))
  86. return
  87. }
  88. html.Redirect(w, r, route.Path(h.router, "feeds"))
  89. }