miniflux/worker/worker.go

33 lines
778 B
Go
Raw Normal View History

2017-11-20 06:10:04 +01: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.
package worker // import "miniflux.app/worker"
2017-11-20 06:10:04 +01:00
import (
2018-08-25 06:51:50 +02:00
"miniflux.app/logger"
"miniflux.app/model"
"miniflux.app/reader/feed"
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
feedHandler *feed.Handler
}
// Run wait for a job and refresh the given feed.
func (w *Worker) Run(c chan model.Job) {
2018-01-30 05:46:01 +01:00
logger.Info("[Worker] #%d started", w.id)
2017-11-20 06:10:04 +01:00
for {
job := <-c
2017-12-16 03:55:57 +01:00
logger.Debug("[Worker #%d] got userID=%d, feedID=%d", w.id, job.UserID, job.FeedID)
2017-11-20 06:10:04 +01:00
err := w.feedHandler.RefreshFeed(job.UserID, job.FeedID)
if err != nil {
2017-12-16 03:55:57 +01:00
logger.Error("[Worker] %v", err)
2017-11-20 06:10:04 +01:00
}
}
}