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

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: address 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::CallSuperDecidePermission(
bulach 2013/09/12 09:18:29 thanks for the explanation! how about "ProceedDeci
acleung1 2013/09/17 00:08:45 Done.
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();
46
47 // Regardless of what the master setting is, we still need to
48 // go back to the UI thread for the rest of the bookkeeping.
bulach 2013/09/12 09:18:29 Perhaps a more detailed explanation would help cla
acleung1 2013/09/17 00:08:45 Done.
49 base::Closure ui_closure;
50 if (enabled) {
51 ui_closure = base::Bind(
52 &ChromeGeolocationPermissionContextAndroid::CallSuperDecidePermission,
bulach 2013/09/12 09:18:29 so if you agree with the comment above, I think "P
acleung1 2013/09/17 00:08:45 Done.
53 base::Unretained(this), id, requesting_frame, embedder, callback);
54 } else {
55 ui_closure = base::Bind(
56 &ChromeGeolocationPermissionContextAndroid::PermissionDecided,
57 base::Unretained(this), id,
58 requesting_frame, embedder, callback, false);
59 }
60
61 // This method is executed from the BlockingPool, post the result
62 // back to the UI thread.
63 content::BrowserThread::PostTask(
64 content::BrowserThread::UI, FROM_HERE,ui_closure);
bulach 2013/09/12 09:18:29 nit: space after comma, s/,ui_clo/, ui_clo/
acleung1 2013/09/17 00:08:45 Done.
65 }
66
24 void ChromeGeolocationPermissionContextAndroid::DecidePermission( 67 void ChromeGeolocationPermissionContextAndroid::DecidePermission(
25 const PermissionRequestID& id, 68 const PermissionRequestID& id,
26 const GURL& requesting_frame, 69 const GURL& requesting_frame,
27 const GURL& embedder, 70 const GURL& embedder,
28 base::Callback<void(bool)> callback) { 71 base::Callback<void(bool)> callback) {
72
73 // Called on the UI thread. However, do the work on a separate thread
74 // to avoid strict mode violation.
29 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI)); 75 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI));
30 76 content::BrowserThread::PostBlockingPoolTask(FROM_HERE,
31 // Check to see if the feature in its entirety has been disabled. 77 base::Bind(
32 // This must happen before other services (e.g. tabs, extensions) 78 &ChromeGeolocationPermissionContextAndroid::CheckMasterLocation,
33 // get an opportunity to allow the geolocation request. 79 base::Unretained(this), id, requesting_frame, embedder, callback));
bulach 2013/09/12 09:18:29 nit: indent
acleung1 2013/09/17 00:08:45 Done.
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 } 80 }
42 81
43 void ChromeGeolocationPermissionContextAndroid::PermissionDecided( 82 void ChromeGeolocationPermissionContextAndroid::PermissionDecided(
44 const PermissionRequestID& id, 83 const PermissionRequestID& id,
45 const GURL& requesting_frame, 84 const GURL& requesting_frame,
46 const GURL& embedder, 85 const GURL& embedder,
47 base::Callback<void(bool)> callback, 86 base::Callback<void(bool)> callback,
48 bool allowed) { 87 bool allowed) {
49 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI));
50 // If Google Apps Location setting is turned off then we ignore 88 // If Google Apps Location setting is turned off then we ignore
51 // the 'allow' website setting for this site and instead show 89 // the 'allow' website setting for this site and instead show
52 // the infobar to go back to the 'settings' to turn it back on. 90 // the infobar to go back to the 'settings' to turn it back on.
53 if (allowed && 91 if (allowed &&
54 !google_location_settings_helper_->IsGoogleAppsLocationSettingEnabled()) { 92 !google_location_settings_helper_->IsGoogleAppsLocationSettingEnabled()) {
55 QueueController()->CreateInfoBarRequest(id, requesting_frame, embedder, 93 QueueController()->CreateInfoBarRequest(id, requesting_frame, embedder,
56 callback); 94 callback);
bulach 2013/10/16 10:47:11 here, I think this could pass the boolean and stri
acleung1 2013/12/12 23:38:30 I don't think that's going to solve the issue we h
acleung1 2013/12/12 23:38:30 I dont' think this will solve our problem because
57 return; 95 return;
58 } 96 }
59 97
60 ChromeGeolocationPermissionContext::PermissionDecided( 98 ChromeGeolocationPermissionContext::PermissionDecided(
61 id, requesting_frame, embedder, callback, allowed); 99 id, requesting_frame, embedder, callback, allowed);
62 } 100 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698