diff options
author | cramya@chromium.org <cramya@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-10-27 00:49:37 +0000 |
---|---|---|
committer | cramya@chromium.org <cramya@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-10-27 00:49:37 +0000 |
commit | cb2322e2bf590f64bd8dee08b418477138d51ae4 (patch) | |
tree | 91e12e9f3a58a7b47bc33e7af68291f7c7b1943a /chrome/browser/android/google_location_settings_helper.cc | |
parent | e5656ec4577ae074bd6b45c3fc715776b3f2c6f7 (diff) | |
download | chromium_src-cb2322e2bf590f64bd8dee08b418477138d51ae4.zip chromium_src-cb2322e2bf590f64bd8dee08b418477138d51ae4.tar.gz chromium_src-cb2322e2bf590f64bd8dee08b418477138d51ae4.tar.bz2 |
Add Google Location Settings geolocation permission flow
Pre MR0 version in Android, we had an explicit "Enable Location"
setting in Chrome that will show the infobar based on the
settings. Post MR0, we use the combination of system master
location setting and system google apps location setting to
decide between
1. Showing the infobar with Allow button (if both master and
google apps are turned on)
2. Showing the infobar with Settings button that will take user
to Google Apps Location Setting activity (if master is on but
google apps location setting is turned off)
3. Do not show infobar (if master is off)
Above functionality has been added in this CL for both pre and
post MR0 cases.
This CL also removes the android unit_test for GeolocationEnabledDisabled. Since the android specific geolocation code is going to be refactored, this test along with few more android specific unit_tests will be added in an upcoming CL.
CQ-DEPEND=0f28fce084f6010242360fb7b6633b8fd7296be4
Review URL: https://chromiumcodereview.appspot.com/11186010
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@164466 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/android/google_location_settings_helper.cc')
-rw-r--r-- | chrome/browser/android/google_location_settings_helper.cc | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/chrome/browser/android/google_location_settings_helper.cc b/chrome/browser/android/google_location_settings_helper.cc new file mode 100644 index 0000000..c9d3b4d --- /dev/null +++ b/chrome/browser/android/google_location_settings_helper.cc @@ -0,0 +1,66 @@ +// Copyright (c) 2012 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "chrome/browser/android/google_location_settings_helper.h" + +#include "base/android/jni_android.h" +#include "base/android/jni_string.h" +#include "jni/GoogleLocationSettingsHelper_jni.h" + +using base::android::AttachCurrentThread; +using base::android::CheckException; +using base::android::ScopedJavaLocalRef; + +GoogleLocationSettingsHelperFactory* + GoogleLocationSettingsHelper::helper_factory_ = NULL; + +GoogleLocationSettingsHelper::GoogleLocationSettingsHelper() { + JNIEnv* env = AttachCurrentThread(); + if (helper_factory_ == NULL) { + SetGoogleLocationSettingsHelperFactory( + new GoogleLocationSettingsHelperFactory()); + } + java_google_location_settings_helper_.Reset(env, + helper_factory_->GetHelperInstance().obj()); +} + +GoogleLocationSettingsHelper::~GoogleLocationSettingsHelper() { +} + +void GoogleLocationSettingsHelper::SetGoogleLocationSettingsHelperFactory( + GoogleLocationSettingsHelperFactory* factory) { + helper_factory_ = factory; +} + +std::string GoogleLocationSettingsHelper::GetAcceptButtonLabel() { + JNIEnv* env = AttachCurrentThread(); + ScopedJavaLocalRef<jstring> infobar_allow_text = + Java_GoogleLocationSettingsHelper_getInfoBarAcceptLabel( + env, java_google_location_settings_helper_.obj()); + return ConvertJavaStringToUTF8(infobar_allow_text); +} + +void GoogleLocationSettingsHelper::ShowGoogleLocationSettings() { + JNIEnv* env = AttachCurrentThread(); + Java_GoogleLocationSettingsHelper_startGoogleLocationSettingsActivity( + env, java_google_location_settings_helper_.obj()); +} + +bool GoogleLocationSettingsHelper::IsGoogleAppsLocationSettingEnabled() { + JNIEnv* env = AttachCurrentThread(); + return Java_GoogleLocationSettingsHelper_isGoogleAppsLocationSettingEnabled( + env, java_google_location_settings_helper_.obj()); +} + +bool GoogleLocationSettingsHelper::IsMasterLocationSettingEnabled() { + JNIEnv* env = AttachCurrentThread(); + return Java_GoogleLocationSettingsHelper_isMasterLocationSettingEnabled( + env, java_google_location_settings_helper_.obj()); +} + +// Register native methods + +bool GoogleLocationSettingsHelper::Register(JNIEnv* env) { + return RegisterNativesImpl(env); +} |