| 25 | } |
| 26 | |
| 27 | func (r *Runner) Run(ctx context.Context) error { |
| 28 | slog.Info("Starting background runner", "namespace", r.namespace, "check_interval", CheckInterval) |
| 29 | |
| 30 | scraper := userstats.NewScraper(r.namespace) |
| 31 | go scraper.Run(ctx) |
| 32 | |
| 33 | ticker := time.NewTicker(CheckInterval) |
| 34 | defer ticker.Stop() |
| 35 | |
| 36 | for { |
| 37 | select { |
| 38 | case <-ctx.Done(): |
| 39 | slog.Info("Shutting down") |
| 40 | return nil |
| 41 | case <-ticker.C: |
| 42 | if updated, err := r.check(ctx); err != nil { |
| 43 | slog.Error("Check failed", "error", err) |
| 44 | } else if updated { |
| 45 | return nil |
| 46 | } |
| 47 | } |
| 48 | } |
| 49 | } |
| 50 | |
| 51 | // Private |
| 52 | |