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

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

Issue 23345004: Fix Android strict-mode violation in GeoLocation info bar. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: addresses comments Created 7 years, 3 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
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_andro id.h" 5 #include "chrome/browser/geolocation/chrome_geolocation_permission_context_andro id.h"
6 6
7 #include "base/prefs/pref_service.h" 7 #include "base/prefs/pref_service.h"
8 #include "chrome/browser/android/google_location_settings_helper.h" 8 #include "chrome/browser/android/google_location_settings_helper.h"
9 #include "chrome/browser/content_settings/permission_request_id.h"
9 #include "chrome/browser/profiles/profile.h" 10 #include "chrome/browser/profiles/profile.h"
10 #include "chrome/common/pref_names.h" 11 #include "chrome/common/pref_names.h"
11 #include "content/public/browser/browser_thread.h" 12 #include "content/public/browser/browser_thread.h"
12 13
13 ChromeGeolocationPermissionContextAndroid:: 14 ChromeGeolocationPermissionContextAndroid::
14 ChromeGeolocationPermissionContextAndroid(Profile* profile) 15 ChromeGeolocationPermissionContextAndroid(Profile* profile)
15 : ChromeGeolocationPermissionContext(profile), 16 : ChromeGeolocationPermissionContext(profile),
16 google_location_settings_helper_( 17 google_location_settings_helper_(
17 GoogleLocationSettingsHelper::Create()) { 18 GoogleLocationSettingsHelper::Create()) {
18 } 19 }
19 20
20 ChromeGeolocationPermissionContextAndroid:: 21 ChromeGeolocationPermissionContextAndroid::
21 ~ChromeGeolocationPermissionContextAndroid() { 22 ~ChromeGeolocationPermissionContextAndroid() {
22 } 23 }
23 24
25 void ChromeGeolocationPermissionContextAndroid::ProceedDecidePermission(
26 const PermissionRequestID& id,
27 const GURL& requesting_frame,
28 const GURL& embedder,
29 base::Callback<void(bool)> callback) {
30 // Super class implementation expects everything in UI thread instead.
31 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI));
32 ChromeGeolocationPermissionContext::DecidePermission(
33 id, requesting_frame, embedder, callback);
34 }
35
36 void ChromeGeolocationPermissionContextAndroid::CheckMasterLocation(
37 const PermissionRequestID& id,
38 const GURL& requesting_frame,
39 const GURL& embedder,
40 base::Callback<void(bool)> callback) {
41 // Check to see if the feature in its entirety has been disabled.
42 // This must happen before other services (e.g. tabs, extensions)
43 // get an opportunity to allow the geolocation request.
44 bool enabled =
45 google_location_settings_helper_->IsMasterLocationSettingEnabled();
bulach 2014/01/15 16:22:07 I think my previous comment was that we could also
46
47 // The flow for geolocation permission on android is:
48 // - ChromeGeolocationPermissionContextAndroid::DecidePermission
49 // intercepts the flow in the UI thread, and posts task
50 // to the blocking pool to CheckMasterLocation (in order to
51 // avoid strict-mode violation).
52 // - At this point the master location permission is either:
53 // -- enabled, in which we case it proceeds the normal flow
54 // via ChromeGeolocationPermissionContext (which may create infobars, etc.).
55 // -- disabled, in which case the permission is already decided.
56 //
57 // In either case, ChromeGeolocationPermissionContext expects these
58 // in the UI thread.
59 base::Closure ui_closure;
60 if (enabled) {
61 ui_closure = base::Bind(
62 &ChromeGeolocationPermissionContextAndroid::ProceedDecidePermission,
63 base::Unretained(this), id, requesting_frame, embedder, callback);
64 } else {
65 ui_closure = base::Bind(
66 &ChromeGeolocationPermissionContextAndroid::PermissionDecided,
67 base::Unretained(this), id,
68 requesting_frame, embedder, callback, false);
69 }
70
71 // This method is executed from the BlockingPool, post the result
72 // back to the UI thread.
73 content::BrowserThread::PostTask(
74 content::BrowserThread::UI, FROM_HERE, ui_closure);
75 }
76
24 void ChromeGeolocationPermissionContextAndroid::DecidePermission( 77 void ChromeGeolocationPermissionContextAndroid::DecidePermission(
25 const PermissionRequestID& id, 78 const PermissionRequestID& id,
26 const GURL& requesting_frame, 79 const GURL& requesting_frame,
27 const GURL& embedder, 80 const GURL& embedder,
28 base::Callback<void(bool)> callback) { 81 base::Callback<void(bool)> callback) {
82
83 // Called on the UI thread. However, do the work on a separate thread
84 // to avoid strict mode violation.
29 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI)); 85 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI));
30 86 content::BrowserThread::PostBlockingPoolTask(FROM_HERE,
31 // Check to see if the feature in its entirety has been disabled. 87 base::Bind(
32 // This must happen before other services (e.g. tabs, extensions) 88 &ChromeGeolocationPermissionContextAndroid::CheckMasterLocation,
33 // get an opportunity to allow the geolocation request. 89 base::Unretained(this), id, requesting_frame, embedder, callback));
34 if (!google_location_settings_helper_->IsMasterLocationSettingEnabled()) {
35 PermissionDecided(id, requesting_frame, embedder, callback, false);
36 return;
37 }
38
39 ChromeGeolocationPermissionContext::DecidePermission(id, requesting_frame,
40 embedder, callback);
41 } 90 }
42 91
43 void ChromeGeolocationPermissionContextAndroid::PermissionDecided( 92 void ChromeGeolocationPermissionContextAndroid::PermissionDecided(
44 const PermissionRequestID& id, 93 const PermissionRequestID& id,
45 const GURL& requesting_frame, 94 const GURL& requesting_frame,
46 const GURL& embedder, 95 const GURL& embedder,
47 base::Callback<void(bool)> callback, 96 base::Callback<void(bool)> callback,
48 bool allowed) { 97 bool allowed) {
49 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI));
50 // If Google Apps Location setting is turned off then we ignore 98 // If Google Apps Location setting is turned off then we ignore
51 // the 'allow' website setting for this site and instead show 99 // the 'allow' website setting for this site and instead show
52 // the infobar to go back to the 'settings' to turn it back on. 100 // the infobar to go back to the 'settings' to turn it back on.
53 if (allowed && 101 if (allowed &&
54 !google_location_settings_helper_->IsGoogleAppsLocationSettingEnabled()) { 102 !google_location_settings_helper_->IsGoogleAppsLocationSettingEnabled()) {
55 QueueController()->CreateInfoBarRequest(id, requesting_frame, embedder, 103 QueueController()->CreateInfoBarRequest(id, requesting_frame, embedder,
56 callback); 104 callback);
57 return; 105 return;
58 } 106 }
59 107
60 ChromeGeolocationPermissionContext::PermissionDecided( 108 ChromeGeolocationPermissionContext::PermissionDecided(
61 id, requesting_frame, embedder, callback, allowed); 109 id, requesting_frame, embedder, callback, allowed);
62 } 110 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698