2023-06-19 14:42:47 -07:00
|
|
|
// SPDX-FileCopyrightText: Copyright The Miniflux Authors. All rights reserved.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0
|
2017-11-19 21:10:04 -08:00
|
|
|
|
2023-08-10 19:46:45 -07:00
|
|
|
package worker // import "miniflux.app/v2/internal/worker"
|
2017-11-19 21:10:04 -08:00
|
|
|
|
|
|
|
import (
|
2023-09-24 16:32:09 -07:00
|
|
|
"log/slog"
|
2020-09-27 16:01:06 -07:00
|
|
|
"time"
|
|
|
|
|
2023-08-10 19:46:45 -07:00
|
|
|
"miniflux.app/v2/internal/config"
|
|
|
|
"miniflux.app/v2/internal/metric"
|
|
|
|
"miniflux.app/v2/internal/model"
|
|
|
|
feedHandler "miniflux.app/v2/internal/reader/handler"
|
|
|
|
"miniflux.app/v2/internal/storage"
|
2017-11-19 21:10:04 -08:00
|
|
|
)
|
|
|
|
|
2017-12-12 21:48:13 -08:00
|
|
|
// Worker refreshes a feed in the background.
|
2017-11-19 21:10:04 -08:00
|
|
|
type Worker struct {
|
2021-01-02 16:33:41 -08:00
|
|
|
id int
|
|
|
|
store *storage.Storage
|
2017-11-19 21:10:04 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
// Run wait for a job and refresh the given feed.
|
2024-02-28 23:44:12 +01:00
|
|
|
func (w *Worker) Run(c <-chan model.Job) {
|
2023-09-24 16:32:09 -07:00
|
|
|
slog.Debug("Worker started",
|
|
|
|
slog.Int("worker_id", w.id),
|
|
|
|
)
|
2017-11-19 21:10:04 -08:00
|
|
|
|
|
|
|
for {
|
|
|
|
job := <-c
|
2023-09-24 16:32:09 -07:00
|
|
|
slog.Debug("Job received by worker",
|
|
|
|
slog.Int("worker_id", w.id),
|
|
|
|
slog.Int64("user_id", job.UserID),
|
|
|
|
slog.Int64("feed_id", job.FeedID),
|
|
|
|
)
|
2020-09-27 16:01:06 -07:00
|
|
|
|
|
|
|
startTime := time.Now()
|
2023-11-08 19:58:56 +00:00
|
|
|
localizedError := feedHandler.RefreshFeed(w.store, job.UserID, job.FeedID, false)
|
2020-09-27 16:01:06 -07:00
|
|
|
|
|
|
|
if config.Opts.HasMetricsCollector() {
|
|
|
|
status := "success"
|
2023-11-08 19:58:56 +00:00
|
|
|
if localizedError != nil {
|
2020-09-27 16:01:06 -07:00
|
|
|
status = "error"
|
|
|
|
}
|
|
|
|
metric.BackgroundFeedRefreshDuration.WithLabelValues(status).Observe(time.Since(startTime).Seconds())
|
|
|
|
}
|
2017-11-19 21:10:04 -08:00
|
|
|
|
2023-11-08 19:58:56 +00:00
|
|
|
if localizedError != nil {
|
2023-09-24 16:32:09 -07:00
|
|
|
slog.Warn("Unable to refresh a feed",
|
|
|
|
slog.Int64("user_id", job.UserID),
|
|
|
|
slog.Int64("feed_id", job.FeedID),
|
2023-11-08 19:58:56 +00:00
|
|
|
slog.Any("error", localizedError.Error()),
|
2023-09-24 16:32:09 -07:00
|
|
|
)
|
2017-11-19 21:10:04 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|