summaryrefslogtreecommitdiffstats
path: root/chrome/browser/policy/cloud_policy_refresh_scheduler.cc
diff options
context:
space:
mode:
Diffstat (limited to 'chrome/browser/policy/cloud_policy_refresh_scheduler.cc')
-rw-r--r--chrome/browser/policy/cloud_policy_refresh_scheduler.cc17
1 files changed, 15 insertions, 2 deletions
diff --git a/chrome/browser/policy/cloud_policy_refresh_scheduler.cc b/chrome/browser/policy/cloud_policy_refresh_scheduler.cc
index dc19b5d..da011df 100644
--- a/chrome/browser/policy/cloud_policy_refresh_scheduler.cc
+++ b/chrome/browser/policy/cloud_policy_refresh_scheduler.cc
@@ -116,8 +116,21 @@ void CloudPolicyRefreshScheduler::OnIPAddressChanged() {
}
void CloudPolicyRefreshScheduler::UpdateLastRefreshFromPolicy() {
- if (store_->has_policy() && !store_->is_managed() &&
- last_refresh_.is_null()) {
+ if (!last_refresh_.is_null())
+ return;
+
+ // If the client has already fetched policy, assume that happened recently. If
+ // that assumption ever breaks, the proper thing to do probably is to move the
+ // |last_refresh_| bookkeeping to CloudPolicyClient.
+ if (client_->policy()) {
+ last_refresh_ = base::Time::NowFromSystemTime();
+ return;
+ }
+
+ // If there is a cached non-managed response, make sure to only re-query the
+ // server after kUnmanagedRefreshDelayMs. NB: For existing policy, an
+ // immediate refresh is intentional.
+ if (store_->has_policy() && !store_->is_managed()) {
last_refresh_ =
base::Time::UnixEpoch() +
base::TimeDelta::FromMilliseconds(store_->policy()->timestamp());