1
0
Fork 0
mirror of https://github.com/miniflux/v2.git synced 2025-06-27 16:36:00 +00:00
miniflux-v2/internal/worker/worker.go

47 lines
1.2 KiB
Go
Raw Normal View History

// SPDX-FileCopyrightText: Copyright The Miniflux Authors. All rights reserved.
// SPDX-License-Identifier: Apache-2.0
2017-11-19 21:10:04 -08:00
package worker // import "miniflux.app/v2/internal/worker"
2017-11-19 21:10:04 -08:00
import (
2020-09-27 16:01:06 -07:00
"time"
"miniflux.app/v2/internal/config"
"miniflux.app/v2/internal/logger"
"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 {
id int
store *storage.Storage
2017-11-19 21:10:04 -08:00
}
// Run wait for a job and refresh the given feed.
func (w *Worker) Run(c chan model.Job) {
logger.Debug("[Worker] #%d started", w.id)
2017-11-19 21:10:04 -08:00
for {
job := <-c
2020-09-27 16:01:06 -07:00
logger.Debug("[Worker #%d] Received feed #%d for user #%d", w.id, job.FeedID, job.UserID)
startTime := time.Now()
refreshErr := feedHandler.RefreshFeed(w.store, job.UserID, job.FeedID, false)
2020-09-27 16:01:06 -07:00
if config.Opts.HasMetricsCollector() {
status := "success"
if refreshErr != nil {
status = "error"
}
metric.BackgroundFeedRefreshDuration.WithLabelValues(status).Observe(time.Since(startTime).Seconds())
}
2017-11-19 21:10:04 -08:00
2020-09-27 16:01:06 -07:00
if refreshErr != nil {
logger.Error("[Worker] Refreshing the feed #%d returned this error: %v", job.FeedID, refreshErr)
2017-11-19 21:10:04 -08:00
}
}
}