OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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/browser_policy_connector.h" | 5 #include "chrome/browser/policy/browser_policy_connector.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/command_line.h" | 8 #include "base/command_line.h" |
9 #include "base/file_path.h" | 9 #include "base/file_path.h" |
10 #include "base/path_service.h" | 10 #include "base/path_service.h" |
| 11 #include "base/stl_util.h" |
11 #include "chrome/browser/net/gaia/token_service.h" | 12 #include "chrome/browser/net/gaia/token_service.h" |
12 #include "chrome/browser/policy/cloud_policy_provider.h" | 13 #include "chrome/browser/policy/cloud_policy_provider.h" |
13 #include "chrome/browser/policy/cloud_policy_provider_impl.h" | 14 #include "chrome/browser/policy/cloud_policy_provider_impl.h" |
14 #include "chrome/browser/policy/cloud_policy_subsystem.h" | 15 #include "chrome/browser/policy/cloud_policy_subsystem.h" |
15 #include "chrome/browser/policy/configuration_policy_pref_store.h" | 16 #include "chrome/browser/policy/configuration_policy_pref_store.h" |
16 #include "chrome/browser/policy/configuration_policy_provider.h" | 17 #include "chrome/browser/policy/configuration_policy_provider.h" |
17 #include "chrome/browser/policy/user_policy_cache.h" | 18 #include "chrome/browser/policy/user_policy_cache.h" |
18 #include "chrome/browser/policy/user_policy_token_cache.h" | 19 #include "chrome/browser/policy/user_policy_token_cache.h" |
19 #include "chrome/common/chrome_notification_types.h" | 20 #include "chrome/common/chrome_notification_types.h" |
20 #include "chrome/common/chrome_paths.h" | 21 #include "chrome/common/chrome_paths.h" |
(...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
90 device_cloud_policy_subsystem_.reset(); | 91 device_cloud_policy_subsystem_.reset(); |
91 device_data_store_.reset(); | 92 device_data_store_.reset(); |
92 #endif | 93 #endif |
93 | 94 |
94 // Shutdown user cloud policy. | 95 // Shutdown user cloud policy. |
95 if (user_cloud_policy_subsystem_.get()) | 96 if (user_cloud_policy_subsystem_.get()) |
96 user_cloud_policy_subsystem_->Shutdown(); | 97 user_cloud_policy_subsystem_->Shutdown(); |
97 user_cloud_policy_subsystem_.reset(); | 98 user_cloud_policy_subsystem_.reset(); |
98 user_policy_token_cache_.reset(); | 99 user_policy_token_cache_.reset(); |
99 user_data_store_.reset(); | 100 user_data_store_.reset(); |
| 101 |
| 102 STLDeleteElements(policy_handlers_.get()); |
100 } | 103 } |
101 | 104 |
102 ConfigurationPolicyProvider* | 105 ConfigurationPolicyProvider* |
103 BrowserPolicyConnector::GetManagedPlatformProvider() const { | 106 BrowserPolicyConnector::GetManagedPlatformProvider() const { |
104 return managed_platform_provider_.get(); | 107 return managed_platform_provider_.get(); |
105 } | 108 } |
106 | 109 |
107 ConfigurationPolicyProvider* | 110 ConfigurationPolicyProvider* |
108 BrowserPolicyConnector::GetManagedCloudProvider() const { | 111 BrowserPolicyConnector::GetManagedCloudProvider() const { |
109 return managed_cloud_provider_.get(); | 112 return managed_cloud_provider_.get(); |
(...skipping 191 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
301 #else | 304 #else |
302 return NULL; | 305 return NULL; |
303 #endif | 306 #endif |
304 } | 307 } |
305 | 308 |
306 const CloudPolicyDataStore* | 309 const CloudPolicyDataStore* |
307 BrowserPolicyConnector::GetUserCloudPolicyDataStore() const { | 310 BrowserPolicyConnector::GetUserCloudPolicyDataStore() const { |
308 return user_data_store_.get(); | 311 return user_data_store_.get(); |
309 } | 312 } |
310 | 313 |
| 314 const ConfigurationPolicyHandler::HandlerList* |
| 315 BrowserPolicyConnector::GetConfigurationPolicyHandlerList() const { |
| 316 return policy_handlers_.get(); |
| 317 } |
| 318 |
311 BrowserPolicyConnector::BrowserPolicyConnector() | 319 BrowserPolicyConnector::BrowserPolicyConnector() |
312 : ALLOW_THIS_IN_INITIALIZER_LIST(weak_ptr_factory_(this)) { | 320 : ALLOW_THIS_IN_INITIALIZER_LIST(weak_ptr_factory_(this)) { |
313 managed_platform_provider_.reset(CreateManagedPlatformProvider()); | 321 managed_platform_provider_.reset(CreateManagedPlatformProvider()); |
314 recommended_platform_provider_.reset(CreateRecommendedPlatformProvider()); | 322 recommended_platform_provider_.reset(CreateRecommendedPlatformProvider()); |
315 | 323 |
316 managed_cloud_provider_.reset(new CloudPolicyProviderImpl( | 324 managed_cloud_provider_.reset(new CloudPolicyProviderImpl( |
317 GetChromePolicyDefinitionList(), | 325 GetChromePolicyDefinitionList(), |
318 CloudPolicyCacheBase::POLICY_LEVEL_MANDATORY)); | 326 CloudPolicyCacheBase::POLICY_LEVEL_MANDATORY)); |
319 recommended_cloud_provider_.reset(new CloudPolicyProviderImpl( | 327 recommended_cloud_provider_.reset(new CloudPolicyProviderImpl( |
320 GetChromePolicyDefinitionList(), | 328 GetChromePolicyDefinitionList(), |
321 CloudPolicyCacheBase::POLICY_LEVEL_RECOMMENDED)); | 329 CloudPolicyCacheBase::POLICY_LEVEL_RECOMMENDED)); |
322 | 330 |
323 #if defined(OS_CHROMEOS) | 331 #if defined(OS_CHROMEOS) |
324 InitializeDevicePolicy(); | 332 InitializeDevicePolicy(); |
325 #endif | 333 #endif |
| 334 policy_handlers_.reset(ConfigurationPolicyHandler::CreateHandlerList()); |
326 } | 335 } |
327 | 336 |
328 BrowserPolicyConnector::BrowserPolicyConnector( | 337 BrowserPolicyConnector::BrowserPolicyConnector( |
329 ConfigurationPolicyProvider* managed_platform_provider, | 338 ConfigurationPolicyProvider* managed_platform_provider, |
330 ConfigurationPolicyProvider* recommended_platform_provider, | 339 ConfigurationPolicyProvider* recommended_platform_provider, |
331 CloudPolicyProvider* managed_cloud_provider, | 340 CloudPolicyProvider* managed_cloud_provider, |
332 CloudPolicyProvider* recommended_cloud_provider) | 341 CloudPolicyProvider* recommended_cloud_provider) |
333 : managed_platform_provider_(managed_platform_provider), | 342 : managed_platform_provider_(managed_platform_provider), |
334 recommended_platform_provider_(recommended_platform_provider), | 343 recommended_platform_provider_(recommended_platform_provider), |
335 managed_cloud_provider_(managed_cloud_provider), | 344 managed_cloud_provider_(managed_cloud_provider), |
336 recommended_cloud_provider_(recommended_cloud_provider), | 345 recommended_cloud_provider_(recommended_cloud_provider), |
337 ALLOW_THIS_IN_INITIALIZER_LIST(weak_ptr_factory_(this)) {} | 346 ALLOW_THIS_IN_INITIALIZER_LIST(weak_ptr_factory_(this)) { |
| 347 policy_handlers_.reset(ConfigurationPolicyHandler::CreateHandlerList()); |
| 348 } |
338 | 349 |
339 void BrowserPolicyConnector::Observe( | 350 void BrowserPolicyConnector::Observe( |
340 int type, | 351 int type, |
341 const content::NotificationSource& source, | 352 const content::NotificationSource& source, |
342 const content::NotificationDetails& details) { | 353 const content::NotificationDetails& details) { |
343 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 354 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
344 if (type == chrome::NOTIFICATION_TOKEN_AVAILABLE) { | 355 if (type == chrome::NOTIFICATION_TOKEN_AVAILABLE) { |
345 const TokenService* token_source = | 356 const TokenService* token_source = |
346 content::Source<const TokenService>(source).ptr(); | 357 content::Source<const TokenService>(source).ptr(); |
347 DCHECK_EQ(token_service_, token_source); | 358 DCHECK_EQ(token_service_, token_source); |
(...skipping 107 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
455 config_dir_path.Append(FILE_PATH_LITERAL("recommended"))); | 466 config_dir_path.Append(FILE_PATH_LITERAL("recommended"))); |
456 } else { | 467 } else { |
457 return NULL; | 468 return NULL; |
458 } | 469 } |
459 #else | 470 #else |
460 return NULL; | 471 return NULL; |
461 #endif | 472 #endif |
462 } | 473 } |
463 | 474 |
464 } // namespace policy | 475 } // namespace policy |
OLD | NEW |