Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/android/password_ui_view_android.h" | 5 #include "chrome/browser/android/password_ui_view_android.h" |
| 6 | 6 |
| 7 #include "base/android/jni_string.h" | 7 #include "base/android/jni_string.h" |
| 8 #include "base/android/jni_weak_ref.h" | 8 #include "base/android/jni_weak_ref.h" |
| 9 #include "base/bind.h" | |
|
vabr (Chromium)
2016/06/08 09:04:04
None of the added #includes except for string_piec
dozsa
2016/06/08 11:22:30
Done.
| |
| 10 #include "base/command_line.h" | |
| 11 #include "base/memory/ptr_util.h" | |
| 9 #include "base/metrics/field_trial.h" | 12 #include "base/metrics/field_trial.h" |
| 13 #include "base/metrics/user_metrics_action.h" | |
| 14 #include "base/strings/string_piece.h" | |
| 15 #include "base/strings/string_split.h" | |
| 16 #include "base/strings/string_util.h" | |
| 17 #include "base/strings/utf_string_conversions.h" | |
| 10 #include "chrome/browser/profiles/profile_manager.h" | 18 #include "chrome/browser/profiles/profile_manager.h" |
| 11 #include "chrome/browser/sync/profile_sync_service_factory.h" | 19 #include "chrome/browser/sync/profile_sync_service_factory.h" |
| 12 #include "components/autofill/core/common/password_form.h" | 20 #include "components/autofill/core/common/password_form.h" |
| 13 #include "components/browser_sync/browser/profile_sync_service.h" | 21 #include "components/browser_sync/browser/profile_sync_service.h" |
| 14 #include "components/password_manager/core/browser/affiliation_utils.h" | 22 #include "components/password_manager/core/browser/affiliation_utils.h" |
| 15 #include "components/password_manager/core/browser/password_bubble_experiment.h" | 23 #include "components/password_manager/core/browser/password_bubble_experiment.h" |
| 16 #include "components/password_manager/core/browser/password_manager_constants.h" | 24 #include "components/password_manager/core/browser/password_manager_constants.h" |
| 25 #include "components/password_manager/core/browser/password_ui_utils.h" | |
| 17 #include "components/password_manager/core/common/experiments.h" | 26 #include "components/password_manager/core/common/experiments.h" |
| 18 #include "jni/PasswordUIView_jni.h" | 27 #include "jni/PasswordUIView_jni.h" |
| 19 | 28 |
| 20 using base::android::ConvertUTF16ToJavaString; | 29 using base::android::ConvertUTF16ToJavaString; |
| 21 using base::android::ConvertUTF8ToJavaString; | 30 using base::android::ConvertUTF8ToJavaString; |
| 22 using base::android::ScopedJavaLocalRef; | 31 using base::android::ScopedJavaLocalRef; |
| 32 using base::StringPiece; | |
|
vabr (Chromium)
2016/06/08 09:04:04
optional: Inlining "base::" in the code below is n
dozsa
2016/06/08 11:22:30
Done.
| |
| 33 using password_manager::PasswordStore; | |
|
vabr (Chromium)
2016/06/08 09:04:05
Appears unused, please remove.
dozsa
2016/06/08 11:22:30
Done.
| |
| 23 | 34 |
| 24 PasswordUIViewAndroid::PasswordUIViewAndroid(JNIEnv* env, jobject obj) | 35 PasswordUIViewAndroid::PasswordUIViewAndroid(JNIEnv* env, jobject obj) |
| 25 : password_manager_presenter_(this), weak_java_ui_controller_(env, obj) {} | 36 : password_manager_presenter_(this), weak_java_ui_controller_(env, obj) {} |
| 26 | 37 |
| 27 PasswordUIViewAndroid::~PasswordUIViewAndroid() {} | 38 PasswordUIViewAndroid::~PasswordUIViewAndroid() {} |
| 28 | 39 |
| 29 void PasswordUIViewAndroid::Destroy(JNIEnv*, const JavaParamRef<jobject>&) { | 40 void PasswordUIViewAndroid::Destroy(JNIEnv*, const JavaParamRef<jobject>&) { |
| 30 delete this; | 41 delete this; |
| 31 } | 42 } |
| 32 | 43 |
| (...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 75 const JavaParamRef<jobject>&, | 86 const JavaParamRef<jobject>&, |
| 76 int index) { | 87 int index) { |
| 77 const autofill::PasswordForm* form = | 88 const autofill::PasswordForm* form = |
| 78 password_manager_presenter_.GetPassword(index); | 89 password_manager_presenter_.GetPassword(index); |
| 79 if (!form) { | 90 if (!form) { |
| 80 return Java_PasswordUIView_createSavedPasswordEntry( | 91 return Java_PasswordUIView_createSavedPasswordEntry( |
| 81 env, | 92 env, |
| 82 ConvertUTF8ToJavaString(env, std::string()).obj(), | 93 ConvertUTF8ToJavaString(env, std::string()).obj(), |
| 83 ConvertUTF16ToJavaString(env, base::string16()).obj()); | 94 ConvertUTF16ToJavaString(env, base::string16()).obj()); |
| 84 } | 95 } |
| 96 bool is_android_uri = false; | |
|
vabr (Chromium)
2016/06/08 09:04:04
The block here is identical to the one on lines 12
dozsa
2016/06/08 11:22:30
Done.
| |
| 97 bool is_clickable = false; | |
| 98 GURL link_url; | |
| 85 std::string human_readable_origin = | 99 std::string human_readable_origin = |
| 86 password_manager::GetHumanReadableOrigin(*form); | 100 password_manager::GetShownOriginAndLinkUrl(*form, &is_android_uri, |
| 101 &link_url, | |
| 102 &is_clickable); | |
| 103 if (!is_clickable) { | |
| 104 human_readable_origin = password_manager::SplitByDotAndReverse( | |
| 105 StringPiece( | |
| 106 &human_readable_origin[ | |
| 107 password_manager:: | |
| 108 kAndroidAppSchemeAndDelimiterLength], | |
| 109 human_readable_origin.length() - | |
| 110 password_manager::kAndroidAppSchemeAndDelimiterLength)); | |
| 111 human_readable_origin = human_readable_origin + " (Android)"; | |
| 112 } | |
| 87 return Java_PasswordUIView_createSavedPasswordEntry( | 113 return Java_PasswordUIView_createSavedPasswordEntry( |
| 88 env, ConvertUTF8ToJavaString(env, human_readable_origin).obj(), | 114 env, ConvertUTF8ToJavaString(env, human_readable_origin).obj(), |
| 89 ConvertUTF16ToJavaString(env, form->username_value).obj()); | 115 ConvertUTF16ToJavaString(env, form->username_value).obj()); |
| 90 } | 116 } |
| 91 | 117 |
| 92 ScopedJavaLocalRef<jstring> PasswordUIViewAndroid::GetSavedPasswordException( | 118 ScopedJavaLocalRef<jstring> PasswordUIViewAndroid::GetSavedPasswordException( |
| 93 JNIEnv* env, | 119 JNIEnv* env, |
| 94 const JavaParamRef<jobject>&, | 120 const JavaParamRef<jobject>&, |
| 95 int index) { | 121 int index) { |
| 96 const autofill::PasswordForm* form = | 122 const autofill::PasswordForm* form = |
| 97 password_manager_presenter_.GetPasswordException(index); | 123 password_manager_presenter_.GetPasswordException(index); |
| 98 if (!form) | 124 if (!form) |
| 99 return ConvertUTF8ToJavaString(env, std::string()); | 125 return ConvertUTF8ToJavaString(env, std::string()); |
| 126 bool is_android_uri = false; | |
| 127 bool is_clickable = false; | |
| 128 GURL link_url; | |
| 100 std::string human_readable_origin = | 129 std::string human_readable_origin = |
| 101 password_manager::GetHumanReadableOrigin(*form); | 130 password_manager::GetShownOriginAndLinkUrl(*form, &is_android_uri, |
| 131 &link_url, | |
| 132 &is_clickable); | |
| 133 if (!is_clickable) { | |
| 134 human_readable_origin = password_manager::SplitByDotAndReverse( | |
| 135 StringPiece | |
| 136 (&human_readable_origin[ | |
| 137 password_manager:: | |
| 138 kAndroidAppSchemeAndDelimiterLength], | |
| 139 human_readable_origin.length() - | |
| 140 password_manager::kAndroidAppSchemeAndDelimiterLength)); | |
| 141 human_readable_origin = human_readable_origin + " (Android)"; | |
| 142 } | |
| 102 return ConvertUTF8ToJavaString(env, human_readable_origin); | 143 return ConvertUTF8ToJavaString(env, human_readable_origin); |
| 103 } | 144 } |
| 104 | 145 |
| 105 void PasswordUIViewAndroid::HandleRemoveSavedPasswordEntry( | 146 void PasswordUIViewAndroid::HandleRemoveSavedPasswordEntry( |
| 106 JNIEnv* env, | 147 JNIEnv* env, |
| 107 const JavaParamRef<jobject>&, | 148 const JavaParamRef<jobject>&, |
| 108 int index) { | 149 int index) { |
| 109 password_manager_presenter_.RemoveSavedPassword(index); | 150 password_manager_presenter_.RemoveSavedPassword(index); |
| 110 } | 151 } |
| 111 | 152 |
| (...skipping 21 matching lines...) Expand all Loading... | |
| 133 | 174 |
| 134 // static | 175 // static |
| 135 static jlong Init(JNIEnv* env, const JavaParamRef<jobject>& obj) { | 176 static jlong Init(JNIEnv* env, const JavaParamRef<jobject>& obj) { |
| 136 PasswordUIViewAndroid* controller = new PasswordUIViewAndroid(env, obj); | 177 PasswordUIViewAndroid* controller = new PasswordUIViewAndroid(env, obj); |
| 137 return reinterpret_cast<intptr_t>(controller); | 178 return reinterpret_cast<intptr_t>(controller); |
| 138 } | 179 } |
| 139 | 180 |
| 140 bool PasswordUIViewAndroid::RegisterPasswordUIViewAndroid(JNIEnv* env) { | 181 bool PasswordUIViewAndroid::RegisterPasswordUIViewAndroid(JNIEnv* env) { |
| 141 return RegisterNativesImpl(env); | 182 return RegisterNativesImpl(env); |
| 142 } | 183 } |
| OLD | NEW |