cleanup_tasks.go 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. // SPDX-FileCopyrightText: Copyright The Miniflux Authors. All rights reserved.
  2. // SPDX-License-Identifier: Apache-2.0
  3. package cli // import "miniflux.app/v2/internal/cli"
  4. import (
  5. "log/slog"
  6. "time"
  7. "miniflux.app/v2/internal/config"
  8. "miniflux.app/v2/internal/metric"
  9. "miniflux.app/v2/internal/model"
  10. "miniflux.app/v2/internal/storage"
  11. )
  12. func runCleanupTasks(store *storage.Storage) {
  13. if nbWebSessions, err := store.CleanOldWebSessions(config.Opts.CleanupRemoveSessionsInterval()); err != nil {
  14. slog.Error("Unable to clean old web sessions", slog.Any("error", err))
  15. } else {
  16. slog.Info("Sessions cleanup completed",
  17. slog.Int64("web_sessions_removed", nbWebSessions),
  18. )
  19. }
  20. startTime := time.Now()
  21. if rowsAffected, err := store.ArchiveEntries(model.EntryStatusRead, config.Opts.CleanupArchiveReadInterval(), config.Opts.CleanupArchiveBatchSize()); err != nil {
  22. slog.Error("Unable to archive read entries", slog.Any("error", err))
  23. } else {
  24. slog.Info("Archiving read entries completed",
  25. slog.Int64("read_entries_archived", rowsAffected),
  26. )
  27. if config.Opts.HasMetricsCollector() {
  28. metric.ArchiveEntriesDuration.WithLabelValues(model.EntryStatusRead).Observe(time.Since(startTime).Seconds())
  29. }
  30. }
  31. startTime = time.Now()
  32. if rowsAffected, err := store.ArchiveEntries(model.EntryStatusUnread, config.Opts.CleanupArchiveUnreadInterval(), config.Opts.CleanupArchiveBatchSize()); err != nil {
  33. slog.Error("Unable to archive unread entries", slog.Any("error", err))
  34. } else {
  35. slog.Info("Archiving unread entries completed",
  36. slog.Int64("unread_entries_archived", rowsAffected),
  37. )
  38. if config.Opts.HasMetricsCollector() {
  39. metric.ArchiveEntriesDuration.WithLabelValues(model.EntryStatusUnread).Observe(time.Since(startTime).Seconds())
  40. }
  41. }
  42. if enclosuresAffected, err := store.DeleteEnclosuresOfRemovedEntries(); err != nil {
  43. slog.Error("Unable to delete enclosures from removed entries", slog.Any("error", err))
  44. } else {
  45. slog.Info("Deleting enclosures from removed entries completed",
  46. slog.Int64("removed_entries_enclosures_deleted", enclosuresAffected))
  47. }
  48. if contentAffected, err := store.ClearRemovedEntriesContent(config.Opts.CleanupArchiveBatchSize()); err != nil {
  49. slog.Error("Unable to clear content from removed entries", slog.Any("error", err))
  50. } else {
  51. slog.Info("Clearing content from removed entries completed",
  52. slog.Int64("removed_entries_content_cleared", contentAffected))
  53. }
  54. }