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

Side by Side Diff: chrome/browser/geolocation/geolocation_permission_context_factory.cc

Issue 330143002: Simplify geolocation permission request in the Content API. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: rebase Created 6 years, 6 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/geolocation/chrome_geolocation_permission_context_facto ry.h" 5 #include "chrome/browser/geolocation/geolocation_permission_context_factory.h"
6 6
7 #include "chrome/browser/profiles/incognito_helpers.h" 7 #include "chrome/browser/profiles/incognito_helpers.h"
8 #include "chrome/browser/profiles/profile.h" 8 #include "chrome/browser/profiles/profile.h"
9 #include "chrome/common/pref_names.h" 9 #include "chrome/common/pref_names.h"
10 #include "components/keyed_service/content/browser_context_dependency_manager.h" 10 #include "components/keyed_service/content/browser_context_dependency_manager.h"
11 #include "components/pref_registry/pref_registry_syncable.h" 11 #include "components/pref_registry/pref_registry_syncable.h"
12 #if defined(OS_ANDROID) 12 #if defined(OS_ANDROID)
13 #include "chrome/browser/geolocation/chrome_geolocation_permission_context_andro id.h" 13 #include "chrome/browser/geolocation/geolocation_permission_context_android.h"
14 #else 14 #else
15 #include "chrome/browser/geolocation/chrome_geolocation_permission_context.h" 15 #include "chrome/browser/geolocation/geolocation_permission_context.h"
16 #endif 16 #endif
17 17
18 namespace { 18 namespace {
19 19
20 class Service : public KeyedService { 20 class Service : public KeyedService {
21 public: 21 public:
22 explicit Service(Profile* profile) { 22 explicit Service(Profile* profile) {
23 #if defined(OS_ANDROID) 23 #if defined(OS_ANDROID)
24 context_ = new ChromeGeolocationPermissionContextAndroid(profile); 24 context_ = new GeolocationPermissionContextAndroid(profile);
25 #else 25 #else
26 context_ = new ChromeGeolocationPermissionContext(profile); 26 context_ = new GeolocationPermissionContext(profile);
27 #endif 27 #endif
28 } 28 }
29 29
30 ChromeGeolocationPermissionContext* context() { 30 GeolocationPermissionContext* context() {
31 return context_.get(); 31 return context_.get();
32 } 32 }
33 33
34 virtual void Shutdown() OVERRIDE { 34 virtual void Shutdown() OVERRIDE {
35 context()->ShutdownOnUIThread(); 35 context()->ShutdownOnUIThread();
36 } 36 }
37 37
38 private: 38 private:
39 scoped_refptr<ChromeGeolocationPermissionContext> context_; 39 scoped_refptr<GeolocationPermissionContext> context_;
40 40
41 DISALLOW_COPY_AND_ASSIGN(Service); 41 DISALLOW_COPY_AND_ASSIGN(Service);
42 }; 42 };
43 43
44 } // namespace 44 } // namespace
45 45
46 // static 46 // static
47 ChromeGeolocationPermissionContext* 47 GeolocationPermissionContext*
48 ChromeGeolocationPermissionContextFactory::GetForProfile(Profile* profile) { 48 GeolocationPermissionContextFactory::GetForProfile(Profile* profile) {
49 return static_cast<Service*>( 49 return static_cast<Service*>(
50 GetInstance()->GetServiceForBrowserContext(profile, true))->context(); 50 GetInstance()->GetServiceForBrowserContext(profile, true))->context();
51 } 51 }
52 52
53 // static 53 // static
54 ChromeGeolocationPermissionContextFactory* 54 GeolocationPermissionContextFactory*
55 ChromeGeolocationPermissionContextFactory::GetInstance() { 55 GeolocationPermissionContextFactory::GetInstance() {
56 return Singleton<ChromeGeolocationPermissionContextFactory>::get(); 56 return Singleton<GeolocationPermissionContextFactory>::get();
57 } 57 }
58 58
59 ChromeGeolocationPermissionContextFactory:: 59 GeolocationPermissionContextFactory::GeolocationPermissionContextFactory()
60 ChromeGeolocationPermissionContextFactory()
61 : BrowserContextKeyedServiceFactory( 60 : BrowserContextKeyedServiceFactory(
62 "ChromeGeolocationPermissionContext", 61 "GeolocationPermissionContext",
63 BrowserContextDependencyManager::GetInstance()) { 62 BrowserContextDependencyManager::GetInstance()) {
64 } 63 }
65 64
66 ChromeGeolocationPermissionContextFactory:: 65 GeolocationPermissionContextFactory::~GeolocationPermissionContextFactory() {
67 ~ChromeGeolocationPermissionContextFactory() {
68 } 66 }
69 67
70 KeyedService* 68 KeyedService*
71 ChromeGeolocationPermissionContextFactory::BuildServiceInstanceFor( 69 GeolocationPermissionContextFactory::BuildServiceInstanceFor(
72 content::BrowserContext* profile) const { 70 content::BrowserContext* profile) const {
73 return new Service(static_cast<Profile*>(profile)); 71 return new Service(static_cast<Profile*>(profile));
74 } 72 }
75 73
76 void ChromeGeolocationPermissionContextFactory::RegisterProfilePrefs( 74 void GeolocationPermissionContextFactory::RegisterProfilePrefs(
77 user_prefs::PrefRegistrySyncable* registry) { 75 user_prefs::PrefRegistrySyncable* registry) {
78 #if defined(OS_ANDROID) 76 #if defined(OS_ANDROID)
79 registry->RegisterBooleanPref( 77 registry->RegisterBooleanPref(
80 prefs::kGeolocationEnabled, 78 prefs::kGeolocationEnabled,
81 true, 79 true,
82 user_prefs::PrefRegistrySyncable::UNSYNCABLE_PREF); 80 user_prefs::PrefRegistrySyncable::UNSYNCABLE_PREF);
83 #endif 81 #endif
84 } 82 }
85 83
86 content::BrowserContext* 84 content::BrowserContext*
87 ChromeGeolocationPermissionContextFactory::GetBrowserContextToUse( 85 GeolocationPermissionContextFactory::GetBrowserContextToUse(
88 content::BrowserContext* context) const { 86 content::BrowserContext* context) const {
89 return chrome::GetBrowserContextOwnInstanceInIncognito(context); 87 return chrome::GetBrowserContextOwnInstanceInIncognito(context);
90 } 88 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698