aboutsummaryrefslogtreecommitdiffhomepage
path: root/scheduler/worker.go
blob: 39382a3845921c15cb5efca7ea57188b764fd3ca (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
// 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 (
	"github.com/miniflux/miniflux2/model"
	"github.com/miniflux/miniflux2/reader/feed"
	"log"
	"time"
)

// A Worker refresh 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) {
	log.Printf("[Worker] #%d started\n", w.id)

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

		err := w.feedHandler.RefreshFeed(job.UserID, job.FeedID)
		if err != nil {
			log.Println("Worker:", err)
		}

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