2017-11-20 00:10:04 -05:00
|
|
|
// Copyright 2017 Frédéric Guillot. All rights reserved.
|
|
|
|
// Use of this source code is governed by the Apache 2.0
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
2018-11-11 18:32:48 -05:00
|
|
|
package worker // import "miniflux.app/worker"
|
2017-11-20 00:10:04 -05:00
|
|
|
|
|
|
|
import (
|
2020-09-27 19:01:06 -04:00
|
|
|
"time"
|
|
|
|
|
|
|
|
"miniflux.app/config"
|
2018-08-25 00:51:50 -04:00
|
|
|
"miniflux.app/logger"
|
2020-09-27 19:01:06 -04:00
|
|
|
"miniflux.app/metric"
|
2018-08-25 00:51:50 -04:00
|
|
|
"miniflux.app/model"
|
2021-01-02 19:33:41 -05:00
|
|
|
feedHandler "miniflux.app/reader/handler"
|
|
|
|
"miniflux.app/storage"
|
2017-11-20 00:10:04 -05:00
|
|
|
)
|
|
|
|
|
2017-12-13 00:48:13 -05:00
|
|
|
// Worker refreshes a feed in the background.
|
2017-11-20 00:10:04 -05:00
|
|
|
type Worker struct {
|
2021-01-02 19:33:41 -05:00
|
|
|
id int
|
|
|
|
store *storage.Storage
|
2017-11-20 00:10:04 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// Run wait for a job and refresh the given feed.
|
|
|
|
func (w *Worker) Run(c chan model.Job) {
|
2018-12-03 00:21:18 -05:00
|
|
|
logger.Debug("[Worker] #%d started", w.id)
|
2017-11-20 00:10:04 -05:00
|
|
|
|
|
|
|
for {
|
|
|
|
job := <-c
|
2020-09-27 19:01:06 -04:00
|
|
|
logger.Debug("[Worker #%d] Received feed #%d for user #%d", w.id, job.FeedID, job.UserID)
|
|
|
|
|
|
|
|
startTime := time.Now()
|
2021-01-02 19:33:41 -05:00
|
|
|
refreshErr := feedHandler.RefreshFeed(w.store, job.UserID, job.FeedID)
|
2020-09-27 19:01:06 -04:00
|
|
|
|
|
|
|
if config.Opts.HasMetricsCollector() {
|
|
|
|
status := "success"
|
|
|
|
if refreshErr != nil {
|
|
|
|
status = "error"
|
|
|
|
}
|
|
|
|
metric.BackgroundFeedRefreshDuration.WithLabelValues(status).Observe(time.Since(startTime).Seconds())
|
|
|
|
}
|
2017-11-20 00:10:04 -05:00
|
|
|
|
2020-09-27 19:01:06 -04:00
|
|
|
if refreshErr != nil {
|
|
|
|
logger.Error("[Worker] Refreshing the feed #%d returned this error: %v", job.FeedID, refreshErr)
|
2017-11-20 00:10:04 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|