cleanup_tasks.go 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  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. nbSessions := store.CleanOldSessions(config.Opts.CleanupRemoveSessionsInterval())
  14. nbUserSessions := store.CleanOldUserSessions(config.Opts.CleanupRemoveSessionsInterval())
  15. slog.Info("Sessions cleanup completed",
  16. slog.Int64("application_sessions_removed", nbSessions),
  17. slog.Int64("user_sessions_removed", nbUserSessions),
  18. )
  19. startTime := time.Now()
  20. if rowsAffected, err := store.ArchiveEntries(model.EntryStatusRead, config.Opts.CleanupArchiveReadInterval(), config.Opts.CleanupArchiveBatchSize()); err != nil {
  21. slog.Error("Unable to archive read entries", slog.Any("error", err))
  22. } else {
  23. slog.Info("Archiving read entries completed",
  24. slog.Int64("read_entries_archived", rowsAffected),
  25. )
  26. if config.Opts.HasMetricsCollector() {
  27. metric.ArchiveEntriesDuration.WithLabelValues(model.EntryStatusRead).Observe(time.Since(startTime).Seconds())
  28. }
  29. }
  30. startTime = time.Now()
  31. if rowsAffected, err := store.ArchiveEntries(model.EntryStatusUnread, config.Opts.CleanupArchiveUnreadInterval(), config.Opts.CleanupArchiveBatchSize()); err != nil {
  32. slog.Error("Unable to archive unread entries", slog.Any("error", err))
  33. } else {
  34. slog.Info("Archiving unread entries completed",
  35. slog.Int64("unread_entries_archived", rowsAffected),
  36. )
  37. if config.Opts.HasMetricsCollector() {
  38. metric.ArchiveEntriesDuration.WithLabelValues(model.EntryStatusUnread).Observe(time.Since(startTime).Seconds())
  39. }
  40. }
  41. if enclosuresAffected, err := store.DeleteEnclosuresOfRemovedEntries(); err != nil {
  42. slog.Error("Unable to delete enclosures from removed entries", slog.Any("error", err))
  43. } else {
  44. slog.Info("Deleting enclosures from removed entries completed",
  45. slog.Int64("removed_entries_enclosures_deleted", enclosuresAffected))
  46. }
  47. if contentAffected, err := store.ClearRemovedEntriesContent(config.Opts.CleanupArchiveBatchSize()); err != nil {
  48. slog.Error("Unable to clear content from removed entries", slog.Any("error", err))
  49. } else {
  50. slog.Info("Clearing content from removed entries completed",
  51. slog.Int64("removed_entries_content_cleared", contentAffected))
  52. }
  53. }