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