aboutsummaryrefslogtreecommitdiffhomepage
path: root/scheduler/worker.go
blob: 68efed777f3ebb419c6b6ed009a8642de9cf56eb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
// 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 "miniflux.app/scheduler"

import (
	"time"

	"miniflux.app/logger"
	"miniflux.app/model"
	"miniflux.app/reader/feed"
)

// Worker refreshes a feed in the background.
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) {
	logger.Info("[Worker] #%d started", w.id)

	for {
		job := <-c
		logger.Debug("[Worker #%d] got userID=%d, feedID=%d", w.id, job.UserID, job.FeedID)

		err := w.feedHandler.RefreshFeed(job.UserID, job.FeedID)
		if err != nil {
			logger.Error("[Worker] %v", err)
		}

		time.Sleep(time.Millisecond * 1000)
	}
}