Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(129)

Side by Side Diff: chrome/browser/policy/configuration_policy_provider.cc

Issue 10386097: Refactored ConfigurationPolicyProvider to provide PolicyBundles instead of PolicyMaps. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Addressed comments Created 8 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/policy/configuration_policy_provider.h" 5 #include "chrome/browser/policy/configuration_policy_provider.h"
6 6
7 #include <algorithm> 7 #include <string>
8 8
9 #include "chrome/browser/policy/policy_map.h" 9 #include "chrome/browser/policy/policy_map.h"
10 #include "policy/policy_constants.h" 10 #include "policy/policy_constants.h"
11 11
12 namespace policy { 12 namespace policy {
13 13
14 namespace { 14 namespace {
15 15
16 const char* kProxyPolicies[] = { 16 const char* kProxyPolicies[] = {
17 key::kProxyMode, 17 key::kProxyMode,
(...skipping 17 matching lines...) Expand all
35 : policy_definition_list_(policy_list) { 35 : policy_definition_list_(policy_list) {
36 } 36 }
37 37
38 ConfigurationPolicyProvider::~ConfigurationPolicyProvider() { 38 ConfigurationPolicyProvider::~ConfigurationPolicyProvider() {
39 FOR_EACH_OBSERVER(ConfigurationPolicyProvider::Observer, 39 FOR_EACH_OBSERVER(ConfigurationPolicyProvider::Observer,
40 observer_list_, 40 observer_list_,
41 OnProviderGoingAway(this)); 41 OnProviderGoingAway(this));
42 } 42 }
43 43
44 bool ConfigurationPolicyProvider::Provide(PolicyMap* result) { 44 bool ConfigurationPolicyProvider::Provide(PolicyMap* result) {
45 if (ProvideInternal(result)) { 45 result->CopyFrom(policy_bundle_.Get(POLICY_DOMAIN_CHROME, std::string()));
46 FixDeprecatedPolicies(result); 46 return true;
47 return true;
48 }
49 return false;
50 } 47 }
51 48
52 bool ConfigurationPolicyProvider::IsInitializationComplete() const { 49 bool ConfigurationPolicyProvider::IsInitializationComplete() const {
53 return true; 50 return true;
54 } 51 }
55 52
56 // static 53 // static
57 void ConfigurationPolicyProvider::FixDeprecatedPolicies(PolicyMap* policies) { 54 void ConfigurationPolicyProvider::FixDeprecatedPolicies(PolicyMap* policies) {
58 // Proxy settings have been configured by 5 policies that didn't mix well 55 // Proxy settings have been configured by 5 policies that didn't mix well
59 // together, and maps of policies had to take this into account when merging 56 // together, and maps of policies had to take this into account when merging
(...skipping 25 matching lines...) Expand all
85 const PolicyMap::Entry* existing = policies->Get(key::kProxySettings); 82 const PolicyMap::Entry* existing = policies->Get(key::kProxySettings);
86 if (!proxy_settings->empty() && 83 if (!proxy_settings->empty() &&
87 (!existing || current_priority.has_higher_priority_than(*existing))) { 84 (!existing || current_priority.has_higher_priority_than(*existing))) {
88 policies->Set(key::kProxySettings, 85 policies->Set(key::kProxySettings,
89 current_priority.level, 86 current_priority.level,
90 current_priority.scope, 87 current_priority.scope,
91 proxy_settings.release()); 88 proxy_settings.release());
92 } 89 }
93 } 90 }
94 91
95 void ConfigurationPolicyProvider::NotifyPolicyUpdated() { 92 void ConfigurationPolicyProvider::UpdatePolicy(
93 scoped_ptr<PolicyBundle> bundle) {
94 policy_bundle_.Swap(bundle.get());
95 FixDeprecatedPolicies(
96 &policy_bundle_.Get(POLICY_DOMAIN_CHROME, std::string()));
96 FOR_EACH_OBSERVER(ConfigurationPolicyProvider::Observer, 97 FOR_EACH_OBSERVER(ConfigurationPolicyProvider::Observer,
97 observer_list_, 98 observer_list_,
98 OnUpdatePolicy(this)); 99 OnUpdatePolicy(this));
99 } 100 }
100 101
101 void ConfigurationPolicyProvider::AddObserver(Observer* observer) { 102 void ConfigurationPolicyProvider::AddObserver(Observer* observer) {
102 observer_list_.AddObserver(observer); 103 observer_list_.AddObserver(observer);
103 } 104 }
104 105
105 void ConfigurationPolicyProvider::RemoveObserver(Observer* observer) { 106 void ConfigurationPolicyProvider::RemoveObserver(Observer* observer) {
106 observer_list_.RemoveObserver(observer); 107 observer_list_.RemoveObserver(observer);
107 } 108 }
108 109
109 ConfigurationPolicyObserverRegistrar::ConfigurationPolicyObserverRegistrar() 110 ConfigurationPolicyObserverRegistrar::ConfigurationPolicyObserverRegistrar()
110 : provider_(NULL), 111 : provider_(NULL),
111 observer_(NULL) {} 112 observer_(NULL) {}
112 113
113 ConfigurationPolicyObserverRegistrar::~ConfigurationPolicyObserverRegistrar() { 114 ConfigurationPolicyObserverRegistrar::~ConfigurationPolicyObserverRegistrar() {
114 if (provider_) 115 // Subtle: see the comment in OnProviderGoingAway().
116 if (observer_)
115 provider_->RemoveObserver(this); 117 provider_->RemoveObserver(this);
116 } 118 }
117 119
118 void ConfigurationPolicyObserverRegistrar::Init( 120 void ConfigurationPolicyObserverRegistrar::Init(
119 ConfigurationPolicyProvider* provider, 121 ConfigurationPolicyProvider* provider,
120 ConfigurationPolicyProvider::Observer* observer) { 122 ConfigurationPolicyProvider::Observer* observer) {
123 // Must be either both NULL or both not NULL.
124 DCHECK(provider);
125 DCHECK(observer);
121 provider_ = provider; 126 provider_ = provider;
122 observer_ = observer; 127 observer_ = observer;
123 provider_->AddObserver(this); 128 provider_->AddObserver(this);
124 } 129 }
125 130
126 void ConfigurationPolicyObserverRegistrar::OnUpdatePolicy( 131 void ConfigurationPolicyObserverRegistrar::OnUpdatePolicy(
127 ConfigurationPolicyProvider* provider) { 132 ConfigurationPolicyProvider* provider) {
128 DCHECK_EQ(provider_, provider); 133 DCHECK_EQ(provider_, provider);
129 observer_->OnUpdatePolicy(provider_); 134 observer_->OnUpdatePolicy(provider_);
130 } 135 }
131 136
132 void ConfigurationPolicyObserverRegistrar::OnProviderGoingAway( 137 void ConfigurationPolicyObserverRegistrar::OnProviderGoingAway(
133 ConfigurationPolicyProvider* provider) { 138 ConfigurationPolicyProvider* provider) {
134 DCHECK_EQ(provider_, provider); 139 DCHECK_EQ(provider_, provider);
135 // The |observer_| might delete |this| during this callback. Don't touch any 140 // The |observer_| might delete |this| during this callback: don't touch any
136 // of |this| field's after it returns. 141 // of |this| field's after it returns.
142 // It might also invoke provider() during this callback, so |provider_| can't
143 // be set to NULL. So we set |observer_| to NULL instead to signal that
144 // we're not observing the provider anymore.
145 ConfigurationPolicyProvider::Observer* observer = observer_;
146 observer_ = NULL;
137 provider_->RemoveObserver(this); 147 provider_->RemoveObserver(this);
138 provider_ = NULL; 148
139 observer_->OnProviderGoingAway(provider); 149 observer->OnProviderGoingAway(provider);
140 } 150 }
141 151
142 } // namespace policy 152 } // namespace policy
OLDNEW
« no previous file with comments | « chrome/browser/policy/configuration_policy_provider.h ('k') | chrome/browser/policy/mock_configuration_policy_provider.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698