| Index: components/doodle/doodle_service.h
|
| diff --git a/components/doodle/doodle_service.h b/components/doodle/doodle_service.h
|
| index f1265e72a3b4753cce78472f3e2d5bbef4a20fec..32ed8d1fadc38a83dd30540e77ca2bd2e9bd72ff 100644
|
| --- a/components/doodle/doodle_service.h
|
| +++ b/components/doodle/doodle_service.h
|
| @@ -10,6 +10,7 @@
|
| #include "base/macros.h"
|
| #include "base/observer_list.h"
|
| #include "base/optional.h"
|
| +#include "base/timer/timer.h"
|
| #include "components/doodle/doodle_fetcher.h"
|
| #include "components/doodle/doodle_types.h"
|
|
|
| @@ -26,7 +27,8 @@ class DoodleService {
|
| virtual void OnDoodleConfigUpdated(const base::Optional<DoodleConfig>&) = 0;
|
| };
|
|
|
| - DoodleService(std::unique_ptr<DoodleFetcher> fetcher);
|
| + DoodleService(std::unique_ptr<DoodleFetcher> fetcher,
|
| + std::unique_ptr<base::OneShotTimer> expiry_timer);
|
| ~DoodleService();
|
|
|
| // Returns the current (cached) config, if any.
|
| @@ -46,16 +48,24 @@ class DoodleService {
|
| void Refresh();
|
|
|
| private:
|
| + // Callback for the fetcher.
|
| void DoodleFetched(DoodleState state,
|
| base::TimeDelta time_to_live,
|
| const base::Optional<DoodleConfig>& doodle_config);
|
|
|
| + void UpdateTimeToLive(base::TimeDelta time_to_live);
|
| +
|
| + // Callback for the expiry timer.
|
| + void DoodleExpired();
|
| +
|
| // The fetcher for getting fresh DoodleConfigs from the network.
|
| std::unique_ptr<DoodleFetcher> fetcher_;
|
|
|
| // The result of the last network fetch.
|
| base::Optional<DoodleConfig> cached_config_;
|
|
|
| + std::unique_ptr<base::OneShotTimer> expiry_timer_;
|
| +
|
| // The list of observers to be notified when the DoodleConfig changes.
|
| base::ObserverList<Observer> observers_;
|
|
|
|
|