xref: /aosp_15_r20/external/cronet/components/metrics/metrics_scheduler.h (revision 6777b5387eb2ff775bb5750e3f5d96f37fb7352b)
1*6777b538SAndroid Build Coastguard Worker // Copyright 2017 The Chromium Authors
2*6777b538SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
3*6777b538SAndroid Build Coastguard Worker // found in the LICENSE file.
4*6777b538SAndroid Build Coastguard Worker 
5*6777b538SAndroid Build Coastguard Worker #ifndef COMPONENTS_METRICS_METRICS_SCHEDULER_H_
6*6777b538SAndroid Build Coastguard Worker #define COMPONENTS_METRICS_METRICS_SCHEDULER_H_
7*6777b538SAndroid Build Coastguard Worker 
8*6777b538SAndroid Build Coastguard Worker #include "base/functional/callback.h"
9*6777b538SAndroid Build Coastguard Worker #include "base/time/time.h"
10*6777b538SAndroid Build Coastguard Worker #include "base/timer/timer.h"
11*6777b538SAndroid Build Coastguard Worker 
12*6777b538SAndroid Build Coastguard Worker namespace metrics {
13*6777b538SAndroid Build Coastguard Worker 
14*6777b538SAndroid Build Coastguard Worker // Scheduler task to drive a MetricsService object's uploading.
15*6777b538SAndroid Build Coastguard Worker class MetricsScheduler {
16*6777b538SAndroid Build Coastguard Worker  public:
17*6777b538SAndroid Build Coastguard Worker   // Creates MetricsScheduler object with the given |task_callback|
18*6777b538SAndroid Build Coastguard Worker   // callback to call when a task should happen.
19*6777b538SAndroid Build Coastguard Worker   MetricsScheduler(const base::RepeatingClosure& task_callback,
20*6777b538SAndroid Build Coastguard Worker                    bool fast_startup_for_testing);
21*6777b538SAndroid Build Coastguard Worker 
22*6777b538SAndroid Build Coastguard Worker   MetricsScheduler(const MetricsScheduler&) = delete;
23*6777b538SAndroid Build Coastguard Worker   MetricsScheduler& operator=(const MetricsScheduler&) = delete;
24*6777b538SAndroid Build Coastguard Worker 
25*6777b538SAndroid Build Coastguard Worker   virtual ~MetricsScheduler();
26*6777b538SAndroid Build Coastguard Worker 
27*6777b538SAndroid Build Coastguard Worker   // Starts scheduling uploads. This in a no-op if the scheduler is already
28*6777b538SAndroid Build Coastguard Worker   // running, so it is safe to call more than once.
29*6777b538SAndroid Build Coastguard Worker   void Start();
30*6777b538SAndroid Build Coastguard Worker 
31*6777b538SAndroid Build Coastguard Worker   // Stops scheduling uploads.
32*6777b538SAndroid Build Coastguard Worker   void Stop();
33*6777b538SAndroid Build Coastguard Worker 
34*6777b538SAndroid Build Coastguard Worker   // Returns the initial delay before the task is run for the first time.
35*6777b538SAndroid Build Coastguard Worker   static int GetInitialIntervalSeconds();
36*6777b538SAndroid Build Coastguard Worker 
37*6777b538SAndroid Build Coastguard Worker  protected:
38*6777b538SAndroid Build Coastguard Worker   // Subclasses should provide task_callback with a wrapper to call this with.
39*6777b538SAndroid Build Coastguard Worker   // This indicates the triggered task was completed/cancelled and the next
40*6777b538SAndroid Build Coastguard Worker   // call can be scheduled.
41*6777b538SAndroid Build Coastguard Worker   void TaskDone(base::TimeDelta next_interval);
42*6777b538SAndroid Build Coastguard Worker 
43*6777b538SAndroid Build Coastguard Worker   // Called by the Timer when it's time to run the task.
44*6777b538SAndroid Build Coastguard Worker   virtual void TriggerTask();
45*6777b538SAndroid Build Coastguard Worker 
46*6777b538SAndroid Build Coastguard Worker  private:
47*6777b538SAndroid Build Coastguard Worker   // Schedules a future call to TriggerTask if one isn't already pending.
48*6777b538SAndroid Build Coastguard Worker   void ScheduleNextTask();
49*6777b538SAndroid Build Coastguard Worker 
50*6777b538SAndroid Build Coastguard Worker   // The method to call when task should happen.
51*6777b538SAndroid Build Coastguard Worker   const base::RepeatingClosure task_callback_;
52*6777b538SAndroid Build Coastguard Worker 
53*6777b538SAndroid Build Coastguard Worker   // Uses a one-shot timer rather than a repeating one because the task may be
54*6777b538SAndroid Build Coastguard Worker   // async, and the length of the interval may change.
55*6777b538SAndroid Build Coastguard Worker   base::OneShotTimer timer_;
56*6777b538SAndroid Build Coastguard Worker 
57*6777b538SAndroid Build Coastguard Worker   // The interval between being told an task is done and starting the next task.
58*6777b538SAndroid Build Coastguard Worker   base::TimeDelta interval_;
59*6777b538SAndroid Build Coastguard Worker 
60*6777b538SAndroid Build Coastguard Worker   // Indicates that the scheduler is running (i.e., that Start has been called
61*6777b538SAndroid Build Coastguard Worker   // more recently than Stop).
62*6777b538SAndroid Build Coastguard Worker   bool running_;
63*6777b538SAndroid Build Coastguard Worker 
64*6777b538SAndroid Build Coastguard Worker   // Indicates that the last triggered task hasn't resolved yet.
65*6777b538SAndroid Build Coastguard Worker   bool callback_pending_;
66*6777b538SAndroid Build Coastguard Worker };
67*6777b538SAndroid Build Coastguard Worker 
68*6777b538SAndroid Build Coastguard Worker }  // namespace metrics
69*6777b538SAndroid Build Coastguard Worker 
70*6777b538SAndroid Build Coastguard Worker #endif  // COMPONENTS_METRICS_METRICS_SCHEDULER_H_
71