miniflux/internal/worker/worker.go

57 lines
1.4 KiB
Go
Raw Permalink Normal View History

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