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/core/browser/autofill_manager.h" | 5 #include "components/autofill/core/browser/autofill_manager.h" |
6 | 6 |
7 #include <stddef.h> | 7 #include <stddef.h> |
8 #include <stdint.h> | 8 #include <stdint.h> |
9 | 9 |
10 #include <algorithm> | 10 #include <algorithm> |
(...skipping 532 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
543 // Need to refresh models before using the form_event_loggers. | 543 // Need to refresh models before using the form_event_loggers. |
544 bool is_autofill_possible = RefreshDataModels(); | 544 bool is_autofill_possible = RefreshDataModels(); |
545 | 545 |
546 FormStructure* form_structure = NULL; | 546 FormStructure* form_structure = NULL; |
547 AutofillField* autofill_field = NULL; | 547 AutofillField* autofill_field = NULL; |
548 bool got_autofillable_form = | 548 bool got_autofillable_form = |
549 GetCachedFormAndField(form, field, &form_structure, &autofill_field) && | 549 GetCachedFormAndField(form, field, &form_structure, &autofill_field) && |
550 // Don't send suggestions or track forms that should not be parsed. | 550 // Don't send suggestions or track forms that should not be parsed. |
551 form_structure->ShouldBeParsed(); | 551 form_structure->ShouldBeParsed(); |
552 | 552 |
553 // Logging interactions of forms that are autofillable. | 553 bool is_filling_credit_card = false; |
| 554 |
| 555 // Log interactions of forms that are autofillable. |
554 if (got_autofillable_form) { | 556 if (got_autofillable_form) { |
555 if (autofill_field->Type().group() == CREDIT_CARD) { | 557 if (autofill_field->Type().group() == CREDIT_CARD) { |
| 558 is_filling_credit_card = true; |
556 driver_->DidInteractWithCreditCardForm(); | 559 driver_->DidInteractWithCreditCardForm(); |
557 credit_card_form_event_logger_->OnDidInteractWithAutofillableForm(); | 560 credit_card_form_event_logger_->OnDidInteractWithAutofillableForm(); |
558 } else { | 561 } else { |
559 address_form_event_logger_->OnDidInteractWithAutofillableForm(); | 562 address_form_event_logger_->OnDidInteractWithAutofillableForm(); |
560 } | 563 } |
561 } | 564 } |
562 | 565 |
563 std::vector<Suggestion> suggestions; | 566 std::vector<Suggestion> suggestions; |
| 567 const bool is_context_secure = |
| 568 !form_structure || |
| 569 (client_->IsContextSecure(form_structure->source_url()) && |
| 570 (!form_structure->target_url().is_valid() || |
| 571 !form_structure->target_url().SchemeIs("http"))); |
| 572 const bool is_http_warning_enabled = |
| 573 security_state::IsHttpWarningInFormEnabled(); |
564 | 574 |
565 if (is_autofill_possible && | 575 if (is_autofill_possible && |
566 driver_->RendererIsAvailable() && | 576 driver_->RendererIsAvailable() && |
567 got_autofillable_form) { | 577 got_autofillable_form) { |
568 AutofillType type = autofill_field->Type(); | |
569 bool is_filling_credit_card = (type.group() == CREDIT_CARD); | |
570 // On desktop, don't return non credit card related suggestions for forms or | 578 // On desktop, don't return non credit card related suggestions for forms or |
571 // fields that have the "autocomplete" attribute set to off. | 579 // fields that have the "autocomplete" attribute set to off. |
572 if (IsDesktopPlatform() && !is_filling_credit_card && | 580 if (IsDesktopPlatform() && !is_filling_credit_card && |
573 !field.should_autocomplete) { | 581 !field.should_autocomplete) { |
574 return; | 582 return; |
575 } | 583 } |
576 if (is_filling_credit_card) { | 584 if (is_filling_credit_card) { |
577 suggestions = GetCreditCardSuggestions(field, type); | 585 suggestions = GetCreditCardSuggestions(field, autofill_field->Type()); |
578 } else { | 586 } else { |
579 suggestions = | 587 suggestions = |
580 GetProfileSuggestions(*form_structure, field, *autofill_field); | 588 GetProfileSuggestions(*form_structure, field, *autofill_field); |
581 } | 589 } |
| 590 |
582 if (!suggestions.empty()) { | 591 if (!suggestions.empty()) { |
583 bool is_context_secure = | |
584 client_->IsContextSecure(form_structure->source_url()) && | |
585 (!form_structure->target_url().is_valid() || | |
586 !form_structure->target_url().SchemeIs("http")); | |
587 if (is_filling_credit_card) | 592 if (is_filling_credit_card) |
588 AutofillMetrics::LogIsQueriedCreditCardFormSecure(is_context_secure); | 593 AutofillMetrics::LogIsQueriedCreditCardFormSecure(is_context_secure); |
589 | 594 |
590 // Don't provide credit card suggestions for non-secure pages, but do | 595 // Don't provide credit card suggestions for non-secure pages, but do |
591 // provide them for secure pages with passive mixed content (see impl. of | 596 // provide them for secure pages with passive mixed content (see impl. of |
592 // IsContextSecure). | 597 // IsContextSecure). |
593 if (is_filling_credit_card && !is_context_secure) { | 598 if (is_filling_credit_card && !is_context_secure) { |
594 bool is_http_warning_enabled = | |
595 security_state::IsHttpWarningInFormEnabled(); | |
596 // Replace the suggestion content with a warning message explaining why | 599 // Replace the suggestion content with a warning message explaining why |
597 // Autofill is disabled for a website. The string is different if the | 600 // Autofill is disabled for a website. The string is different if the |
598 // credit card autofill HTTP warning experiment is enabled. | 601 // credit card autofill HTTP warning experiment is enabled. |
599 Suggestion warning_suggestion(l10n_util::GetStringUTF16( | 602 Suggestion warning_suggestion(l10n_util::GetStringUTF16( |
600 is_http_warning_enabled | 603 is_http_warning_enabled |
601 ? IDS_AUTOFILL_WARNING_PAYMENT_DISABLED | 604 ? IDS_AUTOFILL_WARNING_PAYMENT_DISABLED |
602 : IDS_AUTOFILL_WARNING_INSECURE_CONNECTION)); | 605 : IDS_AUTOFILL_WARNING_INSECURE_CONNECTION)); |
603 warning_suggestion.frontend_id = | 606 warning_suggestion.frontend_id = |
604 POPUP_ITEM_ID_INSECURE_CONTEXT_PAYMENT_DISABLED_MESSAGE; | 607 POPUP_ITEM_ID_INSECURE_CONTEXT_PAYMENT_DISABLED_MESSAGE; |
605 suggestions.assign(1, warning_suggestion); | 608 suggestions.assign(1, warning_suggestion); |
606 | |
607 // On top of the explanation message, first show a "Payment not secure" | |
608 // message. | |
609 if (is_http_warning_enabled) { | |
610 #if !defined(OS_ANDROID) | |
611 suggestions.insert(suggestions.begin(), Suggestion()); | |
612 suggestions.front().frontend_id = POPUP_ITEM_ID_SEPARATOR; | |
613 #endif | |
614 suggestions.insert(suggestions.begin(), | |
615 CreateHttpWarningMessageSuggestionItem( | |
616 form_structure->source_url())); | |
617 } | |
618 } else { | 609 } else { |
619 bool section_is_autofilled = | 610 bool section_is_autofilled = SectionIsAutofilled( |
620 SectionIsAutofilled(*form_structure, form, | 611 *form_structure, form, autofill_field->section()); |
621 autofill_field->section()); | |
622 if (section_is_autofilled) { | 612 if (section_is_autofilled) { |
623 // If the relevant section is auto-filled and the renderer is querying | 613 // If the relevant section is auto-filled and the renderer is querying |
624 // for suggestions, then the user is editing the value of a field. | 614 // for suggestions, then the user is editing the value of a field. |
625 // In this case, mimic autocomplete: don't display labels or icons, | 615 // In this case, mimic autocomplete: don't display labels or icons, |
626 // as that information is redundant. Moreover, filter out duplicate | 616 // as that information is redundant. Moreover, filter out duplicate |
627 // suggestions. | 617 // suggestions. |
628 std::set<base::string16> seen_values; | 618 std::set<base::string16> seen_values; |
629 for (auto iter = suggestions.begin(); iter != suggestions.end();) { | 619 for (auto iter = suggestions.begin(); iter != suggestions.end();) { |
630 if (!seen_values.insert(iter->value).second) { | 620 if (!seen_values.insert(iter->value).second) { |
631 // If we've seen this suggestion value before, remove it. | 621 // If we've seen this suggestion value before, remove it. |
(...skipping 11 matching lines...) Expand all Loading... |
643 // TODO(mathp): Differentiate between number of suggestions available | 633 // TODO(mathp): Differentiate between number of suggestions available |
644 // (current metric) and number shown to the user. | 634 // (current metric) and number shown to the user. |
645 if (!has_logged_address_suggestions_count_ && !section_is_autofilled) { | 635 if (!has_logged_address_suggestions_count_ && !section_is_autofilled) { |
646 AutofillMetrics::LogAddressSuggestionsCount(suggestions.size()); | 636 AutofillMetrics::LogAddressSuggestionsCount(suggestions.size()); |
647 has_logged_address_suggestions_count_ = true; | 637 has_logged_address_suggestions_count_ = true; |
648 } | 638 } |
649 } | 639 } |
650 } | 640 } |
651 } | 641 } |
652 | 642 |
| 643 // Show a "Payment not secure" message. |
| 644 if (!is_context_secure && is_http_warning_enabled) { |
| 645 #if !defined(OS_ANDROID) |
| 646 if (!suggestions.empty()) { |
| 647 suggestions.insert(suggestions.begin(), Suggestion()); |
| 648 suggestions.front().frontend_id = POPUP_ITEM_ID_SEPARATOR; |
| 649 } |
| 650 #endif |
| 651 |
| 652 suggestions.insert( |
| 653 suggestions.begin(), |
| 654 CreateHttpWarningMessageSuggestionItem( |
| 655 form_structure ? form_structure->source_url() : GURL::EmptyGURL())); |
| 656 } |
| 657 |
653 // If there are no Autofill suggestions, consider showing Autocomplete | 658 // If there are no Autofill suggestions, consider showing Autocomplete |
654 // suggestions. We will not show Autocomplete suggestions for a field that | 659 // suggestions. We will not show Autocomplete suggestions for a field that |
655 // specifies autocomplete=off (or an unrecognized type), a field for which we | 660 // specifies autocomplete=off (or an unrecognized type), a field for which we |
656 // will show the credit card signin promo, or a field that we think is a | 661 // will show the credit card signin promo, or a field that we think is a |
657 // credit card expiration, cvc or number. | 662 // credit card expiration, cvc or number. |
658 if (suggestions.empty() && !ShouldShowCreditCardSigninPromo(form, field) && | 663 if (suggestions.empty() && !ShouldShowCreditCardSigninPromo(form, field) && |
659 field.should_autocomplete && | 664 field.should_autocomplete && |
660 !(autofill_field && | 665 !(autofill_field && |
661 (IsCreditCardExpirationType(autofill_field->Type().GetStorableType()) || | 666 (IsCreditCardExpirationType(autofill_field->Type().GetStorableType()) || |
662 autofill_field->Type().html_type() == HTML_TYPE_UNRECOGNIZED || | 667 autofill_field->Type().html_type() == HTML_TYPE_UNRECOGNIZED || |
(...skipping 1475 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2138 if (i > 0) | 2143 if (i > 0) |
2139 fputs("Next oldest form:\n", file); | 2144 fputs("Next oldest form:\n", file); |
2140 } | 2145 } |
2141 fputs("\n", file); | 2146 fputs("\n", file); |
2142 | 2147 |
2143 fclose(file); | 2148 fclose(file); |
2144 } | 2149 } |
2145 #endif // ENABLE_FORM_DEBUG_DUMP | 2150 #endif // ENABLE_FORM_DEBUG_DUMP |
2146 | 2151 |
2147 } // namespace autofill | 2152 } // namespace autofill |
OLD | NEW |