| 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 "components/autofill/content/renderer/password_autofill_agent.h" | 5 #include "components/autofill/content/renderer/password_autofill_agent.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/command_line.h" | 8 #include "base/command_line.h" |
| 9 #include "base/i18n/case_conversion.h" |
| 9 #include "base/memory/scoped_ptr.h" | 10 #include "base/memory/scoped_ptr.h" |
| 10 #include "base/message_loop/message_loop.h" | 11 #include "base/message_loop/message_loop.h" |
| 11 #include "base/metrics/field_trial.h" | 12 #include "base/metrics/field_trial.h" |
| 12 #include "base/metrics/histogram_macros.h" | 13 #include "base/metrics/histogram_macros.h" |
| 13 #include "base/strings/utf_string_conversions.h" | 14 #include "base/strings/utf_string_conversions.h" |
| 14 #include "components/autofill/content/common/autofill_messages.h" | 15 #include "components/autofill/content/common/autofill_messages.h" |
| 15 #include "components/autofill/content/renderer/form_autofill_util.h" | 16 #include "components/autofill/content/renderer/form_autofill_util.h" |
| 16 #include "components/autofill/content/renderer/password_form_conversion_utils.h" | 17 #include "components/autofill/content/renderer/password_form_conversion_utils.h" |
| 17 #include "components/autofill/content/renderer/renderer_save_password_progress_l
ogger.h" | 18 #include "components/autofill/content/renderer/renderer_save_password_progress_l
ogger.h" |
| 18 #include "components/autofill/core/common/autofill_constants.h" | 19 #include "components/autofill/core/common/autofill_constants.h" |
| (...skipping 199 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 218 | 219 |
| 219 bool IsElementEditable(const blink::WebInputElement& element) { | 220 bool IsElementEditable(const blink::WebInputElement& element) { |
| 220 return element.isEnabled() && !element.isReadOnly(); | 221 return element.isEnabled() && !element.isReadOnly(); |
| 221 } | 222 } |
| 222 | 223 |
| 223 bool DoUsernamesMatch(const base::string16& username1, | 224 bool DoUsernamesMatch(const base::string16& username1, |
| 224 const base::string16& username2, | 225 const base::string16& username2, |
| 225 bool exact_match) { | 226 bool exact_match) { |
| 226 if (exact_match) | 227 if (exact_match) |
| 227 return username1 == username2; | 228 return username1 == username2; |
| 228 return base::StartsWith(username1, username2, true); | 229 return base::StartsWith(username1, username2, base::CompareCase::SENSITIVE); |
| 229 } | 230 } |
| 230 | 231 |
| 231 // Returns |true| if the given element is editable. Otherwise, returns |false|. | 232 // Returns |true| if the given element is editable. Otherwise, returns |false|. |
| 232 bool IsElementAutocompletable(const blink::WebInputElement& element) { | 233 bool IsElementAutocompletable(const blink::WebInputElement& element) { |
| 233 return IsElementEditable(element); | 234 return IsElementEditable(element); |
| 234 } | 235 } |
| 235 | 236 |
| 236 // Returns true if the password specified in |form| is a default value. | 237 // Returns true if the password specified in |form| is a default value. |
| 237 bool PasswordValueIsDefault(const base::string16& password_element, | 238 bool PasswordValueIsDefault(const base::string16& password_element, |
| 238 const base::string16& password_value, | 239 const base::string16& password_value, |
| (...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 277 // Sets |suggestions_present| to true if there are any suggestions to be derived | 278 // Sets |suggestions_present| to true if there are any suggestions to be derived |
| 278 // from |fill_data|. Unless |show_all| is true, only considers suggestions with | 279 // from |fill_data|. Unless |show_all| is true, only considers suggestions with |
| 279 // usernames having |current_username| as a prefix. Returns true if a username | 280 // usernames having |current_username| as a prefix. Returns true if a username |
| 280 // from the |fill_data.other_possible_usernames| would be included in the | 281 // from the |fill_data.other_possible_usernames| would be included in the |
| 281 // suggestions. | 282 // suggestions. |
| 282 bool GetSuggestionsStats(const PasswordFormFillData& fill_data, | 283 bool GetSuggestionsStats(const PasswordFormFillData& fill_data, |
| 283 const base::string16& current_username, | 284 const base::string16& current_username, |
| 284 bool show_all, | 285 bool show_all, |
| 285 bool* suggestions_present) { | 286 bool* suggestions_present) { |
| 286 *suggestions_present = false; | 287 *suggestions_present = false; |
| 288 base::string16 current_username_lower = base::i18n::ToLower(current_username); |
| 287 | 289 |
| 288 for (const auto& usernames : fill_data.other_possible_usernames) { | 290 for (const auto& usernames : fill_data.other_possible_usernames) { |
| 289 for (size_t i = 0; i < usernames.second.size(); ++i) { | 291 for (size_t i = 0; i < usernames.second.size(); ++i) { |
| 290 if (show_all || | 292 if (show_all || |
| 291 base::StartsWith(usernames.second[i], current_username, false)) { | 293 base::StartsWith( |
| 294 base::i18n::ToLower(base::string16(usernames.second[i])), |
| 295 current_username_lower, base::CompareCase::SENSITIVE)) { |
| 292 *suggestions_present = true; | 296 *suggestions_present = true; |
| 293 return true; | 297 return true; |
| 294 } | 298 } |
| 295 } | 299 } |
| 296 } | 300 } |
| 297 | 301 |
| 298 if (show_all || base::StartsWith(fill_data.username_field.value, | 302 if (show_all || |
| 299 current_username, false)) { | 303 base::StartsWith(base::i18n::ToLower(fill_data.username_field.value), |
| 304 current_username_lower, base::CompareCase::SENSITIVE)) { |
| 300 *suggestions_present = true; | 305 *suggestions_present = true; |
| 301 return false; | 306 return false; |
| 302 } | 307 } |
| 303 | 308 |
| 304 for (const auto& login : fill_data.additional_logins) { | 309 for (const auto& login : fill_data.additional_logins) { |
| 305 if (show_all || base::StartsWith(login.first, current_username, false)) { | 310 if (show_all || |
| 311 base::StartsWith(base::i18n::ToLower(login.first), |
| 312 current_username_lower, |
| 313 base::CompareCase::SENSITIVE)) { |
| 306 *suggestions_present = true; | 314 *suggestions_present = true; |
| 307 return false; | 315 return false; |
| 308 } | 316 } |
| 309 } | 317 } |
| 310 | 318 |
| 311 return false; | 319 return false; |
| 312 } | 320 } |
| 313 | 321 |
| 314 // Returns true if there exists a credential suggestion whose username field is | 322 // Returns true if there exists a credential suggestion whose username field is |
| 315 // an exact match to the current username (not just a prefix). | 323 // an exact match to the current username (not just a prefix). |
| (...skipping 1174 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1490 void PasswordAutofillAgent::LegacyPasswordAutofillAgent::DidStopLoading() { | 1498 void PasswordAutofillAgent::LegacyPasswordAutofillAgent::DidStopLoading() { |
| 1491 agent_->DidStopLoading(); | 1499 agent_->DidStopLoading(); |
| 1492 } | 1500 } |
| 1493 | 1501 |
| 1494 void PasswordAutofillAgent::LegacyPasswordAutofillAgent:: | 1502 void PasswordAutofillAgent::LegacyPasswordAutofillAgent:: |
| 1495 DidStartProvisionalLoad(blink::WebLocalFrame* navigated_frame) { | 1503 DidStartProvisionalLoad(blink::WebLocalFrame* navigated_frame) { |
| 1496 agent_->LegacyDidStartProvisionalLoad(navigated_frame); | 1504 agent_->LegacyDidStartProvisionalLoad(navigated_frame); |
| 1497 } | 1505 } |
| 1498 | 1506 |
| 1499 } // namespace autofill | 1507 } // namespace autofill |
| OLD | NEW |