unread_entries.go 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  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. "fmt"
  6. "net/http"
  7. "time"
  8. "miniflux.app/v2/internal/config"
  9. "miniflux.app/v2/internal/http/request"
  10. "miniflux.app/v2/internal/http/response/html"
  11. "miniflux.app/v2/internal/http/route"
  12. "miniflux.app/v2/internal/model"
  13. "miniflux.app/v2/internal/ui/session"
  14. "miniflux.app/v2/internal/ui/view"
  15. )
  16. func (h *handler) showUnreadPage(w http.ResponseWriter, r *http.Request) {
  17. beginPreProcessing := time.Now()
  18. user, err := h.store.UserByID(request.UserID(r))
  19. if err != nil {
  20. html.ServerError(w, r, err)
  21. return
  22. }
  23. beginSqlCountUnreadEntries := time.Now()
  24. offset := request.QueryIntParam(r, "offset", 0)
  25. builder := h.store.NewEntryQueryBuilder(user.ID)
  26. builder.WithStatus(model.EntryStatusUnread)
  27. builder.WithGloballyVisible()
  28. countUnread, err := builder.CountEntries()
  29. if err != nil {
  30. html.ServerError(w, r, err)
  31. return
  32. }
  33. finishSqlCountUnreadEntries := time.Now()
  34. if offset >= countUnread {
  35. offset = 0
  36. }
  37. beginSqlFetchUnreadEntries := time.Now()
  38. builder = h.store.NewEntryQueryBuilder(user.ID)
  39. builder.WithStatus(model.EntryStatusUnread)
  40. builder.WithSorting(user.EntryOrder, user.EntryDirection)
  41. builder.WithSorting("id", user.EntryDirection)
  42. builder.WithOffset(offset)
  43. builder.WithLimit(user.EntriesPerPage)
  44. builder.WithGloballyVisible()
  45. entries, err := builder.GetEntries()
  46. if err != nil {
  47. html.ServerError(w, r, err)
  48. return
  49. }
  50. finishSqlFetchUnreadEntries := time.Now()
  51. sess := session.New(h.store, request.SessionID(r))
  52. view := view.New(h.tpl, r, sess)
  53. view.Set("entries", entries)
  54. view.Set("pagination", getPagination(route.Path(h.router, "unread"), countUnread, offset, user.EntriesPerPage))
  55. view.Set("menu", "unread")
  56. view.Set("user", user)
  57. view.Set("countUnread", countUnread)
  58. view.Set("countErrorFeeds", h.store.CountUserFeedsWithErrors(user.ID))
  59. view.Set("hasSaveEntry", h.store.HasSaveEntry(user.ID))
  60. finishPreProcessing := time.Now()
  61. beginTemplateRendering := time.Now()
  62. render := view.Render("unread_entries")
  63. finishTemplateRendering := time.Now()
  64. if config.Opts.HasServerTimingHeader() {
  65. w.Header().Set("Server-Timing", fmt.Sprintf("pre_processing;dur=%d,sql_count_unread_entries;dur=%d,sql_fetch_unread_entries;dur=%d,template_rendering;dur=%d",
  66. finishPreProcessing.Sub(beginPreProcessing).Milliseconds(),
  67. finishSqlCountUnreadEntries.Sub(beginSqlCountUnreadEntries).Milliseconds(),
  68. finishSqlFetchUnreadEntries.Sub(beginSqlFetchUnreadEntries).Milliseconds(),
  69. finishTemplateRendering.Sub(beginTemplateRendering).Milliseconds(),
  70. ))
  71. }
  72. html.OK(w, r, render)
  73. }