feed_refresh.go 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. // SPDX-FileCopyrightText: Copyright The Miniflux Authors. All rights reserved.
  2. // SPDX-License-Identifier: Apache-2.0
  3. package ui // import "miniflux.app/v2/internal/ui"
  4. import (
  5. "log/slog"
  6. "net/http"
  7. "miniflux.app/v2/internal/http/request"
  8. "miniflux.app/v2/internal/http/response/html"
  9. "miniflux.app/v2/internal/http/route"
  10. feedHandler "miniflux.app/v2/internal/reader/handler"
  11. )
  12. func (h *handler) refreshFeed(w http.ResponseWriter, r *http.Request) {
  13. feedID := request.RouteInt64Param(r, "feedID")
  14. forceRefresh := request.QueryBoolParam(r, "forceRefresh", false)
  15. if err := feedHandler.RefreshFeed(h.store, request.UserID(r), feedID, forceRefresh); err != nil {
  16. slog.Warn("Unable to refresh feed",
  17. slog.Int64("user_id", request.UserID(r)),
  18. slog.Int64("feed_id", feedID),
  19. slog.Bool("force_refresh", forceRefresh),
  20. slog.Any("error", err),
  21. )
  22. }
  23. html.Redirect(w, r, route.Path(h.router, "feedEntries", "feedID", feedID))
  24. }
  25. func (h *handler) refreshAllFeeds(w http.ResponseWriter, r *http.Request) {
  26. userID := request.UserID(r)
  27. jobs, err := h.store.NewUserBatch(userID, h.store.CountFeeds(userID))
  28. if err != nil {
  29. html.ServerError(w, r, err)
  30. return
  31. }
  32. go func() {
  33. h.pool.Push(jobs)
  34. }()
  35. html.Redirect(w, r, route.Path(h.router, "feeds"))
  36. }