| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/permissions/permission_manager_factory.h" | 5 #include "chrome/browser/permissions/permission_manager_factory.h" |
| 6 | 6 |
| 7 #include "chrome/browser/content_settings/host_content_settings_map_factory.h" | 7 #include "chrome/browser/content_settings/host_content_settings_map_factory.h" |
| 8 #include "chrome/browser/permissions/permission_context.h" | |
| 9 #include "chrome/browser/permissions/permission_manager.h" | 8 #include "chrome/browser/permissions/permission_manager.h" |
| 10 #include "chrome/browser/profiles/incognito_helpers.h" | 9 #include "chrome/browser/profiles/incognito_helpers.h" |
| 11 #include "chrome/browser/profiles/profile.h" | 10 #include "chrome/browser/profiles/profile.h" |
| 12 #include "components/keyed_service/content/browser_context_dependency_manager.h" | 11 #include "components/keyed_service/content/browser_context_dependency_manager.h" |
| 13 | 12 |
| 14 // static | 13 // static |
| 15 PermissionManager* | 14 PermissionManager* |
| 16 PermissionManagerFactory::GetForProfile(Profile* profile) { | 15 PermissionManagerFactory::GetForProfile(Profile* profile) { |
| 17 return static_cast<PermissionManager*>( | 16 return static_cast<PermissionManager*>( |
| 18 GetInstance()->GetServiceForBrowserContext(profile, true)); | 17 GetInstance()->GetServiceForBrowserContext(profile, true)); |
| 19 } | 18 } |
| 20 | 19 |
| 21 // static | 20 // static |
| 22 PermissionManagerFactory* PermissionManagerFactory::GetInstance() { | 21 PermissionManagerFactory* PermissionManagerFactory::GetInstance() { |
| 23 return base::Singleton<PermissionManagerFactory>::get(); | 22 return base::Singleton<PermissionManagerFactory>::get(); |
| 24 } | 23 } |
| 25 | 24 |
| 26 PermissionManagerFactory::PermissionManagerFactory() | 25 PermissionManagerFactory::PermissionManagerFactory() |
| 27 : BrowserContextKeyedServiceFactory( | 26 : BrowserContextKeyedServiceFactory( |
| 28 "PermissionManagerFactory", | 27 "PermissionManagerFactory", |
| 29 BrowserContextDependencyManager::GetInstance()) { | 28 BrowserContextDependencyManager::GetInstance()) { |
| 30 DependsOn(HostContentSettingsMapFactory::GetInstance()); | 29 DependsOn(HostContentSettingsMapFactory::GetInstance()); |
| 31 for (KeyedServiceBaseFactory* factory : PermissionContext::GetFactories()) | |
| 32 DependsOn(factory); | |
| 33 } | 30 } |
| 34 | 31 |
| 35 PermissionManagerFactory::~PermissionManagerFactory() { | 32 PermissionManagerFactory::~PermissionManagerFactory() { |
| 36 } | 33 } |
| 37 | 34 |
| 38 KeyedService* PermissionManagerFactory::BuildServiceInstanceFor( | 35 KeyedService* PermissionManagerFactory::BuildServiceInstanceFor( |
| 39 content::BrowserContext* context) const { | 36 content::BrowserContext* context) const { |
| 40 return new PermissionManager(Profile::FromBrowserContext(context)); | 37 return new PermissionManager(Profile::FromBrowserContext(context)); |
| 41 } | 38 } |
| 42 | 39 |
| 43 content::BrowserContext* | 40 content::BrowserContext* |
| 44 PermissionManagerFactory::GetBrowserContextToUse( | 41 PermissionManagerFactory::GetBrowserContextToUse( |
| 45 content::BrowserContext* context) const { | 42 content::BrowserContext* context) const { |
| 46 return chrome::GetBrowserContextOwnInstanceInIncognito(context); | 43 return chrome::GetBrowserContextOwnInstanceInIncognito(context); |
| 47 } | 44 } |
| OLD | NEW |