worker.go 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. // SPDX-FileCopyrightText: Copyright The Miniflux Authors. All rights reserved.
  2. // SPDX-License-Identifier: Apache-2.0
  3. package worker // import "miniflux.app/worker"
  4. import (
  5. "time"
  6. "miniflux.app/config"
  7. "miniflux.app/logger"
  8. "miniflux.app/metric"
  9. "miniflux.app/model"
  10. feedHandler "miniflux.app/reader/handler"
  11. "miniflux.app/storage"
  12. )
  13. // Worker refreshes a feed in the background.
  14. type Worker struct {
  15. id int
  16. store *storage.Storage
  17. }
  18. // Run wait for a job and refresh the given feed.
  19. func (w *Worker) Run(c chan model.Job) {
  20. logger.Debug("[Worker] #%d started", w.id)
  21. for {
  22. job := <-c
  23. logger.Debug("[Worker #%d] Received feed #%d for user #%d", w.id, job.FeedID, job.UserID)
  24. startTime := time.Now()
  25. refreshErr := feedHandler.RefreshFeed(w.store, job.UserID, job.FeedID)
  26. if config.Opts.HasMetricsCollector() {
  27. status := "success"
  28. if refreshErr != nil {
  29. status = "error"
  30. }
  31. metric.BackgroundFeedRefreshDuration.WithLabelValues(status).Observe(time.Since(startTime).Seconds())
  32. }
  33. if refreshErr != nil {
  34. logger.Error("[Worker] Refreshing the feed #%d returned this error: %v", job.FeedID, refreshErr)
  35. }
  36. }
  37. }