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 scheduler
|
|
|
|
|
|
|
|
import (
|
|
|
|
"time"
|
2017-12-13 06:48:13 +01:00
|
|
|
|
2017-12-16 03:55:57 +01:00
|
|
|
"github.com/miniflux/miniflux/logger"
|
2017-12-13 06:48:13 +01:00
|
|
|
"github.com/miniflux/miniflux/model"
|
|
|
|
"github.com/miniflux/miniflux/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
|
|
|
}
|
|
|
|
|
|
|
|
time.Sleep(time.Millisecond * 1000)
|
|
|
|
}
|
|
|
|
}
|