diff options
author | 2023-08-10 19:46:45 -0700 | |
---|---|---|
committer | 2023-08-10 20:29:34 -0700 | |
commit | 168a870c025bfef6efdeb46e166e79a16093c157 (patch) | |
tree | 4d8ab69c7e3ef03a7ade06e7b5e5053429a64c3b /internal/cli/cleanup_tasks.go | |
parent | c2349032552891745cbbc3d2a9e772845a0239f4 (diff) | |
download | v2-168a870c025bfef6efdeb46e166e79a16093c157.tar.gz v2-168a870c025bfef6efdeb46e166e79a16093c157.tar.zst v2-168a870c025bfef6efdeb46e166e79a16093c157.zip |
Move internal packages to an internal folder
For reference: https://go.dev/doc/go1.4#internalpackages
Diffstat (limited to 'internal/cli/cleanup_tasks.go')
-rw-r--r-- | internal/cli/cleanup_tasks.go | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/internal/cli/cleanup_tasks.go b/internal/cli/cleanup_tasks.go new file mode 100644 index 00000000..f7e791e7 --- /dev/null +++ b/internal/cli/cleanup_tasks.go @@ -0,0 +1,42 @@ +// SPDX-FileCopyrightText: Copyright The Miniflux Authors. All rights reserved. +// SPDX-License-Identifier: Apache-2.0 + +package cli // import "miniflux.app/v2/internal/cli" + +import ( + "time" + + "miniflux.app/v2/internal/config" + "miniflux.app/v2/internal/logger" + "miniflux.app/v2/internal/metric" + "miniflux.app/v2/internal/model" + "miniflux.app/v2/internal/storage" +) + +func runCleanupTasks(store *storage.Storage) { + nbSessions := store.CleanOldSessions(config.Opts.CleanupRemoveSessionsDays()) + nbUserSessions := store.CleanOldUserSessions(config.Opts.CleanupRemoveSessionsDays()) + logger.Info("[Sessions] Removed %d application sessions and %d user sessions", nbSessions, nbUserSessions) + + startTime := time.Now() + if rowsAffected, err := store.ArchiveEntries(model.EntryStatusRead, config.Opts.CleanupArchiveReadDays(), config.Opts.CleanupArchiveBatchSize()); err != nil { + logger.Error("[ArchiveReadEntries] %v", err) + } else { + logger.Info("[ArchiveReadEntries] %d entries changed", rowsAffected) + + if config.Opts.HasMetricsCollector() { + metric.ArchiveEntriesDuration.WithLabelValues(model.EntryStatusRead).Observe(time.Since(startTime).Seconds()) + } + } + + startTime = time.Now() + if rowsAffected, err := store.ArchiveEntries(model.EntryStatusUnread, config.Opts.CleanupArchiveUnreadDays(), config.Opts.CleanupArchiveBatchSize()); err != nil { + logger.Error("[ArchiveUnreadEntries] %v", err) + } else { + logger.Info("[ArchiveUnreadEntries] %d entries changed", rowsAffected) + + if config.Opts.HasMetricsCollector() { + metric.ArchiveEntriesDuration.WithLabelValues(model.EntryStatusUnread).Observe(time.Since(startTime).Seconds()) + } + } +} |