Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/schema_registry_service_factory.h" | 5 #include "chrome/browser/policy/schema_registry_service_factory.h" |
| 6 | 6 |
| 7 #include "base/logging.h" | 7 #include "base/logging.h" |
| 8 #include "base/macros.h" | |
|
bartfab (slow)
2014/06/20 09:44:23
Nit: Move this to the header, which uses DISALLOW_
Joao da Silva
2014/06/20 15:36:08
Done.
| |
| 8 #include "chrome/browser/policy/schema_registry_service.h" | 9 #include "chrome/browser/policy/schema_registry_service.h" |
| 9 #include "components/keyed_service/content/browser_context_dependency_manager.h" | 10 #include "components/keyed_service/content/browser_context_dependency_manager.h" |
| 10 #include "components/policy/core/common/schema.h" | 11 #include "components/policy/core/common/schema.h" |
| 11 #include "components/policy/core/common/schema_registry.h" | 12 #include "components/policy/core/common/schema_registry.h" |
| 12 #include "content/public/browser/browser_context.h" | 13 #include "content/public/browser/browser_context.h" |
| 13 | 14 |
| 15 #if defined(OS_CHROMEOS) | |
| 16 #include "chrome/browser/browser_process.h" | |
| 17 #include "chrome/browser/chromeos/login/users/user.h" | |
| 18 #include "chrome/browser/chromeos/login/users/user_manager.h" | |
| 19 #include "chrome/browser/chromeos/policy/browser_policy_connector_chromeos.h" | |
| 20 #include "chrome/browser/chromeos/policy/device_local_account_policy_service.h" | |
| 21 #include "chrome/browser/chromeos/profiles/profile_helper.h" | |
| 22 #include "chrome/browser/profiles/profile.h" | |
| 23 #endif | |
| 24 | |
| 14 namespace policy { | 25 namespace policy { |
| 15 | 26 |
| 27 #if defined(OS_CHROMEOS) | |
| 28 namespace { | |
| 29 | |
| 30 DeviceLocalAccountPolicyBroker* GetBroker(content::BrowserContext* context) { | |
| 31 Profile* profile = Profile::FromBrowserContext(context); | |
| 32 | |
| 33 if (chromeos::ProfileHelper::IsSigninProfile(profile)) | |
| 34 return NULL; | |
| 35 | |
| 36 chromeos::UserManager* user_manager = chromeos::UserManager::Get(); | |
| 37 chromeos::User* user = user_manager->GetUserByProfile(profile); | |
| 38 if (!user) | |
| 39 return NULL; | |
| 40 | |
| 41 BrowserPolicyConnectorChromeOS* connector = | |
| 42 g_browser_process->platform_part()->browser_policy_connector_chromeos(); | |
|
bartfab (slow)
2014/06/20 09:44:23
Nit: #include "chrome/browser/browser_process_plat
Joao da Silva
2014/06/20 15:36:08
Done.
| |
| 43 DeviceLocalAccountPolicyService* service = | |
| 44 connector->GetDeviceLocalAccountPolicyService(); | |
| 45 return service->GetBrokerForUser(user->email()); | |
| 46 } | |
| 47 | |
| 48 } // namespace | |
| 49 #endif // OS_CHROMEOS | |
| 50 | |
| 16 // static | 51 // static |
| 17 SchemaRegistryServiceFactory* SchemaRegistryServiceFactory::GetInstance() { | 52 SchemaRegistryServiceFactory* SchemaRegistryServiceFactory::GetInstance() { |
| 18 return Singleton<SchemaRegistryServiceFactory>::get(); | 53 return Singleton<SchemaRegistryServiceFactory>::get(); |
| 19 } | 54 } |
| 20 | 55 |
| 21 // static | 56 // static |
| 22 SchemaRegistryService* SchemaRegistryServiceFactory::GetForContext( | 57 SchemaRegistryService* SchemaRegistryServiceFactory::GetForContext( |
| 23 content::BrowserContext* context) { | 58 content::BrowserContext* context) { |
| 24 return GetInstance()->GetForContextInternal(context); | 59 return GetInstance()->GetForContextInternal(context); |
| 25 } | 60 } |
| (...skipping 27 matching lines...) Expand all Loading... | |
| 53 return it->second; | 88 return it->second; |
| 54 } | 89 } |
| 55 | 90 |
| 56 scoped_ptr<SchemaRegistryService> | 91 scoped_ptr<SchemaRegistryService> |
| 57 SchemaRegistryServiceFactory::CreateForContextInternal( | 92 SchemaRegistryServiceFactory::CreateForContextInternal( |
| 58 content::BrowserContext* context, | 93 content::BrowserContext* context, |
| 59 const Schema& chrome_schema, | 94 const Schema& chrome_schema, |
| 60 CombinedSchemaRegistry* global_registry) { | 95 CombinedSchemaRegistry* global_registry) { |
| 61 DCHECK(!context->IsOffTheRecord()); | 96 DCHECK(!context->IsOffTheRecord()); |
| 62 DCHECK(registries_.find(context) == registries_.end()); | 97 DCHECK(registries_.find(context) == registries_.end()); |
| 63 SchemaRegistryService* registry = | 98 |
| 64 new SchemaRegistryService(chrome_schema, global_registry); | 99 scoped_ptr<SchemaRegistryService> registry; |
| 65 registries_[context] = registry; | 100 |
| 66 return make_scoped_ptr(registry); | 101 #if defined(OS_CHROMEOS) |
| 102 DeviceLocalAccountPolicyBroker* broker = GetBroker(context); | |
| 103 if (broker) { | |
| 104 // The DeviceLocalAccountPolicyBroker creates a SchemaRegistryService for | |
| 105 // device local accounts earlier, so that the external data can be preloaded | |
|
bartfab (slow)
2014/06/20 09:44:23
Nit: s/device local/device-local/
Joao da Silva
2014/06/20 15:36:08
Done.
| |
| 106 // before the session is started. Transfer its ownership now. | |
| 107 registry = broker->release_schema_registry(); | |
| 108 } | |
| 109 #endif | |
| 110 | |
| 111 if (!registry) | |
| 112 registry.reset(new SchemaRegistryService(chrome_schema, global_registry)); | |
| 113 | |
| 114 registries_[context] = registry.get(); | |
| 115 return registry.Pass(); | |
| 67 } | 116 } |
| 68 | 117 |
| 69 void SchemaRegistryServiceFactory::BrowserContextShutdown( | 118 void SchemaRegistryServiceFactory::BrowserContextShutdown( |
| 70 content::BrowserContext* context) { | 119 content::BrowserContext* context) { |
| 71 if (context->IsOffTheRecord()) | 120 if (context->IsOffTheRecord()) |
| 72 return; | 121 return; |
| 73 RegistryMap::iterator it = registries_.find(context); | 122 RegistryMap::iterator it = registries_.find(context); |
| 74 if (it != registries_.end()) | 123 if (it != registries_.end()) { |
| 124 #if defined(OS_CHROMEOS) | |
| 125 DeviceLocalAccountPolicyBroker* broker = GetBroker(context); | |
| 126 if (broker) { | |
| 127 // Give the broker a notification to clean up any observers of the | |
| 128 // SchemaRegistryService. | |
| 129 broker->OnSchemaRegistryShutdown(); | |
| 130 } | |
| 131 #endif | |
| 75 it->second->Shutdown(); | 132 it->second->Shutdown(); |
| 76 else | 133 } else { |
| 77 NOTREACHED(); | 134 NOTREACHED(); |
| 135 } | |
| 78 } | 136 } |
| 79 | 137 |
| 80 void SchemaRegistryServiceFactory::BrowserContextDestroyed( | 138 void SchemaRegistryServiceFactory::BrowserContextDestroyed( |
| 81 content::BrowserContext* context) { | 139 content::BrowserContext* context) { |
| 82 registries_.erase(context); | 140 registries_.erase(context); |
| 83 BrowserContextKeyedBaseFactory::BrowserContextDestroyed(context); | 141 BrowserContextKeyedBaseFactory::BrowserContextDestroyed(context); |
| 84 } | 142 } |
| 85 | 143 |
| 86 void SchemaRegistryServiceFactory::SetEmptyTestingFactory( | 144 void SchemaRegistryServiceFactory::SetEmptyTestingFactory( |
| 87 content::BrowserContext* context) {} | 145 content::BrowserContext* context) {} |
| 88 | 146 |
| 89 void SchemaRegistryServiceFactory::CreateServiceNow( | 147 void SchemaRegistryServiceFactory::CreateServiceNow( |
| 90 content::BrowserContext* context) {} | 148 content::BrowserContext* context) {} |
| 91 | 149 |
| 92 } // namespace policy | 150 } // namespace policy |
| OLD | NEW |