OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/password_manager/account_chooser_dialog_android.h" | 5 #include "chrome/browser/password_manager/account_chooser_dialog_android.h" |
6 | 6 |
7 #include <utility> | 7 #include <utility> |
8 | 8 |
9 #include "base/android/jni_android.h" | 9 #include "base/android/jni_android.h" |
10 #include "base/android/jni_string.h" | 10 #include "base/android/jni_string.h" |
(...skipping 21 matching lines...) Expand all Loading... |
32 using base::android::AttachCurrentThread; | 32 using base::android::AttachCurrentThread; |
33 using base::android::ConvertUTF16ToJavaString; | 33 using base::android::ConvertUTF16ToJavaString; |
34 using base::android::JavaParamRef; | 34 using base::android::JavaParamRef; |
35 using base::android::ScopedJavaLocalRef; | 35 using base::android::ScopedJavaLocalRef; |
36 | 36 |
37 namespace { | 37 namespace { |
38 | 38 |
39 void AddElementsToJavaCredentialArray( | 39 void AddElementsToJavaCredentialArray( |
40 JNIEnv* env, | 40 JNIEnv* env, |
41 ScopedJavaLocalRef<jobjectArray> java_credentials_array, | 41 ScopedJavaLocalRef<jobjectArray> java_credentials_array, |
42 const std::vector<const autofill::PasswordForm*>& password_forms, | 42 const std::vector<std::unique_ptr<autofill::PasswordForm>>& password_forms, |
43 password_manager::CredentialType type, | 43 password_manager::CredentialType type, |
44 int indexStart = 0) { | 44 int indexStart = 0) { |
45 int index = indexStart; | 45 int index = indexStart; |
46 for (auto* password_form : password_forms) { | 46 for (const auto& password_form : password_forms) { |
47 ScopedJavaLocalRef<jobject> java_credential = CreateNativeCredential( | 47 ScopedJavaLocalRef<jobject> java_credential = CreateNativeCredential( |
48 env, *password_form, index - indexStart, static_cast<int>(type)); | 48 env, *password_form, index - indexStart, static_cast<int>(type)); |
49 env->SetObjectArrayElement(java_credentials_array.obj(), index, | 49 env->SetObjectArrayElement(java_credentials_array.obj(), index, |
50 java_credential.obj()); | 50 java_credential.obj()); |
51 index++; | 51 index++; |
52 } | 52 } |
53 } | 53 } |
54 | 54 |
55 class AvatarFetcherAndroid : public AccountAvatarFetcher { | 55 class AvatarFetcherAndroid : public AccountAvatarFetcher { |
56 public: | 56 public: |
(...skipping 28 matching lines...) Expand all Loading... |
85 base::android::ScopedJavaLocalRef<jobject> java_bitmap = | 85 base::android::ScopedJavaLocalRef<jobject> java_bitmap = |
86 gfx::ConvertToJavaBitmap(bitmap); | 86 gfx::ConvertToJavaBitmap(bitmap); |
87 Java_AccountChooserDialog_imageFetchComplete( | 87 Java_AccountChooserDialog_imageFetchComplete( |
88 AttachCurrentThread(), java_dialog_, index_, java_bitmap); | 88 AttachCurrentThread(), java_dialog_, index_, java_bitmap); |
89 } | 89 } |
90 delete this; | 90 delete this; |
91 } | 91 } |
92 | 92 |
93 void FetchAvatars( | 93 void FetchAvatars( |
94 const base::android::ScopedJavaGlobalRef<jobject>& java_dialog, | 94 const base::android::ScopedJavaGlobalRef<jobject>& java_dialog, |
95 const std::vector<const autofill::PasswordForm*>& password_forms, | 95 const std::vector<std::unique_ptr<autofill::PasswordForm>>& password_forms, |
96 int index, | 96 int index, |
97 net::URLRequestContextGetter* request_context) { | 97 net::URLRequestContextGetter* request_context) { |
98 for (auto* password_form : password_forms) { | 98 for (const auto& password_form : password_forms) { |
99 if (!password_form->icon_url.is_valid()) | 99 if (!password_form->icon_url.is_valid()) |
100 continue; | 100 continue; |
101 // Fetcher deletes itself once fetching is finished. | 101 // Fetcher deletes itself once fetching is finished. |
102 auto* fetcher = | 102 auto* fetcher = |
103 new AvatarFetcherAndroid(password_form->icon_url, index, java_dialog); | 103 new AvatarFetcherAndroid(password_form->icon_url, index, java_dialog); |
104 fetcher->Start(request_context); | 104 fetcher->Start(request_context); |
105 ++index; | 105 ++index; |
106 } | 106 } |
107 } | 107 } |
108 | 108 |
109 }; // namespace | 109 }; // namespace |
110 | 110 |
111 AccountChooserDialogAndroid::AccountChooserDialogAndroid( | 111 AccountChooserDialogAndroid::AccountChooserDialogAndroid( |
112 content::WebContents* web_contents, | 112 content::WebContents* web_contents, |
113 ScopedVector<autofill::PasswordForm> local_credentials, | 113 std::vector<std::unique_ptr<autofill::PasswordForm>> local_credentials, |
114 ScopedVector<autofill::PasswordForm> federated_credentials, | 114 std::vector<std::unique_ptr<autofill::PasswordForm>> federated_credentials, |
115 const GURL& origin, | 115 const GURL& origin, |
116 const ManagePasswordsState::CredentialsCallback& callback) | 116 const ManagePasswordsState::CredentialsCallback& callback) |
117 : content::WebContentsObserver(web_contents), | 117 : content::WebContentsObserver(web_contents), |
118 web_contents_(web_contents), | 118 web_contents_(web_contents), |
119 origin_(origin) { | 119 origin_(origin) { |
120 passwords_data_.set_client( | 120 passwords_data_.set_client( |
121 ChromePasswordManagerClient::FromWebContents(web_contents_)); | 121 ChromePasswordManagerClient::FromWebContents(web_contents_)); |
122 passwords_data_.OnRequestCredentials( | 122 passwords_data_.OnRequestCredentials( |
123 std::move(local_credentials), std::move(federated_credentials), origin); | 123 std::move(local_credentials), std::move(federated_credentials), origin); |
124 passwords_data_.set_credentials_callback(callback); | 124 passwords_data_.set_credentials_callback(callback); |
125 } | 125 } |
126 | 126 |
127 AccountChooserDialogAndroid::~AccountChooserDialogAndroid() {} | 127 AccountChooserDialogAndroid::~AccountChooserDialogAndroid() {} |
128 | 128 |
129 void AccountChooserDialogAndroid::ShowDialog() { | 129 void AccountChooserDialogAndroid::ShowDialog() { |
130 JNIEnv* env = AttachCurrentThread(); | 130 JNIEnv* env = AttachCurrentThread(); |
131 bool is_smartlock_branding_enabled = | 131 bool is_smartlock_branding_enabled = |
132 password_bubble_experiment::IsSmartLockUser( | 132 password_bubble_experiment::IsSmartLockUser( |
133 ProfileSyncServiceFactory::GetForProfile( | 133 ProfileSyncServiceFactory::GetForProfile( |
134 Profile::FromBrowserContext(web_contents_->GetBrowserContext()))); | 134 Profile::FromBrowserContext(web_contents_->GetBrowserContext()))); |
135 base::string16 title; | 135 base::string16 title; |
136 gfx::Range title_link_range = gfx::Range(); | 136 gfx::Range title_link_range = gfx::Range(); |
137 GetAccountChooserDialogTitleTextAndLinkRange( | 137 GetAccountChooserDialogTitleTextAndLinkRange( |
138 is_smartlock_branding_enabled, local_credentials_forms().size() > 1, | 138 is_smartlock_branding_enabled, local_credentials_forms().size() > 1, |
139 &title, &title_link_range); | 139 &title, &title_link_range); |
140 gfx::NativeWindow native_window = web_contents_->GetTopLevelNativeWindow(); | 140 gfx::NativeWindow native_window = web_contents_->GetTopLevelNativeWindow(); |
141 size_t credential_array_size = | 141 size_t credential_array_size = |
142 local_credentials_forms().size() + federated_credentials_forms().size(); | 142 local_credentials_forms().size() + federation_providers_forms().size(); |
143 ScopedJavaLocalRef<jobjectArray> java_credentials_array = | 143 ScopedJavaLocalRef<jobjectArray> java_credentials_array = |
144 CreateNativeCredentialArray(env, credential_array_size); | 144 CreateNativeCredentialArray(env, credential_array_size); |
145 AddElementsToJavaCredentialArray( | 145 AddElementsToJavaCredentialArray( |
146 env, java_credentials_array, local_credentials_forms(), | 146 env, java_credentials_array, local_credentials_forms(), |
147 password_manager::CredentialType::CREDENTIAL_TYPE_PASSWORD); | 147 password_manager::CredentialType::CREDENTIAL_TYPE_PASSWORD); |
148 AddElementsToJavaCredentialArray( | 148 AddElementsToJavaCredentialArray( |
149 env, java_credentials_array, federated_credentials_forms(), | 149 env, java_credentials_array, federation_providers_forms(), |
150 password_manager::CredentialType::CREDENTIAL_TYPE_FEDERATED, | 150 password_manager::CredentialType::CREDENTIAL_TYPE_FEDERATED, |
151 local_credentials_forms().size()); | 151 local_credentials_forms().size()); |
152 base::android::ScopedJavaGlobalRef<jobject> java_dialog_global; | 152 base::android::ScopedJavaGlobalRef<jobject> java_dialog_global; |
153 const std::string origin = password_manager::GetShownOrigin(origin_); | 153 const std::string origin = password_manager::GetShownOrigin(origin_); |
154 base::string16 signin_button; | 154 base::string16 signin_button; |
155 if (local_credentials_forms().size() == 1) { | 155 if (local_credentials_forms().size() == 1) { |
156 signin_button = | 156 signin_button = |
157 l10n_util::GetStringUTF16(IDS_PASSWORD_MANAGER_ACCOUNT_CHOOSER_SIGN_IN); | 157 l10n_util::GetStringUTF16(IDS_PASSWORD_MANAGER_ACCOUNT_CHOOSER_SIGN_IN); |
158 } | 158 } |
159 dialog_jobject_.Reset(Java_AccountChooserDialog_createAndShowAccountChooser( | 159 dialog_jobject_.Reset(Java_AccountChooserDialog_createAndShowAccountChooser( |
160 env, native_window->GetJavaObject(), reinterpret_cast<intptr_t>(this), | 160 env, native_window->GetJavaObject(), reinterpret_cast<intptr_t>(this), |
161 java_credentials_array, | 161 java_credentials_array, |
162 base::android::ConvertUTF16ToJavaString(env, title), | 162 base::android::ConvertUTF16ToJavaString(env, title), |
163 title_link_range.start(), title_link_range.end(), | 163 title_link_range.start(), title_link_range.end(), |
164 base::android::ConvertUTF8ToJavaString(env, origin), | 164 base::android::ConvertUTF8ToJavaString(env, origin), |
165 base::android::ConvertUTF16ToJavaString(env, signin_button))); | 165 base::android::ConvertUTF16ToJavaString(env, signin_button))); |
166 net::URLRequestContextGetter* request_context = | 166 net::URLRequestContextGetter* request_context = |
167 Profile::FromBrowserContext(web_contents_->GetBrowserContext()) | 167 Profile::FromBrowserContext(web_contents_->GetBrowserContext()) |
168 ->GetRequestContext(); | 168 ->GetRequestContext(); |
169 FetchAvatars(dialog_jobject_, local_credentials_forms(), 0, request_context); | 169 FetchAvatars(dialog_jobject_, local_credentials_forms(), 0, request_context); |
170 FetchAvatars(dialog_jobject_, federated_credentials_forms(), | 170 FetchAvatars(dialog_jobject_, federation_providers_forms(), |
171 local_credentials_forms().size(), request_context); | 171 local_credentials_forms().size(), request_context); |
172 } | 172 } |
173 | 173 |
174 void AccountChooserDialogAndroid::OnCredentialClicked( | 174 void AccountChooserDialogAndroid::OnCredentialClicked( |
175 JNIEnv* env, | 175 JNIEnv* env, |
176 const JavaParamRef<jobject>& obj, | 176 const JavaParamRef<jobject>& obj, |
177 jint credential_item, | 177 jint credential_item, |
178 jint credential_type, | 178 jint credential_type, |
179 jboolean signin_button_clicked) { | 179 jboolean signin_button_clicked) { |
180 ChooseCredential( | 180 ChooseCredential( |
(...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
214 OnDialogCancel(); | 214 OnDialogCancel(); |
215 JNIEnv* env = AttachCurrentThread(); | 215 JNIEnv* env = AttachCurrentThread(); |
216 Java_AccountChooserDialog_dismissDialog(env, dialog_jobject_); | 216 Java_AccountChooserDialog_dismissDialog(env, dialog_jobject_); |
217 } | 217 } |
218 | 218 |
219 void AccountChooserDialogAndroid::OnDialogCancel() { | 219 void AccountChooserDialogAndroid::OnDialogCancel() { |
220 ChooseCredential(-1, password_manager::CredentialType::CREDENTIAL_TYPE_EMPTY, | 220 ChooseCredential(-1, password_manager::CredentialType::CREDENTIAL_TYPE_EMPTY, |
221 false /* signin_button_clicked */); | 221 false /* signin_button_clicked */); |
222 } | 222 } |
223 | 223 |
224 const std::vector<const autofill::PasswordForm*>& | 224 const std::vector<std::unique_ptr<autofill::PasswordForm>>& |
225 AccountChooserDialogAndroid::local_credentials_forms() const { | 225 AccountChooserDialogAndroid::local_credentials_forms() const { |
226 return passwords_data_.GetCurrentForms(); | 226 return passwords_data_.GetCurrentForms(); |
227 } | 227 } |
228 | 228 |
229 const std::vector<const autofill::PasswordForm*>& | 229 const std::vector<std::unique_ptr<autofill::PasswordForm>>& |
230 AccountChooserDialogAndroid::federated_credentials_forms() const { | 230 AccountChooserDialogAndroid::federation_providers_forms() const { |
231 return passwords_data_.federated_credentials_forms(); | 231 return passwords_data_.federation_providers_forms(); |
232 } | 232 } |
233 | 233 |
234 void AccountChooserDialogAndroid::ChooseCredential( | 234 void AccountChooserDialogAndroid::ChooseCredential( |
235 size_t index, | 235 size_t index, |
236 password_manager::CredentialType type, | 236 password_manager::CredentialType type, |
237 bool signin_button_clicked) { | 237 bool signin_button_clicked) { |
238 using namespace password_manager; | 238 using namespace password_manager; |
239 password_manager::metrics_util::AccountChooserUserAction action; | 239 password_manager::metrics_util::AccountChooserUserAction action; |
240 if (type == CredentialType::CREDENTIAL_TYPE_EMPTY) { | 240 if (type == CredentialType::CREDENTIAL_TYPE_EMPTY) { |
241 passwords_data_.ChooseCredential(nullptr); | 241 passwords_data_.ChooseCredential(nullptr); |
242 action = metrics_util::ACCOUNT_CHOOSER_DISMISSED; | 242 action = metrics_util::ACCOUNT_CHOOSER_DISMISSED; |
243 } else { | 243 } else { |
244 action = signin_button_clicked | 244 action = signin_button_clicked |
245 ? metrics_util::ACCOUNT_CHOOSER_SIGN_IN | 245 ? metrics_util::ACCOUNT_CHOOSER_SIGN_IN |
246 : metrics_util::ACCOUNT_CHOOSER_CREDENTIAL_CHOSEN; | 246 : metrics_util::ACCOUNT_CHOOSER_CREDENTIAL_CHOSEN; |
247 const auto& credentials_forms = | 247 const auto& credentials_forms = |
248 (type == CredentialType::CREDENTIAL_TYPE_PASSWORD) | 248 (type == CredentialType::CREDENTIAL_TYPE_PASSWORD) |
249 ? local_credentials_forms() | 249 ? local_credentials_forms() |
250 : federated_credentials_forms(); | 250 : federation_providers_forms(); |
251 if (index < credentials_forms.size()) { | 251 if (index < credentials_forms.size()) { |
252 passwords_data_.ChooseCredential(credentials_forms[index]); | 252 passwords_data_.ChooseCredential(credentials_forms[index].get()); |
253 } | 253 } |
254 } | 254 } |
255 | 255 |
256 if (local_credentials_forms().size() == 1) { | 256 if (local_credentials_forms().size() == 1) { |
257 password_manager::metrics_util::LogAccountChooserUserActionOneAccount( | 257 password_manager::metrics_util::LogAccountChooserUserActionOneAccount( |
258 action); | 258 action); |
259 } else { | 259 } else { |
260 password_manager::metrics_util::LogAccountChooserUserActionManyAccounts( | 260 password_manager::metrics_util::LogAccountChooserUserActionManyAccounts( |
261 action); | 261 action); |
262 } | 262 } |
263 } | 263 } |
264 | 264 |
265 bool RegisterAccountChooserDialogAndroid(JNIEnv* env) { | 265 bool RegisterAccountChooserDialogAndroid(JNIEnv* env) { |
266 return RegisterNativesImpl(env); | 266 return RegisterNativesImpl(env); |
267 } | 267 } |
OLD | NEW |