worker.go 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. // SPDX-FileCopyrightText: Copyright The Miniflux Authors. All rights reserved.
  2. // SPDX-License-Identifier: Apache-2.0
  3. package worker // import "miniflux.app/v2/internal/worker"
  4. import (
  5. "log/slog"
  6. "sync"
  7. "time"
  8. "miniflux.app/v2/internal/config"
  9. "miniflux.app/v2/internal/metric"
  10. "miniflux.app/v2/internal/model"
  11. feedHandler "miniflux.app/v2/internal/reader/handler"
  12. "miniflux.app/v2/internal/storage"
  13. )
  14. type worker struct {
  15. id int
  16. store *storage.Storage
  17. }
  18. // Run processes feed refresh jobs from the channel until it is closed.
  19. func (w *worker) Run(c <-chan model.Job, wg *sync.WaitGroup) {
  20. defer wg.Done()
  21. slog.Debug("Worker started",
  22. slog.Int("worker_id", w.id),
  23. )
  24. for job := range c {
  25. slog.Debug("Job received by worker",
  26. slog.Int("worker_id", w.id),
  27. slog.Int64("user_id", job.UserID),
  28. slog.Int64("feed_id", job.FeedID),
  29. slog.String("feed_url", job.FeedURL),
  30. )
  31. startTime := time.Now()
  32. localizedError := feedHandler.RefreshFeed(w.store, job.UserID, job.FeedID, false)
  33. if config.Opts.HasMetricsCollector() {
  34. status := metric.StatusSuccess
  35. if localizedError != nil {
  36. status = metric.StatusError
  37. }
  38. metric.BackgroundFeedRefreshDuration.WithLabelValues(status).Observe(time.Since(startTime).Seconds())
  39. }
  40. }
  41. }