Chromium Code Reviews| Index: chrome/browser/policy/asynchronous_policy_provider.cc |
| diff --git a/chrome/browser/policy/asynchronous_policy_provider.cc b/chrome/browser/policy/asynchronous_policy_provider.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..1e80ee5f857d9a59feb35445597486e32259ca76 |
| --- /dev/null |
| +++ b/chrome/browser/policy/asynchronous_policy_provider.cc |
| @@ -0,0 +1,72 @@ |
| +// Copyright (c) 2010 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "chrome/browser/policy/asynchronous_policy_provider.h" |
| + |
| +#include "base/task.h" |
| +#include "chrome/browser/browser_thread.h" |
| +#include "chrome/browser/policy/asynchronous_policy_loader.h" |
| + |
| +namespace { |
| + |
| +// The time interval for rechecking policy. This is our fallback in case the |
| +// delegate never reports a change to the ReloadObserver. |
| +const int kReloadIntervalMinutes = 15; |
|
Mattias Nissler (ping if slow)
2010/12/02 18:16:00
Is the hardcoded interval appropriate for this ver
danno
2010/12/03 17:05:38
Done.
|
| + |
| +} |
| + |
| +namespace policy { |
| + |
| +class TriggerReloadPolicyChangeObserver |
| + : public AsynchronousPolicyProvider::PolicyChangeObserver { |
| + public: |
| + TriggerReloadPolicyChangeObserver( |
| + scoped_refptr<AsynchronousPolicyLoader> loader) |
| + : AsynchronousPolicyProvider::PolicyChangeObserver(), |
| + loader_(loader) {} |
| + virtual ~TriggerReloadPolicyChangeObserver() {} |
| + |
| + virtual void OnPolicyChange() { |
| + if (BrowserThread::CurrentlyOn(BrowserThread::FILE)) { |
| + loader_->Reload(); |
| + } else { |
| + BrowserThread::PostTask( |
| + BrowserThread::FILE, FROM_HERE, |
| + NewRunnableMethod(loader_.get(), |
| + &AsynchronousPolicyLoader::Reload)); |
| + } |
| + } |
| + |
| + private: |
| + scoped_refptr<AsynchronousPolicyLoader> loader_; |
| + DISALLOW_COPY_AND_ASSIGN(TriggerReloadPolicyChangeObserver); |
| +}; |
| + |
| +AsynchronousPolicyProvider::AsynchronousPolicyProvider( |
| + const PolicyDefinitionList* policy_list, |
| + AsynchronousPolicyProvider::Delegate* delegate) |
| + : ConfigurationPolicyProvider(policy_list), |
| + delegate_(delegate) { |
| + loader_ = new AsynchronousPolicyLoader( |
| + this->AsWeakPtr(), |
| + delegate, |
| + kReloadIntervalMinutes); |
| + loader_->Init(); |
| + delegate_->Init(new TriggerReloadPolicyChangeObserver(loader_)); |
| +} |
| + |
| +AsynchronousPolicyProvider::~AsynchronousPolicyProvider() { |
| + delegate_->Stop(); |
| + loader_->Stop(); |
| +} |
| + |
| +bool AsynchronousPolicyProvider::Provide( |
| + ConfigurationPolicyStoreInterface* store) { |
| + scoped_ptr<DictionaryValue> policy(loader_->GetPolicy()); |
| + DCHECK(policy.get()); |
| + DecodePolicyValueTree(policy.get(), store); |
| + return true; |
| +} |
| + |
| +} // namespace policy |